.
require_once("../inc/boinc_db.inc");
require_once("../inc/email.inc");
require_once("../inc/pm.inc");
require_once("../inc/forum.inc");
require_once("../inc/akismet.inc");
check_get_args(array("replyto", "deleted", "userid", "action", "sent", "id", "tnow", "ttok", "teamid"));
function show_block_link($userid) {
echo " ";
show_image(REPORT_POST_IMAGE, tra("Block messages from this user"), tra("Block user"), REPORT_POST_IMAGE_HEIGHT);
echo "";
}
$logged_in_user = get_logged_in_user();
BoincForumPrefs::lookup($logged_in_user);
function make_script() {
echo "
";
}
// show all private messages,
// and delete notifications of new messages
//
function do_inbox($logged_in_user) {
page_head(tra("Private messages").": ".tra("Inbox"));
make_script();
if (get_int("sent", true) == 1) {
echo "
| \n";
echo "".tra("Reply")."\n";
echo " · ".tra("Delete")."\n";
echo " · ".tra("Inbox")."\n";
end_table();
if ($message->opened == 0) {
$message->update("opened=1");
}
page_tail();
}
function do_new($logged_in_user) {
global $replyto, $userid;
check_banished($logged_in_user);
pm_form($replyto, $userid);
}
function do_delete($logged_in_user) {
$id = get_int("id", true);
if ($id == null) {
$id = post_int("id");
}
check_tokens($logged_in_user->authenticator);
BoincPrivateMessage::delete_aux("userid=".$logged_in_user->id." AND id=$id");
header("Location: pm.php");
}
function do_send_team($logged_in_user) {
check_tokens($logged_in_user->authenticator);
$subject = post_str("subject", true);
$content = post_str("content", true);
$teamid = post_int("teamid");
if (post_str("preview", true) == tra("Preview")) {
pm_team_form($logged_in_user, $teamid);
return;
}
// make sure user is authorized, i.e. is a team admin
//
$team = BoincTeam::lookup_id($teamid);
if (!$team) {
error_page("no such team");
}
if (!is_team_admin($logged_in_user, $team)) {
error_page("no team admin");
}
if (($subject == null) || ($content == null)) {
pm_team_form(
$logged_in_user, $teamid,
tra("You need to fill all fields to send a private message")
);
return;
}
$subject = "Message from team ".$team->name.": ".$subject;
// don't use tra() here because we don't know language of recipient
// Also, we use it in pm_count() to exclude team messages from limit check
$users = BoincUser::enum("teamid=$teamid");
foreach ($users as $user) {
pm_send_msg($logged_in_user, $user, $subject, $content, true);
}
page_head(tra("Message sent"));
echo tra("Your message was sent to %1 team members.", count($users));
page_tail();
}
function do_send($logged_in_user) {
global $replyto, $userid;
check_banished($logged_in_user);
check_tokens($logged_in_user->authenticator);
$to = sanitize_tags(post_str("to", true));
$subject = post_str("subject", true);
$content = post_str("content", true);
if (post_str("preview", true) == tra("Preview")) {
pm_form($replyto, $userid);
}
if (($to == null) || ($subject == null) || ($content == null)) {
pm_form($replyto, $userid, tra("You need to fill all fields to send a private message"));
return;
}
if (!akismet_check($logged_in_user, $content)) {
pm_form($replyto, $userid, tra("Your message was flagged as spam
by the Akismet anti-spam system.
Please modify your text and try again.")
);
}
$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 given
$userid = $user[0];
$user = BoincUser::lookup_id($userid);
if ($user == null) {
pm_form($replyto, $userid, tra("Could not find user with id %1", $userid));
}
} else {
$users = BoincUser::lookup_name($username);
if (count($users) == 0) {
pm_form($replyto, $userid, tra("Could not find user with username %1", $username));
} elseif (count($users) > 1) { // Non-unique username
pm_form($replyto, $userid, tra("%1 is not a unique username; you will have to use user ID", $username));
}
$user = $users[0];
}
BoincForumPrefs::lookup($user);
if (is_ignoring($user, $logged_in_user)) {
pm_form($replyto, $userid, tra("User %1 (ID: %2) is not accepting private messages from you.", $user->name, $user->id));
}
if (!isset($userids[$user->id])) {
$userlist[] = $user;
$userids[$user->id] = true;
}
}
foreach ($userlist as $user) {
if (!is_moderator($logged_in_user, null)) {
check_pm_count($logged_in_user->id);
}
pm_send_msg($logged_in_user, $user, $subject, $content, true);
}
Header("Location: pm.php?action=inbox&sent=1");
}
function do_block($logged_in_user) {
$id = get_int("id");
$user = BoincUser::lookup_id($id);
if (!$user) {
error_page(tra("No such user"));
}
page_head(tra("Really block %1?", $user->name));
echo " ".tra("Are you really sure you want to block user %1 from sending you private messages?", $user->name)." \n";
echo tra("Please note that you can only block a limited amount of users.")." \n";
echo "".tra("Once the user has been blocked you can unblock it using forum preferences page.")." \n";
echo "\n";
page_tail();
}
function do_confirmedblock($logged_in_user) {
check_tokens($logged_in_user->authenticator);
$id = post_int("id");
$blocked_user = BoincUser::lookup_id($id);
if (!$blocked_user) error_page(tra("no such user"));
add_ignored_user($logged_in_user, $blocked_user);
page_head(tra("User %1 blocked", $blocked_user->name));
echo "".tra("User %1 has been blocked from sending you private messages.", $blocked_user->name)."\n";
echo tra("To unblock, visit %1 message board preferences %2", " ", "")." \n";
page_tail();
}
function do_delete_selected($logged_in_user) {
check_tokens($logged_in_user->authenticator);
$msgs = BoincPrivateMessage::enum(
"userid=$logged_in_user->id"
);
foreach($msgs as $msg) {
$x = "pm_select_$msg->id";
if (post_str($x, true)) {
$msg = BoincPrivateMessage::lookup_id($msg->id);
$msg->delete();
}
}
Header("Location: pm.php?action=inbox&deleted=1");
}
$replyto = get_int("replyto", true);
$userid = get_int("userid", true);
$teamid = get_int("teamid", true);
if (!$teamid) {
$teamid = post_int("teamid", true);
}
$action = sanitize_tags(get_str("action", true));
if (!$action) {
$action = sanitize_tags(post_str("action", true));
}
if (!$action) {
$action = "inbox";
}
if ($action == "inbox") {
do_inbox($logged_in_user);
} elseif ($action == "read") {
do_read($logged_in_user);
} elseif ($action == "new") {
if (!$teamid) $teamid = post_int("teamid", true);
if ($teamid) {
pm_team_form($logged_in_user, $teamid);
} else {
do_new($logged_in_user);
}
} elseif ($action == "delete") {
do_delete($logged_in_user);
} elseif ($action == "send") {
if ($teamid) {
do_send_team($logged_in_user);
} else {
do_send($logged_in_user);
}
} elseif ($action == "block") {
do_block($logged_in_user);
} elseif ($action == "confirmedblock") {
do_confirmedblock($logged_in_user);
} elseif ($action == "delete_selected") {
do_delete_selected($logged_in_user);
} else {
error_page(tra("Unknown action"));
}
$cvs_version_tracker[]="\$Id: pm.php 14077 2007-11-03 04:26:47Z davea $";
?>
|