class Rack::Session::Pool
Rack::Session::Pool
provides simple cookie based session management. Session
data is stored in a hash held by @pool. In the context of a multithreaded environment, sessions being committed to the pool is done in a merging manner.
The :drop option is available in rack.session.options if you wish to explicitly remove the session from the session cache.
Example:
myapp = MyRackApp.new sessioned = Rack::Session::Pool.new(myapp, :domain => 'foo.com', :expire_after => 2592000 ) Rack::Handler::WEBrick.run sessioned
Constants
- DEFAULT_OPTIONS
Attributes
Public Class Methods
Source
# File lib/rack/session/pool.rb, line 33 def initialize(app, options = {}) super @pool = Hash.new @mutex = Mutex.new end
Calls superclass method
Rack::Session::Abstract::Persisted::new
Public Instance Methods
Source
# File lib/rack/session/pool.rb, line 63 def delete_session(req, session_id, options) with_lock(req) do @pool.delete(session_id.public_id) @pool.delete(session_id.private_id) generate_sid unless options[:drop] end end
Source
# File lib/rack/session/pool.rb, line 46 def find_session(req, sid) with_lock(req) do unless sid and session = get_session_with_fallback(sid) sid, session = generate_sid, {} @pool.store sid.private_id, session end [sid, session] end end
Source
# File lib/rack/session/pool.rb, line 39 def generate_sid loop do sid = super break sid unless @pool.key? sid.private_id end end
Calls superclass method
Rack::Session::Abstract::PersistedSecure#generate_sid
Source
# File lib/rack/session/pool.rb, line 71 def with_lock(req) @mutex.lock if req.multithread? yield ensure @mutex.unlock if @mutex.locked? end
Source
# File lib/rack/session/pool.rb, line 56 def write_session(req, session_id, new_session, options) with_lock(req) do @pool.store session_id.private_id, new_session session_id end end