mcordell/grape_token_auth

View on GitHub
lib/grape_token_auth/authentication_header.rb

Summary

Maintainability
A
0 mins
Test Coverage
# frozen_string_literal: true
module GrapeTokenAuth
  class AuthenticationHeader
    extend Forwardable

    def initialize(data, start_time)
      @resource = data.first_authenticated_resource
      @request_start = start_time
      @data = data
    end

    def headers
      return {} unless resource && resource.valid? && client_id && !skip_auth_headers
      auth_headers_from_resource
    end

    def self.build_auth_headers(token, uid)
      {
        'access-token' => token.to_s,
        'expiry' => token.expiry.to_s,
        'client' => token.client_id.to_s,
        'token-type' => 'Bearer',
        'uid' => uid.to_s
      }
    end

    private

    attr_reader :request_start, :resource, :data

    def_delegators :data, :token, :client_id, :skip_auth_headers

    def auth_headers_from_resource
      auth_headers = {}
      resource.while_record_locked do
        if was_not_authenticated_with_token
          auth_headers = resource.create_new_auth_token
        elsif !GrapeTokenAuth.change_headers_on_each_request
          auth_headers = resource.extend_batch_buffer(token, client_id)
        elsif batch_request?
          resource.extend_batch_buffer(token, client_id)
        else
          auth_headers = resource.create_new_auth_token(client_id)
        end
      end
      coerce_headers_to_strings(auth_headers)
    end

    def was_not_authenticated_with_token
      !data.authed_with_token
    end

    def coerce_headers_to_strings(auth_headers)
      auth_headers.each { |k, v|  auth_headers[k] = v.to_s }
    end

    def batch_request?
      @batch_request ||= resource.tokens[client_id] &&
                         resource.tokens[client_id]['updated_at'] &&
                         within_batch_request_window?
    end

    def within_batch_request_window?
      end_of_window = Time.parse(resource.tokens[client_id]['updated_at']) +
                      GrapeTokenAuth.batch_request_buffer_throttle

      request_start < end_of_window
    end
  end
end