/
EmptyTableController.php
97 lines (76 loc) · 2.87 KB
/
EmptyTableController.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
<?php
declare(strict_types=1);
namespace PhpMyAdmin\Controllers\Database\Structure;
use PhpMyAdmin\Bookmarks\BookmarkRepository;
use PhpMyAdmin\Config;
use PhpMyAdmin\ConfigStorage\Relation;
use PhpMyAdmin\ConfigStorage\RelationCleanup;
use PhpMyAdmin\Controllers\Database\StructureController;
use PhpMyAdmin\Controllers\InvocableController;
use PhpMyAdmin\Current;
use PhpMyAdmin\DatabaseInterface;
use PhpMyAdmin\FlashMessages;
use PhpMyAdmin\Http\Response;
use PhpMyAdmin\Http\ServerRequest;
use PhpMyAdmin\Message;
use PhpMyAdmin\ResponseRenderer;
use PhpMyAdmin\Sql;
use PhpMyAdmin\Table\Table;
use PhpMyAdmin\Template;
use PhpMyAdmin\Transformations;
use PhpMyAdmin\Util;
use PhpMyAdmin\Utils\ForeignKey;
use function __;
final class EmptyTableController implements InvocableController
{
public function __construct(
private readonly ResponseRenderer $response,
private readonly Template $template,
private readonly DatabaseInterface $dbi,
private readonly Relation $relation,
private readonly RelationCleanup $relationCleanup,
private readonly FlashMessages $flash,
private readonly StructureController $structureController,
) {
}
public function __invoke(ServerRequest $request): Response|null
{
$multBtn = $_POST['mult_btn'] ?? '';
/** @var string[] $selected */
$selected = $request->getParsedBodyParam('selected', []);
if ($multBtn !== __('Yes')) {
$this->flash->addMessage('success', __('No change'));
$this->response->redirectToRoute('/database/structure', ['db' => Current::$database]);
return null;
}
$defaultFkCheckValue = ForeignKey::handleDisableCheckInit();
$GLOBALS['sql_query'] = '';
$this->dbi->selectDb(Current::$database);
foreach ($selected as $selectedValue) {
if (Table::get($selectedValue, Current::$database, $this->dbi)->isView()) {
continue;
}
$aQuery = 'TRUNCATE ';
$aQuery .= Util::backquote($selectedValue);
$GLOBALS['sql_query'] .= $aQuery . ';' . "\n";
$this->dbi->query($aQuery);
}
if (! empty($_REQUEST['pos'])) {
$sql = new Sql(
$this->dbi,
$this->relation,
$this->relationCleanup,
new Transformations(),
$this->template,
new BookmarkRepository($this->dbi, $this->relation),
Config::getInstance(),
);
$_REQUEST['pos'] = $sql->calculatePosForLastPage(Current::$database, Current::$table, $_REQUEST['pos']);
}
ForeignKey::handleDisableCheckCleanup($defaultFkCheckValue);
$GLOBALS['message'] = Message::success();
unset($_POST['mult_btn']);
($this->structureController)($request);
return null;
}
}