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

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

ただいまの
回答率

90.51%

  • Ruby on Rails

    8854questions

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

  • Facebook

    442questions

    Facebookは、実名登録制のSNS(ソーシャル・ネットワーキング・サービス)です。開発者用のデベロッパーサイトが存在し、一般ユーザーによるFacebook向けアプリケーション開発が可能です。

  • Devise

    311questions

    Deviseとは、Ruby-on-Railsの認証機能を追加するプラグインです。

  • OAuth 2.0

    105questions

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

device・OAuthを用いたfacebookログインができません。。。

受付中

回答 0

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 42

urarishi

score 0

前提・実現したいこと

【omniauth-facebook】を用いたログイン機構の実装。

上記を実装中なのですがリンクをクリックしても、
デバイスで用意されたサインアップページにリダイレクトされてしまいます...

発生している問題・エラーメッセージ

トップページ
ページ中央のsign in facebook をクリックしても、
下記のdeviseによって用意されたサインアップページにリダイレクトされてしまいます...

サインアップページ
エラーメッセージすら出ず、ページがリダイレクトされてしまいます。

コード情報

【User.rb】

class User < ApplicationRecord
  # Include default devise modules. Others available are:
  # :confirmable, :lockable, :timeoutable, :trackable and :omniauthable
  devise :database_authenticatable, :registerable,
         :recoverable, :rememberable, :validatable, :omniauthable

  def self.from_omniauth(auth)
    where(provider: auth.provider, uid: auth.uid).first_or_create do |user|
      user.email = auth.info.email
      # user.update_attribute(:email, auth.info.email)
      user.password = Devise.friendly_token[0,20]
      user.name = auth.info.name   # assuming the user model has a name
      user.image = auth.info.image # assuming the user model has an image
      # If you are using confirmable and the provider(s) you use validate emails, 
      # uncomment the line below to skip the confirmation emails.
      # user.skip_confirmation!
    end
  end
end

【omniauth_callbacks_controller.rb】

class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
  def facebook
    # You need to implement the method below in your model (e.g. app/models/user.rb)
    @user = User.from_omniauth(request.env["omniauth.auth"])

    if @user.persisted?
      sign_in_and_redirect @user, event: :authentication #this will throw if @user is not activated
      set_flash_message(:notice, :success, kind: "Facebook") if is_navigational_format?
    else
      session["devise.facebook_data"] = request.env["omniauth.auth"]
      redirect_to new_user_registration_url
    end
  end

  def failure
    redirect_to root_path
  end
end

【routes.rb】

Rails.application.routes.draw do
  devise_for :users, controllers: { omniauth_callbacks: 'users/omniauth_callbacks' }
  get 'users/new'

  root 'static_pages#home'
  get 'static_pages/terms'
  get 'static_pages/home'
end

【サーバーログ】

Started GET "/users/auth/facebook" for 119.224.169.247 at 2019-05-15 11:15:07 +0000
I, [2019-05-15T11:15:07.630826 #4023]  INFO -- omniauth: (facebook) Request phase initiated.
Started GET "/users/auth/facebook" for 119.224.169.247 at 2019-05-15 11:15:08 +0000
I, [2019-05-15T11:15:08.340298 #4023]  INFO -- omniauth: (facebook) Request phase initiated.
Started GET "/users/auth/facebook/callback?code=〜〜〜〜〜コード〜〜〜〜〜" for 119.224.169.247 at 2019-05-15 11:15:09 +0000
I, [2019-05-15T11:15:09.049863 #4023]  INFO -- omniauth: (facebook) Callback phase initiated.
Processing by Users::OmniauthCallbacksController#facebook as HTML
  Parameters: {"code"=>"〜〜〜コード〜〜〜, "state"=>"〜〜〜ステート〜〜〜〜"}
  User Load (0.2ms)  SELECT  "users".* FROM "users" WHERE "users"."provider" = ? AND "users"."uid" = ? ORDER BY "users"."id" ASC LIMIT ?  [["provider", "facebook"], ["uid", "589989758173505"], ["LIMIT", 1]]
   (0.1ms)  begin transaction
   (0.0ms)  rollback transaction
Redirected to https:(ドメイン名).vfs.cloud9.us-east-2.amazonaws.com/users/sign_up
Completed 302 Found in 156ms (ActiveRecord: 0.3ms)

上記のように、それぞれリクエストフェーズ、コールバックフェーズには至っているものの、
最終的にrollbackされてしまいます...
どなたかご助言を頂けませんでしょうか。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

同じタグがついた質問を見る

  • Ruby on Rails

    8854questions

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

  • Facebook

    442questions

    Facebookは、実名登録制のSNS(ソーシャル・ネットワーキング・サービス)です。開発者用のデベロッパーサイトが存在し、一般ユーザーによるFacebook向けアプリケーション開発が可能です。

  • Devise

    311questions

    Deviseとは、Ruby-on-Railsの認証機能を追加するプラグインです。

  • OAuth 2.0

    105questions

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