質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
ドメイン

ドメインとは本来、領域や範囲の意味を持ち、インターネット上では特定の部分領域を指します。ネットワークやコンピュータの識別に利用され、所得することでホームページを公開したり、メールアドレスを作成できます。

OAuth

OAuth(Open Authorization)は、APIを通して保護されたリソース(サードパーティのアプリケーション)へアクセスする為のオープンプロトコルです。

OAuth 2.0

OAuth 2.0(Open Authorization 2.0)は、APIを通して保護されたリソース(サードパーティのアプリケーション)へアクセスする為のオープンプロトコルです。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

585閲覧

Rails OAuth2 サブドメイン対応について

ruby_0ct

総合スコア57

ドメイン

ドメインとは本来、領域や範囲の意味を持ち、インターネット上では特定の部分領域を指します。ネットワークやコンピュータの識別に利用され、所得することでホームページを公開したり、メールアドレスを作成できます。

OAuth

OAuth(Open Authorization)は、APIを通して保護されたリソース(サードパーティのアプリケーション)へアクセスする為のオープンプロトコルです。

OAuth 2.0

OAuth 2.0(Open Authorization 2.0)は、APIを通して保護されたリソース(サードパーティのアプリケーション)へアクセスする為のオープンプロトコルです。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2018/05/11 07:18

サブドメインでRailsアプリケーションを運用しているのですが、Googleログインでcallbackされる際にnginxの404 Not Foundが表示されてしまいます。

https://トップドメイン.com/users/auth/google_oauth2/callback?state=値&code=値にコールバックされ、404になります。
サブドメインでコールバックされないのが原因でしょうか?
どのように設定すれば正常に処理されるのか、解決策をいただけると助かります。

設定状況

Google APIには以下の通りに登録しています。
承認済みの JavaScript 生成元http://サブドメイン名.トップドメイン.com
承認済みのリダイレクト URIhttp://サブドメイン名.トップドメイン.com/users/auth/google_oauth2/callback

ルーティングはすべてconstraints subdomain: 'サブドメイン名' doで囲っています。
routes.rb

ruby

1Rails.application.routes.draw do 2 constraints subdomain: 'サブドメイン名' do 3 devise_for :users, controllers: { 4 omniauth_callbacks: "users/omniauth_callbacks" 5 } 6 root to: 'signin#index' 7 8 devise_scope :user do 9 get '/users/sign_out' => 'devise/sessions#destroy' 10 end 11 12 get 'dashboard', to: 'dashboard#index' 13 end 14end

ルーティング

new_user_session GET /users/sign_in(.:format) devise/sessions#new {:subdomain=>"サブドメイン名"} user_session POST /users/sign_in(.:format) devise/sessions#create {:subdomain=>"サブドメイン名"} destroy_user_session DELETE /users/sign_out(.:format) devise/sessions#destroy {:subdomain=>"サブドメイン名"} user_google_oauth2_omniauth_authorize GET|POST /users/auth/google_oauth2(.:format) users/omniauth_callbacks#passthru {:subdomain=>"サブドメイン名"} user_google_oauth2_omniauth_callback GET|POST /users/auth/google_oauth2/callback(.:format) users/omniauth_callbacks#google_oauth2 {:subdomain=>"サブドメイン名"} new_user_password GET /users/password/new(.:format) devise/passwords#new {:subdomain=>"サブドメイン名"} edit_user_password GET /users/password/edit(.:format) devise/passwords#edit {:subdomain=>"サブドメイン名"} user_password PATCH /users/password(.:format) devise/passwords#update {:subdomain=>"サブドメイン名"} PUT /users/password(.:format) devise/passwords#update {:subdomain=>"サブドメイン名"} POST /users/password(.:format) devise/passwords#create {:subdomain=>"サブドメイン名"} cancel_user_registration GET /users/cancel(.:format) devise/registrations#cancel {:subdomain=>"サブドメイン名"} new_user_registration GET /users/sign_up(.:format) devise/registrations#new {:subdomain=>"サブドメイン名"} edit_user_registration GET /users/edit(.:format) devise/registrations#edit {:subdomain=>"サブドメイン名"} user_registration PATCH /users(.:format) devise/registrations#update {:subdomain=>"サブドメイン名"} PUT /users(.:format) devise/registrations#update {:subdomain=>"サブドメイン名"} DELETE /users(.:format) devise/registrations#destroy {:subdomain=>"サブドメイン名"} POST /users(.:format) devise/registrations#create {:subdomain=>"サブドメイン名"} root GET / signin#index {:subdomain=>"サブドメイン名"}

omniauth_callbacks_controller.rb

ruby

1class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController 2 def google_oauth2 3 @user = User.find_for_google_oauth2(request.env["omniauth.auth"]) 4 5 if @user.persisted? 6 flash[:notice] = I18n.t "devise.omniauth_callbacks.success", 7 :kind => "Google" 8 sign_in_and_redirect @user, :event => :authentication and return 9 else 10 session["devise.google_data"] = request.env["omniauth.auth"] 11 redirect_to new_user_registration_url and return 12 end 13 end 14end

device.rb

ruby

1config.omniauth :google_oauth2, 2 Rails.application.secrets.google_client_id, 3 Rails.application.secrets.google_client_secret

application_controller.rb(ログイン後に遷移するページの設定)

ruby

1protected 2 def after_sign_in_path_for(resource) 3 dashboard_path 4 end

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

Googleはサブドメイン非対応とのこと。

投稿2018/05/19 05:21

ruby_0ct

総合スコア57

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問