Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/phpmyadmin/phpmyadmin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPiotr Przybylski <piotrprz@gmail.com>2011-07-13 14:25:06 +0400
committerPiotr Przybylski <piotrprz@gmail.com>2011-07-13 14:25:06 +0400
commitbf9469ec189998671c27cb1717c6f5dd9c5a0df2 (patch)
tree2e70cca30368dc1cb978812c25d93ba11286cf4f /db_routines.php
parentb57bc2ff5d4417a7affd4a8e9cef6041bdba57e1 (diff)
parent0ebd961db7a39ccb02bc1a5772e95df803b9c38c (diff)
Merge remote-tracking branch 'origin/master' into drizzle
Diffstat (limited to 'db_routines.php')
-rw-r--r--db_routines.php428
1 files changed, 6 insertions, 422 deletions
diff --git a/db_routines.php b/db_routines.php
index 13234a5539..726674c7d3 100644
--- a/db_routines.php
+++ b/db_routines.php
@@ -11,7 +11,6 @@
*/
require_once './libraries/common.inc.php';
require_once './libraries/common.lib.php';
-require_once './libraries/db_routines.lib.php';
require_once './libraries/mysql_charsets.lib.php';
if (PMA_DRIZZLE) {
require_once './libraries/data_drizzle.inc.php';
@@ -24,432 +23,17 @@ if (PMA_DRIZZLE) {
*/
$GLOBALS['js_include'][] = 'jquery/jquery-ui-1.8.custom.js';
$GLOBALS['js_include'][] = 'jquery/timepicker.js';
-$GLOBALS['js_include'][] = 'db_routines.js';
+$GLOBALS['js_include'][] = 'rte/common.js';
+$GLOBALS['js_include'][] = 'rte/routines.js';
/**
- * Create labels for the list
+ * Include all other files
*/
-$titles = PMA_buildActionTitles();
-
-if ($GLOBALS['is_ajax_request'] != true) {
- /**
- * Displays the header
- */
- require_once './libraries/db_common.inc.php';
- /**
- * Displays the tabs
- */
- require_once './libraries/db_info.inc.php';
-} else {
- if (strlen($db)) {
- PMA_DBI_select_db($db);
- if (! isset($url_query)) {
- $url_query = PMA_generate_common_url($db);
- }
- }
-}
+require_once './libraries/rte/rte_routines.lib.php';
/**
- * Process all requests
+ * Do the magic
*/
-
-// Some definitions
-$param_directions = array('IN',
- 'OUT',
- 'INOUT');
-$param_opts_num = array('UNSIGNED',
- 'ZEROFILL',
- 'UNSIGNED ZEROFILL');
-$param_sqldataaccess = array('NO SQL',
- 'CONTAINS SQL',
- 'READS SQL DATA',
- 'MODIFIES SQL DATA');
-
-/**
- * Generate the conditional classes that will be used to attach jQuery events to links.
- */
-$ajax_class = array(
- 'add' => '',
- 'edit' => '',
- 'exec' => '',
- 'drop' => '',
- 'export' => ''
- );
-if ($GLOBALS['cfg']['AjaxEnable']) {
- $ajax_class['add'] = 'class="add_routine_anchor"';
- $ajax_class['edit'] = 'class="edit_routine_anchor"';
- $ajax_class['exec'] = 'class="exec_routine_anchor"';
- $ajax_class['drop'] = 'class="drop_routine_anchor"';
- $ajax_class['export'] = 'class="export_routine_anchor"';
-}
-
-/**
- * Keep a list of errors that occured while processing an 'Add' or 'Edit' operation.
- */
-$routine_errors = array();
-
-/**
- * Handle all user requests other than the default of listing routines
- */
-if (! empty($_REQUEST['execute_routine']) && ! empty($_REQUEST['routine_name'])) {
- // Build the queries
- $routine = PMA_RTN_getRoutineDataFromName($db, $_REQUEST['routine_name'], false);
- if ($routine !== false) {
- $queries = array();
- $end_query = array();
- $args = array();
- for ($i=0; $i<$routine['num_params']; $i++) {
- if (isset($_REQUEST['params'][$routine['param_name'][$i]])) {
- $value = $_REQUEST['params'][$routine['param_name'][$i]];
- if (is_array($value)) { // is SET type
- $value = implode(',', $value);
- }
- $value = PMA_sqlAddSlashes($value);
- if (! empty($_REQUEST['funcs'][$routine['param_name'][$i]])
- && in_array($_REQUEST['funcs'][$routine['param_name'][$i]], $cfg['Functions'])) {
- $queries[] = "SET @p$i={$_REQUEST['funcs'][$routine['param_name'][$i]]}('$value');\n";
- } else {
- $queries[] = "SET @p$i='$value';\n";
- }
- $args[] = "@p$i";
- } else {
- $args[] = "@p$i";
- }
- if ($routine['type'] == 'PROCEDURE') {
- if ($routine['param_dir'][$i] == 'OUT' || $routine['param_dir'][$i] == 'INOUT') {
- $end_query[] = "@p$i AS " . PMA_backquote($routine['param_name'][$i]);
- }
- }
- }
- if ($routine['type'] == 'PROCEDURE') {
- $queries[] = "CALL " . PMA_backquote($routine['name'])
- . "(" . implode(', ', $args) . ");\n";
- if (count($end_query)) {
- $queries[] = "SELECT " . implode(', ', $end_query) . ";\n";
- }
- } else {
- $queries[] = "SELECT " . PMA_backquote($routine['name'])
- . "(" . implode(', ', $args) . ") "
- . "AS " . PMA_backquote($routine['name']) . ";\n";
- }
- // Execute the queries
- $affected = 0;
- $result = null;
- $outcome = true;
- foreach ($queries as $num => $query) {
- $resource = PMA_DBI_try_query($query);
- if ($resource === false) {
- $outcome = false;
- break;
- }
- while (true) {
- if(! PMA_DBI_more_results()) {
- break;
- }
- PMA_DBI_next_result();
- }
- if (substr($query, 0, 6) == 'SELECT') {
- $result = $resource;
- } else if (substr($query, 0, 4) == 'CALL') {
- $affected = PMA_DBI_affected_rows() - PMA_DBI_num_rows($resource);
- }
- }
- // Generate output
- if ($outcome) {
- $message = __('Your SQL query has been executed successfully');
- if ($routine['type'] == 'PROCEDURE') {
- $message .= '<br />';
- $message .= sprintf(_ngettext('%d row affected by the last statement inside the procedure', '%d rows affected by the last statement inside the procedure', $affected), $affected);
- }
- $message = PMA_message::success($message);
- // Pass the SQL queries through the "pretty printer"
- $output = '<code class="sql" style="margin-bottom: 1em;">';
- $output .= PMA_SQP_formatHtml(PMA_SQP_parse(implode($queries)));
- $output .= '</code>';
- // Display results
- if ($result) {
- $output .= "<fieldset><legend>";
- $output .= sprintf(__('Execution results of routine %s'),
- PMA_backquote(htmlspecialchars($routine['name'])));
- $output .= "</legend>";
- $output .= "<table><tr>";
- foreach (PMA_DBI_get_fields_meta($result) as $key => $field) {
- $output .= "<th>" . htmlspecialchars($field->name) . "</th>";
- }
- $output .= "</tr>";
- // Stored routines can only ever return ONE ROW.
- $data = PMA_DBI_fetch_single_row($result);
- foreach ($data as $key => $value) {
- if ($value === null) {
- $value = '<i>NULL</i>';
- } else {
- $value = htmlspecialchars($value);
- }
- $output .= "<td class='odd'>" . $value . "</td>";
- }
- $output .= "</table></fieldset>";
- } else {
- $notice = __('MySQL returned an empty result set (i.e. zero rows).');
- $output .= PMA_message::notice($notice)->getDisplay();
- }
- } else {
- $output = '';
- $message = PMA_message::error(sprintf(__('The following query has failed: "%s"'), $query) . '<br /><br />'
- . __('MySQL said: ') . PMA_DBI_getError(null));
- }
- // Print/send output
- if ($GLOBALS['is_ajax_request']) {
- $extra_data = array('dialog' => false);
- PMA_ajaxResponse($message->getDisplay() . $output, $message->isSuccess(), $extra_data);
- } else {
- echo $message->getDisplay() . $output;
- if ($message->isError()) {
- // At least one query has failed, so shouldn't
- // execute any more queries, so we quit.
- exit;
- }
- unset($_POST);
- // Now deliberately fall through to displaying the routines list
- }
- } else {
- $message = __('Error in processing request') . ' : '
- . sprintf(__('No routine with name %1$s found in database %2$s'),
- htmlspecialchars(PMA_backquote($_REQUEST['routine_name'])),
- htmlspecialchars(PMA_backquote($db)));
- $message = PMA_message::error($message);
- if ($GLOBALS['is_ajax_request']) {
- PMA_ajaxResponse($message, $message->isSuccess());
- } else {
- echo $message->getDisplay();
- unset($_POST);
- }
- }
-} else if (! empty($_GET['execute_dialog']) && ! empty($_GET['routine_name'])) {
- /**
- * Display the execute form for a routine.
- */
- $routine = PMA_RTN_getRoutineDataFromName($db, $_GET['routine_name'], false);
- if ($routine !== false) {
- $form = PMA_RTN_getExecuteForm($routine, $GLOBALS['is_ajax_request']);
- if ($GLOBALS['is_ajax_request'] == true) {
- $extra_data = array();
- $extra_data['dialog'] = true;
- $extra_data['title'] = __("Execute routine") . " ";
- $extra_data['title'] .= PMA_backquote(htmlentities($_GET['routine_name'], ENT_QUOTES));
- PMA_ajaxResponse($form, true, $extra_data);
- } else {
- echo "\n\n<h2>" . __("Execute routine") . "</h2>\n\n";
- echo $form;
- require './libraries/footer.inc.php';
- // exit;
- }
- } else if (($GLOBALS['is_ajax_request'] == true)) {
- $message = __('Error in processing request') . ' : '
- . sprintf(__('No routine with name %1$s found in database %2$s'),
- htmlspecialchars(PMA_backquote($_REQUEST['routine_name'])),
- htmlspecialchars(PMA_backquote($db)));
- $message = PMA_message::error($message);
- PMA_ajaxResponse($message, false);
- }
-} else if (! empty($_GET['exportroutine']) && ! empty($_GET['routine_name'])) {
- /**
- * Display the export for a routine.
- */
- $routine_name = htmlspecialchars(PMA_backquote($_GET['routine_name']));
- $routine_type = PMA_DBI_fetch_value("SELECT ROUTINE_TYPE "
- . "FROM INFORMATION_SCHEMA.ROUTINES "
- . "WHERE ROUTINE_SCHEMA='" . PMA_sqlAddSlashes($db) . "' "
- . "AND SPECIFIC_NAME='" . PMA_sqlAddSlashes($_GET['routine_name']) . "';");
- if (! empty($routine_type) && $create_proc = PMA_DBI_get_definition($db, $routine_type, $_GET['routine_name'])) {
- $create_proc = '<textarea cols="40" rows="15" style="width: 100%;">' . htmlspecialchars($create_proc) . '</textarea>';
- if ($GLOBALS['is_ajax_request']) {
- $extra_data = array('title' => sprintf(__('Export of routine %s'), $routine_name));
- PMA_ajaxResponse($create_proc, true, $extra_data);
- } else {
- echo '<fieldset>' . "\n"
- . ' <legend>' . sprintf(__('Export of routine %s'), $routine_name) . '</legend>' . "\n"
- . $create_proc . "\n"
- . '</fieldset>';
- }
- } else {
- $response = __('Error in processing request') . ' : '
- . sprintf(__('No routine with name %1$s found in database %2$s'),
- $routine_name, htmlspecialchars(PMA_backquote($db)));
- $response = PMA_message::error($response);
- if ($GLOBALS['is_ajax_request']) {
- PMA_ajaxResponse($response, false);
- } else {
- $response->display();
- }
- }
-} else if (! empty($_REQUEST['routine_process_addroutine']) || ! empty($_REQUEST['routine_process_editroutine'])) {
- /**
- * Handle a request to create/edit a routine
- */
- $sql_query = '';
- $routine_query = PMA_RTN_getQueryFromRequest();
- if (! count($routine_errors)) { // set by PMA_RTN_getQueryFromRequest()
- // Execute the created query
- if (! empty($_REQUEST['routine_process_editroutine'])) {
- if (! in_array($_REQUEST['routine_original_type'], array('PROCEDURE', 'FUNCTION'))) {
- $routine_errors[] = sprintf(__('Invalid routine type: "%s"'), htmlspecialchars($_REQUEST['routine_original_type']));
- } else {
- // Backup the old routine, in case something goes wrong
- $create_routine = PMA_DBI_get_definition($db, $_REQUEST['routine_original_type'], $_REQUEST['routine_original_name']);
- $drop_routine = "DROP {$_REQUEST['routine_original_type']} " . PMA_backquote($_REQUEST['routine_original_name']) . ";\n";
- $result = PMA_DBI_try_query($drop_routine);
- if (! $result) {
- $routine_errors[] = sprintf(__('The following query has failed: "%s"'), $drop_routine) . '<br />'
- . __('MySQL said: ') . PMA_DBI_getError(null);
- } else {
- $result = PMA_DBI_try_query($routine_query);
- if (! $result) {
- $routine_errors[] = sprintf(__('The following query has failed: "%s"'), $routine_query) . '<br />'
- . __('MySQL said: ') . PMA_DBI_getError(null);
- // We dropped the old routine, but were unable to create the new one
- // Try to restore the backup query
- $result = PMA_DBI_try_query($create_routine);
- if (! $result) {
- // OMG, this is really bad! We dropped the query, failed to create a new one
- // and now even the backup query does not execute!
- // This should not happen, but we better handle this just in case.
- $routine_errors[] = __('Sorry, we failed to restore the dropped routine.') . '<br />'
- . __('The backed up query was:') . "\"$create_routine\"" . '<br />'
- . __('MySQL said: ') . PMA_DBI_getError(null);
- }
- } else {
- $message = PMA_Message::success(__('Routine %1$s has been modified.'));
- $message->addParam(PMA_backquote($_REQUEST['routine_name']));
- $sql_query = $drop_routine . $routine_query;
- }
- }
- }
- } else {
- // 'Add a new routine' mode
- $result = PMA_DBI_try_query($routine_query);
- if (! $result) {
- $routine_errors[] = sprintf(__('The following query has failed: "%s"'), $routine_query) . '<br /><br />'
- . __('MySQL said: ') . PMA_DBI_getError(null);
- } else {
- $message = PMA_Message::success(__('Routine %1$s has been created.'));
- $message->addParam(PMA_backquote($_REQUEST['routine_name']));
- $sql_query = $routine_query;
- }
- }
- }
-
- if (count($routine_errors)) {
- $message = PMA_Message::error(__('<b>One or more errors have occured while processing your request:</b>'));
- $message->addString('<ul>');
- foreach ($routine_errors as $num => $string) {
- $message->addString('<li>' . $string . '</li>');
- }
- $message->addString('</ul>');
- }
-
- $output = PMA_showMessage($message, $sql_query);
- if ($GLOBALS['is_ajax_request']) {
- $extra_data = array();
- if ($message->isSuccess()) {
- $columns = "`SPECIFIC_NAME`, `ROUTINE_NAME`, `ROUTINE_TYPE`, `DTD_IDENTIFIER`, `ROUTINE_DEFINITION`";
- $where = "ROUTINE_SCHEMA='" . PMA_sqlAddSlashes($db) . "' AND ROUTINE_NAME='" . PMA_sqlAddSlashes($_REQUEST['routine_name']) . "'";
- $routine = PMA_DBI_fetch_single_row("SELECT $columns FROM `INFORMATION_SCHEMA`.`ROUTINES` WHERE $where;");
- $extra_data['name'] = htmlspecialchars(strtoupper($_REQUEST['routine_name']));
- $extra_data['new_row'] = PMA_RTN_getRowForRoutinesList($routine, 0, true);
- $response = $output;
- } else {
- $response = $message;
- }
- PMA_ajaxResponse($response, $message->isSuccess(), $extra_data);
- }
-}
-
-/**
- * Display a form used to add/edit a routine, if necessary
- */
-if (count($routine_errors) || ( empty($_REQUEST['routine_process_addroutine']) && empty($_REQUEST['routine_process_editroutine']) &&
- (! empty($_REQUEST['addroutine']) || ! empty($_REQUEST['editroutine'])
- || ! empty($_REQUEST['routine_addparameter']) || ! empty($_REQUEST['routine_removeparameter'])
- || ! empty($_REQUEST['routine_changetype'])))) { // FIXME: this must be simpler than that
- // Handle requests to add/remove parameters and changing routine type
- // This is necessary when JS is disabled
- $operation = '';
- if (! empty($_REQUEST['routine_addparameter'])) {
- $operation = 'add';
- } else if (! empty($_REQUEST['routine_removeparameter'])) {
- $operation = 'remove';
- } else if (! empty($_REQUEST['routine_changetype'])) {
- $operation = 'change';
- }
- // Get the data for the form (if any)
- if (! empty($_REQUEST['addroutine'])) {
- $title = __("Create routine");
- $routine = PMA_RTN_getRoutineDataFromRequest();
- $mode = 'add';
- } else if (! empty($_REQUEST['editroutine'])) {
- $title = __("Edit routine");
- if (! $operation && ! empty($_REQUEST['routine_name']) && empty($_REQUEST['routine_process_editroutine'])) {
- $routine = PMA_RTN_getRoutineDataFromName($db, $_REQUEST['routine_name']);
- if ($routine !== false) {
- $routine['original_name'] = $routine['name'];
- $routine['original_type'] = $routine['type'];
- }
- } else {
- $routine = PMA_RTN_getRoutineDataFromRequest();
- }
- $mode = 'edit';
- }
- if ($routine !== false) {
- // Show form
- $editor = PMA_RTN_getEditorForm($mode, $operation, $routine, $routine_errors, $GLOBALS['is_ajax_request']);
- if ($GLOBALS['is_ajax_request']) {
- $template = PMA_RTN_getParameterRow();
- $extra_data = array('title' => $title, 'param_template' => $template, 'type' => $routine['type']);
- PMA_ajaxResponse($editor, true, $extra_data);
- }
- echo "\n\n<h2>$title</h2>\n\n$editor";
- require './libraries/footer.inc.php';
- // exit;
- } else {
- $message = __('Error in processing request') . ' : '
- . sprintf(__('No routine with name %1$s found in database %2$s'),
- htmlspecialchars(PMA_backquote($_REQUEST['routine_name'])),
- htmlspecialchars(PMA_backquote($db)));
- $message = PMA_message::error($message);
- if ($GLOBALS['is_ajax_request']) {
- PMA_ajaxResponse($message, false);
- } else {
- $message->display();
- }
- }
-}
-
-/**
- * Display a list of available routines
- */
-echo PMA_RTN_getRoutinesList();
-
-/**
- * Display the form for adding a new routine, if the user has the privileges.
- */
-echo PMA_RTN_getAddRoutineLink();
-
-/**
- * Display a warning for users with PHP's old "mysql" extension.
- */
-if ($GLOBALS['cfg']['Server']['extension'] === 'mysql') {
- trigger_error(__('You are using PHP\'s deprecated \'mysql\' extension, '
- . 'which is not capable of handling multi queries. '
- . '<b>The execution of some stored routines may fail!</b> '
- . 'Please use the improved \'mysqli\' extension to '
- . 'avoid any problems.'), E_USER_WARNING);
-}
-
-if ($GLOBALS['is_ajax_request'] != true) {
- /**
- * Displays the footer
- */
- require './libraries/footer.inc.php';
-}
+require_once './libraries/rte/rte_main.inc.php';
?>