前提・実現したいこと
Ruby on RailsでGoogleAPIを使った連携アプリを作っています。現在、Googleの連携ログイン(OAuth)を実装しています。
発生している問題・エラーメッセージ
以下のサイトを参考にして、Googleログインを導入し、Herokuにデプロイしました。
https://qiita.com/kenzoukenzou104809/items/c10a5642afbee93a961a
アクセスすると、Googleのログインページまでは行けるのですが、コールバックされたあとのページでエラーが出ます。Herokuのログを見たところ、長いログが出力されていました。
2020-02-06T11:57:37.765594+00:00 app[web.1]: F, [2020-02-06T11:57:37.765467 #4] FATAL -- : [2a5295bc-4273-46dc-b16c-fc03cf81abb1] 2020-02-06T11:57:37.765608+00:00 app[web.1]: [2a5295bc-4273-46dc-b16c-fc03cf81abb1] NoMethodError (undefined method `new_session_path' for #<Users::OmniauthCallbacksController:0x00005564ee8d9908> (以下略)
該当のソースコード
app/controllers/users/omniauth_callback_controller.rb
Ruby
1class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController 2 def google 3 @user = User.find_for_google(request.env['omniauth.auth']) 4 5 if @user.persisted? 6 flash[:notice] = I18n.t 'devise.omniauth_callbacks.success', kind: 'Google' 7 sign_in_and_redirect @user, event: :authentication 8 session[:user_id] = @user.id #add 9 else 10 session['devise.google_data'] = request.env['omniauth.auth'] 11 redirect_to new_user_registration_url 12 end 13 end 14end
config/routes.rb
Ruby
1Rails.application.routes.draw do 2 root "home#index" 3 devise_for :users, controllers: { 4 omniauth_callbacks: "users/omniauth_callbacks" 5 } 6 # For details on the DSL available within this file, see https://guides.rubyonrails.org/routing.html 7end
app/models/user.rb
Ruby
1class User < ApplicationRecord 2 # Include default devise modules. Others available are: 3 # :confirmable, :lockable, :timeoutable, :trackable and :omniauthable 4 devise :registerable, :rememberable, :validatable, 5 :omniauthable, omniauth_providers: %i(google) 6 7 protected 8 def self.find_for_google(auth) 9 user = User.find_by(uid: auth.uid) 10 11 unless user 12 user = User.create(name: auth.info.name, 13 provider: auth.provider, 14 uid: auth.uid, 15 token: auth.credentials.token, 16 password: Devise.friendly_token[0, 20], 17 meta: auth.to_yaml) 18 end 19 user 20 end 21end
試したこと
現在のエラーになる前は、emailカラムがないという主旨のエラーが出ていたので、emailカラムを使わないように変更しました。
Google側の設定は一通り確認済みです。
どなたかご教授お願いたします。
補足情報(FW/ツールのバージョンなど)
Heroku
Ruby 2.6.3
Ruby on Rails 6.0.1
あなたの回答
tips
プレビュー