2007-07-02 05:51:26 +00:00
|
|
|
<?php
|
2007-07-11 11:19:16 +00:00
|
|
|
if (isset($_POST["query"])) {
|
2007-07-27 11:02:05 +00:00
|
|
|
setcookie("highlight", $_POST["highlight"], strtotime("+1 month"), preg_replace('~\\?.*~', '', $_SERVER["REQUEST_URI"]));
|
2007-07-13 07:07:28 +00:00
|
|
|
$_COOKIE["highlight"] = $_POST["highlight"];
|
2007-07-11 11:19:16 +00:00
|
|
|
}
|
2008-04-10 14:37:10 +00:00
|
|
|
page_header(lang('SQL command'), $error);
|
2007-07-02 05:51:26 +00:00
|
|
|
|
2008-04-10 14:37:10 +00:00
|
|
|
if (!$error && $_POST && is_string($query = (isset($_POST["query"]) ? $_POST["query"] : get_file("sql_file")))) {
|
2007-07-09 06:12:22 +00:00
|
|
|
$delimiter = ";";
|
|
|
|
$offset = 0;
|
|
|
|
$empty = true;
|
|
|
|
while (rtrim($query)) {
|
|
|
|
if (!$offset && preg_match('~^\\s*DELIMITER\\s+(.+)~i', $query, $match)) {
|
|
|
|
$delimiter = preg_quote($match[1], '~');
|
|
|
|
$query = substr($query, strlen($match[0]));
|
2008-04-15 15:42:21 +00:00
|
|
|
} elseif (preg_match("~$delimiter|['`\"]|/\\*|-- |#|\$~", $query, $match, PREG_OFFSET_CAPTURE, $offset)) {
|
2007-07-09 06:12:22 +00:00
|
|
|
if ($match[0][0] && $match[0][0] != $delimiter) {
|
2008-04-15 15:42:21 +00:00
|
|
|
$pattern = ($match[0][0] == "-- " || $match[0][0] == "#" ? '~.*~' : ($match[0][0] == "/*" ? '~.*\\*/~sU' : '~\\G([^\\\\' . $match[0][0] . ']+|\\\\.)*(' . $match[0][0] . '|$)~s'));
|
2007-07-17 10:59:44 +00:00
|
|
|
preg_match($pattern, $query, $match, PREG_OFFSET_CAPTURE, $match[0][1] + 1);
|
2007-07-09 06:12:22 +00:00
|
|
|
$offset = $match[0][1] + strlen($match[0][0]);
|
|
|
|
} else {
|
|
|
|
$empty = false;
|
2007-07-10 06:30:04 +00:00
|
|
|
echo "<pre class='jush-sql'>" . htmlspecialchars(substr($query, 0, $match[0][1])) . "</pre>\n";
|
2007-07-11 18:02:13 +00:00
|
|
|
//! don't allow changing of character_set_results, convert encoding of displayed query
|
2007-07-10 13:30:42 +00:00
|
|
|
if (!$mysql->multi_query(substr($query, 0, $match[0][1]))) {
|
|
|
|
echo "<p class='error'>" . lang('Error in query') . ": " . htmlspecialchars($mysql->error) . "</p>\n";
|
2007-07-11 18:02:13 +00:00
|
|
|
} else {
|
2007-07-10 13:30:42 +00:00
|
|
|
do {
|
|
|
|
$result = $mysql->store_result();
|
|
|
|
if (is_object($result)) {
|
|
|
|
select($result);
|
|
|
|
} else {
|
2008-04-16 08:57:10 +00:00
|
|
|
if (preg_match("~^\\s*(CREATE|DROP)(\\s+|/\\*.*\\*/|(#|-- )[^\n]*\n)+(DATABASE|SCHEMA)\\b~isU", $query)) {
|
2007-07-17 05:54:19 +00:00
|
|
|
unset($_SESSION["databases"][$_GET["server"]]);
|
|
|
|
}
|
2007-07-10 13:30:42 +00:00
|
|
|
echo "<p class='message'>" . lang('Query executed OK, %d row(s) affected.', $mysql->affected_rows) . "</p>\n";
|
|
|
|
}
|
|
|
|
} while ($mysql->next_result());
|
|
|
|
}
|
2007-07-09 06:12:22 +00:00
|
|
|
$query = substr($query, $match[0][1] + strlen($match[0][0]));
|
|
|
|
$offset = 0;
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2007-07-09 06:12:22 +00:00
|
|
|
if ($empty) {
|
|
|
|
echo "<p class='message'>" . lang('No commands to execute.') . "</p>\n";
|
|
|
|
}
|
2007-07-10 13:51:37 +00:00
|
|
|
} elseif ($_POST) {
|
2007-07-09 06:12:22 +00:00
|
|
|
echo "<p class='error'>" . lang('Unable to upload a file.') . "</p>\n";
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
|
|
|
?>
|
2007-07-09 14:45:11 +00:00
|
|
|
|
2007-07-10 13:51:37 +00:00
|
|
|
<form action="" method="post">
|
2007-07-13 13:15:52 +00:00
|
|
|
<p><textarea name="query" rows="20" cols="80" style="width: 98%;"><?php echo htmlspecialchars($_POST["query"]); ?></textarea></p>
|
2007-07-11 11:19:16 +00:00
|
|
|
<p>
|
|
|
|
<input type="hidden" name="token" value="<?php echo $token; ?>" />
|
|
|
|
<input type="submit" value="<?php echo lang('Execute'); ?>" />
|
|
|
|
<script type="text/javascript">
|
2007-07-13 07:07:28 +00:00
|
|
|
document.write('<label for="highlight"><input type="checkbox" name="highlight" id="highlight" value="jush"<?php echo ($_COOKIE["highlight"] == "jush" ? ' checked="checked"' : ''); ?> /><?php echo addcslashes(lang('Syntax highlighting'), "\r\n'\\"); ?></label>');
|
2007-07-11 11:19:16 +00:00
|
|
|
</script>
|
|
|
|
</p>
|
2007-07-09 06:12:22 +00:00
|
|
|
</form>
|
|
|
|
|
|
|
|
<?php
|
|
|
|
if (!ini_get("file_uploads")) {
|
|
|
|
echo "<p>" . lang('File uploads are disabled.') . "</p>\n";
|
|
|
|
} else { ?>
|
2007-07-10 13:51:37 +00:00
|
|
|
<form action="" method="post" enctype="multipart/form-data">
|
2007-07-09 06:12:22 +00:00
|
|
|
<p>
|
|
|
|
<?php echo lang('File upload'); ?>: <input type="file" name="sql_file" />
|
|
|
|
<input type="hidden" name="token" value="<?php echo $token; ?>" />
|
|
|
|
<input type="submit" value="<?php echo lang('Execute'); ?>" />
|
|
|
|
</p>
|
2007-07-02 05:51:26 +00:00
|
|
|
</form>
|
2007-07-09 06:12:22 +00:00
|
|
|
<?php } ?>
|