2007-07-02 05:51:26 +00:00
|
|
|
<?php
|
2009-08-29 13:57:50 +00:00
|
|
|
$TABLE = $_GET["edit"];
|
|
|
|
$fields = fields($TABLE);
|
2012-12-12 05:25:56 +00:00
|
|
|
$where = (isset($_GET["select"]) ? (count($_POST["check"]) == 1 ? where_check($_POST["check"][0], $fields) : "") : where($_GET, $fields));
|
|
|
|
$update = (isset($_GET["select"]) ? $_POST["edit"] : $where);
|
2007-07-25 15:18:59 +00:00
|
|
|
foreach ($fields as $name => $field) {
|
2010-01-09 23:33:41 +00:00
|
|
|
if (!isset($field["privileges"][$update ? "update" : "insert"]) || $adminer->fieldName($field) == "") {
|
2007-07-25 15:18:59 +00:00
|
|
|
unset($fields[$name]);
|
2007-07-09 06:12:22 +00:00
|
|
|
}
|
2007-07-05 10:41:53 +00:00
|
|
|
}
|
2013-05-02 01:28:04 +00:00
|
|
|
|
2008-10-01 11:39:13 +00:00
|
|
|
if ($_POST && !$error && !isset($_GET["select"])) {
|
2010-03-05 16:18:45 +00:00
|
|
|
$location = $_POST["referer"];
|
|
|
|
if ($_POST["insert"]) { // continue edit or insert
|
2010-04-15 14:59:40 +00:00
|
|
|
$location = ($update ? null : $_SERVER["REQUEST_URI"]);
|
2010-03-05 16:18:45 +00:00
|
|
|
} elseif (!ereg('^.+&select=.+$', $location)) {
|
2009-08-29 13:57:50 +00:00
|
|
|
$location = ME . "select=" . urlencode($TABLE);
|
2009-08-03 13:37:29 +00:00
|
|
|
}
|
2013-05-02 01:28:04 +00:00
|
|
|
|
2013-05-11 20:03:39 +00:00
|
|
|
$indexes = indexes($TABLE);
|
|
|
|
$unique_array = unique_array($_GET["where"], $indexes);
|
|
|
|
$query_where = "\nWHERE $where";
|
|
|
|
|
2009-12-14 11:37:59 +00:00
|
|
|
if (isset($_POST["delete"])) {
|
2013-05-11 20:03:39 +00:00
|
|
|
$query = "FROM " . table($TABLE);
|
|
|
|
query_redirect(
|
|
|
|
"DELETE" . ($unique_array ? " $query$query_where" : limit1($query, $query_where)),
|
|
|
|
$location,
|
|
|
|
lang('Item has been deleted.')
|
|
|
|
);
|
2009-07-23 16:31:28 +00:00
|
|
|
} else {
|
2009-12-14 11:37:59 +00:00
|
|
|
$set = array();
|
|
|
|
foreach ($fields as $name => $field) {
|
|
|
|
$val = process_input($field);
|
2010-04-21 12:01:32 +00:00
|
|
|
if ($val !== false && $val !== null) {
|
|
|
|
$set[idf_escape($name)] = ($update ? "\n" . idf_escape($name) . " = $val" : $val);
|
2009-12-14 11:37:59 +00:00
|
|
|
}
|
|
|
|
}
|
2013-05-02 01:28:04 +00:00
|
|
|
|
2009-12-14 11:37:59 +00:00
|
|
|
if ($update) {
|
2010-04-21 12:01:32 +00:00
|
|
|
if (!$set) {
|
|
|
|
redirect($location);
|
|
|
|
}
|
2013-05-11 20:03:39 +00:00
|
|
|
$query = table($TABLE) . " SET" . implode(",", $set);
|
|
|
|
query_redirect(
|
|
|
|
"UPDATE" . ($unique_array ? " $query$query_where" : limit1($query, $query_where)),
|
|
|
|
$location,
|
|
|
|
lang('Item has been updated.')
|
|
|
|
);
|
2013-06-29 19:41:35 +00:00
|
|
|
if (is_ajax()) {
|
|
|
|
page_headers();
|
|
|
|
page_messages($error);
|
|
|
|
exit;
|
|
|
|
}
|
2009-12-14 11:37:59 +00:00
|
|
|
} else {
|
2010-05-12 16:07:46 +00:00
|
|
|
$result = insert_into($TABLE, $set);
|
|
|
|
$last_id = ($result ? last_id() : 0);
|
|
|
|
queries_redirect($location, lang('Item%s has been inserted.', ($last_id ? " $last_id" : "")), $result); //! link
|
2009-12-14 11:37:59 +00:00
|
|
|
}
|
2009-07-23 16:31:28 +00:00
|
|
|
}
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
2009-07-11 19:45:57 +00:00
|
|
|
|
2013-06-24 12:53:23 +00:00
|
|
|
$table_name = $adminer->tableName(table_status1($TABLE, true));
|
2009-07-11 19:45:57 +00:00
|
|
|
page_header(
|
2009-08-21 16:54:10 +00:00
|
|
|
($update ? lang('Edit') : lang('Insert')),
|
2009-07-11 19:45:57 +00:00
|
|
|
$error,
|
2009-08-29 13:57:50 +00:00
|
|
|
array("select" => array($TABLE, $table_name)),
|
2013-07-05 08:31:53 +00:00
|
|
|
$table_name
|
2009-07-11 19:45:57 +00:00
|
|
|
);
|
2007-07-02 05:51:26 +00:00
|
|
|
|
2010-04-22 12:19:22 +00:00
|
|
|
$row = null;
|
2009-06-07 23:53:51 +00:00
|
|
|
if ($_POST["save"]) {
|
2007-07-16 14:01:28 +00:00
|
|
|
$row = (array) $_POST["fields"];
|
2007-07-02 05:51:26 +00:00
|
|
|
} elseif ($where) {
|
2007-07-06 13:48:25 +00:00
|
|
|
$select = array();
|
2007-07-02 05:51:26 +00:00
|
|
|
foreach ($fields as $name => $field) {
|
2009-06-13 17:00:48 +00:00
|
|
|
if (isset($field["privileges"]["select"])) {
|
2012-09-09 05:56:34 +00:00
|
|
|
$as = convert_field($field);
|
|
|
|
if ($_POST["clone"] && $field["auto_increment"]) {
|
|
|
|
$as = "''";
|
|
|
|
}
|
|
|
|
if ($jush == "sql" && ereg("enum|set", $field["type"])) {
|
|
|
|
$as = "1*" . idf_escape($name);
|
|
|
|
}
|
|
|
|
$select[] = ($as ? "$as AS " : "") . idf_escape($name);
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
|
|
|
}
|
2008-10-09 13:23:54 +00:00
|
|
|
$row = array();
|
2007-07-10 13:30:42 +00:00
|
|
|
if ($select) {
|
2010-10-13 15:53:59 +00:00
|
|
|
$rows = get_rows("SELECT" . limit(implode(", ", $select) . " FROM " . table($TABLE), " WHERE $where", (isset($_GET["select"]) ? 2 : 1)));
|
|
|
|
$row = (isset($_GET["select"]) && count($rows) != 1 ? null : reset($rows));
|
2007-07-10 13:30:42 +00:00
|
|
|
}
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
2011-08-01 19:50:57 +00:00
|
|
|
|
|
|
|
if ($row === false) {
|
|
|
|
echo "<p class='error'>" . lang('No rows.') . "\n";
|
|
|
|
}
|
2007-07-02 05:51:26 +00:00
|
|
|
?>
|
2007-07-09 14:45:11 +00:00
|
|
|
|
2013-06-29 19:41:35 +00:00
|
|
|
<div id="message"></div>
|
|
|
|
|
2011-01-31 14:57:28 +00:00
|
|
|
<form action="" method="post" enctype="multipart/form-data" id="form">
|
2007-07-02 05:51:26 +00:00
|
|
|
<?php
|
2012-12-16 07:13:51 +00:00
|
|
|
if (!$fields) {
|
|
|
|
echo "<p class='error'>" . lang('You have no privileges to update this table.') . "\n";
|
|
|
|
} else {
|
2011-01-25 16:13:57 +00:00
|
|
|
echo "<table cellspacing='0' onkeydown='return editingKeydown(event);'>\n";
|
2013-05-02 01:28:04 +00:00
|
|
|
|
2007-07-10 20:26:17 +00:00
|
|
|
foreach ($fields as $name => $field) {
|
2009-07-27 11:25:37 +00:00
|
|
|
echo "<tr><th>" . $adminer->fieldName($field);
|
2009-07-30 08:12:54 +00:00
|
|
|
$default = $_GET["set"][bracket_escape($name)];
|
2013-04-27 06:21:09 +00:00
|
|
|
if ($default === null) {
|
|
|
|
$default = $field["default"];
|
|
|
|
if ($field["type"] == "bit" && ereg("^b'([01]*)'\$", $default, $regs)) {
|
|
|
|
$default = $regs[1];
|
|
|
|
}
|
|
|
|
}
|
2012-05-14 06:54:07 +00:00
|
|
|
$value = ($row !== null
|
2012-07-21 16:50:50 +00:00
|
|
|
? ($row[$name] != "" && $jush == "sql" && ereg("enum|set", $field["type"]) ? (is_array($row[$name]) ? array_sum($row[$name]) : +$row[$name]) : $row[$name])
|
2013-04-27 06:21:09 +00:00
|
|
|
: (!$update && $field["auto_increment"] ? "" : (isset($_GET["select"]) ? false : $default))
|
2009-06-07 23:53:51 +00:00
|
|
|
);
|
2009-07-27 16:32:56 +00:00
|
|
|
if (!$_POST["save"] && is_string($value)) {
|
|
|
|
$value = $adminer->editVal($value, $field);
|
|
|
|
}
|
2012-05-14 06:54:07 +00:00
|
|
|
$function = ($_POST["save"] ? (string) $_POST["function"][$name] : ($update && $field["on_update"] == "CURRENT_TIMESTAMP" ? "now" : ($value === false ? null : ($value !== null ? '' : 'NULL'))));
|
2013-02-20 00:57:04 +00:00
|
|
|
if (ereg("time", $field["type"]) && $value == "CURRENT_TIMESTAMP") {
|
2009-08-21 17:08:10 +00:00
|
|
|
$value = "";
|
|
|
|
$function = "now";
|
|
|
|
}
|
2009-07-23 14:42:38 +00:00
|
|
|
input($field, $value, $function);
|
2009-07-11 20:30:40 +00:00
|
|
|
echo "\n";
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
2013-05-02 01:28:04 +00:00
|
|
|
|
2007-07-10 20:26:17 +00:00
|
|
|
echo "</table>\n";
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
|
|
|
?>
|
2007-07-09 06:12:22 +00:00
|
|
|
<p>
|
2008-10-01 11:39:13 +00:00
|
|
|
<?php
|
|
|
|
if ($fields) {
|
2010-11-23 10:50:53 +00:00
|
|
|
echo "<input type='submit' value='" . lang('Save') . "'>\n";
|
2009-08-21 16:54:10 +00:00
|
|
|
if (!isset($_GET["select"])) {
|
2013-06-29 19:41:35 +00:00
|
|
|
echo "<input type='submit' name='insert' value='" . ($update
|
|
|
|
? lang('Save and continue edit') . "' onclick='return !ajaxForm(this.form, \"" . lang('Loading') . '", this)'
|
|
|
|
: lang('Save and insert next')
|
|
|
|
) . "' title='Ctrl+Shift+Enter'>\n";
|
2009-06-07 23:24:37 +00:00
|
|
|
}
|
|
|
|
}
|
2011-02-02 15:28:22 +00:00
|
|
|
echo ($update ? "<input type='submit' name='delete' value='" . lang('Delete') . "' onclick=\"return confirm('" . lang('Are you sure?') . "');\">\n"
|
2013-05-05 00:02:59 +00:00
|
|
|
: ($_POST || !$fields ? "" : "<script type='text/javascript'>focus(document.getElementById('form').getElementsByTagName('td')[1].firstChild);</script>\n")
|
2011-01-31 14:57:28 +00:00
|
|
|
);
|
2011-03-08 12:43:05 +00:00
|
|
|
if (isset($_GET["select"])) {
|
|
|
|
hidden_fields(array("check" => (array) $_POST["check"], "clone" => $_POST["clone"], "all" => $_POST["all"]));
|
|
|
|
}
|
2009-06-07 23:24:37 +00:00
|
|
|
?>
|
2011-03-08 12:43:05 +00:00
|
|
|
<input type="hidden" name="referer" value="<?php echo h(isset($_POST["referer"]) ? $_POST["referer"] : $_SERVER["HTTP_REFERER"]); ?>">
|
|
|
|
<input type="hidden" name="save" value="1">
|
|
|
|
<input type="hidden" name="token" value="<?php echo $token; ?>">
|
2007-07-02 05:51:26 +00:00
|
|
|
</form>
|