Sha256: 3a12a6234369b31893171e0983b73a973c915a32ee463a480fd619fbb1a85a2e

Contents?: true

Size: 695 Bytes

Versions: 2

Compression:

Stored size: 695 Bytes

Contents

require 'devise/oauth2_providable/strategies/oauth2_grant_type_strategy'

module Devise
  module Strategies
    class Oauth2RefreshTokenGrantTypeStrategy < Oauth2GrantTypeStrategy
      def grant_type
        'refresh_token'
      end

      def authenticate!
        if client && refresh_token = client.refresh_tokens.valid.find_by_token(params[:refresh_token])
          env['oauth2.refresh_token'] = refresh_token
          success! refresh_token.user
        elsif !halted?
          oauth_error! :invalid_grant, 'invalid refresh token'
        end
      end
    end
  end
end

Warden::Strategies.add(:oauth2_refresh_token_grantable, Devise::Strategies::Oauth2RefreshTokenGrantTypeStrategy)

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
devise_oauth2_providable-1.0.0 lib/devise/oauth2_providable/strategies/oauth2_refresh_token_grant_type_strategy.rb
devise_oauth2_providable-1.0.0.beta1 lib/devise/oauth2_providable/strategies/oauth2_refresh_token_grant_type_strategy.rb