public static function start($lifetime = 0, $path = '/', $domain = NULL) { if (!self::$_initialized) { if (!is_object(Symphony::Database()) || !Symphony::Database()->isConnected()) { return false; } self::$_cache = new Cacheable(Symphony::Database()); $installed = self::$_cache->check('_session_config'); if (!$installed) { if (!self::createTable()) { return false; } self::$_cache->write('_session_config', true); } ini_set('session.save_handler', 'user'); ini_set('session.gc_maxlifetime', $lifetime); session_set_save_handler(array('Session', 'open'), array('Session', 'close'), array('Session', 'read'), array('Session', 'write'), array('Session', 'destroy'), array('Session', 'gc')); session_set_cookie_params($lifetime, $path, $domain ? $domain : self::getDomain(), false, false); if (strlen(session_id()) == 0) { if (headers_sent()) { throw new Exception('Headers already sent. Cannot start session.'); } session_start(); } self::$_initialized = true; } return session_id(); }
public static function start($lifetime = 0, $path = '/', $domain = NULL) { if (!self::$_initialized) { ## Crude method of determining if we're in the admin or frontend if (class_exists('Frontend')) { self::$_db =& Frontend::instance()->Database; } elseif (class_exists('Administration')) { self::$_db =& Administration::instance()->Database; } else { return false; } if (!is_object(self::$_db) || !self::$_db->isConnected()) { return false; } self::$_cache = new Cacheable(self::$_db); $installed = self::$_cache->check('_session_config'); if (!$installed) { if (!self::createTable()) { return false; } self::$_cache->write('_session_config', true); } ini_set('session.save_handler', 'user'); session_set_save_handler(array('Session', 'open'), array('Session', 'close'), array('Session', 'read'), array('Session', 'write'), array('Session', 'destroy'), array('Session', 'gc')); session_set_cookie_params($lifetime, $path, $domain ? $domain : self::getDomain(), false, false); self::$_initialized = true; if (session_id() == '') { session_start(); } } return session_id(); }