engelsystem/includes/pages/admin_news.php

93 lines
3.7 KiB
PHP
Raw Normal View History

2011-06-03 05:49:56 +02:00
<?php
function admin_news() {
2012-12-26 14:02:27 +01:00
global $user;
2011-06-03 05:49:56 +02:00
2012-12-26 14:02:27 +01:00
if (!isset ($_GET["action"])) {
2012-12-30 18:27:45 +01:00
redirect(page_link_to("news"));
2012-12-26 14:02:27 +01:00
} else {
$html = "";
switch ($_GET["action"]) {
case 'edit' :
if (isset ($_REQUEST['id']) && preg_match("/^[0-9]{1,11}$/", $_REQUEST['id']))
$id = $_REQUEST['id'];
else
return error("Incomplete call, missing News ID.", true);
2011-06-03 05:49:56 +02:00
2012-12-26 14:02:27 +01:00
$news = sql_select("SELECT * FROM `News` WHERE `ID`=" . sql_escape($id) . " LIMIT 1");
if (count($news) > 0) {
list ($news) = $news;
2011-06-03 05:49:56 +02:00
$user_source = User($news['UID']);
if($user_source === false)
engelsystem_error("Unable to load user.");
2012-12-26 14:02:27 +01:00
$html .= '<a href="' . page_link_to("news") . '">&laquo Back</a>';
2011-06-03 05:49:56 +02:00
2012-12-26 14:02:27 +01:00
$html .= "<form action=\"" . page_link_to("admin_news") . "&action=save\" method=\"post\">\n";
2011-06-03 05:49:56 +02:00
2012-12-26 14:02:27 +01:00
$html .= "<table>\n";
$html .= " <tr><td>Datum</td><td>" .
date("Y-m-d H:i", $news['Datum']) . "</td></tr>\n";
$html .= " <tr><td>Betreff</td><td><input type=\"text\" size=\"40\" name=\"eBetreff\" value=\"" .
$news["Betreff"] . "\"></td></tr>\n";
$html .= " <tr><td>Text</td><td><textarea rows=\"10\" cols=\"80\" name=\"eText\">" .
$news["Text"] . "</textarea></td></tr>\n";
$html .= " <tr><td>Engel</td><td>" .
User_Nick_render($user_source) . "</td></tr>\n";
2012-12-26 14:02:27 +01:00
$html .= " <tr><td>Treffen</td><td>" . html_select_key('eTreffen', 'eTreffen', array (
'1' => "Ja",
'0' => "Nein"
), $news['Treffen']) . "</td></tr>\n";
$html .= "</table>";
2011-06-03 05:49:56 +02:00
2012-12-26 14:02:27 +01:00
$html .= "<input type=\"hidden\" name=\"id\" value=\"" . $id . "\">\n";
$html .= "<input type=\"submit\" name=\"submit\" value=\"Speichern\">\n";
$html .= "</form>";
2011-06-03 05:49:56 +02:00
2012-12-26 14:02:27 +01:00
$html .= "<form action=\"" . page_link_to("admin_news") . "&action=delete\" method=\"POST\">\n";
$html .= "<input type=\"hidden\" name=\"id\" value=\"" . $id . "\">\n";
$html .= "<input type=\"submit\" name=\"submit\" value=\"Löschen\">\n";
$html .= "</form>";
} else
return error("No News found.", true);
break;
2011-06-03 05:49:56 +02:00
2012-12-26 14:02:27 +01:00
case 'save' :
if (isset ($_REQUEST['id']) && preg_match("/^[0-9]{1,11}$/", $_REQUEST['id']))
$id = $_REQUEST['id'];
else
return error("Incomplete call, missing News ID.", true);
2011-06-03 05:49:56 +02:00
2012-12-26 14:02:27 +01:00
$news = sql_select("SELECT * FROM `News` WHERE `ID`=" . sql_escape($id) . " LIMIT 1");
if (count($news) > 0) {
list ($news) = $news;
2011-06-03 05:49:56 +02:00
2012-12-26 14:02:27 +01:00
sql_query("UPDATE `News` SET `Datum`='" . sql_escape(time()) . "', `Betreff`='" . sql_escape($_POST["eBetreff"]) . "', `Text`='" . sql_escape($_POST["eText"]) . "', `UID`='" . sql_escape($user['UID']) .
"', `Treffen`='" . sql_escape($_POST["eTreffen"]) . "' WHERE `ID`=".sql_escape($id)." LIMIT 1");
engelsystem_log("News updated: " . $_POST["eBetreff"]);
2012-12-30 18:27:45 +01:00
redirect(page_link_to("news"));
2012-12-26 14:02:27 +01:00
} else
return error("No News found.", true);
break;
2011-06-03 05:49:56 +02:00
2012-12-26 14:02:27 +01:00
case 'delete' :
if (isset ($_REQUEST['id']) && preg_match("/^[0-9]{1,11}$/", $_REQUEST['id']))
$id = $_REQUEST['id'];
else
return error("Incomplete call, missing News ID.", true);
2011-06-03 05:49:56 +02:00
2012-12-26 14:02:27 +01:00
$news = sql_select("SELECT * FROM `News` WHERE `ID`=" . sql_escape($id) . " LIMIT 1");
if (count($news) > 0) {
list ($news) = $news;
sql_query("DELETE FROM `News` WHERE `ID`=" . sql_escape($id) . " LIMIT 1");
engelsystem_log("News deleted: " . $news['Betreff']);
2012-12-30 18:27:45 +01:00
redirect(page_link_to("news"));
2012-12-26 14:02:27 +01:00
} else
return error("No News found.", true);
break;
}
}
return $html;
2011-06-03 05:49:56 +02:00
}
?>