Oauth2令牌不适用于gmail_xoauth gem

时间:2015-07-16 01:26:10

标签: ruby gmail-api gmail-imap

我目前通过以下omniauth-google-oauth2宝石获取令牌:https://github.com/zquestz/omniauth-google-oauth2

我存储从auth_hash返回的令牌。

然后我尝试通过调用:

来使用令牌
require 'gmail_xoauth'
imap = Net::IMAP.new('imap.gmail.com', 993, usessl = true, certs = nil, verify = false)
imap.authenticate('XOAUTH2', 'myemail@gmail.com', Token.last)

问题是我收到错误:

[8] pry(main)> imap.authenticate('XOAUTH2', 'myemail@gmail.com', Token.last)
  Token Load (0.6ms)  SELECT  "tokens".* FROM "tokens"  ORDER BY "tokens"."id" DESC LIMIT 1
Net::IMAP::NoResponseError:  Invalid credentials (Failure)
from /Users/username/.rvm/rubies/ruby-2.2.1/lib/ruby/2.2.0/net/imap.rb:1171:in `get_tagged_response'

2 个答案:

答案 0 :(得分:0)

好的,我看了一下google-api-client,我又开始使用它了。似乎目前最好的解决方案是执行以下操作:

  1. 创建包含gmail parameters和gmail api_method
  2. 的选项哈希
  3. 使用您使用access_token初始化的服务在options哈希
  4. 中创建查询

    下面你可以看到一个粗略的例子,你可以使用

    client = Google::APIClient.new
    client.authorization.access_token = token
    service = client.discovered_api 'gmail'
    options = {parameters: {'userId' => 'email@gmail.com'}, api_method: service.users.messages.list}
    client.execute(options)
    

    我的意思是这很笨重,应该干嘛。 (希望谷歌围绕这个创建一个更好的gem

答案 1 :(得分:0)

解决方案是更新gmail的omniauth范围。

Rails.application.config.middleware.use OmniAuth::Builder do
  provider :google_oauth2, ENV['GOOGLE_CLIENT_ID'], ENV['GOOGLE_CLIENT_SECRET'], 
  {
    scope: [
            'https://mail.google.com/','https://www.googleapis.com/auth/userinfo.email'
            ]
  }
end