Sha256: 9f40b213f92a4fe2d0726f33cb54b9005d1f431b1d31121fe6ab19860f3fc7f8

Contents?: true

Size: 722 Bytes

Versions: 2

Compression:

Stored size: 722 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_grant_type(client)
        if refresh_token = client.refresh_tokens.find_by_token(params[:refresh_token])
          env[Devise::Oauth2Providable::REFRESH_TOKEN_ENV_REF] = 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.1.1 lib/devise/oauth2_providable/strategies/oauth2_refresh_token_grant_type_strategy.rb
devise_oauth2_providable-1.1.0 lib/devise/oauth2_providable/strategies/oauth2_refresh_token_grant_type_strategy.rb