фон
У меня есть стратегия подкласса omniauth-oauth2, работающая в моем приложении rails. Когда обновлять access_token, я вижу, что мне нужно создать OAuth2::AccessToken
. Но для его создания, похоже, требуется OAuth2::Client
, который, я думаю, можно получить из «стратегии подкласса omniauth-oauth2».
нашел это решение Обновить токен с помощью Omniauth-oauth2 в приложении Rails Вот как они решили получить стратегию
# the initial param:nil is meant to be a rack object, but since
# we don't use it here, we give it a nil
strategy = OmniAuth::Strategies::YOUR_PROVIDER.new nil, client_id, client_secret
client = strategy.client
your_expired_at_from_your_provider = Time.now.to_i
hash = {
access_token: "your access_token from your provider",
refresh_token: "your refresh_token from your provider",
expires_at: your_expired_at_from_your_provider,
}
access_token_object = OAuth2::AccessToken.from_hash(client, hash)
access_token_object.refresh!
https://github.com/omniauth/omniauth/blob/v1.6.1/lib/omniauth/strategy.rb#L132 https://github.com/intridea/omniauth-oauth2/blob/v1.4.0/lib/omniauth/стратегии/oauth2.rb#L35 https://github.com/intridea/oauth2/blob/master/lib/oauth2/access_token.rb#L12 https://github.com/intridea/oauth2/blob/v1.4.0/lib/oauth2/access_token.rb#L82
проблема
Чего я не понимаю, так это то, что это выглядит несколько хитроумными способами создания стратегии, давая nil
первому аргументу.
«Стратегия подкласса omniauth-oauth2» находится в стойке (как на изображении ниже), поэтому я думаю, что есть способ получить доступ к стратегии из промежуточного программного обеспечения стойки, где-то?
вопрос
Является ли создание стратегии, подобной описанной выше, единственным способом обновить токен? strategy -> client -> access_token_object -> refresh!