lib/doorkeeper/server.rb



module Doorkeeper
  class Server
    attr_accessor :context

    def initialize(context = nil)
      @context = context
    end

    def authorization_request(strategy)
      klass = Request.authorization_strategy strategy
      klass.build self
    end

    def token_request(strategy)
      klass = Request.token_strategy strategy
      klass.build self
    end

    # TODO: context should be the request
    def parameters
      context.request.parameters
    end

    def client
      @client ||= OAuth::Client.authenticate(credentials)
    end

    def client_via_uid
      @client_via_uid ||= OAuth::Client.find(parameters[:client_id])
    end

    def current_resource_owner
      context.send :current_resource_owner
    end

    def current_refresh_token
      Doorkeeper::AccessToken.by_refresh_token(parameters[:refresh_token])
    end

    def grant
      Doorkeeper::AccessGrant.authenticate(parameters[:code])
    end

    # TODO: Use configuration and evaluate proper context on block
    def resource_owner
      context.send :resource_owner_from_credentials
    end

    def credentials
      methods = Doorkeeper.configuration.client_credentials_methods
      @credentials ||= OAuth::Client::Credentials.from_request(context.request, *methods)
    end
  end
end