format_interval(3600), 10800 => format_interval(10800), 21600 => format_interval(21600), 32400 => format_interval(32400), 43200 => format_interval(43200), 86400 => format_interval(86400), 172800 => format_interval(172800), 259200 => format_interval(259200), 604800 => format_interval(604800), 1209600 => format_interval(1209600), 2419200 => format_interval(2419200), 1000000000 => t("Never")); $output .= form_select(t("Discard entries older than"), "queue_clear", variable_get("queue_clear", 604800), $period, t("The time nodes should be kept in the submission queue. Older entries will be automatically discarded. Requires crontab.")); return $output; } function queue_perm() { return array("access submission queue"); } function queue_link($type) { if ($type == "menu" && user_access("access submission queue")) { $links[] = "". t("submission queue") ." (". queue_count() .")"; } return $links ? $links : array(); } function queue_cron() { global $status; db_query("UPDATE node SET status = '$status[dumped]' WHERE status = '$status[queued]' AND ". time() ." - timestamp > ". variable_get("queue_clear", 604800)); } function queue_count() { global $status; $result = db_query("SELECT COUNT(nid) FROM node WHERE status = '$status[queued]'"); return ($result) ? db_result($result, 0) : 0; } function queue_score($id) { $result = db_query("SELECT score FROM node WHERE nid = '$id'"); return ($result) ? db_result($result, 0) : 0; } function queue_vote($id, $vote) { global $status, $user; if ($node = node_get_object(array(nid => $id))) { if (!field_get($node->users, $user->uid)) { // Update submission's score- and votes-field: db_query("UPDATE node SET score = score $vote, votes = votes + 1, users = '". field_set($node->users, $user->uid, $vote) ."' WHERE nid = $id"); $node = node_get_object(array(nid => $id, type => $node->type)); if (variable_get($node->type ."_post", 4) <= $node->score) { node_save(array(nid => $id, status => $status[posted], timestamp => time()), array(status, timestamp)); watchdog("special", "node: posted '$node->title' - moderation"); } else if (variable_get($node->type ."_dump", -2) >= $node->score) { node_save(array(nid => $id, status => $status[dumped], timestamp => time()), array(status, timestamp)); watchdog("special", "node: dumped '$node->title' - moderation"); } else if (variable_get($node->type ."_expire", 8) <= $node->votes) { node_save(array(nid => $id, status => $status[expired], timestamp => time()), array(status, timestamp)); watchdog("special", "node: expired '$node->title' - moderation"); } } } } function queue_overview() { global $status, $theme, $user; $result = db_query("SELECT n.*, u.name, u.uid FROM node n LEFT JOIN users u ON n.author = u.uid WHERE n.status = '$status[queued]'"); $content .= "\n"; $content .= " \n"; while ($node = db_fetch_object($result)) { if ($user->uid == $node->author || field_get($node->users, $user->uid)) $content .= " \n"; else $content .= " \n"; } $content .= "
". t("Subject") ."". t("Author") ."". t("Type") ."". t("Score") ."
nid\">". check_output($node->title) ."". format_name($node) ."". check_output($node->type) ."". queue_score($node->nid) ."
nid\">". check_output($node->title) ."". format_name($node) ."". check_output($node->type) ."nid\">". t("vote") ."
\n"; $theme->header(); $theme->box(t("Moderation queue"), $content); $theme->footer(); } function queue_node($id) { global $theme, $user; $node = node_get_object(array(nid => $id)); if ($user->uid == $node->author || field_get($node->users, $user->uid)) { header("Location: node.php?id=$node->nid"); } else { $queue_votes = array("neutral (+0)" => "+ 0", "post it (+1)" => "+ 1", "dump it (-1)" => "- 1"); // The keys of this associative array are displayed in each submission's selection box whereas the corresponding values represent the mathematical calculation to be performed to update a comment's value. if ($n = node_get_object(array("nid" => $node->pid))) { $output .= " ". t("The above node is a proposed update of an existing node:") ." \"nid\">". check_output($n->title) ."\"."; } if ($node->log) { $output .= " ". t("The log message to accompany this submission is given below:") ."

". check_output($node->log, 1) ."

"; } // moderation form: $output .= "
\n"; foreach ($queue_votes as $key=>$value) $options .= " \n"; $output .= "\n"; $output .= "nid\">\n"; $output .= "\n"; $output .= "
\n"; $theme->header(); node_view($node); $theme->box(t("Moderate"), $output); $theme->footer(); } } function queue_page() { global $user, $id, $op, $theme, $vote; if ($user->uid && user_access("access submission queue")) { switch($op) { case "Vote"; queue_vote(check_input($id), check_input($vote)); // fall through: case "view": queue_node(check_input($id)); break; default: queue_overview(); break; } } else { $theme->header(); $theme->box(t("Moderation queue"), message_access()); $theme->footer(); } } ?>