Sha256: 6a64e70ba4ae8c5b943a7b3efc08ffbb6ce14cd0056d38f0985bf13f970abec0

Contents?: true

Size: 1.92 KB

Versions: 13

Compression:

Stored size: 1.92 KB

Contents

# frozen_string_literal: true

module Doorkeeper
  module OAuth
    class Token
      class << self
        def from_request(request, *methods)
          methods.inject(nil) do |_, method|
            method = self.method(method) if method.is_a?(Symbol)
            credentials = method.call(request)
            break credentials unless credentials.blank?
          end
        end

        def authenticate(request, *methods)
          if (token = from_request(request, *methods))
            access_token = AccessToken.by_token(token)
            refresh_token_enabled = Doorkeeper.configuration.refresh_token_enabled?
            if access_token.present? && refresh_token_enabled
              access_token.revoke_previous_refresh_token!
            end
            access_token
          end
        end

        def from_access_token_param(request)
          request.parameters[:access_token]
        end

        def from_bearer_param(request)
          request.parameters[:bearer_token]
        end

        def from_bearer_authorization(request)
          pattern = /^Bearer /i
          header  = request.authorization
          token_from_header(header, pattern) if match?(header, pattern)
        end

        def from_basic_authorization(request)
          pattern = /^Basic /i
          header  = request.authorization
          token_from_basic_header(header, pattern) if match?(header, pattern)
        end

        private

        def token_from_basic_header(header, pattern)
          encoded_header = token_from_header(header, pattern)
          decode_basic_credentials_token(encoded_header)
        end

        def decode_basic_credentials_token(encoded_header)
          Base64.decode64(encoded_header).split(/:/, 2).first
        end

        def token_from_header(header, pattern)
          header.gsub pattern, ""
        end

        def match?(header, pattern)
          header&.match(pattern)
        end
      end
    end
  end
end

Version data entries

13 entries across 13 versions & 1 rubygems

Version Path
doorkeeper-5.1.2 lib/doorkeeper/oauth/token.rb
doorkeeper-5.2.6 lib/doorkeeper/oauth/token.rb
doorkeeper-5.1.1 lib/doorkeeper/oauth/token.rb
doorkeeper-5.2.5 lib/doorkeeper/oauth/token.rb
doorkeeper-5.2.4 lib/doorkeeper/oauth/token.rb
doorkeeper-5.2.3 lib/doorkeeper/oauth/token.rb
doorkeeper-5.2.2 lib/doorkeeper/oauth/token.rb
doorkeeper-5.2.1 lib/doorkeeper/oauth/token.rb
doorkeeper-5.2.0 lib/doorkeeper/oauth/token.rb
doorkeeper-5.2.0.rc3 lib/doorkeeper/oauth/token.rb
doorkeeper-5.2.0.rc2 lib/doorkeeper/oauth/token.rb
doorkeeper-5.2.0.rc1 lib/doorkeeper/oauth/token.rb
doorkeeper-5.1.0 lib/doorkeeper/oauth/token.rb