Initial commit
This commit is contained in:
		| @@ -0,0 +1,123 @@ | ||||
| <?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), | ||||
|         ]); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user