Sha256: 544489c529af15569dd08febe148a4d70201a9af15873a1e3e5fce5f0a823350

Contents?: true

Size: 1.32 KB

Versions: 9

Compression:

Stored size: 1.32 KB

Contents

# After authenticate hook to verify if the user in the given scope asked to be
# remembered while he does not sign out. Generates a new remember token for
# that specific user and adds a cookie with this user info to sign in this user
# automatically without asking for credentials. Refer to rememberable strategy
# for more info.
Warden::Manager.prepend_after_authentication do |record, warden, options|
  scope = options[:scope]
  remember_me = warden.params[scope].try(:fetch, :remember_me, nil)

  if Devise::TRUE_VALUES.include?(remember_me) &&
     warden.authenticated?(scope) && record.respond_to?(:remember_me!)
    record.remember_me!

    warden.response.set_cookie "remember_#{scope}_token", {
      :value => record.class.serialize_into_cookie(record),
      :expires => record.remember_expires_at,
      :path => "/"
    }
  end
end

# Before logout hook to forget the user in the given scope, only if rememberable
# is activated for this scope. Also clear remember token to ensure the user
# won't be remembered again.
# Notice that we forget the user if the record is frozen. This usually means the
# user was just deleted.
Warden::Manager.before_logout do |record, warden, scope|
  if record.respond_to?(:forget_me!)
    record.forget_me! unless record.frozen?
    warden.response.delete_cookie "remember_#{scope}_token"
  end
end

Version data entries

9 entries across 9 versions & 3 rubygems

Version Path
devise-1.0.9 lib/devise/hooks/rememberable.rb
dcu-devise-1.0.7 lib/devise/hooks/rememberable.rb
devise-1.0.8 lib/devise/hooks/rememberable.rb
ivanvc-devise-1.0.7.1 lib/devise/hooks/rememberable.rb
devise-1.0.7 lib/devise/hooks/rememberable.rb
devise-1.0.6 lib/devise/hooks/rememberable.rb
devise-1.0.5 lib/devise/hooks/rememberable.rb
devise-1.0.4 lib/devise/hooks/rememberable.rb
devise-1.1.pre4 lib/devise/hooks/rememberable.rb