'Session', 'alias' => 'Session', 'table' => 'cake_sessions', ); } else { $settings = array( 'class' => $modelName, 'alias' => 'Session', ); } $this->_model = ClassRegistry::init($settings); $this->_timeout = Configure::read('Session.timeout') * 60; } /** * Method called on open of a database session. * * @return boolean Success */ public function open() { return true; } /** * Method called on close of a database session. * * @return boolean Success */ public function close() { $probability = mt_rand(1, 150); if ($probability <= 3) { $this->gc(); } return true; } /** * Method used to read from a database session. * * @param mixed $id The key of the value to read * @return mixed The value of the key or false if it does not exist */ public function read($id) { $row = $this->_model->find('first', array( 'conditions' => array($this->_model->primaryKey => $id) )); if (empty($row[$this->_model->alias]['data'])) { return false; } return $row[$this->_model->alias]['data']; } /** * Helper function called on write for database sessions. * * @param integer $id ID that uniquely identifies session in database * @param mixed $data The value of the data to be saved. * @return boolean True for successful write, false otherwise. */ public function write($id, $data) { if (!$id) { return false; } $expires = time() + $this->_timeout; $record = compact('id', 'data', 'expires'); $record[$this->_model->primaryKey] = $id; return $this->_model->save($record); } /** * Method called on the destruction of a database session. * * @param integer $id ID that uniquely identifies session in database * @return boolean True for successful delete, false otherwise. */ public function destroy($id) { return $this->_model->delete($id); } /** * Helper function called on gc for database sessions. * * @param integer $expires Timestamp (defaults to current time) * @return boolean Success */ public function gc($expires = null) { if (!$expires) { $expires = time(); } return $this->_model->deleteAll(array($this->_model->alias . ".expires <" => $expires), false, false); } /** * Closes the session before the objects handling it become unavailable * * @return void */ public function __destruct() { try { session_write_close(); } catch (Exception $e) {} } }