server_info >= 5) { $out = ""; foreach (array("FUNCTION", "PROCEDURE") as $routine) { $result = $mysql->query("SHOW $routine STATUS WHERE Db = '" . $mysql->escape_string($db) . "'"); while ($row = $result->fetch_assoc()) { if (!$out) { echo "DELIMITER ;;\n\n"; $out = "DELIMITER ;\n\n"; } echo $mysql->result($mysql->query("SHOW CREATE $routine " . idf_escape($row["Db"]) . "." . idf_escape($row["Name"])), 2) . ";;\n\n"; } $result->free(); } echo $out; } } function dump($db, $style) { global $mysql; if ($_POST["format"] != "csv" && in_array($style, array("DROP, CREATE", "CREATE", "CREATE, ALTER")) && ($result = $mysql->query("SHOW CREATE DATABASE " . idf_escape($db)))) { if ($style == "DROP, CREATE") { echo "DROP DATABASE IF EXISTS " . idf_escape($db) . ";\n"; } $create = $mysql->result($result, 1); echo ($style == "CREATE, ALTER" ? preg_replace('~^CREATE DATABASE ~', '\\0IF NOT EXISTS ', $create) : $create) . ";\n"; $result->free(); } if ($style) { echo ($_POST["format"] != "csv" ? "USE " . idf_escape($db) . ";\n" : ""); if (!strlen($_GET["db"])) { $views = array(); if ($_POST["tables"][0] || $_POST["data"][0]) { $result = $mysql->query("SHOW TABLE STATUS"); while ($row = $result->fetch_assoc()) { if (isset($row["Engine"])) { if ($_POST["format"] == "csv") { ob_start(); } dump_table($row["Name"], $_POST["tables"][0]); dump_data($row["Name"], $_POST["data"][0]); if ($_POST["format"] == "csv") { echo tar_file("$db/$row[Name].csv", ob_get_clean()); } } elseif ($_POST["format"] != "csv") { $views[] = $row["Name"]; } } $result->free(); } foreach ($views as $view) { dump_table($view, $_POST["tables"][0]); } dump_routines($db); } } } function tar_file($filename, $contents) { $return = pack("a100a8a8a8a12a12", $filename, 644, 0, 0, decoct(strlen($contents)), decoct(time())); $checksum = 8*32; // space for checksum itself for ($i=0; $i < strlen($return); $i++) { $checksum += ord($return{$i}); } $return .= sprintf("%06o", $checksum) . "\0 "; return $return . str_repeat("\0", 512 - strlen($return)) . $contents . str_repeat("\0", 511 - (strlen($contents) + 511) % 512); } if ($_POST) { $ext = dump_headers((strlen($_GET["dump"]) ? $_GET["dump"] : $_GET["db"]), (!strlen($_GET["db"]) || count(array_filter($_POST["tables"]) + array_filter($_POST["data"])) > 1)); if ($_POST["format"] != "csv") { $max_packet = 16777216; echo "SET NAMES utf8;\n"; echo "SET foreign_key_checks = 0;\n"; echo "SET time_zone = '" . $mysql->escape_string($mysql->result($mysql->query("SELECT @@time_zone"))) . "';\n"; echo "SET max_allowed_packet = $max_packet, GLOBAL max_allowed_packet = $max_packet;\n"; echo "\n"; } foreach ($_POST["databases"] as $db => $style) { $db = bracket_escape($db, "back"); if ($mysql->select_db($db)) { dump($db, $style); } } if (strlen($_GET["db"])) { foreach ($_POST["tables"] as $key => $style) { if ($style || $_POST["data"][$key]) { $table = bracket_escape($key, "back"); if ($ext == "tar") { ob_start(); } dump_table($table, $style); dump_data($table, $_POST["data"][$key]); if ($ext == "tar") { echo tar_file("$table.csv", ob_get_clean()); } } } dump_routines($_GET["db"]); } exit; } page_header(lang('Export'), "", (strlen($_GET["export"]) ? array("table" => $_GET["export"]) : array()), $_GET["db"]); ?>

\n" . lang('Database') . ""; foreach (array('', 'USE', 'DROP, CREATE', 'CREATE', 'CREATE, ALTER') as $val) { echo "" . ($val ? $val : lang('skip')) . ""; } echo "\n"; if (!strlen($_GET["db"]) && !isset($_SESSION["databases"][$_GET["server"]])) { $_SESSION["databases"][$_GET["server"]] = get_vals("SHOW DATABASES"); } foreach ((strlen($_GET["db"]) ? array($_GET["db"]) : $_SESSION["databases"][$_GET["server"]]) as $db) { if ($db != "information_schema" || $mysql->server_info < 5) { echo "" . htmlspecialchars($db) . ""; foreach (array('', 'USE', 'DROP, CREATE', 'CREATE', 'CREATE, ALTER') as $val) { echo '"; } echo "\n"; } } echo "\n"; echo "\n"; foreach (array('', 'DROP, CREATE', 'CREATE', 'CREATE, ALTER') as $val) { echo ""; } foreach (array('', 'TRUNCATE, INSERT', 'INSERT', 'UPDATE') as $val) { echo ""; } echo "\n"; $views = ""; $result = $mysql->query(strlen($_GET["db"]) ? "SHOW TABLE STATUS" : "SELECT 'Engine'"); while ($row = $result->fetch_assoc()) { $print = ""; foreach (array('', 'DROP, CREATE', 'CREATE', 'CREATE, ALTER') as $val) { $print .= '"; } if (!$row["Engine"]) { $views .= "$print\n"; } else { foreach (array('', 'TRUNCATE, INSERT', 'INSERT', 'UPDATE') as $val) { $print .= '"; } echo "$print\n"; } } echo "$views
" . lang('Tables') . "" . lang('Structure') . "" . lang('Data') . "
" . ($val ? $val : lang('skip')) . "" . ($val ? $val : lang('skip')) . "
" . htmlspecialchars($row["Name"]) . "
\n"; ?>