| Linux hosting5.siteguarding.com 3.10.0-962.3.2.lve1.5.88.el7.x86_64 #1 SMP Fri Sep 26 14:06:42 UTC 2025 x86_64 Path : /home/devsafetybis/op4103.dev.safetybis.com/system/library/session/ |
| Current File : /home/devsafetybis/op4103.dev.safetybis.com/system/library/session/db.php |
<?php
/*
CREATE TABLE IF NOT EXISTS `session` (
`session_id` varchar(32) NOT NULL,
`data` text NOT NULL,
`expire` datetime NOT NULL,
PRIMARY KEY (`session_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
*/
namespace Opencart\System\Library\Session;
/**
* Class DB
*
* @package Opencart\System\Library\Session
*/
class DB {
/**
* @var object
*/
private object $db;
/**
* @var object
*/
private object $config;
/**
* Constructor
*
* @param \Opencart\System\Engine\Registry $registry
*/
public function __construct(\Opencart\System\Engine\Registry $registry) {
$this->db = $registry->get('db');
$this->config = $registry->get('config');
}
/**
* Read
*
* @param string $session_id
*
* @return array<mixed>
*/
public function read(string $session_id): array {
$query = $this->db->query("SELECT `data` FROM `" . DB_PREFIX . "session` WHERE `session_id` = '" . $this->db->escape($session_id) . "' AND `expire` > '" . $this->db->escape(gmdate('Y-m-d H:i:s')) . "'");
if ($query->num_rows) {
return (array)json_decode($query->row['data'], true);
} else {
return [];
}
}
/**
* Write
*
* @param string $session_id
* @param array<mixed> $data
*
* @return bool
*/
public function write(string $session_id, array $data): bool {
if ($session_id) {
$this->db->query("REPLACE INTO `" . DB_PREFIX . "session` SET `session_id` = '" . $this->db->escape($session_id) . "', `data` = '" . $this->db->escape($data ? json_encode($data) : '') . "', `expire` = '" . $this->db->escape(gmdate('Y-m-d H:i:s', time() + $this->config->get('session_expire'))) . "'");
}
return true;
}
/**
* Destroy
*
* @param string $session_id
*
* @return bool
*/
public function destroy(string $session_id): bool {
$this->db->query("DELETE FROM `" . DB_PREFIX . "session` WHERE `session_id` = '" . $this->db->escape($session_id) . "'");
return true;
}
/**
* GC
*
* @return bool
*/
public function gc(): bool {
if (round(mt_rand(1, $this->config->get('session_divisor') / $this->config->get('session_probability'))) == 1) {
$this->db->query("DELETE FROM `" . DB_PREFIX . "session` WHERE `expire` < '" . $this->db->escape(gmdate('Y-m-d H:i:s', time())) . "'");
}
return true;
}
}