summaryrefslogtreecommitdiff
path: root/app/controllers/application_controller.rb
blob: ea108b41b2133b358cf30c1cda4000fe2aa7e752 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
# frozen_string_literal: true

# The father class of all controllers.
class ApplicationController < ActionController::API
  def logic(permitted_params)
    @logic = Object.const_get("#{self.class}::#{action_name.camelize}Logic").new(permitted_params)
  end

  protected

  def current_user_account
    return if decoded_token.nil?

    email = decoded_token[0]['data']
    @current_user_account ||= UserAccount.find_by(email:)
  end

  def authentication_token
    @authentication_token ||= request.headers[:authorization]&.sub(/^Bearer /, '')
  end

  def decoded_token
    @decoded_token ||= JWT.decode(authentication_token, ENV['HMAC_SECRET_KEY'], true, { algorithm: 'HS512' })
  rescue JWT::ExpiredSignature
    @decoded_token = nil
  end
end