boinc/html/user/forum_moderate_thread_actio...

82 lines
2.1 KiB
PHP
Raw Normal View History

<?php
require_once("../inc/db.inc");
require_once("../inc/user.inc");
require_once("../inc/profile.inc");
require_once("../inc/util.inc");
require_once("../inc/image.inc");
require_once("../inc/forum.inc");
db_init();
$user = get_logged_in_user();
$user = getForumPreferences($user);
if (!post_str('action')) {
if (!get_str('action')){
echo "You must specify an action...";
exit();
} else {
$action = get_str('action');
}
} else {
$action = post_str('action');
}
$thread = getThread(get_int('thread'));
if (!$thread){
// TODO: Standard error page
echo "Invalid thread ID.<br>";
exit();
}
if (!isSpecialUser($user,0)) {
// Can't moderate without being moderator
echo "You are not authorized to moderate this post.";
exit();
}
if ($action=="hide"){
$result=mysql_query("update thread set hidden = ".post_int("category")." where id=".$thread->id);
echo mysql_error();
} elseif ($action=="unhide"){
$result=mysql_query("update thread set hidden = 0 where id=".$thread->id);
echo mysql_error();
} elseif ($action=="sticky"){
$result=mysql_query("update thread set sticky = 1 where id=".$thread->id);
echo mysql_error();
} elseif ($action=="desticky"){
$result=mysql_query("update thread set sticky = 0 where id=".$thread->id);
echo mysql_error();
/*} elseif ($_POST['action']=="move"){
if (getThread($_POST['threadid'])){
$result=mysql_query("update post set thread = ".intval($_POST['threadid'])." where id=".$post->id);
echo mysql_error();
//TODO: correct the number of posts in this thread
//TODO: correct the number of posts in destination thread
} else {
echo "Destination not found, please check and try again.";
exit();
}*/
} else {
echo "Unknown action ";
exit();
}
if ($result) {
echo mysql_error();
if (post_str('reason')){
send_thread_moderation_email(lookup_user_id($post->user),$thread, post_str("reason"));
}
header('Location: forum_thread.php?id='.$thread->id);
} else {
page_head("Moderation update");
echo "Couldn't moderate the thread.<br>\n";
echo mysql_error();
page_tail();
}
?>