我目前通过以下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'
答案 0 :(得分:0)
好的,我看了一下google-api-client
,我又开始使用它了。似乎目前最好的解决方案是执行以下操作:
parameters
和gmail api_method
access_token
初始化的服务在options
哈希下面你可以看到一个粗略的例子,你可以使用
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