| | |
| | | ini_set('session.use_only_cookies', 1); |
| | | ini_set('session.cookie_httponly', 1); |
| | | |
| | | // use database for storing session data |
| | | $storage = $this->config->get('session_storage', 'db'); |
| | | $this->session = $this->get_session($storage); |
| | | // get storage driver from config |
| | | // $storage = $this->config->get('session_storage', 'db'); |
| | | |
| | | // register default gc handler |
| | | $this->session->register_gc_handler(array($this, 'gc')); |
| | | |
| | | $this->session->set_secret($this->config->get('des_key') . dirname($_SERVER['SCRIPT_NAME'])); |
| | | $this->session->set_ip_check($this->config->get('ip_check')); |
| | | |
| | | if ($this->config->get('session_auth_name')) { |
| | | $this->session->set_cookiename($this->config->get('session_auth_name')); |
| | | } |
| | | // get session driver instance |
| | | $this->session = rcube_session::factory($this->config); |
| | | |
| | | // start PHP session (if not in CLI mode) |
| | | if ($_SERVER['REMOTE_ADDR']) { |
| | | $this->session->start($this->config); |
| | | $this->session->start(); |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * get an rcube_session instance |
| | | * |
| | | * @return rcube_session |
| | | */ |
| | | private function get_session($storage) |
| | | { |
| | | // class name for this storage |
| | | $class = "rcube_session_" . $storage; |
| | | |
| | | // try to instantiate class |
| | | if(class_exists($class)) { |
| | | return new $class(); |
| | | } |
| | | |
| | | // no storage found, raise error |
| | | rcube::raise_error(array('code' => 604, 'type' => 'session', |
| | | 'line' => __LINE__, 'file' => __FILE__, |
| | | 'message' => "Failed to find session driver. Check session_storage config option"), |
| | | true, true); |
| | | } |
| | | |
| | | |
| | | /** |
| | | * Garbage collector - cache/temp cleaner |
| | |
| | | +-----------------------------------------------------------------------+ |
| | | | Author: Thomas Bruederli <roundcube@gmail.com> | |
| | | | Author: Aleksander Machniak <alec@alec.pl> | |
| | | | Author: Cor Bosman <cor@roundcu.be> | |
| | | +-----------------------------------------------------------------------+ |
| | | */ |
| | | |
| | |
| | | protected $secret = ''; |
| | | protected $ip_check = false; |
| | | protected $logging = false; |
| | | protected $config; |
| | | |
| | | /** |
| | | * Blocks session data from being written to database. |
| | |
| | | * @var boolean |
| | | */ |
| | | public $nowrite = false; |
| | | |
| | | |
| | | /** |
| | | * Factory, returns driver-specific instance of the class |
| | | * |
| | | * @param object $config |
| | | * @return Object rcube_session |
| | | */ |
| | | public static function factory($config) |
| | | { |
| | | // get session storage driver |
| | | $storage = $config->get('session_storage', 'db'); |
| | | |
| | | // class name for this storage |
| | | $class = "rcube_session_" . $storage; |
| | | |
| | | // try to instantiate class |
| | | if (class_exists($class)) { |
| | | return new $class($config); |
| | | } |
| | | |
| | | // no storage found, raise error |
| | | rcube::raise_error(array('code' => 604, 'type' => 'session', |
| | | 'line' => __LINE__, 'file' => __FILE__, |
| | | 'message' => "Failed to find session driver. Check session_storage config option"), |
| | | true, true); |
| | | } |
| | | |
| | | /** |
| | | * @param Object $config |
| | | */ |
| | | public function __construct($config) |
| | | { |
| | | $this->config = $config; |
| | | |
| | | // register default gc handler |
| | | $this->register_gc_handler(array($this, 'gc')); |
| | | |
| | | // set secret |
| | | $this->set_secret($this->config->get('des_key') . dirname($_SERVER['SCRIPT_NAME'])); |
| | | |
| | | // set ip check |
| | | $this->set_ip_check($this->config->get('ip_check')); |
| | | |
| | | // set cookie name |
| | | if ($this->config->get('session_auth_name')) { |
| | | $this->set_cookiename($this->config->get('session_auth_name')); |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * register session handler |
| | | */ |
| | |
| | | /** |
| | | * Wrapper for session_start() |
| | | */ |
| | | public function start($config) |
| | | public function start() |
| | | { |
| | | $this->start = microtime(true); |
| | | $this->ip = rcube_utils::remote_addr(); |
| | | $this->logging = $config->get('log_session', false); |
| | | $this->logging = $this->config->get('log_session', false); |
| | | |
| | | $lifetime = $config->get('session_lifetime', 1) * 60; |
| | | $lifetime = $this->config->get('session_lifetime', 1) * 60; |
| | | $this->set_lifetime($lifetime); |
| | | |
| | | session_start(); |
| | |
| | | */ |
| | | public function sess_write($key, $vars) |
| | | { |
| | | if ($this->nowrite) |
| | | if ($this->nowrite) { |
| | | return true; |
| | | } |
| | | |
| | | // check cache |
| | | $oldvars = $this->get_cache($key); |
| | |
| | | protected function gc_shutdown() |
| | | { |
| | | if ($this->gc_enabled) { |
| | | // just delete all expired sessions |
| | | if ($this->storage == 'db') { |
| | | $this->db->query("DELETE FROM {$this->table_name}" |
| | | . " WHERE `changed` < " . $this->db->now(-$this->gc_enabled)); |
| | | } |
| | | |
| | | foreach ($this->gc_handlers as $fct) { |
| | | call_user_func($fct); |
| | | } |
| | |
| | | private $db; |
| | | private $table_name; |
| | | |
| | | public function __construct() |
| | | /** |
| | | * @param Object $config |
| | | */ |
| | | public function __construct($config) |
| | | { |
| | | parent::__construct($config); |
| | | |
| | | // get db instance |
| | | $this->db = rcube::get_instance()->get_dbh(); |
| | | |
| | |
| | | +-----------------------------------------------------------------------+ |
| | | | Author: Thomas Bruederli <roundcube@gmail.com> | |
| | | | Author: Aleksander Machniak <alec@alec.pl> | |
| | | | Author: Cor Bosman <cor@roundcu.be> | |
| | | | Author: Cor Bosman <cor@roundcu.bet> | |
| | | +-----------------------------------------------------------------------+ |
| | | */ |
| | | |
| | |
| | | { |
| | | private $memcache; |
| | | |
| | | public function __construct() |
| | | /** |
| | | * @param Object $config |
| | | */ |
| | | public function __construct($config) |
| | | { |
| | | parent::__construct($config); |
| | | |
| | | $this->memcache = rcube::get_instance()->get_memcache(); |
| | | |
| | | if(! $this->memcache) { |
| | | if (!$this->memcache) { |
| | | rcube::raise_error(array('code' => 604, 'type' => 'db', |
| | | 'line' => __LINE__, 'file' => __FILE__, |
| | | 'message' => "Failed to connect to memcached. Please check configuration"), |
| | |
| | | |
| | | // register sessions handler |
| | | $this->register_session_handler(); |
| | | |
| | | } |
| | | |
| | | /** |
| | |
| | | */ |
| | | class rcube_session_php extends rcube_session { |
| | | |
| | | |
| | | /** |
| | | * native php sessions don't need a save handler |
| | | * we do need to define abstract function implementations but they are not used. |
| | |
| | | public function write($key, $vars) {} |
| | | public function update($key, $newvars, $oldvars) {} |
| | | |
| | | /** |
| | | * @param Object $config |
| | | */ |
| | | public function __construct($config) |
| | | { |
| | | parent::__construct($config); |
| | | } |
| | | |
| | | /** |
| | | * Wrapper for session_write_close() |
| | |
| | | /** |
| | | * Wrapper for session_start() |
| | | */ |
| | | public function start($config) |
| | | public function start() |
| | | { |
| | | parent::start($config); |
| | | parent::start(); |
| | | |
| | | $this->key = session_id(); |
| | | $this->ip = $_SESSION['__IP']; |
| | |
| | | | PURPOSE: | |
| | | | Provide database supported session management | |
| | | +-----------------------------------------------------------------------+ |
| | | | Author: Thomas Bruederli <roundcube@gmail.com> | |
| | | | Author: Aleksander Machniak <alec@alec.pl> | |
| | | | Author: Cor Bosman <cor@roundcu.be> | |
| | | +-----------------------------------------------------------------------+ |
| | | */ |
| | |
| | | |
| | | private $redis; |
| | | |
| | | public function __construct() |
| | | /** |
| | | * @param Object $config |
| | | */ |
| | | public function __construct($config) |
| | | { |
| | | parent::__construct($config); |
| | | |
| | | // instantiate Redis object |
| | | $this->redis = new Redis(); |
| | | |
| | | if (! $this->redis) { |
| | | if (!$this->redis) { |
| | | rcube::raise_error(array('code' => 604, 'type' => 'session', |
| | | 'line' => __LINE__, 'file' => __FILE__, |
| | | 'message' => "Failed to find Redis. Make sure php-redis is included"), |
| | |
| | | } |
| | | |
| | | // get config instance |
| | | $hosts = rcube::get_instance()->config->get('redis_hosts', array()); |
| | | $hosts = $this->config->get('redis_hosts', array('localhost')); |
| | | |
| | | // host config is wrong |
| | | if (!is_array($hosts) || empty($hosts) ) { |
| | | if (!is_array($hosts) || empty($hosts)) { |
| | | rcube::raise_error(array('code' => 604, 'type' => 'session', |
| | | 'line' => __LINE__, 'file' => __FILE__, |
| | | 'message' => "Redis host not configured"), |
| | |
| | | true, true); |
| | | } |
| | | |
| | | foreach($hosts as $config) { |
| | | foreach ($hosts as $host) { |
| | | // explode individual fields |
| | | list($host, $port, $database, $password) = array_pad(explode(':', $config, 4), 4, null); |
| | | list($host, $port, $database, $password) = array_pad(explode(':', $host, 4), 4, null); |
| | | |
| | | // set default values if not set |
| | | $host = ($host !== null) ? $host : '127.0.0.1'; |
| | |
| | | |
| | | // register sessions handler |
| | | $this->register_session_handler(); |
| | | |
| | | } |
| | | |
| | | /** |