Example #1
0
 public function init()
 {
     /** @var Uri $uri */
     $uri = $this->grav['uri'];
     $config = $this->grav['config'];
     $is_admin = false;
     $session_timeout = $config->get('system.session.timeout', 1800);
     $session_path = $config->get('system.session.path', '/' . ltrim($uri->rootUrl(false), '/'));
     // Activate admin if we're inside the admin path.
     if ($config->get('plugins.admin.enabled')) {
         $route = $config->get('plugins.admin.route');
         $base = '/' . trim($route, '/');
         if (substr($uri->route(), 0, strlen($base)) == $base) {
             $session_timeout = $config->get('plugins.admin.session.timeout', 1800);
             $is_admin = true;
         }
     }
     if ($config->get('system.session.enabled') || $is_admin) {
         // Define session service.
         parent::__construct($session_timeout, $session_path);
         $unique_identifier = GRAV_ROOT;
         $this->setName($config->get('system.session.name', 'grav_site') . '-' . substr(md5($unique_identifier), 0, 7) . ($is_admin ? '-admin' : ''));
         $this->start();
         setcookie(session_name(), session_id(), time() + $session_timeout, $session_path);
     }
 }
Example #2
0
 public function init()
 {
     /** @var Uri $uri */
     $uri = $this->grav['uri'];
     $config = $this->grav['config'];
     if ($config->get('system.session.enabled')) {
         // Define session service.
         parent::__construct($config->get('system.session.timeout', 1800), $config->get('system.session.path', '/' . ltrim($uri->rootUrl(false), '/')));
         $site_identifier = $config->get('site.title', 'unkown');
         $this->setName($config->get('system.session.name', 'grav_site') . '_' . substr(md5($site_identifier), 0, 7));
         $this->start();
     }
 }
Example #3
0
 /**
  * Session init
  */
 public function init()
 {
     /** @var Uri $uri */
     $uri = $this->grav['uri'];
     $config = $this->grav['config'];
     $is_admin = false;
     $base_url = $uri->rootUrl(false);
     $session_timeout = $config->get('system.session.timeout', 1800);
     $session_path = $config->get('system.session.path');
     if (!$session_path) {
         $session_path = '/' . ltrim($base_url, '/');
     }
     // Activate admin if we're inside the admin path.
     if ($config->get('plugins.admin.enabled')) {
         $route = $config->get('plugins.admin.route');
         // Uri::route() is not processed yet, let's quickly get what we need
         $current_route = str_replace($base_url, '', parse_url($uri->url(true), PHP_URL_PATH));
         $base = '/' . trim($route, '/');
         if (substr($current_route, 0, strlen($base)) == $base || substr($current_route, 3, strlen($base)) == $base || substr($current_route, 6, strlen($base)) == $base) {
             //handle region specific language prefix (en-US)
             $session_timeout = $config->get('plugins.admin.session.timeout', 1800);
             $is_admin = true;
         }
     }
     if ($config->get('system.session.enabled') || $is_admin) {
         $domain = $uri->host();
         if ($domain === 'localhost') {
             $domain = '';
         }
         // Fix for HUGE session timeouts
         if ($session_timeout > 99999999999) {
             $session_timeout = 9999999999;
         }
         // Define session service.
         parent::__construct($session_timeout, $session_path, $domain);
         $secure = $config->get('system.session.secure', false);
         $httponly = $config->get('system.session.httponly', true);
         $unique_identifier = GRAV_ROOT;
         $inflector = new Inflector();
         $session_name = $inflector->hyphenize($config->get('system.session.name', 'grav_site')) . '-' . substr(md5($unique_identifier), 0, 7);
         $split_session = $config->get('system.session.split', true);
         if ($is_admin && $split_session) {
             $session_name .= '-admin';
         }
         $this->setName($session_name);
         $this->start();
         setcookie(session_name(), session_id(), time() + $session_timeout, $session_path, $domain, $secure, $httponly);
     }
 }