Ruby Oauth2令牌不适用于gmail_xOAuthgem

Ruby Oauth2令牌不适用于gmail_xOAuthgem,ruby,gmail-api,gmail-imap,Ruby,Gmail Api,Gmail Imap,我目前通过omniauth-google-oauth2gem获得令牌,具体如下: 我存储从auth\u散列返回的令牌 然后,我尝试通过调用以下命令来使用令牌: require 'gmail_xoauth' imap = Net::IMAP.new('imap.gmail.com', 993, usessl = true, certs = nil, verify = false) imap.authenticate('XOAUTH2', 'myemail@gmail.com', Token.las

我目前通过
omniauth-google-oauth2
gem获得令牌,具体如下:

我存储从
auth\u散列返回的令牌

然后,我尝试通过调用以下命令来使用令牌:

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'

好的,我看了一下
GoogleAPI客户端
,我开始更多地使用它。似乎目前最好的解决方案是执行以下操作:

  • 创建一个选项散列,其中包括gmail
    参数和gmail
    api\u方法
  • 使用您用
    access\u令牌初始化的服务
    选项
    散列中创建查询
  • 下面你可以看到一个粗略的例子,你可以使用

    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

    好的,我看了一下
    谷歌api客户端,开始更多地使用它。似乎目前最好的解决方案是执行以下操作:

  • 创建一个选项散列,其中包括gmail
    参数和gmail
    api\u方法
  • 使用您用
    access\u令牌初始化的服务
    选项
    散列中创建查询
  • 下面你可以看到一个粗略的例子,你可以使用

    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

    解决方案是为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
    

    解决方案是为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
    

    我也知道这是正确的标记,因为当我使用
    google api客户端
    gem时,我可以直接连接到服务。您是否也尝试在
    google api客户端
    中使用IMAP?如果没有,那么可能值得额外查看您请求的作用域<代码>https://mail.google.com/
    必须存在IMAP。我已经设置了该范围。我不打算将
    谷歌api客户端用于上述目的。只是告诉你,让你知道我的代币没有问题,我听到了。Ruby不是我最喜欢的衣服。你看过这个帖子吗?是的,我看到了-这正是我尝试验证时失败的地方。我也知道这是正确的令牌,因为当我使用
    google api客户端
    gem时,我能够直接连接到服务。你也尝试在
    google api客户端
    中使用IMAP吗?如果没有,那么可能值得额外查看您请求的作用域<代码>https://mail.google.com/
    必须存在IMAP。我已经设置了该范围。我不打算将
    谷歌api客户端用于上述目的。只是告诉你,让你知道我的代币没有问题,我听到了。Ruby不是我最喜欢的衣服。你看过这个帖子吗?是的,看到了-这正是我尝试验证时失败的地方