Update website
This commit is contained in:
parent
a0b0d3dae7
commit
ae7ef6ad45
3151 changed files with 566766 additions and 48 deletions
|
@ -0,0 +1,213 @@
|
|||
<?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,
|
||||
]);
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue