ÿØÿà JFIF ÿÛ „ ( %"1"%)+...383,7(-.-
![]() Server : Apache/2.4.6 (CentOS) OpenSSL/1.0.2k-fips PHP/7.4.20 System : Linux st2.domain.com 3.10.0-1127.10.1.el7.x86_64 #1 SMP Wed Jun 3 14:28:03 UTC 2020 x86_64 User : apache ( 48) PHP Version : 7.4.20 Disable Function : NONE Directory : /proc/self/cwd/usr/share/phpMyAdmin/libraries/classes/Controllers/Table/ |
<?php declare(strict_types=1); namespace PhpMyAdmin\Controllers\Table; use PhpMyAdmin\Html\Generator; use PhpMyAdmin\Response; use PhpMyAdmin\Table\Maintenance; use PhpMyAdmin\Template; use function count; use function is_array; final class MaintenanceController extends AbstractController { /** @var Maintenance */ private $model; /** * @param Response $response * @param string $db * @param string $table */ public function __construct( $response, Template $template, $db, $table, Maintenance $model ) { parent::__construct($response, $template, $db, $table); $this->model = $model; } public function analyze(): void { global $cfg; /** @var string[] $selected */ $selected = $_POST['selected_tbl'] ?? []; if (empty($selected) || ! is_array($selected)) { $this->response->setRequestStatus(false); $this->response->addJSON('message', __('No table selected.')); return; } if ($cfg['DisableMultiTableMaintenance'] && count($selected) > 1) { $this->response->setRequestStatus(false); $this->response->addJSON('message', __('Maintenance operations on multiple tables are disabled.')); return; } [$rows, $query] = $this->model->getAnalyzeTableRows($this->db, $selected); $message = Generator::getMessage( __('Your SQL query has been executed successfully.'), $query, 'success' ); $this->render('table/maintenance/analyze', [ 'message' => $message, 'rows' => $rows, ]); } public function check(): void { global $cfg; /** @var string[] $selected */ $selected = $_POST['selected_tbl'] ?? []; if (empty($selected) || ! is_array($selected)) { $this->response->setRequestStatus(false); $this->response->addJSON('message', __('No table selected.')); return; } if ($cfg['DisableMultiTableMaintenance'] && count($selected) > 1) { $this->response->setRequestStatus(false); $this->response->addJSON('message', __('Maintenance operations on multiple tables are disabled.')); return; } [$rows, $query] = $this->model->getCheckTableRows($this->db, $selected); $message = Generator::getMessage( __('Your SQL query has been executed successfully.'), $query, 'success' ); $indexesProblems = $this->model->getIndexesProblems($this->db, $selected); $this->render('table/maintenance/check', [ 'message' => $message, 'rows' => $rows, 'indexes_problems' => $indexesProblems, ]); } public function checksum(): void { global $cfg; /** @var string[] $selected */ $selected = $_POST['selected_tbl'] ?? []; if (empty($selected) || ! is_array($selected)) { $this->response->setRequestStatus(false); $this->response->addJSON('message', __('No table selected.')); return; } if ($cfg['DisableMultiTableMaintenance'] && count($selected) > 1) { $this->response->setRequestStatus(false); $this->response->addJSON('message', __('Maintenance operations on multiple tables are disabled.')); return; } [$rows, $query, $warnings] = $this->model->getChecksumTableRows($this->db, $selected); $message = Generator::getMessage( __('Your SQL query has been executed successfully.'), $query, 'success' ); $this->render('table/maintenance/checksum', [ 'message' => $message, 'rows' => $rows, 'warnings' => $warnings, ]); } public function optimize(): void { global $cfg; /** @var string[] $selected */ $selected = $_POST['selected_tbl'] ?? []; if (empty($selected) || ! is_array($selected)) { $this->response->setRequestStatus(false); $this->response->addJSON('message', __('No table selected.')); return; } if ($cfg['DisableMultiTableMaintenance'] && count($selected) > 1) { $this->response->setRequestStatus(false); $this->response->addJSON('message', __('Maintenance operations on multiple tables are disabled.')); return; } [$rows, $query] = $this->model->getOptimizeTableRows($this->db, $selected); $message = Generator::getMessage( __('Your SQL query has been executed successfully.'), $query, 'success' ); $this->render('table/maintenance/optimize', [ 'message' => $message, 'rows' => $rows, ]); } public function repair(): void { global $cfg; /** @var string[] $selected */ $selected = $_POST['selected_tbl'] ?? []; if (empty($selected) || ! is_array($selected)) { $this->response->setRequestStatus(false); $this->response->addJSON('message', __('No table selected.')); return; } if ($cfg['DisableMultiTableMaintenance'] && count($selected) > 1) { $this->response->setRequestStatus(false); $this->response->addJSON('message', __('Maintenance operations on multiple tables are disabled.')); return; } [$rows, $query] = $this->model->getRepairTableRows($this->db, $selected); $message = Generator::getMessage( __('Your SQL query has been executed successfully.'), $query, 'success' ); $this->render('table/maintenance/repair', [ 'message' => $message, 'rows' => $rows, ]); } }