Sha256: 816fbdec6137f9971cf8dda23ec705d437721909bd60041203d710cf517bd811

Contents?: true

Size: 1.23 KB

Versions: 8

Compression:

Stored size: 1.23 KB

Contents

module Rack
  module OAuth2
    module Server
      class Resource < Abstract::Handler
        ACCESS_TOKEN = 'rack.oauth2.access_token'
        DEFAULT_REALM = 'Protected by OAuth 2.0'
        attr_accessor :realm, :request

        def initialize(app, realm = nil, &authenticator)
          @app = app
          @realm = realm
          super(&authenticator)
        end

        def _call(env)
          if request.oauth2?
            access_token = authenticate! request.setup!
            env[ACCESS_TOKEN] = access_token
          end
          @app.call(env)
        rescue Rack::OAuth2::Server::Abstract::Error => e
          e.realm ||= realm
          e.finish
        end

        private

        def authenticate!(request)
          @authenticator.call(request)
        end

        class Request < Rack::Request
          attr_reader :access_token

          def initialize(env)
            @env = env
            @auth_header = Rack::Auth::AbstractRequest.new(env)
          end

          def setup!
            raise 'Define me!'
          end

          def oauth2?
            raise 'Define me!'
          end
        end
      end
    end
  end
end

require 'rack/oauth2/server/resource/error'
require 'rack/oauth2/server/resource/bearer'

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
rack-oauth2-2.2.1 lib/rack/oauth2/server/resource.rb
rack-oauth2-2.2.0 lib/rack/oauth2/server/resource.rb
rack-oauth2-2.1.0 lib/rack/oauth2/server/resource.rb
rack-oauth2-2.0.1 lib/rack/oauth2/server/resource.rb
rack-oauth2-2.0.0 lib/rack/oauth2/server/resource.rb
rack-oauth2-2.0.0.rc3 lib/rack/oauth2/server/resource.rb
rack-oauth2-2.0.0.rc2 lib/rack/oauth2/server/resource.rb
rack-oauth2-2.0.0.rc1 lib/rack/oauth2/server/resource.rb