Как получить доступ к сеансу из обратного вызова Warden/Devise after_authentication в Rails
Я пытаюсь получить доступ к текущему сеансу из обратного вызова Warden after_authenticate (работает под Devise) в Rails 3.
В верхней части моего контроллера приложений я хочу сделать что-то вроде:
Warden::Manager.after_authentication do |user,auth,opts|
user.associate_with_ids(session[:pending_ids])
end
Конечная цель состоит в том, чтобы взять список идентификаторов записей, которые были сохранены в сеансе до регистрации, и связать их с моделью пользователя после входа.
Любая помощь приветствуется.
4 ответа
"auth.session" получает / устанавливает данные в ключе сеанса "warden.user. # {scope}.session".
Предположим, вы сохранили pending_ids в вашем приложении rails:
session[:pending_ids] = ...
и вы хотели получить доступ к крюку надзирателя, вы можете получить к нему доступ таким образом:
Warden::Manager.after_authentication do |user,auth,opts|
user.associate_with_ids(auth.env['rack.session'][:pending_ids])
end
Мне потребовалось некоторое время, чтобы выяснить это, поэтому я думаю, что это могло бы помочь кому-то.
(изначально взято с diegoscataglini.com/2012/02/09/383/manipulation-sessions-in-wardendevise, который сейчас мертв).
Вы можете получить доступ к хранилищу сеансов через auth
:
Warden::Manager.after_authentication do |user,auth,opts|
user.associate_with_ids(auth.session[:pending_ids])
end
Вы также можете получить доступ к сессии через auth.request.session
,
Итак, ваш пример будет:
Warden::Manager.after_authentication do |user,auth,opts|
user.associate_with_ids(auth.request.session[:pending_ids])
end