Sha256: cc3b3b4b004b32c8f1f897379ca5c8204be3f4ee4c58317746ac696c4391cbc3
Contents?: true
Size: 1.27 KB
Versions: 4
Compression:
Stored size: 1.27 KB
Contents
require 'oauth2/rack' # 2.3.1. Client Password # Send client_id and client_secret in request params class OAuth2::Rack::Authentication::Client::RequestParams def initialize(app, opts = {}, &authenticator) @app = app @required = opts.fetch(:required, true) @authenticator = authenticator || opts[:authenticator] end def call(env) return @app.call(env) if env.has_key?('oauth2.client') @request = Rack::Request.new(env) client_id = @request['client_id'] client_secret = @request['client_secret'] if client_id.nil? && client_secret.nil? return @required ? unauthorized : @app.call(env) elsif client_id.nil? || client_secret.nil? return bad_request end client = @authenticator.call(:client_id => client_id, :client_secret => client_secret) if client env['oauth2.client'] = client @app.call(env) else unauthorized end end private def authenticate(opts) @authenticator && @authenticator.call(opts) end def unauthorized [ 401, { 'Content-Type' => 'text/plain', 'Content-Length' => '0' }, [] ] end def bad_request [ 400, { 'Content-Type' => 'text/plain', 'Content-Length' => '0' }, [] ] end end
Version data entries
4 entries across 4 versions & 1 rubygems