From 5586d58c0f21284c0060838a630e7c9b40aa53ee Mon Sep 17 00:00:00 2001 From: Dries Buytaert Date: Sat, 24 Mar 2001 16:31:17 +0000 Subject: - the "submission.module" is going to be replaced by a "moderation.module" --- modules/moderation.module | 112 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 112 insertions(+) create mode 100644 modules/moderation.module (limited to 'modules/moderation.module') diff --git a/modules/moderation.module b/modules/moderation.module new file mode 100644 index 000000000..3d0b0f4c8 --- /dev/null +++ b/modules/moderation.module @@ -0,0 +1,112 @@ + "moderation_menu", + "page" => "moderation_page"); + +include_once "includes/common.inc"; + +function moderation_menu() { + return array("". t("moderation queue") ." (". moderation_count() .")"); +} + +function moderation_count() { + $result = db_query("SELECT COUNT(nid) FROM nodes WHERE status = 1"); + return ($result) ? db_result($result, 0) : 0; +} + +function moderation_score($id) { + $result = db_query("SELECT score FROM nodes WHERE nid = '$id'"); + return ($result) ? db_result($result, 0) : 0; +} + +function moderation_vote($id, $vote) { + global $user; + + if (!user_get($user, "history", "n$id")) { + // Update submission's score- and votes-field: + db_query("UPDATE nodes SET score = score $vote, votes = votes + 1 WHERE nid = $id"); + + // Update user's history record: + $user = user_set($user, "history", "n$id", $vote); + + $result = db_query("SELECT * FROM nodes WHERE nid = $id"); + if ($node = db_fetch_object($result)) { + if (node_post_threshold($node) <= $node->score) { + db_query("UPDATE nodes SET status = 2, timestamp = '". time() ."' WHERE nid = $id"); + watchdog("message", "posted node '$node->subject'"); + } + else if (node_dump_threshold($node) >= $node->score) { + db_query("UPDATE nodes SET status = 0, timestamp = '". time() ."' WHERE nid = $id"); + watchdog("message", "dumped node '$node->subject'"); + } + else if (node_timout_threshold($node) <= $node->votes) { + db_query("UPDATE nodes SET status = 0, timestamp = '". time() ."' WHERE nid = $id"); + watchdog("message", "expired node '$node->subject'"); + } + } + } +} + +function moderation_overview() { + global $theme, $user; + + $result = db_query("SELECT n.*, u.userid FROM nodes n LEFT JOIN users u ON n.author = u.id WHERE n.status = 1"); + + $content .= "\n"; + $content .= " \n"; + while ($node = db_fetch_object($result)) { + if ($user->id == $node->author || user_get($user, "history", "n$node->nid")) $content .= " \n"; + else $content .= " \n"; + } + $content .= "
". t("Subject") ."". t("Author") ."". t("Type") ."". t("Score") ."
nid\">". check_output($node->title) ."". format_username($node->userid) ."". check_output($node->type) ."". moderation_score($node->nid) ."
nid\">". check_output($node->title) ."". format_username($node->userid) ."". check_output($node->type) ."nid\">". t("vote") ."
\n"; + + $theme->header(); + $theme->box(t("Moderation queue"), $content); + $theme->footer(); +} + +function moderation_node($id) { + global $theme, $user, $moderation_votes; + + $node = node_get_object(nid, $id); + + if ($user->id == $node->author || user_get($user, "history", "n$node->nid")) { + header("Location: node.php?id=$node->nid"); + } + else { + // moderation form: + $output .= "
\n"; + foreach ($moderation_votes as $key=>$value) $options .= " \n"; + $output .= "\n"; + $output .= "nid\">\n"; + $output .= "\n"; + $output .= "
\n"; + + $theme->header(); + node_view($node, 1); + $theme->box(t("Moderate"), $output); + $theme->footer(); + } +} + +function moderation_page() { + global $id, $op, $user, $vote; + + if ($user->id) { + $user = user_load($user->userid); + + switch($op) { + case "Vote"; + moderation_vote(check_input($id), check_input($vote)); + // fall through: + case "view": + moderation_node(check_input($id)); + break; + default: + moderation_overview(); + break; + } + } +} + +?> -- cgit v1.2.3