Class/Module Index [+]

Quicksearch

Merb::CookieSession

If you have more than 4K of session data or don't want your data to be visible to the user, pick another session store.

CookieOverflow is raised if you attempt to store more than 4K of data. TamperedWithCookie is raised if the data integrity check fails.

A message digest is included with the cookie to ensure data integrity: a user cannot alter session data without knowing the secret key included in the hash.

To use Cookie Sessions, set in config/merb.yml

:session_secret_key - your secret digest key
:session_store - cookie

Constants

DIGEST
MAX

Cookies can typically store 4096 bytes.

Attributes

_original_session_data[RW]

:api: private

Public Class Methods

generate() click to toggle source

Generates a new session ID and creates a new session.

Returns

SessionContainer

The new session.

:api: private

# File lib/merb-core/dispatch/session/cookie.rb, line 46
def generate
  self.new(Merb::SessionMixin.rand_uuid, "", Merb::Request._session_secret_key)
end
new(session_id, cookie, secret) click to toggle source

Parameters

session_id<String>

A unique identifier for this session.

cookie<String>

The raw cookie data.

secret<String>

A session secret.

Raises

ArgumentError

blank or insufficiently long secret.

:api: private

# File lib/merb-core/dispatch/session/cookie.rb, line 78
def initialize(session_id, cookie, secret)
  super session_id
  if secret.blank? || secret.length < 16
    msg = "You must specify a session_secret_key in your init file, and it must be at least 16 characters"
    Merb.logger.warn(msg)
    raise ArgumentError, msg
  end
  @secret = secret
  self.update(unmarshal(cookie))
end
setup(request) click to toggle source

Set up a new session on request: make it available on request instance.

Parameters

request<Merb::Request>

The Merb::Request that came in from Rack.

Returns

SessionContainer

a SessionContainer. If no sessions were found,

a new SessionContainer will be generated.

:api: private

# File lib/merb-core/dispatch/session/cookie.rb, line 60
def setup(request)
  session = self.new(Merb::SessionMixin.rand_uuid,
    request.session_cookie_value, request._session_secret_key)
  session._original_session_data = session.to_cookie
  request.session = session
end

Public Instance Methods

finalize(request) click to toggle source

Teardown and/or persist the current session.

If @_destroy is true, clear out the session completely, including removal of the session cookie itself.

Parameters

request<Merb::Request>

request object created from Rack environment.

:api: private

# File lib/merb-core/dispatch/session/cookie.rb, line 98
def finalize(request)
  if @_destroy
    request.destroy_session_cookie
  elsif _original_session_data != (new_session_data = self.to_cookie)
    request.set_session_cookie_value(new_session_data)
  end
end
regenerate() click to toggle source

Regenerate the session_id.

:api: private

# File lib/merb-core/dispatch/session/cookie.rb, line 109
def regenerate
  self.session_id = Merb::SessionMixin.rand_uuid
end

Protected Instance Methods

serialize() click to toggle source

Serialize current session data as a Hash. Uses Base64 encoding for integrity.

Returns

String

Base64 encoded dump of the session hash.

:api: private

# File lib/merb-core/dispatch/session/cookie.rb, line 219
def serialize
  Base64.encode64(Marshal.dump(self.to_hash)).chop
end
unserialize(data) click to toggle source

Unserialize the raw cookie data to a Hash

Returns

Hash

the session hash Base64 decoded from the data dump.

:api: private

# File lib/merb-core/dispatch/session/cookie.rb, line 229
def unserialize(data)
  Marshal.load(Base64.decode64(data)) rescue {}
end

[Validate]

Generated with the Darkfish Rdoc Generator 2.