Как получить доступ к сеансу из обратного вызова 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

Вы также можете найти всю сессию из auth.raw_session

Другие вопросы по тегам