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
new(app, options = {})
click to toggle source
Calls superclass method
ActionDispatch::Session::Compatibility.new
# File lib/action_dispatch/middleware/session/cache_store.rb, line 14 def initialize(app, options = {}) @cache = options[:cache] || Rails.cache options[:expire_after] ||= @cache.options[:expires_in] super end
Public Instance Methods
delete_session(env, sid, options)
click to toggle source
Remove a session from the cache.
# File lib/action_dispatch/middleware/session/cache_store.rb, line 40 def delete_session(env, sid, options) @cache.delete(cache_key(sid)) generate_sid end
find_session(env, sid)
click to toggle source
Get a session from the cache.
# File lib/action_dispatch/middleware/session/cache_store.rb, line 21 def find_session(env, sid) unless sid && (session = @cache.read(cache_key(sid))) sid, session = generate_sid, {} end [sid, session] end
write_session(env, sid, session, options)
click to toggle source
Set a session in the cache.
# File lib/action_dispatch/middleware/session/cache_store.rb, line 29 def write_session(env, sid, session, options) key = cache_key(sid) if session @cache.write(key, session, expires_in: options[:expire_after]) else @cache.delete(key) end sid end
Private Instance Methods
cache_key(sid)
click to toggle source
Turn the session id into a cache key.
# File lib/action_dispatch/middleware/session/cache_store.rb, line 47 def cache_key(sid) "_session_id:#{sid}" end