Viewing file: RoutinesController.php (3.66 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
declare(strict_types=1);
namespace PhpMyAdmin\Controllers\Database;
use PhpMyAdmin\CheckUserPrivileges; use PhpMyAdmin\Core; use PhpMyAdmin\Database\Routines; use PhpMyAdmin\DatabaseInterface; use PhpMyAdmin\DbTableExists; use PhpMyAdmin\Response; use PhpMyAdmin\Template; use PhpMyAdmin\Url; use PhpMyAdmin\Util; use function in_array; use function strlen;
/** * Routines management. */ class RoutinesController extends AbstractController { /** @var CheckUserPrivileges */ private $checkUserPrivileges;
/** @var DatabaseInterface */ private $dbi;
/** * @param Response $response * @param string $db Database name * @param DatabaseInterface $dbi */ public function __construct($response, Template $template, $db, CheckUserPrivileges $checkUserPrivileges, $dbi) { parent::__construct($response, $template, $db); $this->checkUserPrivileges = $checkUserPrivileges; $this->dbi = $dbi; }
public function index(): void { global $db, $table, $tables, $num_tables, $total_num_tables, $sub_part; global $tooltip_truename, $tooltip_aliasname, $pos; global $errors, $PMA_Theme, $text_dir, $err_url, $url_params, $cfg;
$type = $_REQUEST['type'] ?? null;
$this->checkUserPrivileges->getPrivileges();
if (! $this->response->isAjax()) { /** * Displays the header and tabs */ if (! empty($table) && in_array($table, $this->dbi->getTables($db))) { Util::checkParameters(['db', 'table']);
$url_params = ['db' => $db, 'table' => $table]; $err_url = Util::getScriptNameForOption($cfg['DefaultTabTable'], 'table'); $err_url .= Url::getCommon($url_params, '&');
DbTableExists::check(); } else { $table = '';
Util::checkParameters(['db']);
$err_url = Util::getScriptNameForOption($cfg['DefaultTabDatabase'], 'database'); $err_url .= Url::getCommon(['db' => $db], '&');
if (! $this->hasDatabase()) { return; }
[ $tables, $num_tables, $total_num_tables, $sub_part,,, $tooltip_truename, $tooltip_aliasname, $pos, ] = Util::getDbInfo($db, $sub_part ?? ''); } } elseif (strlen($db) > 0) { $this->dbi->selectDb($db); }
/** * Keep a list of errors that occurred while * processing an 'Add' or 'Edit' operation. */ $errors = [];
$routines = new Routines($this->dbi, $this->template, $this->response);
$routines->handleEditor(); $routines->handleExecute(); $routines->export();
if (! Core::isValid($type, ['FUNCTION', 'PROCEDURE'])) { $type = null; }
$items = $this->dbi->getRoutines($db, $type); $isAjax = $this->response->isAjax() && empty($_REQUEST['ajax_page_request']);
$rows = ''; foreach ($items as $item) { $rows .= $routines->getRow($item, $isAjax ? 'ajaxInsert hide' : ''); }
$this->render('database/routines/index', [ 'db' => $db, 'table' => $table, 'items' => $items, 'rows' => $rows, 'select_all_arrow_src' => $PMA_Theme->getImgPath() . 'arrow_' . $text_dir . '.png', 'has_privilege' => Util::currentUserHasPrivilege('CREATE ROUTINE', $db, $table), ]); } }
|