2007-07-02 05:51:26 +00:00
|
|
|
<?php
|
2009-06-15 09:07:05 +00:00
|
|
|
$history = &$_SESSION["history"][$_GET["server"]][$_GET["db"]];
|
2009-07-17 13:53:10 +00:00
|
|
|
if (!$error && $_POST["clear"]) {
|
|
|
|
$history = array();
|
|
|
|
redirect(remove_from_uri("history"));
|
|
|
|
}
|
|
|
|
|
|
|
|
page_header(lang('SQL command'), $error);
|
2007-07-02 05:51:26 +00:00
|
|
|
|
2008-09-30 12:22:24 +00:00
|
|
|
if (!$error && $_POST) {
|
2009-07-16 13:46:49 +00:00
|
|
|
$query = (isset($_POST["file"]) ? get_file("sql_file") : $_POST["query"]);
|
|
|
|
if (is_string($query)) { // get_file() returns error as number
|
2009-06-21 23:20:32 +00:00
|
|
|
@set_time_limit(0); // set_time_limit() can be disabled
|
|
|
|
$query = str_replace("\r", "", $query); // parser looks for \n
|
2009-06-16 10:31:09 +00:00
|
|
|
$query = rtrim($query);
|
2009-06-21 23:56:37 +00:00
|
|
|
if (strlen($query) && (!$history || end($history) != $query)) { // don't add repeated
|
2009-06-15 09:07:05 +00:00
|
|
|
$history[] = $query;
|
|
|
|
}
|
2008-09-30 12:22:24 +00:00
|
|
|
$delimiter = ";";
|
|
|
|
$offset = 0;
|
|
|
|
$empty = true;
|
2008-10-02 15:23:30 +00:00
|
|
|
$space = "(\\s+|/\\*.*\\*/|(#|-- )[^\n]*\n|--\n)";
|
2009-06-03 18:34:57 +00:00
|
|
|
$dbh2 = (strlen($_GET["db"]) ? connect() : null); // connection for exploring indexes (to not replace FOUND_ROWS()) //! PDO - silent error
|
|
|
|
if (is_object($dbh2)) {
|
|
|
|
$dbh2->select_db($_GET["db"]);
|
|
|
|
}
|
2009-06-16 10:31:09 +00:00
|
|
|
while (strlen($query)) {
|
2008-09-30 12:22:24 +00:00
|
|
|
if (!$offset && preg_match('~^\\s*DELIMITER\\s+(.+)~i', $query, $match)) {
|
2008-10-02 15:23:30 +00:00
|
|
|
$delimiter = $match[1];
|
2008-09-30 12:22:24 +00:00
|
|
|
$query = substr($query, strlen($match[0]));
|
2008-10-02 15:23:30 +00:00
|
|
|
} elseif (preg_match('(' . preg_quote($delimiter) . '|[\'`"]|/\\*|-- |#|$)', $query, $match, PREG_OFFSET_CAPTURE, $offset)) {
|
2008-09-30 12:22:24 +00:00
|
|
|
if ($match[0][0] && $match[0][0] != $delimiter) {
|
2009-06-21 23:20:32 +00:00
|
|
|
// is not end of a query - find closing part
|
2008-09-30 12:22:24 +00:00
|
|
|
$pattern = ($match[0][0] == "-- " || $match[0][0] == "#" ? '~.*~' : ($match[0][0] == "/*" ? '~.*\\*/~sU' : '~\\G([^\\\\' . $match[0][0] . ']+|\\\\.)*(' . $match[0][0] . '|$)~s'));
|
|
|
|
preg_match($pattern, $query, $match, PREG_OFFSET_CAPTURE, $match[0][1] + 1);
|
|
|
|
$offset = $match[0][1] + strlen($match[0][0]);
|
2007-07-11 18:02:13 +00:00
|
|
|
} else {
|
2008-09-30 12:22:24 +00:00
|
|
|
$empty = false;
|
2009-06-15 09:07:05 +00:00
|
|
|
echo "<pre class='jush-sql'>" . shorten_utf8(trim(substr($query, 0, $match[0][1]))) . "</pre>\n";
|
2009-06-22 10:06:09 +00:00
|
|
|
ob_flush();
|
2009-06-21 23:20:32 +00:00
|
|
|
flush(); // can take a long time - show the running query
|
|
|
|
$start = explode(" ", microtime()); // microtime(true) is available since PHP 5
|
2008-09-30 12:22:24 +00:00
|
|
|
//! don't allow changing of character_set_results, convert encoding of displayed query
|
2009-05-08 05:23:03 +00:00
|
|
|
if (!$dbh->multi_query(substr($query, 0, $match[0][1]))) {
|
2009-07-11 20:30:40 +00:00
|
|
|
echo "<p class='error'>" . lang('Error in query') . ": " . htmlspecialchars($dbh->error) . "\n";
|
2009-02-24 10:48:59 +00:00
|
|
|
if ($_POST["error_stops"]) {
|
|
|
|
break;
|
|
|
|
}
|
2008-09-30 12:22:24 +00:00
|
|
|
} else {
|
2009-05-25 10:05:36 +00:00
|
|
|
$end = explode(" ", microtime());
|
2009-07-11 20:30:40 +00:00
|
|
|
echo "<p class='time'>" . lang('%.3f s', max(0, $end[0] - $start[0] + $end[1] - $start[1])) . "\n";
|
2008-09-30 12:22:24 +00:00
|
|
|
do {
|
2009-05-08 05:23:03 +00:00
|
|
|
$result = $dbh->store_result();
|
2008-09-30 12:22:24 +00:00
|
|
|
if (is_object($result)) {
|
2009-06-03 18:34:57 +00:00
|
|
|
select($result, $dbh2);
|
2008-09-30 12:22:24 +00:00
|
|
|
} else {
|
2008-10-02 15:23:30 +00:00
|
|
|
if (preg_match("~^$space*(CREATE|DROP)$space+(DATABASE|SCHEMA)\\b~isU", $query)) {
|
2009-06-21 23:20:32 +00:00
|
|
|
unset($_SESSION["databases"][$_GET["server"]]); // clear cache
|
2008-09-30 12:22:24 +00:00
|
|
|
}
|
2009-07-11 20:30:40 +00:00
|
|
|
echo "<p class='message'>" . lang('Query executed OK, %d row(s) affected.', $dbh->affected_rows) . "\n";
|
2007-07-17 05:54:19 +00:00
|
|
|
}
|
2009-05-08 05:23:03 +00:00
|
|
|
} while ($dbh->next_result());
|
2008-09-30 12:22:24 +00:00
|
|
|
}
|
|
|
|
$query = substr($query, $match[0][1] + strlen($match[0][0]));
|
|
|
|
$offset = 0;
|
2007-07-10 13:30:42 +00:00
|
|
|
}
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
|
|
|
}
|
2008-09-30 12:22:24 +00:00
|
|
|
if ($empty) {
|
2009-07-11 20:30:40 +00:00
|
|
|
echo "<p class='message'>" . lang('No commands to execute.') . "\n";
|
2008-09-30 12:22:24 +00:00
|
|
|
}
|
|
|
|
} else {
|
2009-07-16 13:46:49 +00:00
|
|
|
echo "<p class='error'>" . upload_error($query) . "\n";
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|
2007-07-09 14:45:11 +00:00
|
|
|
|
2009-06-15 08:18:19 +00:00
|
|
|
<form action="" method="post" enctype="multipart/form-data">
|
2009-07-11 20:30:40 +00:00
|
|
|
<p><textarea name="query" rows="20" cols="80" style="width: 98%;"><?php echo htmlspecialchars($_POST ? $_POST["query"] : (strlen($_GET["history"]) ? $_SESSION["history"][$_GET["server"]][$_GET["db"]][$_GET["history"]] : $_GET["sql"])); ?></textarea>
|
2007-07-11 11:19:16 +00:00
|
|
|
<p>
|
2009-07-11 20:30:40 +00:00
|
|
|
<input type="hidden" name="token" value="<?php echo $token; ?>">
|
|
|
|
<input type="submit" value="<?php echo lang('Execute'); ?>">
|
|
|
|
<label><input type="checkbox" name="error_stops" value="1"<?php echo ($_POST["error_stops"] ? " checked='checked'" : ""); ?>><?php echo lang('Stop on error'); ?></label>
|
2007-07-09 06:12:22 +00:00
|
|
|
|
2009-06-21 23:58:15 +00:00
|
|
|
<p>
|
2007-07-09 06:12:22 +00:00
|
|
|
<?php
|
|
|
|
if (!ini_get("file_uploads")) {
|
2009-06-21 23:58:15 +00:00
|
|
|
echo lang('File uploads are disabled.');
|
2007-07-09 06:12:22 +00:00
|
|
|
} else { ?>
|
2009-07-11 20:30:40 +00:00
|
|
|
<?php echo lang('File upload'); ?>: <input type="file" name="sql_file">
|
2009-07-13 22:42:47 +00:00
|
|
|
<input type="submit" name="file" value="<?php echo lang('Run file'); ?>">
|
2009-06-21 23:58:15 +00:00
|
|
|
<?php } ?>
|
2009-06-15 09:07:05 +00:00
|
|
|
|
|
|
|
<?php
|
|
|
|
if ($history) {
|
|
|
|
echo "<fieldset><legend>" . lang('History') . "</legend>\n";
|
|
|
|
foreach ($history as $key => $val) {
|
2009-06-21 23:20:32 +00:00
|
|
|
//! save and display timestamp
|
2009-07-11 20:30:40 +00:00
|
|
|
echo '<a href="' . htmlspecialchars($SELF . "sql=&history=$key") . '">' . lang('Edit') . '</a> <code class="jush-sql">' . shorten_utf8(str_replace("\n", " ", $val), 80, "</code>") . "<br>\n";
|
2009-06-15 09:07:05 +00:00
|
|
|
}
|
2009-07-17 13:53:10 +00:00
|
|
|
echo "<input type='submit' name='clear' value='" . lang('Clear') . "'>\n";
|
2009-06-15 09:07:05 +00:00
|
|
|
echo "</fieldset>\n";
|
|
|
|
}
|
|
|
|
?>
|
|
|
|
|
2007-07-02 05:51:26 +00:00
|
|
|
</form>
|