4

Devise,基于 Warden 的 Ruby 身份验证 gem(另一个身份验证 gem)不支持 Twitter Oauth 作为身份验证策略,但 Warden 支持。有一种方法可以在 Devise 中使用 Warden Twitter Oauth 策略,但我无法弄清楚。我在设计配置文件中使用以下块:

  config.warden do |manager|
       manager.oauth(:twitter) do |twitter|
          twitter.consumer_secret = <SECRET>
          twitter.consumer_key  = <KEY>
          twitter.options :site => 'http://twitter.com'
       end
       manager.default_strategies.unshift :twitter_oauth
  end

但我不断收到各种错误消息。有谁知道如何使这项工作?我假设这里还有更多工作要做(配置一个新的链接/路由来与 Warden 对话,可能会向 Devise User 模型添加属性等),但我不知道它们是什么。请帮忙。

4

4 回答 4

4
# Needed gems. Add to your Gemfile if you are using Rails3.  
gem 'devise'
gem 'warden_oauth'

#models/user.rb
devise :token_authenticatable, :oauthable # <-- Must have these

#/config/initializers/devise.rb
require 'warden_oauth'
config.warden do |manager|
  manager.oauth(:twitter) do |twitter|
    twitter.consumer_secret = '<SECRET>'
    twitter.consumer_key  = '<CONSUMER KEY>'
    twitter.options :site => 'http://twitter.com'
  end
  manager.default_strategies(:scope => :user).unshift :twitter_oauth
end

Warden::OAuth.access_token_user_finder(:twitter) do |access_token|
  User.find_or_create_by(:token => access_token.token, :secret => access_token.secret).tap do |user|
    #... 
  end
end

# Link to "Login With Twitter" somewhere in your view
<%= link_to( "Login With Twitter", user_session_path(:warden_oauth_provider => 'twitter') ) %>
于 2010-08-07T20:11:51.123 回答
3

Omniauth让这一切变得简单。有一个 Railscast 使用 Omniauth 和 Devise(第 1部分,第 2 部分)。

于 2010-12-01T20:09:24.453 回答
0

这个解决方案确实有效。您只需要确保在指定 :warden_oauth_provider => 'twitter' 时调用了受保护的操作,否则 Rails 将简单地忽略它。

要使用上面的示例,请将链接更改为:

<%= link_to( "Login With Twitter", user_session_path(:warden_oauth_provider => 'twitter'), :method => :post ) %>
于 2010-10-01T16:28:15.893 回答
0

尝试检查您是否定义了一个名为 Twitter 的类或模块(您可以通过运行脚本/控制台然后键入 Twitter 来检查),如果您定义了,请将其命名为不存在的名称。

于 2011-03-24T06:41:43.180 回答