次後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にリダイレクトする理由を理解できません - ユーザーが作成されているか存在しているので、何が関連していますか?
明らかに混乱しています。 :)
おかげで、そのレコードがデータベースに保存されているかどうか
デイブ
を説明するようにあなたが正しいです。私はsign_in_count(deviseの一部)を使用して、ユーザーが最初にログインしたかどうかを判断しました。明確な説明をありがとう。 – Dave
問題ありません!役に立ったと投票してください:) –
@Dave:どのビューファイルにコードを書き込む必要がありますか? – inquisitive