dbi = $dbi; $this->transformations = $transformations; $this->relationCleanup = $relationCleanup; } public function __invoke(): void { global $selected, $errorUrl, $cfg, $dblist, $reload; if ( ! $this->response->isAjax() || (! $this->dbi->isSuperUser() && ! $cfg['AllowUserDropDatabase']) ) { $message = Message::error(); $json = ['message' => $message]; $this->response->setRequestStatus($message->isSuccess()); $this->response->addJSON($json); return; } $selected_dbs = isset($_POST['selected_dbs']) && is_array($_POST['selected_dbs']) ? $_POST['selected_dbs'] : []; $selected_dbs = array_filter($selected_dbs, static function ($database): bool { return is_string($database) && ! Utilities::isSystemSchema($database, true) && $database !== ($GLOBALS['cfg']['Server']['pmadb'] ?? ''); }); if ($selected_dbs === []) { $message = Message::error(__('No databases selected.')); $json = ['message' => $message]; $this->response->setRequestStatus($message->isSuccess()); $this->response->addJSON($json); return; } $errorUrl = Url::getFromRoute('/server/databases'); $selected = $selected_dbs; $numberOfDatabases = count($selected_dbs); foreach ($selected_dbs as $database) { $this->relationCleanup->database($database); $aQuery = 'DROP DATABASE ' . Util::backquote($database); $reload = true; $this->dbi->query($aQuery); $this->transformations->clear($database); } $dblist->databases->build(); $message = Message::success( _ngettext( '%1$d database has been dropped successfully.', '%1$d databases have been dropped successfully.', $numberOfDatabases ) ); $message->addParam($numberOfDatabases); $json = ['message' => $message]; $this->response->setRequestStatus($message->isSuccess()); $this->response->addJSON($json); } }