class ActionDispatch::Session::CacheStore
A session store that uses an ActiveSupport::Cache::Store
to store the sessions. This store is most useful if you don't store critical data in your sessions and you don't need them to live for extended periods of time.
Options
-
cache
- The cache to use. If it is not specified,Rails.cache
will be used. -
expire_after
- The length of time a session will be stored before automatically expiring. By default, the:expires_in
option of the cache is used.
Public Class Methods
# File actionpack/lib/action_dispatch/middleware/session/cache_store.rb, line 16 def initialize(app, options = {}) @cache = options[:cache] || Rails.cache options[:expire_after] ||= @cache.options[:expires_in] super end
Calls superclass method
ActionDispatch::Session::Compatibility::new
Public Instance Methods
# File actionpack/lib/action_dispatch/middleware/session/cache_store.rb, line 42 def delete_session(env, sid, options) @cache.delete(cache_key(sid.private_id)) @cache.delete(cache_key(sid.public_id)) generate_sid end
Remove a session from the cache.
# File actionpack/lib/action_dispatch/middleware/session/cache_store.rb, line 23 def find_session(env, sid) unless sid && (session = get_session_with_fallback(sid)) sid, session = generate_sid, {} end [sid, session] end
Get a session from the cache.
# File actionpack/lib/action_dispatch/middleware/session/cache_store.rb, line 31 def write_session(env, sid, session, options) key = cache_key(sid.private_id) if session @cache.write(key, session, expires_in: options[:expire_after]) else @cache.delete(key) end sid end
Set a session in the cache.
© 2004–2020 David Heinemeier Hansson
Licensed under the MIT License.