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, ]); } }