Я следую указаниям Райана по Омниавту здесь .
Однако есть сценарий, который Райан не охватил:
У нас уже есть аккаунт, но они впервые заходят через 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
конец