#ruby #oauth #gmail #omniauth #xauth
#ruby #oauth #gmail #omniauth #xauth
Вопрос:
Я хочу получить токены oauth или xauth из GMail для использования с gmail-oauth. Я подумываю об использовании OmniAuth, но, похоже, он пока не поддерживает GMail, что означает, что со стандартным доступом OmniAuth невозможно. Это правильно? Я что-то упускаю?
Ответ №1:
Omniauth поддерживает как OAuth, так и OAuth2, которые оба позволят вам аутентифицировать учетную запись Google.
Вот все стратегии, которые вы можете использовать с помощью omniauth: https://github.com/intridea/omniauth/wiki/List-of-Strategies
Вот два драгоценных камня Google OAuth:
Согласно документации первого драгоценного камня:
Добавьте промежуточное программное обеспечение в приложение Rails в config/ initializers / omniauth.rb:
Rails.application.config.middleware.use OmniAuth::Builder do
provider :google, CONSUMER_KEY, CONSUMER_SECRET
# plus any other strategies you would like to support
end
Это делается в дополнение к настройке основного гема omniauth.
Комментарии:
1. Я думаю, что вопрос заключается в получении access_token, а не только в аутентификации. Этот access_token полезен для использования API Google.
2. Ах, я прочитал еще, что OP посчитал, что они не могут выполнить аутентификацию с помощью omniauth через Google, поэтому они задавались вопросом, нужно ли им запускать свои собственные. Omniauth имеет расширения для авторизации через Google, но это на шаг выше базовой реализации.
Ответ №2:
У меня, как и у вас, возникли проблемы с использованием существующих gems с OAuth2 и Gmail, поскольку протокол OAuth1 от Google теперь устарел, и многие gems еще не обновлены для использования их протокола OAuth2. Наконец-то я смог заставить его работать, используя Net::IMAP
напрямую.
Вот рабочий пример получения электронной почты из Google с использованием протокола OAuth2. В этом примере используются mail
, gmail_xoauth
omniauth
и omniauth-google-oauth2
драгоценные камни.
Вам также потребуется зарегистрировать свое приложение в консоли API Google, чтобы получить свои токены API.
# in an initializer:
ENV['GOOGLE_KEY'] = 'yourkey'
ENV['GOOGLE_SECRET'] = 'yoursecret'
Rails.application.config.middleware.use OmniAuth::Builder do
provider :google_oauth2, ENV['GOOGLE_KEY'], ENV['GOOGLE_SECRET'], {
scope: 'https://mail.google.com/,https://www.googleapis.com/auth/userinfo.email'
}
end
# ...after handling login with OmniAuth...
# in your script
email = auth_hash[:info][:email]
access_token = auth_hash[:credentials][:token]
imap = Net::IMAP.new('imap.gmail.com', 993, usessl = true, certs = nil, verify = false)
imap.authenticate('XOAUTH2', email, access_token)
imap.select('INBOX')
imap.search(['ALL']).each do |message_id|
msg = imap.fetch(message_id,'RFC822')[0].attr['RFC822']
mail = Mail.read_from_string msg
puts mail.subject
puts mail.text_part.body.to_s
puts mail.html_part.body.to_s
end