2012-02-09 12 views
5

次後3.1考案のOauthのFacebookのルーティングの混乱:Railsの

https://github.com/plataformatec/devise/wiki/OmniAuth:-Overview

は私がFacebook経由のユーザーをサインアップすることができます。しかし、私は自分のリダイレクトを定義するのに苦労しています。

は明らかにそれはすでにFacebookの/でサインアップした既存のユーザーは、私のアプリにリダイレクトし、上継続されますが、それは、新たに私が興味Facebook経由作成されたユーザーの場合だと完璧です。

class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController 
    def facebook 
    # You need to implement the method below in your model 
    @user = User.find_for_facebook_oauth(request.env["omniauth.auth"], current_user) 

    if @user.persisted? 
     flash[:notice] = I18n.t "devise.omniauth_callbacks.success", :kind => "Facebook" 
     sign_in_and_redirect @user, :event => :authentication 
    else 
     session["devise.facebook_data"] = request.env["omniauth.auth"] 
     redirect_to new_user_registration_url 
    end 
    end 
end 

user.persistedとは何ですか? find_for_facebook_oauthはdevise wikiページと同じです。すなわち、電子メールでユーザを見つけ出し、存在する場合にはそれを返すか、そうでない場合には自動原パスワードを有する新しいユーザを作成する。

しかし、新しく作成したユーザーをパスワードを設定するページにリダイレクトする必要があります。私はスタブのパスワードを維持したくない、私はユーザーにすぐにa)自分の名前を確認し、b)パスワードを確認する画面が表示されるようにします。

私は、/ devise/invitations/editのビューにある招待状(https://github.com/scambra/devise_invitable/経由)を受け入れる人にこのような画面を実装しています。

この種類のリダイレクトにはどのようなリダイレクトを追加すればよいですか?上記のfacebookメソッドは、解釈するのがかなり混乱していることがわかります。私は新しいユーザー登録URLにリダイレクトする理由を理解できません - ユーザーが作成されているか存在しているので、何が関連していますか?

明らかに混乱しています。 :)

おかげで、そのレコードがデータベースに保存されているかどうか

デイブ

答えて

9

.persisted?方法をチェックします。これは、ユーザーが正常に見つかったか作成されたかどうかを確認する方法の方法です。そうでない場合は、new_user_registration_urlにリダイレクトされます。これは、サインアップに失敗したため(ユーザーが再試行できるようにするため)です。

ユーザーが新規であるかどうかに基づいてリダイレクトするには、新しいユーザーオブジェクトであることを示すフラグがあるかどうかをユーザーオブジェクトで確認できます。 (未テスト)パスワードを述べたので、このような何かは仕事ができる:

if @user.persisted? 
    flash[:notice] = I18n.t "devise.omniauth_callbacks.success", :kind => "Facebook" 
    if @user.password.exists? 
    sign_in_and_redirect @user, :event => :authentication 
    else 
    sign_in @user 
    redirect_to ______ #insert path to set password etc 
    end 
else 
    session["devise.facebook_data"] = request.env["omniauth.auth"] 
    redirect_to new_user_registration_url 
end 

代替を(あなたがより多くの微調整を取得したい場合)は、after_sign_in_path_for(resource_or_scope)をカスタマイズしたい場合があり、on the Devise wiki

+1

を説明するようにあなたが正しいです。私はsign_in_count(deviseの一部)を使用して、ユーザーが最初にログインしたかどうかを判断しました。明確な説明をありがとう。 – Dave

+0

問題ありません!役に立ったと投票してください:) –

+0

@Dave:どのビューファイルにコードを書き込む必要がありますか? – inquisitive