\n"; if (mysql_num_rows($messagequery) == 0) { $row["messages"] .= "You do not have any messages."; } elseif (mysql_num_rows($messagequery) == 1) { if ($messages["status"] == 0) { $messages["new"] = "*"; } else { $messages["new"] = ""; } if ($messages["gold"] != 0) { $messages["money"] = "\$"; } else { $messages["money"] = ""; } $row["messages"] .= parsetemplate(gettemplate("mailbox_listrow"), $messages); } else { foreach($messages as $a=>$b) { if ($b["status"] == 0) { $b["new"] = "*"; } else { $b["new"] = ""; } if ($b["gold"] != 0) { $b["money"] = "\$"; } else { $b["money"] = ""; } $row["messages"] .= parsetemplate(gettemplate("mailbox_listrow"), $b); } } $row["messages"] .= "
\n"; display("Post Office", parsetemplate(gettemplate("mailbox_list"), $row)); } function outbox() { global $userrow; $messagequery = doquery("SELECT *, DATE_FORMAT(postdate, '%m.%d.%Y ~ %H:%i') AS fpostdate FROM {{table}} WHERE senderid='".$userrow["id"]."' ORDER BY postdate DESC", "messages"); $messages = dorow($messagequery); $row["messages"] = "\n"; if (mysql_num_rows($messagequery) == 0) { $row["messages"] .= ""; } elseif (mysql_num_rows($messagequery) == 1) { $row["messages"] .= parsetemplate(gettemplate("mailbox_listoutrow"), $messages); } else { foreach($messages as $a=>$b) { $row["messages"] .= parsetemplate(gettemplate("mailbox_listoutrow"), $b); } } $row["messages"] .= "
You do not have any sent messages.

\n"; display("Post Office", parsetemplate(gettemplate("mailbox_listout"), $row)); } function letter() { global $userrow; if (!is_numeric($_GET["id"])) { err("Invalid action. Please go back and try again."); } $message = dorow(doquery("SELECT *, DATE_FORMAT(postdate, '%m.%d.%Y ~ %H:%i') AS fpostdate FROM {{table}} WHERE id='".$_GET["id"]."' LIMIT 1", "messages")); if ($message == false) { err("Invalid action. Please go back and try again."); } if ($message["recipientid"] != $userrow["id"]) { err("Invalid action. Please go back and try again."); } // Handle money transfers. $message["moneytransfer"] = ""; if ($message["gold"] != 0) { $userrow["gold"] += $message["gold"]; $message["moneytransfer"] = "You have received ".$message["gold"]." Gold with this message.
"; updateuserrow(); } // Reset status to old, and gold to zero, so they can't keep reading the message to get more money. if ($message["status"] == 0) { $statusquery = doquery("UPDATE {{table}} SET status='1', gold='0' WHERE id='".$_GET["id"]."' LIMIT 1", "messages"); } // Pull the sender's userrow so we can show avatars. $sender = dorow(doquery("SELECT * FROM {{table}} WHERE id='".$message["senderid"]."' LIMIT 1", "users")); if ($sender["charpicture"] != "") { $message["senderavatar"] = "\"".$sender["charname"]."\""; } else { $message["senderavatar"] = "\"".$sender["charname"]."\""; } $message["message"] = nl2br($message["message"]); display("Post Office", parsetemplate(gettemplate("mailbox_letter"), $message)); } function letterout() { global $userrow; if (!is_numeric($_GET["id"])) { err("Invalid action. Please go back and try again."); } $message = dorow(doquery("SELECT *, DATE_FORMAT(postdate, '%m.%d.%Y ~ %H:%i') AS fpostdate FROM {{table}} WHERE id='".$_GET["id"]."' LIMIT 1", "messages")); if ($message == false) { err("Invalid action. Please go back and try again."); } if ($message["senderid"] != $userrow["id"]) { err("Invalid action. Please go back and try again."); } $message["message"] = nl2br($message["message"]); display("Post Office", parsetemplate(gettemplate("mailbox_letterout"), $message)); } function mailnew() { global $userrow; if (isset($_POST["submit"])) { // Check for errors. extract($_POST); $errors = 0; $errorlist = ""; if ($userrow["gold"] < 5) { $errors++; $errorlist .= "You do not have enough gold to cover the postage fee.
"; } $checkuser = dorow(doquery("SELECT * FROM {{table}} WHERE charname='$recipient' LIMIT 1", "users")); if ($checkuser == false) { $errors++; $errorlist .= "There is no player with that Character Name.
"; } if (trim($gold) != "") { if (!is_numeric($gold)) { $errors++; $errorlist .= "The Send Gold field must be a number.
"; } if ($gold < 1) { $errors++; $errorlist .= "Money Transfer amount must be greater than 0.
"; } if ($userrow["gold"] < $gold + 5) { $errors++; $errorlist .= "You don't have that much gold to send.
"; } if ($userrow["account"] == $checkuser["account"] && $gold >= ($userrow["gold"] / 10)) { $errors++; $errorlist .= "You are only allowed to send up to 10% of your gold to another character on your account.
"; } } if ($recipient == $userrow["charname"]) { $errors++; $errorlist .= "You cannot send a message to yourself. That would be a waste of 5 gold, dummy!"; } if (trim($title) == "") { $errors++; $errorlist .= "You must enter a Subject.
"; } if ($errors == 0) { // Subtract gold. $userrow["gold"] -= 5; if (trim($gold) != "") { $userrow["gold"] -= $gold; } updateuserrow(); // And send the message. $send = doquery("INSERT INTO {{table}} SET id='', postdate=NOW(), senderid='".$userrow["id"]."', sendername='".$userrow["charname"]."', recipientid='".$checkuser["id"]."', recipientname='$recipient', status='0', title='$title', message='$message', gold='$gold'", "messages"); display("Post Office", gettemplate("mailbox_sent")); } else { // Die gracefully on errors. err("The following error(s) occurred when trying to send your letter:
$errorlist
Please go back and try again."); } } display("Post Office", gettemplate("mailbox_new")); } function mailreply() { global $userrow; if (!is_numeric($_GET["id"])) { err("Invalid action. Please go back and try again."); } $origmessage = dorow(doquery("SELECT *, DATE_FORMAT(postdate, '%m.%d.%Y ~ %H:%i') AS fpostdate FROM {{table}} WHERE id='".$_GET["id"]."' LIMIT 1", "messages")); if ($origmessage == false) { err("Invalid action. Please go back and try again."); } if ($origmessage["recipientid"] != $userrow["id"]) { err("Invalid action. Please go back and try again."); } if (isset($_POST["submit"])) { // Check for errors. extract($_POST); $errors = 0; $errorlist = ""; if ($userrow["gold"] < 5) { $errors++; $errorlist .= "You do not have enough gold to cover the postage fee.
"; } $checkuser = dorow(doquery("SELECT * FROM {{table}} WHERE charname='".$origmessage["sendername"]."' LIMIT 1", "users")); if ($checkuser == false) { $errors++; $errorlist .= "There is no player with that Character Name.
"; } if (trim($gold) != "") { if (!is_numeric($gold)) { $errors++; $errorlist .= "The Send Gold field must be a number.
"; } if ($gold < 1) { $errors++; $errorlist .= "Money Transfer amount must be greater than 0.
"; } if ($userrow["gold"] < $gold + 5) { $errors++; $errorlist .= "You don't have that much gold to send.
"; } if ($userrow["account"] == $checkuser["account"] && $gold >= ($userrow["gold"] / 10)) { $errors++; $errorlist .= "You are only allowed to send up to 10% of your gold to another character on your account.
"; } } if (trim($title) == "") { $errors++; $errorlist .= "You must enter a Subject.
"; } if ($errors == 0) { // Subtract gold. $userrow["gold"] -= 5; if (trim($gold) != "") { $userrow["gold"] -= $gold; } updateuserrow(); // And send the message. $send = doquery("INSERT INTO {{table}} SET id='', postdate=NOW(), senderid='".$userrow["id"]."', sendername='".$userrow["charname"]."', recipientid='".$origmessage["senderid"]."', recipientname='".$origmessage["sendername"]."', status='0', title='$title', message='$message', gold='$gold'", "messages"); display("Post Office", gettemplate("mailbox_sent")); } else { // Die gracefully on errors. err("The following error(s) occurred when trying to send your letter:
$errorlist
Please go back and try again."); } } $origmessage["message"] = nl2br($origmessage["message"]); display("Post Office", parsetemplate(gettemplate("mailbox_reply"), $origmessage)); } function maildelete() { global $userrow; if (!is_numeric($_GET["id"])) { err("Invalid action. Please go back and try again."); } $message = dorow(doquery("SELECT *, DATE_FORMAT(postdate, '%m.%d.%Y ~ %H:%i') AS fpostdate FROM {{table}} WHERE id='".$_GET["id"]."' LIMIT 1", "messages")); if ($message == false) { err("Invalid action. Please go back and try again."); } if ($message["recipientid"] != $userrow["id"]) { err("Invalid action. Please go back and try again."); } $delete = doquery("DELETE FROM {{table}} WHERE id='".$_GET["id"]."'", "messages"); die(header("Location: index.php?do=mailbox")); } ?>