$field) { if (isset($_GET["default"]) ? !$field["auto_increment"] : isset($field["privileges"][$where ? "update" : "insert"])) { $fields[$name] = $field; } } if ($_POST && !$error) { if (isset($_POST["delete"])) { $set = true; $query = "DELETE FROM " . idf_escape($_GET["edit"]) . " WHERE " . implode(" AND ", $where) . " LIMIT 1"; $message = lang('Item has been deleted.'); } else { $set = array(); foreach ($fields as $name => $field) { $val = process_input($name, $field); if ($val !== false) { $set[] = idf_escape($name) . (isset($_GET["default"]) ? ($val == "NULL" ? " DROP DEFAULT" : " SET DEFAULT $val") : " = $val"); } } if (isset($_GET["default"])) { $query = "ALTER TABLE " . idf_escape($_GET["edit"]) . " ALTER " . implode(", ALTER ", $set); $message = lang('Default values has been set.'); } elseif ($where) { $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.'); } } if (!$set || $mysql->query($query)) { redirect($SELF . (isset($_GET["default"]) ? "table=" : ($_POST["insert"] ? "edit=" : "select=")) . urlencode($_GET["edit"]), ($set ? $message : null)); } $error = $mysql->error; } page_header((isset($_GET["default"]) ? lang('Default values') : ($_GET["where"] ? lang('Edit') : lang('Insert'))) . ": " . htmlspecialchars($_GET["edit"])); if ($_POST) { echo "

" . lang('Error during saving') . ": " . htmlspecialchars($error) . "

\n"; $row = (array) $_POST["fields"]; foreach ((array) $_POST["null"] as $key => $val) { $row[$key] = null; } } elseif ($where) { $select = array(); foreach ($fields as $name => $field) { if (isset($field["privileges"]["select"]) && !preg_match('~binary|blob~', $field["type"])) { $select[] = ($field["type"] == "enum" || $field["type"] == "set" ? "1*" . idf_escape($name) . " AS " : "") . idf_escape($name); } } if ($select) { $result = $mysql->query("SELECT " . implode(", ", $select) . " FROM " . idf_escape($_GET["edit"]) . " WHERE " . implode(" AND ", $where) . " LIMIT 1"); $row = $result->fetch_assoc(); } else { $row = array(); } } else { unset($row); } ?>
\n"; foreach ($fields as $name => $field) { echo "" . htmlspecialchars($name) . ""; if (!isset($row)) { $value = $field["default"]; } elseif (strlen($row[$name]) && ($field["type"] == "enum" || $field["type"] == "set")) { $value = intval($row[$name]); } else { $value = $row[$name]; } input($name, $field, $value); echo "\n"; } echo "\n"; } ?>