Server IP : 15.235.198.142 / Your IP : 216.73.216.154 Web Server : Apache/2.4.58 (Ubuntu) System : Linux ballsack 6.8.0-45-generic #45-Ubuntu SMP PREEMPT_DYNAMIC Fri Aug 30 12:02:04 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 8.3.6 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : OFF Directory : /usr/share/phpmyadmin/libraries/classes/Controllers/Server/Variables/ |
Upload File : |
<?php declare(strict_types=1); namespace PhpMyAdmin\Controllers\Server\Variables; use PhpMyAdmin\Controllers\AbstractController; use PhpMyAdmin\DatabaseInterface; use PhpMyAdmin\Http\ServerRequest; use PhpMyAdmin\Providers\ServerVariables\ServerVariablesProvider; use PhpMyAdmin\ResponseRenderer; use PhpMyAdmin\Template; use PhpMyAdmin\Util; use function header; use function implode; final class GetVariableController extends AbstractController { /** @var DatabaseInterface */ private $dbi; public function __construct(ResponseRenderer $response, Template $template, DatabaseInterface $dbi) { parent::__construct($response, $template); $this->dbi = $dbi; } /** * @param array $params Request parameters */ public function __invoke(ServerRequest $request, array $params): void { if (! $this->response->isAjax()) { return; } // Send with correct charset header('Content-Type: text/html; charset=UTF-8'); // Do not use double quotes inside the query to avoid a problem // when server is running in ANSI_QUOTES sql_mode $varValue = $this->dbi->fetchSingleRow( 'SHOW GLOBAL VARIABLES WHERE Variable_name=\'' . $this->dbi->escapeString($params['name']) . '\';', DatabaseInterface::FETCH_NUM ); $json = [ 'message' => $varValue[1], ]; $variableType = ServerVariablesProvider::getImplementation()->getVariableType($params['name']); if ($variableType === 'byte') { /** @var string[] $bytes */ $bytes = Util::formatByteDown($varValue[1], 3, 3); $json['message'] = implode(' ', $bytes); } $this->response->addJSON($json); } }