Sha256: 95f699cabe839b3122cee090cae8e8f62a90301c0c637e0d802e9f1b156e063a
Contents?: true
Size: 1.14 KB
Versions: 2
Compression:
Stored size: 1.14 KB
Contents
# Each time a record is set we check whether its session has already timed out # or not, based on last request time. If so, the record is logged out and # redirected to the sign in page. Also, each time the request comes and the # record is set, we set the last request time inside its scoped session to # verify timeout in the following request. Warden::Manager.after_set_user do |record, warden, options| scope = options[:scope] env = warden.request.env if record && record.respond_to?(:timedout?) && warden.authenticated?(scope) && options[:store] != false last_request_at = warden.session(scope)['last_request_at'] proxy = Devise::Hooks::Proxy.new(warden) if record.timedout?(last_request_at) && !env['devise.skip_timeout'] Devise.sign_out_all_scopes ? proxy.sign_out : proxy.sign_out(scope) if record.respond_to?(:expire_auth_token_on_timeout) && record.expire_auth_token_on_timeout record.reset_authentication_token! end throw :warden, :scope => scope, :message => :timeout end unless env['devise.skip_trackable'] warden.session(scope)['last_request_at'] = Time.now.utc end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
devise-3.2.3 | lib/devise/hooks/timeoutable.rb |
devise-3.2.2 | lib/devise/hooks/timeoutable.rb |