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参数和gmailapi\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参数和gmailapi\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不是我最喜欢的衣服。你看过这个帖子吗?是的,看到了-这正是我尝试验证时失败的地方