Зарегистрированный пользователь впервые авторизуется через Facebook - Omniauth - PullRequest
0 голосов
/ 28 ноября 2011

Я следую указаниям Райана по Омниавту здесь .

Однако есть сценарий, который Райан не охватил: У нас уже есть аккаунт, но они впервые заходят через Facebook / Linkedin. В этом случае я бы хотел, чтобы пользователь выполнил вход с использованием традиционного входа (через Devise), и, если ему это удалось, создайте новый объект аутентификации для будущих входов.

В частности, когда зарегистрированный пользователь нажимает «Войти через Facebook» в первый раз, я получу хеш от обратного вызова, который содержит информацию о его учетной записи Facebook. Но я пока не хочу создавать для него аутентификацию. Вместо этого я перенаправлю его на страницу входа в Devise, что позволит ему ввести имя пользователя и пароль. Если он выполнит успешный вход, я хотел бы создать новый объект аутентификации на основе информации, полученной от обратного вызова Facebook.

Что может быть хорошим способом временного хранения хэша Facebook, пока пользователь не войдет в систему?

Спасибо.

Ниже приведен код из AuthenticationController.rb, созданный Райаном, который не справился с ситуацией, которую я только что упомянул:

  def create
    omniauth = request.env["omniauth.auth"]

authentication = Authentication.find_by_provider_and_uid(omniauth['provider'], omniauth['uid'])
if authentication
  flash[:notice] = "Signed in successfully."
  sign_in_and_redirect(:user, authentication.user)
elsif current_user
  current_user.authentications.create!(:provider => omniauth['provider'], :uid => omniauth['uid'])
  flash[:notice] = "Authentication successful."
  redirect_to authentications_url
else
  user = User.new
  user.apply_omniauth(omniauth)
  if user.save
    flash[:notice] = "Signed in successfully."
    sign_in_and_redirect(:user, user)
  else
    session[:omniauth] = omniauth
    redirect_to new_user_registration_url
  end
end

конец

1 Ответ

0 голосов
/ 28 ноября 2011

Вместо этого, не могли бы вы проверить, есть ли другой пользователь с таким же адресом электронной почты, когда он регистрируется на Facebook? Если это так, добавьте Facebook в качестве второго метода аутентификации, а если нет, создайте новую учетную запись.

...