You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
137 lines
4.3 KiB
137 lines
4.3 KiB
<?php |
|
|
|
declare(strict_types=1); |
|
|
|
namespace PhpMyAdmin\Controllers\Server; |
|
|
|
use PhpMyAdmin\Controllers\AbstractController; |
|
use PhpMyAdmin\DatabaseInterface; |
|
use PhpMyAdmin\Html\Generator; |
|
use PhpMyAdmin\Providers\ServerVariables\ServerVariablesProvider; |
|
use PhpMyAdmin\ResponseRenderer; |
|
use PhpMyAdmin\Template; |
|
use PhpMyAdmin\Url; |
|
use PhpMyAdmin\Util; |
|
|
|
use function implode; |
|
use function in_array; |
|
use function is_numeric; |
|
use function str_replace; |
|
use function strtolower; |
|
use function trim; |
|
|
|
/** |
|
* Handles viewing and editing server variables |
|
*/ |
|
class VariablesController extends AbstractController |
|
{ |
|
/** @var DatabaseInterface */ |
|
private $dbi; |
|
|
|
public function __construct(ResponseRenderer $response, Template $template, DatabaseInterface $dbi) |
|
{ |
|
parent::__construct($response, $template); |
|
$this->dbi = $dbi; |
|
} |
|
|
|
public function __invoke(): void |
|
{ |
|
global $errorUrl; |
|
|
|
$params = ['filter' => $_GET['filter'] ?? null]; |
|
$errorUrl = Url::getFromRoute('/'); |
|
|
|
if ($this->dbi->isSuperUser()) { |
|
$this->dbi->selectDb('mysql'); |
|
} |
|
|
|
$filterValue = ! empty($params['filter']) ? $params['filter'] : ''; |
|
|
|
$this->addScriptFiles(['server/variables.js']); |
|
|
|
$variables = []; |
|
$serverVarsResult = $this->dbi->tryQuery('SHOW SESSION VARIABLES;'); |
|
if ($serverVarsResult !== false) { |
|
$serverVarsSession = $serverVarsResult->fetchAllKeyPair(); |
|
|
|
unset($serverVarsResult); |
|
|
|
$serverVars = $this->dbi->fetchResult('SHOW GLOBAL VARIABLES;', 0, 1); |
|
|
|
// list of static (i.e. non-editable) system variables |
|
$staticVariables = ServerVariablesProvider::getImplementation()->getStaticVariables(); |
|
|
|
foreach ($serverVars as $name => $value) { |
|
$hasSessionValue = isset($serverVarsSession[$name]) |
|
&& $serverVarsSession[$name] !== $value; |
|
$docLink = Generator::linkToVarDocumentation( |
|
$name, |
|
$this->dbi->isMariaDB(), |
|
str_replace('_', ' ', $name) |
|
); |
|
|
|
[$formattedValue, $isEscaped] = $this->formatVariable($name, $value); |
|
if ($hasSessionValue) { |
|
[$sessionFormattedValue] = $this->formatVariable($name, $serverVarsSession[$name]); |
|
} |
|
|
|
$variables[] = [ |
|
'name' => $name, |
|
'is_editable' => ! in_array(strtolower($name), $staticVariables), |
|
'doc_link' => $docLink, |
|
'value' => $formattedValue, |
|
'is_escaped' => $isEscaped, |
|
'has_session_value' => $hasSessionValue, |
|
'session_value' => $sessionFormattedValue ?? null, |
|
]; |
|
} |
|
} |
|
|
|
$this->render('server/variables/index', [ |
|
'variables' => $variables, |
|
'filter_value' => $filterValue, |
|
'is_superuser' => $this->dbi->isSuperUser(), |
|
'is_mariadb' => $this->dbi->isMariaDB(), |
|
]); |
|
} |
|
|
|
/** |
|
* Format Variable |
|
* |
|
* @param string $name variable name |
|
* @param int|string $value variable value |
|
* |
|
* @return array formatted string and bool if string is HTML formatted |
|
*/ |
|
private function formatVariable($name, $value): array |
|
{ |
|
$isHtmlFormatted = false; |
|
$formattedValue = $value; |
|
|
|
if (is_numeric($value)) { |
|
$variableType = ServerVariablesProvider::getImplementation()->getVariableType($name); |
|
|
|
if ($variableType === 'byte') { |
|
$isHtmlFormatted = true; |
|
/** @var string[] $bytes */ |
|
$bytes = Util::formatByteDown($value, 3, 3); |
|
$formattedValue = trim( |
|
$this->template->render( |
|
'server/variables/format_variable', |
|
[ |
|
'valueTitle' => Util::formatNumber($value, 0), |
|
'value' => implode(' ', $bytes), |
|
] |
|
) |
|
); |
|
} else { |
|
$formattedValue = Util::formatNumber($value, 0); |
|
} |
|
} |
|
|
|
return [ |
|
$formattedValue, |
|
$isHtmlFormatted, |
|
]; |
|
} |
|
}
|
|
|