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.
Create a new store. The cache to use can be passed in the :cache option. If it is not specified, Rails.cache will be used.
# File lib/action_dispatch/middleware/session/cache_store.rb, line 12 def initialize(app, options = {}) @cache = options[:cache] || Rails.cache options[:expire_after] ||= @cache.options[:expires_in] super end
Remove a session from the cache.
# File lib/action_dispatch/middleware/session/cache_store.rb, line 38 def destroy_session(env, sid, options) @cache.delete(cache_key(sid)) generate_sid end
Get a session from the cache.
# File lib/action_dispatch/middleware/session/cache_store.rb, line 19 def get_session(env, sid) sid ||= generate_sid session = @cache.read(cache_key(sid)) session ||= {} [sid, session] end
Set a session in the cache.
# File lib/action_dispatch/middleware/session/cache_store.rb, line 27 def set_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
Generated with the Darkfish Rdoc Generator 2.