0

Devise で Omniauth (twitter サインイン) を使用する Rails アプリケーションがあります。ユーザーが「Twitter でサインアップ」をクリックして認証に同意すると、アプリケーションはデバイス登録ページ (redirect_to new_user_registration_url) に移動し、そこでユーザーは電子メールを提供する必要があります。ユーザーがメールを入力した後、ホームページに戻りますが、ユーザーはサインインしていません。したがって、ここの指示に従って新しい Devise 登録コントローラーを作成しましたhttps://github.com/plataformatec/devise/wiki/How-To% 3a-Redirect-to-a-specific-page-on-successful-sign-up-%28registration%29 しかし、私はまだ同じ問題を抱えています。さらに、私が含めた put ステートメントはサーバー レコードに記録されていないため、何か間違ったことをしたと思います。

これを機能させるために私ができることを説明できますか?

登録コントローラー (after_sign_up_path_for 内のコードが正しいかどうかはわかりませんが、何らかの理由で puts ステートメントがログに記録されないことに注意してください)

class RegistrationsController < Devise::RegistrationsController
  protected
  def after_sign_up_path_for(user)
    # puts resource
     puts "checking resource"
    # session[:user_id] = user.id
    sign_in_and_redirect user
  end
end

users_controller.rb

def all
    user = User.from_omniauth(request.env["omniauth.auth"])
    if user.persisted?
      puts "user persisted"
      session[:user_id] = user.id
      flash.notice = "Signed in!"
      sign_in_and_redirect user
    else
      session["devise.user_attributes"] = user.attributes
      redirect_to new_user_registration_url
    end
  end

ユーザー.rb

def self.from_omniauth(auth)
  where(auth.slice(:provider, :uid)).first_or_create do |user|
    user.provider = auth.provider
    user.uid = auth.uid
    user.name = auth.info.nickname
    user.image = auth["info"]["image"]
  end
end
4

1 に答える 1

0

Devise 登録コントローラーをオーバーライドするには、新しいコントローラーのルートを設定する必要があります。

devise_for :users, controllers: { registrations: 'registrations'}
于 2013-02-24T10:25:42.710 に答える