Class: Rack::Session::Pool

Inherits:
Abstract::PersistedSecure show all
Defined in:
lib/rack/session/pool.rb

Overview

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

Constant Summary collapse

DEFAULT_OPTIONS =
Abstract::ID::DEFAULT_OPTIONS.merge drop: false

Instance Attribute Summary collapse

Attributes inherited from Abstract::Persisted

#default_options, #key, #sid_secure

Instance Method Summary collapse

Methods inherited from Abstract::PersistedSecure

#extract_session_id

Methods inherited from Abstract::Persisted

#call, #commit_session, #context

Constructor Details

#initialize(app, options = {}) ⇒ Pool

Returns a new instance of Pool.



33
34
35
36
37
# File 'lib/rack/session/pool.rb', line 33

def initialize(app, options = {})
  super
  @pool = Hash.new
  @mutex = Mutex.new
end

Instance Attribute Details

#mutexObject (readonly)

Returns the value of attribute mutex.



30
31
32
# File 'lib/rack/session/pool.rb', line 30

def mutex
  @mutex
end

#poolObject (readonly)

Returns the value of attribute pool.



30
31
32
# File 'lib/rack/session/pool.rb', line 30

def pool
  @pool
end

Instance Method Details

#delete_session(req, session_id, options) ⇒ Object



63
64
65
66
67
68
69
# 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

#find_session(req, sid) ⇒ Object



46
47
48
49
50
51
52
53
54
# 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

#generate_sidObject



39
40
41
42
43
44
# 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

#with_lock(req) ⇒ Object



71
72
73
74
75
76
# 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

#write_session(req, session_id, new_session, options) ⇒ Object



56
57
58
59
60
61
# 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