213 lines
5.9 KiB
PHP
213 lines
5.9 KiB
PHP
<?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,
|
|
]);
|
|
}
|
|
}
|