2007-07-02 05:51:26 +00:00
|
|
|
<?php
|
2007-07-09 06:12:22 +00:00
|
|
|
$where = where();
|
2007-07-25 15:18:59 +00:00
|
|
|
$fields = fields($_GET["edit"]);
|
|
|
|
foreach ($fields as $name => $field) {
|
|
|
|
if (isset($_GET["default"]) ? $field["auto_increment"] : !isset($field["privileges"][$where ? "update" : "insert"])) {
|
|
|
|
unset($fields[$name]);
|
2007-07-09 06:12:22 +00:00
|
|
|
}
|
2007-07-05 10:41:53 +00:00
|
|
|
}
|
2007-07-09 06:12:22 +00:00
|
|
|
if ($_POST && !$error) {
|
2007-07-02 05:51:26 +00:00
|
|
|
if (isset($_POST["delete"])) {
|
2007-07-09 06:12:22 +00:00
|
|
|
$set = true;
|
2007-07-02 05:51:26 +00:00
|
|
|
$query = "DELETE FROM " . idf_escape($_GET["edit"]) . " WHERE " . implode(" AND ", $where) . " LIMIT 1";
|
|
|
|
$message = lang('Item has been deleted.');
|
|
|
|
} else {
|
|
|
|
$set = array();
|
2007-07-09 06:12:22 +00:00
|
|
|
foreach ($fields as $name => $field) {
|
2007-07-09 14:45:11 +00:00
|
|
|
$val = process_input($name, $field);
|
|
|
|
if ($val !== false) {
|
2007-07-25 15:18:59 +00:00
|
|
|
if (!isset($_GET["default"])) {
|
|
|
|
$set[] = idf_escape($name) . " = $val";
|
|
|
|
} elseif ($field["type"] == "timestamp") {
|
|
|
|
$set[] = " MODIFY " . idf_escape($name) . " timestamp" . ($field["null"] ? " NULL" : "") . " DEFAULT $val"; //! ON UPDATE
|
|
|
|
} else {
|
|
|
|
$set[] = " ALTER " . idf_escape($name) . ($val == "NULL" ? " DROP DEFAULT" : " SET DEFAULT $val");
|
|
|
|
}
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
|
|
|
}
|
2007-07-09 06:12:22 +00:00
|
|
|
if (isset($_GET["default"])) {
|
2007-07-25 15:18:59 +00:00
|
|
|
$query = "ALTER TABLE " . idf_escape($_GET["edit"]) . implode(",", $set);
|
2007-07-09 06:12:22 +00:00
|
|
|
$message = lang('Default values has been set.');
|
|
|
|
} elseif ($where) {
|
2007-07-02 05:51:26 +00:00
|
|
|
$query = "UPDATE " . idf_escape($_GET["edit"]) . " SET " . implode(", ", $set) . " WHERE " . implode(" AND ", $where) . " LIMIT 1";
|
|
|
|
$message = lang('Item has been updated.');
|
|
|
|
} else {
|
|
|
|
$query = "INSERT INTO " . idf_escape($_GET["edit"]) . " SET " . implode(", ", $set);
|
|
|
|
$message = lang('Item has been inserted.');
|
|
|
|
}
|
|
|
|
}
|
2007-07-10 13:30:42 +00:00
|
|
|
if (!$set || $mysql->query($query)) {
|
2007-07-09 06:12:22 +00:00
|
|
|
redirect($SELF . (isset($_GET["default"]) ? "table=" : ($_POST["insert"] ? "edit=" : "select=")) . urlencode($_GET["edit"]), ($set ? $message : null));
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
2007-07-10 13:30:42 +00:00
|
|
|
$error = $mysql->error;
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
2007-07-09 06:12:22 +00:00
|
|
|
page_header((isset($_GET["default"]) ? lang('Default values') : ($_GET["where"] ? lang('Edit') : lang('Insert'))) . ": " . htmlspecialchars($_GET["edit"]));
|
2007-07-02 05:51:26 +00:00
|
|
|
|
|
|
|
if ($_POST) {
|
2007-07-02 16:42:42 +00:00
|
|
|
echo "<p class='error'>" . lang('Error during saving') . ": " . htmlspecialchars($error) . "</p>\n";
|
2007-07-16 14:01:28 +00:00
|
|
|
$row = (array) $_POST["fields"];
|
2007-07-09 06:12:22 +00:00
|
|
|
foreach ((array) $_POST["null"] as $key => $val) {
|
2007-07-16 14:01:28 +00:00
|
|
|
$row[$key] = null;
|
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) {
|
2007-07-09 06:12:22 +00:00
|
|
|
if (isset($field["privileges"]["select"]) && !preg_match('~binary|blob~', $field["type"])) {
|
2007-07-06 13:48:25 +00:00
|
|
|
$select[] = ($field["type"] == "enum" || $field["type"] == "set" ? "1*" . idf_escape($name) . " AS " : "") . idf_escape($name);
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
|
|
|
}
|
2007-07-10 13:30:42 +00:00
|
|
|
if ($select) {
|
|
|
|
$result = $mysql->query("SELECT " . implode(", ", $select) . " FROM " . idf_escape($_GET["edit"]) . " WHERE " . implode(" AND ", $where) . " LIMIT 1");
|
2007-07-16 14:01:28 +00:00
|
|
|
$row = $result->fetch_assoc();
|
2007-07-10 13:30:42 +00:00
|
|
|
} else {
|
2007-07-16 14:01:28 +00:00
|
|
|
$row = array();
|
2007-07-10 13:30:42 +00:00
|
|
|
}
|
2007-07-02 05:51:26 +00:00
|
|
|
} else {
|
2007-07-16 14:01:28 +00:00
|
|
|
unset($row);
|
2007-07-02 05:51:26 +00:00
|
|
|
}
|
|
|
|
?>
|
2007-07-09 14:45:11 +00:00
|
|
|
|
2007-07-09 06:12:22 +00:00
|
|
|
<form action="" method="post" enctype="multipart/form-data">
|
2007-07-02 05:51:26 +00:00
|
|
|
<?php
|
2007-07-10 20:26:17 +00:00
|
|
|
if ($fields) {
|
|
|
|
echo "<table border='0' cellspacing='0' cellpadding='2'>\n";
|
|
|
|
foreach ($fields as $name => $field) {
|
|
|
|
echo "<tr><th>" . htmlspecialchars($name) . "</th><td>";
|
2007-07-16 14:01:28 +00:00
|
|
|
if (!isset($row)) {
|
2007-07-10 20:26:17 +00:00
|
|
|
$value = $field["default"];
|
2007-07-16 14:01:28 +00:00
|
|
|
} elseif (strlen($row[$name]) && ($field["type"] == "enum" || $field["type"] == "set")) {
|
|
|
|
$value = intval($row[$name]);
|
2007-07-10 20:26:17 +00:00
|
|
|
} else {
|
2007-07-16 14:01:28 +00:00
|
|
|
$value = $row[$name];
|
2007-07-10 20:26:17 +00:00
|
|
|
}
|
|
|
|
input($name, $field, $value);
|
|
|
|
echo "</td></tr>\n";
|
2007-07-02 05:51:26 +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>
|
|
|
|
<input type="hidden" name="token" value="<?php echo $token; ?>" />
|
2007-07-09 14:45:11 +00:00
|
|
|
<?php if ($fields) { ?>
|
2007-07-09 06:12:22 +00:00
|
|
|
<input type="submit" value="<?php echo lang('Save'); ?>" />
|
|
|
|
<?php if (!isset($_GET["default"])) { ?><input type="submit" name="insert" value="<?php echo lang('Save and insert'); ?>" /><?php } ?>
|
|
|
|
<?php } ?>
|
|
|
|
<?php if ($where) { ?> <input type="submit" name="delete" value="<?php echo lang('Delete'); ?>" /><?php } ?>
|
|
|
|
</p>
|
2007-07-02 05:51:26 +00:00
|
|
|
</form>
|