Sha256: ea535527f728783af7277cbd4dd51d1688d665b4071e0619a2b47e46263d3fe2

Contents?: true

Size: 1.27 KB

Versions: 7

Compression:

Stored size: 1.27 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'
require 'rack/oauth2/server/resource/mac'

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
rack-oauth2-1.5.1 lib/rack/oauth2/server/resource.rb
rack-oauth2-1.5.0 lib/rack/oauth2/server/resource.rb
rack-oauth2-1.4.0 lib/rack/oauth2/server/resource.rb
rack-oauth2-1.3.1 lib/rack/oauth2/server/resource.rb
rack-oauth2-1.3.0 lib/rack/oauth2/server/resource.rb
rack-oauth2-1.2.3 lib/rack/oauth2/server/resource.rb
rack-oauth2-1.2.2 lib/rack/oauth2/server/resource.rb