gl-website-deployer/admin/phpMyAdmin/libraries/classes/Controllers/View/OperationsController.php

116 lines
3.3 KiB
PHP
Raw Normal View History

2024-11-19 08:02:04 +01:00
<?php
declare(strict_types=1);
namespace PhpMyAdmin\Controllers\View;
use PhpMyAdmin\Controllers\AbstractController;
use PhpMyAdmin\DatabaseInterface;
use PhpMyAdmin\DbTableExists;
use PhpMyAdmin\Html\Generator;
use PhpMyAdmin\Message;
use PhpMyAdmin\Operations;
use PhpMyAdmin\ResponseRenderer;
use PhpMyAdmin\Template;
use PhpMyAdmin\Url;
use PhpMyAdmin\Util;
use function __;
/**
* View manipulations
*/
class OperationsController extends AbstractController
{
/** @var Operations */
private $operations;
/** @var DatabaseInterface */
private $dbi;
public function __construct(
ResponseRenderer $response,
Template $template,
Operations $operations,
DatabaseInterface $dbi
) {
parent::__construct($response, $template);
$this->operations = $operations;
$this->dbi = $dbi;
}
public function __invoke(): void
{
global $sql_query, $urlParams, $reload, $result, $warning_messages;
global $db, $table, $cfg, $errorUrl;
$tableObject = $this->dbi->getTable($db, $table);
$this->addScriptFiles(['table/operations.js']);
Util::checkParameters(['db', 'table']);
$urlParams = ['db' => $db, 'table' => $table];
$errorUrl = Util::getScriptNameForOption($cfg['DefaultTabTable'], 'table');
$errorUrl .= Url::getCommon($urlParams, '&');
DbTableExists::check();
$urlParams['goto'] = $urlParams['back'] = Url::getFromRoute('/view/operations');
$message = new Message();
$type = 'success';
if (isset($_POST['submitoptions'])) {
if (isset($_POST['new_name'])) {
if ($tableObject->rename($_POST['new_name'])) {
$message->addText($tableObject->getLastMessage());
$result = true;
$table = $tableObject->getName();
/* Force reread after rename */
$tableObject->getStatusInfo(null, true);
$reload = true;
} else {
$message->addText($tableObject->getLastError());
$result = false;
}
}
$warning_messages = $this->operations->getWarningMessagesArray();
}
if (isset($result)) {
// set to success by default, because result set could be empty
// (for example, a table rename)
if (empty($message->getString())) {
if ($result) {
$message->addText(
__('Your SQL query has been executed successfully.')
);
} else {
$message->addText(__('Error'));
}
// $result should exist, regardless of $_message
$type = $result ? 'success' : 'error';
}
if (! empty($warning_messages)) {
$message->addMessagesString($warning_messages);
$message->isError(true);
}
$this->response->addHTML(Generator::getMessage(
$message,
$sql_query,
$type
));
}
$this->render('table/operations/view', [
'db' => $db,
'table' => $table,
'url_params' => $urlParams,
]);
}
}