| Class | CGI::Session::PStore |
| In: |
cgi/session/pstore.rb
|
| Parent: | Object |
Public Class methods
Create a new CGI::Session::PStore instance
This constructor is used internally by CGI::Session. The user does not generally need to call it directly.
session is the session for which this instance is being created. The session id must only contain alphanumeric characters; automatically generated session ids observe this requirement.
option is a hash of options for the initialiser. The following options are recognised:
| tmpdir: | the directory to use for storing the PStore file. Defaults to Dir::tmpdir (generally "/tmp" on Unix systems). |
| prefix: | the prefix to add to the session id when generating the filename for this session’s PStore file. Defaults to the empty string. |
This session’s PStore file will be created if it does not exist, or opened if it does.
# File cgi/session/pstore.rb, line 56
56: def initialize session, option={}
57: dir = option['tmpdir'] || Dir::tmpdir
58: prefix = option['prefix'] || ''
59: id = session.session_id
60: require 'digest/md5'
61: md5 = Digest::MD5.hexdigest(id)[0,16]
62: path = dir+"/"+prefix+md5
63: path.untaint
64: unless File::exist?(path)
65: unless session.new_session
66: raise CGI::Session::NoSession, "uninitialized session"
67: end
68: @hash = {}
69: end
70: @p = ::PStore.new(path)
71: @p.transaction do |p|
72: File.chmod(0600, p.path)
73: end
74: end