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