docs/api/source-admin.controller.startup.session.html
| 1: | <?php | | 2: | namespace Opencart\Admin\Controller\Startup; | | 3: | /** | | 4: | * Class Session | | 5: | * | | 6: | * @package Opencart\Admin\Controller\Startup | | 7: | */ | | 8: | class Session extends \Opencart\System\Engine\Controller { | | 9: | /** | | 10: | * Index | | 11: | * | | 12: | * @throws \Exception | | 13: | * | | 14: | * @return void | | 15: | */ | | 16: | public function index(): void { | | 17: | $session = new \Opencart\System\Library\Session($this->config->get('session_engine'), $this->registry); | | 18: | $this->registry->set('session', $session); | | 19: | | | 20: | if (isset($this->request->cookie[$this->config->get('session_name')])) { | | 21: | $session_id = $this->request->cookie[$this->config->get('session_name')]; | | 22: | } else { | | 23: | $session_id = ''; | | 24: | } | | 25: | | | 26: | $session->start($session_id); | | 27: | | | 28: | // Update the session lifetime | | 29: | if ($this->config->get('config_session_expire')) { | | 30: | $this->config->set('session_expire', $this->config->get('config_session_expire')); | | 31: | } | | 32: | | | 33: | // Require higher security for session cookies | | 34: | $option = [ | | 35: | 'expires' => $this->config->get('config_session_expire') ? time() + (int)$this->config->get('config_session_expire') : 0, | | 36: | 'path' => $this->config->get('session_path'), | | 37: | 'secure' => $this->request->server['HTTPS'], | | 38: | 'httponly' => false, | | 39: | 'SameSite' => $this->config->get('config_session_samesite') | | 40: | ]; | | 41: | | | 42: | setcookie($this->config->get('session_name'), $session->getId(), $option); | | 43: | } | | 44: | } | | 45: | |
OpenCart API API documentation generated by ApiGen dev-master