\n"; $imapConnection = sqimap_login($username, $key, $imapServerAddress, 0); displayPageHeader($color, "None"); // This function is used when not sending or adding attachments function newMail () { global $forward_id, $imapConnection, $msg, $ent_num, $body_ary, $body, $reply_id, $send_to, $send_to_cc, $mailbox; $send_to = decodeHeader($send_to); $send_to_cc = decodeHeader($send_to_cc); if ($forward_id) { sqimap_mailbox_select($imapConnection, $mailbox); $msg = sqimap_get_message($imapConnection, $forward_id, $mailbox); if (containsType($msg, "text", "html", $ent_num)) { $body = decodeBody($msg["ENTITIES"][$ent_num]["BODY"], $msg["ENTITIES"][$ent_num]["ENCODING"]); } else if (containsType($msg, "text", "plain", $ent_num)) { $body = decodeBody($msg["ENTITIES"][$ent_num]["BODY"], $msg["ENTITIES"][$ent_num]["ENCODING"]); } // add other primary displaying msg types here else { // find any type that's displayable if (containsType($msg, "text", "any_type", $ent_num)) { $body = decodeBody($msg["ENTITIES"][$ent_num]["BODY"], $msg["ENTITIES"][$ent_num]["ENCODING"]); } else if (containsType($msg, "msg", "any_type", $ent_num)) { $body = decodeBody($msg["ENTITIES"][$ent_num]["BODY"], $msg["ENTITIES"][$ent_num]["ENCODING"]); } else { $body = _("No Message"); } } $type1 = $msg["ENTITIES"][$ent_num]["TYPE1"]; $tmp = _("-------- Original Message ---------\n"); $body_ary = explode("\n", $body); $body = ""; for ($i=0;$i < count($body_ary);$i++) { if ($type1 == "html") $tmp .= strip_tags($body_ary[$i]); else $tmp .= $body_ary[$i]; $body = "$body$tmp\n"; $tmp = ""; } } if ($reply_id) { sqimap_mailbox_select($imapConnection, $mailbox); $msg = sqimap_get_message($imapConnection, $reply_id, $mailbox); if (containsType($msg, "text", "html", $ent_num)) { $body = decodeBody($msg["ENTITIES"][$ent_num]["BODY"], $msg["ENTITIES"][$ent_num]["ENCODING"], false); } else if (containsType($msg, "text", "plain", $ent_num)) { $body = decodeBody($msg["ENTITIES"][$ent_num]["BODY"], $msg["ENTITIES"][$ent_num]["ENCODING"], false); } // add other primary displaying msg types here else { // find any type that's displayable if (containsType($msg, "text", "any_type", $ent_num)) { $body = decodeBody($msg["ENTITIES"][$ent_num]["BODY"], $msg["ENTITIES"][$ent_num]["ENCODING"], false); } else if (containsType($msg, "msg", "any_type", $ent_num)) { $body = decodeBody($msg["ENTITIES"][$ent_num]["BODY"], $msg["ENTITIES"][$ent_num]["ENCODING"], false); } else { $body = _("No Message"); } } $type1 = $msg["ENTITIES"][$ent_num]["TYPE1"]; $body_ary = explode("\n", $body); $body = ""; for ($i=0;$i < count($body_ary);$i++) { if ($type1 == "html") $tmp = strip_tags($body_ary[$i]); else $tmp = $body_ary[$i]; $body = "$body> $tmp\n"; } } $send_to = sqimap_find_email($send_to); $send_to = ereg_replace("\"", "", $send_to); $send_to = stripslashes($send_to); /** This formats a CC string if they hit "reply all" **/ if ($send_to_cc != "") { $send_to_cc = ereg_replace(";", ",", $send_to_cc); $sendcc = explode(",", $send_to_cc); $send_to_cc = ""; for ($i = 0; $i < count($sendcc); $i++) { $sendcc[$i] = trim($sendcc[$i]); if ($sendcc[$i] == "") continue; $sendcc[$i] = sqimap_find_email($sendcc[$i]); $whofrom = sqimap_find_displayable_name($msg["HEADER"]["FROM"]); $whoreplyto = sqimap_find_email($msg["HEADER"]["REPLYTO"]); if ((strtolower(trim($sendcc[$i])) != strtolower(trim($whofrom))) && (strtolower(trim($sendcc[$i])) != strtolower(trim($whoreplyto))) && (trim($sendcc[$i]) != "")) { $send_to_cc .= trim($sendcc[$i]) . ", "; } } $send_to_cc = trim($send_to_cc); if (substr($send_to_cc, -1) == ",") { $send_to_cc = substr($send_to_cc, 0, strlen($send_to_cc) - 1); } } } // function newMail() function showInputForm () { global $send_to, $send_to_cc, $reply_subj, $forward_subj, $body, $passed_body, $color, $use_signature, $signature, $editor_size, $attachments, $subject, $newmail; $subject = decodeHeader($subject); $reply_subj = decodeHeader($reply_subj); $forward_subj = decodeHeader($forward_subj); echo "\n
\n"; echo "\n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; // This code is for attachments echo " \n"; echo " \n"; echo " \n"; echo " \n"; if (isset($attachments) && count($attachments)>0) { echo ""; } // End of attachment code echo "
\n"; echo " "; echo _("To:"); echo " \n"; echo " \n"; if ($send_to) echo "
"; else echo "
"; echo "
\n"; echo " "._("CC").":\n"; echo " \n"; if ($send_to_cc) echo "
"; else echo "
"; echo "
\n"; echo " BCC:\n"; echo " \n"; if ($send_to_bcc) echo "
"; else echo "
"; echo "
\n"; echo " "; echo _("Subject:"); echo " \n"; echo " \n"; if ($reply_subj) { $reply_subj = str_replace("\"", "'", $reply_subj); $reply_subj = stripslashes($reply_subj); $reply_subj = trim($reply_subj); if (substr(strtolower($reply_subj), 0, 3) != "re:") $reply_subj = "Re: $reply_subj"; echo " "; } else if ($forward_subj) { $forward_subj = str_replace("\"", "'", $forward_subj); $forward_subj = stripslashes($forward_subj); $forward_subj = trim($forward_subj); if ((substr(strtolower($forward_subj), 0, 4) != "fwd:") && (substr(strtolower($forward_subj), 0, 5) != "[fwd:") && (substr(strtolower($forward_subj), 0, 6) != "[ fwd:")) $forward_subj = "[Fwd: $forward_subj]"; echo " "; } else { echo " "; } echo "  "; echo "
\n"; if ($use_signature == true && $newmail == true) echo "   
"; else echo "   
\n"; echo "
\n"; echo " "; echo "
"._("Attach:")."
\n"; echo "
\n"; // echo " \n"; echo " \n"; echo "   \n"; echo "
\n"; echo " "; echo ""; while (list($localname, $remotename) = each($attachments)) { echo "\n"; echo "$remotename
\n"; } echo "\n"; echo "
\n"; echo "
"; } function showSentForm () { echo ""; echo "


Message Sent!

"; echo "You will be automatically forwarded.
If not, click here"; echo "
"; } function checkInput () { global $body, $send_to, $subject; if ($body == "") { plain_error_message(_("You have not entered a message body."), $color); return false; } else if ($send_to == "") { displayPageHeader($color, "None"); plain_error_message(_("You have not filled in the \"To:\" field."), $color); return false; } else if ($subject == "") { plain_error_message(_("You have not entered a subject."), $color); return false; } return true; } // function checkInput() if(isset($send)) { if (checkInput()) { sendMessage($send_to, $send_to_cc, $send_to_bcc, $subject, $body); showSentForm(); } else { showInputForm(); } } else if (isset($attach)) { $localfilename = md5("$attachfile, $attachfile_name, $REMOTE_IP, $REMOTE_PORT, $UNIQUE_ID, and everything else that may add entropy"); $localfilename = $localfilename; // Put the file in a better place error_reporting(0); // Rename will produce error output if it fails if (!rename($attachfile, $attachment_dir.$localfilename)) { if (!copy($attachfile, $attachment_dir.$localfilename)) { plain_error_message(_("Could not move/copy file. File not attached")); $failed = true; } } // If it still exists, PHP will remove the original file if (!$failed) { // Write information about the file $fp = fopen ($attachment_dir.$localfilename.".info", "w"); fputs ($fp, "$attachfile_type\n$attachfile_name\n"); fclose ($fp); $attachments[$localfilename] = $attachfile_name; } showInputForm(); } else if (isset($do_delete)) { while (list($key, $localname) = each($delete)) { array_splice ($attachments, $key, 1); unlink ($attachment_dir.$localname); unlink ($attachment_dir.$localname.".info"); } showInputForm(); } else { $newmail = true; newMail(); showInputForm(); } ?>