首先需要添加setup: true才能升级服务的权限列表:
Devise.setup do |config|
config.omniauth :facebook, ENV['FACEBOOK_KEY'], ENV['FACEBOOK_SECRET'],
:scope => 'email,offline_access,user_about_me',
:setup => true
end
在routes.rb中添加两条路由:
devise_scope :user do
get '/users/auth/:provider/upgrade' => 'omniauth_callbacks#upgrade', as: :user_omniauth_upgrade
get '/users/auth/:provider/setup', :to => 'omniauth_callbacks#setup'
end
第一个路由是用户应该使用user_omniauth_upgrade_path(:facebook) 链接到的位置。第二个设置路由是omniauth内部调用的回调,我们可以用来改变范围参数。
这些进入omniauth_callbacks_controller.rb:
def upgrade
scope = nil
if params[:provider] == "facebook"
scope = 'email,offline_access,user_about_me,publish_stream'
end
redirect_to user_omniauth_authorize_path(params[:provider]), flash: {scope: scope}
end
当您在omniauth 配置中指定setup: true 时,默认调用setup_path。我们将使用它来更改策略中的默认范围。将此添加到omniauth_callbacks_controller.rb:
def setup
request.env['omniauth.strategy'].options['scope'] = flash[:scope] || request.env['omniauth.strategy'].options['scope']
render :text => "Setup complete.", :status => 404
end
最后,您可以在视图中添加:
<%= link_to "Upgrade Access", user_omniauth_upgrade_path(:facebook) %>
来源:
http://willschenk.com/setting-up-devise-with-twitter-and-facebook-and-other-omniauth-schemes-without-email-addresses/#passing-dynamic-scopes-to-omniauth