我正在尝试覆盖omniauth gem中设置的默认作用域。我已经尝试通过初始化器设置作用域,并尝试将作用域保留为空。我希望能够做到
/auth/<provider>?scope=<scope>作为登录的链接。
但是,无论我如何设置提供程序,
config/initializers/omniauth.rb例如:
Rails.application.config.middleware.use OmniAuth::Builder do
provider :<provider>, <app_uid>, <app_secret>,
:scope => "",
:client_options => {
:site => "https://api.<provider_url>",
:authorize_url => "https://api.<provider_url>/oauth/authorize",
:token_url => "https://api.<provider_url>/oauth/token"
}
end它仍然尝试发送omniauth / oauth-2请求,使用
omniauth-<provider> gem如何通过向传递给提供者的url传递范围参数来覆盖gem中声明的默认作用域?
发布于 2013-06-25 03:04:53
我可以使用下面的初始化器来做到这一点。
Rails.application.config.middleware.use OmniAuth::Builder do
:<provider>, <app_uid>, <app_secret>,
:setup => lambda { |env| env["omniauth.strategy"].options[:scope] = env["rack.session"]["omniauth.params"]["scope"]},
:client_options => {
:site => "https://api.<provider_url>",
:authorize_url => "https://api.<provider_url>/oauth/authorize",
:token_url => "https://api.<provider_url>/oauth/token"
}
endhttps://stackoverflow.com/questions/17257562
复制相似问题