mirror of https://github.com/BOINC/boinc.git
298 lines
12 KiB
PHP
298 lines
12 KiB
PHP
<?php
|
|
$cvs_version_tracker[]="\$Id$";
|
|
|
|
require_once("../inc/forum.inc");
|
|
require_once("../inc/forum_std.inc");
|
|
require_once("../inc/email.inc");
|
|
require_once("../inc/akismet.inc");
|
|
|
|
db_init();
|
|
|
|
function show_block_link($userid) {
|
|
echo " <a href=\"forum_pm.php?action=block&id=$userid\">";
|
|
show_image(REPORT_POST_IMAGE, "Block messages from this user", REPORT_POST_IMAGE_HEIGHT);
|
|
echo "</a>";
|
|
}
|
|
|
|
$action = get_str("action", true);
|
|
if ($action == null) {
|
|
$action = post_str("action", true);
|
|
}
|
|
|
|
if ($action == null) {
|
|
// Prepend "select_" because translated actions may clash with default actions
|
|
$action = "select_".post_str("action_select", true);
|
|
}
|
|
if ($action == "select_") {
|
|
$action = "inbox";
|
|
}
|
|
|
|
$logged_in_user = get_logged_in_user();
|
|
|
|
function make_script() {
|
|
echo "
|
|
<script>
|
|
function set_all(val) {
|
|
f = document.msg_list;
|
|
n = f.elements.length;
|
|
for (i=0; i<n; i++) {
|
|
e = f.elements[i];
|
|
if (e.type=='checkbox') {
|
|
e.checked = val;
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
";
|
|
}
|
|
|
|
function do_inbox($logged_in_user) {
|
|
page_head(tra("Private messages").": ".tra("Inbox"));
|
|
|
|
make_script();
|
|
if (get_int("sent", true) == 1) {
|
|
echo "<div class=\"notice\">".tra("Your message has been sent.")."</div>\n";
|
|
}
|
|
$options = new output_options;
|
|
|
|
$query = mysql_query("SELECT * FROM private_messages WHERE userid=".$logged_in_user->id." ORDER BY date DESC");
|
|
if (mysql_num_rows($query) == 0) {
|
|
echo tra("You have no private messages.");
|
|
} else {
|
|
echo "<form name=msg_list action=\"forum_pm.php\" method=\"POST\">\n";
|
|
echo form_tokens($logged_in_user->authenticator);
|
|
start_table();
|
|
echo "<tr><th>".tra("Subject")."</th><th>".tra("Sender and date")."</th><th>".tra("Message")."</th></tr>\n";
|
|
$i = 0;
|
|
while ($row = mysql_fetch_object($query)) {
|
|
$i++;
|
|
$class = ($i%2)? "row0": "row1";
|
|
echo "<tr class=$class>\n";
|
|
$checkbox = "<input type=\"checkbox\" name=\"pm_select[]\" value=\"".$row->id."\">";
|
|
if (!$row->opened) {
|
|
mysql_query("UPDATE private_messages SET opened=1 WHERE id=$row->id");
|
|
}
|
|
echo "<td valign=top> $checkbox $row->subject </td>\n";
|
|
echo "<td valign=top>".user_links(get_user_from_id($row->senderid));
|
|
show_block_link($row->senderid);
|
|
echo "<br>".time_str($row->date)."</td>\n";
|
|
echo "<td valign=top>".output_transform($row->content, $options)."<p>";
|
|
$tokens = url_tokens($logged_in_user->authenticator);
|
|
show_button("forum_pm.php?action=delete&id=$row->id&$tokens", tra("Delete"), "Delete this message");
|
|
show_button("forum_pm.php?action=new&replyto=$row->id", tra("Reply"), "Reply to this message");
|
|
echo "</td></tr>\n";
|
|
}
|
|
echo "
|
|
<tr><td class=shaded>
|
|
<a href=\"javascript:set_all(1)\">Select all</a>
|
|
|
|
|
<a href=\"javascript:set_all(0)\">Unselect all</a>
|
|
</td>
|
|
<td class=shaded colspan=2>
|
|
<input type=\"submit\" name=\"action_select\" value=\"".tra("Delete")."\">
|
|
selected messages
|
|
</td></tr>
|
|
";
|
|
end_table();
|
|
echo "</form>\n";
|
|
}
|
|
}
|
|
|
|
function do_read($logged_in_user) {
|
|
$id = get_int("id");
|
|
$message = mysql_query("SELECT * FROM private_messages WHERE id=".$id." AND userid=".$logged_in_user->id);
|
|
if (mysql_num_rows($message) == 0) {
|
|
error_page(tra("No such message"));
|
|
} else {
|
|
$message = mysql_fetch_object($message);
|
|
page_head(tra("Private messages")." : ".$message->subject);
|
|
pm_header();
|
|
|
|
start_table();
|
|
echo "<tr><th>".tra("Subject")."</th><td>".$message->subject."</td></tr>";
|
|
echo "<tr><th>".tra("Sender")."</th><td>".user_links(get_user_from_id($message->senderid));
|
|
show_block_link($message->senderid);
|
|
echo "</td></tr>";
|
|
echo "<tr><th>".tra("Date")."</th><td>".time_str($message->date)."</td></tr>";
|
|
echo "<tr><th>".tra("Message")."</th><td>".output_transform($message->content, $options)."</td></tr>";
|
|
echo "<tr><td class=\"pm_footer\"></td><td>\n";
|
|
echo "<a href=\"forum_pm.php?action=delete&id=$id\">".tra("Delete")."</a>\n";
|
|
echo " | <a href=\"forum_pm.php?action=new&replyto=$id\">".tra("Reply")."</a>\n";
|
|
echo " | <a href=\"forum_pm.php?action=inbox\">".tra("Inbox")."</a>\n";
|
|
end_table();
|
|
|
|
if ($message->opened == 0) {
|
|
mysql_query("UPDATE private_messages SET opened=1 WHERE id=$id");
|
|
}
|
|
}
|
|
}
|
|
|
|
function do_new($logged_in_user) {
|
|
check_banished(new User($logged_in_user->id));
|
|
pm_create_new();
|
|
}
|
|
|
|
function do_delete($logged_in_user) {
|
|
$id = get_int("id", true);
|
|
if ($id == null) { $id = post_int("id"); }
|
|
check_tokens($logged_in_user->authenticator);
|
|
mysql_query("DELETE FROM private_messages WHERE userid=".$logged_in_user->id." AND id=$id");
|
|
header("Location: forum_pm.php");
|
|
}
|
|
|
|
function do_send($logged_in_user) {
|
|
check_banished(new User($logged_in_user->id));
|
|
check_tokens($logged_in_user->authenticator);
|
|
|
|
$to = stripslashes(post_str("to", true));
|
|
$subject = stripslashes(post_str("subject", true));
|
|
$content = stripslashes(post_str("content", true));
|
|
|
|
if (post_str("preview", true) == tra("Preview")) {
|
|
pm_create_new();
|
|
}
|
|
if (($to == null) || ($subject == null) || ($content == null)) {
|
|
pm_create_new(tra("You need to fill all fields to send a private message"));
|
|
} else {
|
|
akismet_check(new User($logged_in_user->id), $content);
|
|
$to = str_replace(", ", ",", $to); // Filter out spaces after separator
|
|
$users = explode(",", $to);
|
|
|
|
$userlist = array();
|
|
$userids = array(); // To prevent from spamming a single user by adding it multiple times
|
|
|
|
foreach ($users as $username) {
|
|
$user = explode(" ", $username);
|
|
if (is_numeric($user[0])) { // user ID is gived
|
|
$userid = $user[0];
|
|
$user = lookup_user_id($userid);
|
|
if ($user == null) {
|
|
pm_create_new(tra("Could not find user with id %1", $userid));
|
|
}
|
|
} else {
|
|
$user = lookup_user_name($username);
|
|
if ($user == null) {
|
|
pm_create_new(tra("Could not find user with username %1", $username));
|
|
} elseif ($user == -1) { // Non-unique username
|
|
pm_create_new(tra("%1 is not a unique username; you will have to use user ID", $username));
|
|
}
|
|
}
|
|
$ignorelist = mysql_query("SELECT ignorelist FROM forum_preferences WHERE userid=".$user->id);
|
|
$ignorelist = mysql_fetch_object($ignorelist);
|
|
$ignorelist = $ignorelist->ignorelist;
|
|
$ignorelist = explode("|", $ignorelist);
|
|
if (in_array($logged_in_user->id, $ignorelist)) {
|
|
pm_create_new(tra("User %1 (ID: %2) is not accepting private messages from you.", $user->name, $user->id));
|
|
}
|
|
if ($userids[$user->id] == null) {
|
|
$userlist[] = $user;
|
|
$userids[$user->id] = true;
|
|
}
|
|
}
|
|
|
|
foreach ($userlist as $user) {
|
|
check_pm_count($logged_in_user->id);
|
|
pm_send($user, $subject, $content);
|
|
}
|
|
|
|
Header("Location: forum_pm.php?action=inbox&sent=1");
|
|
}
|
|
}
|
|
|
|
function do_block($logged_in_user) {
|
|
$id = get_int("id");
|
|
$user = mysql_query("SELECT name FROM user WHERE id=$id");
|
|
if ($user) {
|
|
$user = mysql_fetch_object($user);
|
|
page_head(tra("Really block %1?", $user->name));
|
|
echo "<div>".tra("Are you really sure you want to block user %1 from sending you private messages?", $user->name)."<br>\n";
|
|
echo tra("Please note that you can only block a limited amount of users.")."</div>\n";
|
|
echo "<div>".tra("Once the user has been blocked you can unblock it using forum preferences page.")."</div>\n";
|
|
|
|
echo "<form action=\"forum_pm.php\" method=\"POST\">\n";
|
|
echo form_tokens($logged_in_user->authenticator);
|
|
echo "<input type=\"hidden\" name=\"action\" value=\"confirmedblock\">\n";
|
|
echo "<input type=\"hidden\" name=\"id\" value=\"$id\">\n";
|
|
echo "<input type=\"submit\" value=\"".tra("Add user to filter")."\">\n";
|
|
echo "<a href=\"forum_pm.php?action=inbox\">".tra("No, cancel")."</a>\n";
|
|
echo "</form>\n";
|
|
} else {
|
|
error_page(tra("No such user"));
|
|
}
|
|
}
|
|
|
|
function do_confirmedblock($logged_in_user) {
|
|
check_tokens($logged_in_user->authenticator);
|
|
$id = post_int("id");
|
|
$user = new User($logged_in_user->id);
|
|
$blocked = new User($id);
|
|
$user->addIgnoredUser($blocked);
|
|
|
|
page_head(tra("User %1 blocked", $blocked->getName()));
|
|
|
|
echo "<div>".tra("User %1 has been blocked from sending you private messages.", $blocked->getName())."\n";
|
|
echo tra("To unblock, visit %1message board preferences%2", "<a href=\"edit_forum_preferences_form.php\">", "</a>")."</div>\n";
|
|
}
|
|
|
|
function do_delete_selected($logged_in_user) {
|
|
check_tokens($logged_in_user->authenticator);
|
|
foreach ($_POST["pm_select"] as $id) {
|
|
$query = mysql_query("SELECT * FROM private_messages WHERE id=".mysql_real_escape_string($id)." AND userid=".$logged_in_user->id);
|
|
if (mysql_num_rows($query) == 1) {
|
|
// User has rights to delete the message
|
|
mysql_query("DELETE FROM private_messages WHERE id=".mysql_real_escape_string($id));
|
|
}
|
|
}
|
|
Header("Location: forum_pm.php?action=inbox&deleted=1");
|
|
}
|
|
|
|
function do_mark_as_read_selected($logged_in_user) {
|
|
check_tokens($logged_in_user->authenticator);
|
|
foreach ($_POST["pm_select"] as $id) {
|
|
$query = mysql_query("SELECT * FROM private_messages WHERE id=".mysql_real_escape_string($id)." AND userid=".$logged_in_user->id);
|
|
if (mysql_num_rows($query) == 1) {
|
|
mysql_query("UPDATE private_messages SET opened=1 WHERE id=".mysql_real_escape_string($id));
|
|
}
|
|
}
|
|
Header("Location: forum_pm.php?action=inbox");
|
|
}
|
|
|
|
function do_mark_as_unread_selected($logged_in_user) {
|
|
check_tokens($logged_in_user->authenticator);
|
|
foreach ($_POST["pm_select"] as $id) {
|
|
$query = mysql_query("SELECT * FROM private_messages WHERE id=".mysql_real_escape_string($id)." AND userid=".$logged_in_user->id);
|
|
if (mysql_num_rows($query) == 1) {
|
|
mysql_query("UPDATE private_messages SET opened=0 WHERE id=".mysql_real_escape_string($id));
|
|
}
|
|
}
|
|
Header("Location: forum_pm.php?action=inbox");
|
|
}
|
|
|
|
if ($action == "inbox") {
|
|
do_inbox($logged_in_user);
|
|
} elseif ($action == "read") {
|
|
do_read($logged_in_user);
|
|
} elseif ($action == "new") {
|
|
do_new($logged_in_user);
|
|
} elseif ($action == "delete") {
|
|
do_delete($logged_in_user);
|
|
} elseif ($action == "send") {
|
|
do_send($logged_in_user);
|
|
} elseif ($action == "block") {
|
|
do_block($logged_in_user);
|
|
} elseif ($action == "confirmedblock") {
|
|
do_confirmedblock($logged_in_user);
|
|
} elseif ($action == "select_".tra("Delete")) {
|
|
do_delete_selected($logged_in_user);
|
|
} elseif ($action == "select_".tra("Mark as read")) {
|
|
do_mark_as_read_selected($logged_in_user);
|
|
} elseif ($action == "select_".tra("Mark as unread")) {
|
|
do_mark_as_unread_selected($logged_in_user);
|
|
} else {
|
|
error_page("Unknown action");
|
|
}
|
|
|
|
page_tail();
|
|
|
|
?>
|