1
0
mirror of https://github.com/e107inc/e107.git synced 2025-01-18 05:09:05 +01:00

218 lines
6.8 KiB
PHP

<?php
/*
+ ----------------------------------------------------------------------------+
| e107 website system
|
| ©Steve Dunstan 2001-2002
| http://e107.org
| jalist@e107.org
|
| Released under the terms and conditions of the
| GNU General Public License (http://gnu.org).
|
| $Source: /cvs_backup/e107_0.8/e107_handlers/mail.php,v $
| $Revision: 1.7 $
| $Date: 2007-04-15 22:12:44 $
| $Author: e107coders $
+----------------------------------------------------------------------------+
*/
if (!defined('e107_INIT')) { exit; }
if(is_readable(THEME."email_template.php"))
{
require(THEME."email_template.php");
}
else
{
require(e_THEME."templates/email_template.php");
}
if(isset($EMAIL_HEADER) && isset($EMAIL_FOOTER) && is_object($tp)){
$EMAIL_HEADER = $tp->parseTemplate($EMAIL_HEADER);
$EMAIL_FOOTER = $tp->parseTemplate($EMAIL_FOOTER);
}
/*
Please note that mailed attachments have been found to be corrupted using php 4.3.3
php 4.3.6 does NOT have this problem.
*/
// Comment out the line below if you have trouble with some people not receiving emails.
// e107_ini_set(sendmail_path, "/usr/sbin/sendmail -t -f ".$pref['siteadminemail']);
function sendemail($send_to, $subject, $message, $to_name, $send_from, $from_name, $attachments='', $Cc='', $Bcc='', $returnpath='', $returnreceipt='',$inline ="") {
global $pref,$mailheader_e107id,$tp;
require_once(e_HANDLER."phpmailer/class.phpmailer.php");
$mail = new PHPMailer();
// ----- Mail pref. template override for parked domains, site mirrors or dynamic values
global $EMAIL_METHOD, $EMAIL_SMTP_SERVER, $EMAIL_SMTP_USER, $EMAIL_SMTP_PASS, $EMAIL_SENDMAIL_PATH, $EMAIL_FROM, $EMAIL_FROM_NAME, $EMAIL_POP3AUTH,$EMAIL_DEBUG,$EMAIL_RETURN;
if($EMAIL_METHOD){ $pref['mailer'] = $EMAIL_METHOD; }
if($EMAIL_SMTP_SERVER){ $pref['smtp_server'] = $EMAIL_SMTP_SERVER; }
if($EMAIL_SMTP_USER){ $pref['smtp_username'] = $EMAIL_SMTP_USER; }
if($EMAIL_SMTP_PASS){ $pref['smtp_password'] = $EMAIL_SMTP_PASS; }
if($EMAIL_SENDMAIL_PATH){ $pref['sendmail'] = $EMAIL_SENDMAIL_PATH; }
if($EMAIL_FROM){ $pref['siteadminemail'] = $EMAIL_FROM; }
if($EMAIL_FROM_NAME){ $pref['siteadmin'] = $EMAIL_FROM_NAME; }
if($EMAIL_POP3AUTH){ $pref['smtp_pop3auth'] = TRUE; }
if($EMAIL_RETURN){ $returnpath = $EMAIL_RETURN; }
if($EMAIL_DEBUG){
$mail->SMTPDebug = TRUE;
}
// -------------------------------------------------------------------------
if($mailheader_e107id){
$mail->AddCustomHeader("X-e107-id: {$mailheader_e107id}");
}
if ($pref['mailer']== 'smtp') {
if(isset($pref['smtp_pop3auth']) && $pref['smtp_pop3auth']){
// http://www.corephp.co.uk/archives/18-POP-before-SMTP-Authentication-for-PHPMailer.html
require_once(e_HANDLER."phpmailer/class.pop3.php");
$pop = new POP3();
$pop->Authorise($pref['smtp_server'], 110, 30, $pref['smtp_username'], $pref['smtp_password'], 1);
}
$mail->Mailer = "smtp";
$mail->SMTPKeepAlive = FALSE;
$mail->Host = $pref['smtp_server'];
if($pref['smtp_username'] && $pref['smtp_password']){
$mail->SMTPAuth = (isset($pref['smtp_pop3auth']) && $pref['smtp_pop3auth']) ? FALSE : TRUE;
$mail->Username = $pref['smtp_username'];
$mail->Password = $pref['smtp_password'];
$mail->PluginDir = e_HANDLER."phpmailer/";
}
} elseif ($pref['mailer']== 'sendmail'){
$mail->Mailer = "sendmail";
$mail->Sendmail = ($pref['sendmail']) ? $pref['sendmail'] : "/usr/sbin/sendmail -t -i -r ".$pref['siteadminemail'];
} else {
$mail->Mailer = "mail";
}
$to_name = ($to_name) ? $to_name: $send_to;
$mail->CharSet = CHARSET;
$mail->From = ($send_from)? $send_from: $tp->toEmail($pref['siteadminemail'],"","parse_sc, no_make_clickable, defs");
$mail->FromName = ($from_name)? $from_name: $tp->toEmail($pref['siteadmin'],"","parse_sc, no_make_clickable, defs");
$mail->Subject = $subject;
$mail->SetLanguage("en",e_HANDLER."phpmailer/language/");
$lb = "\n";
// Clean up the HTML. ==
if (preg_match('/<(font|br|a|img|b)/i', $message)) {
$Html = $message; // Assume html if it begins with one of these tags
} else {
$Html = htmlspecialchars($message);
$Html = preg_replace('%(http|ftp|https)(://\S+)%', '<a href="\1\2">\1\2</a>', $Html);
$Html = preg_replace('/([[:space:]()[{}])(www.[-a-zA-Z0-9@:%_\+.~#?&\/\/=]+)/i', '\\1<a href="http://\\2">\\2</a>', $Html);
$Html = preg_replace('/([_\.0-9a-z-]+@([0-9a-z][0-9a-z-]+\.)+[a-z]{2,3})/i', '<a href="mailto:\\1">\\1</a>', $Html);
$Html = str_replace("\r","\n",$Html); // Handle alternative newline characters
$Html = str_replace("\n", "<br />\n", $Html);
}
if (strpos($message,"</style>") !== FALSE){
$text = strstr($message,"</style>");
}else{
$text = $message;
}
$text = str_replace("<br />", "\n", $text);
$text = strip_tags(str_replace("<br>", "\n", $text));
$mail->Body = $Html; //Main message is HTML
$mail->IsHTML(TRUE);
$mail->AltBody = $text; //Include regular plaintext as well
$tmp = explode(",",$send_to);
foreach($tmp as $adr){
$mail->AddAddress($adr, $to_name);
}
if ($attachments){
if (is_array($attachments)) {
foreach($attachments as $attach){
if(is_readable($attach)){
$mail->AddAttachment($attach, basename($attach),"base64",mime_content_type($attach));
}
}
}else{
if(is_readable($attachments)){
$mail->AddAttachment($attachments, basename($attachments),"base64",mime_content_type($attachments));
}
}
}
if($inline){
$tmp = explode(",",$inline);
foreach($tmp as $inline_img){
if(is_readable($inline_img) && !is_dir($inline_img)){
$mail->AddEmbeddedImage($inline_img, md5($inline_img), basename($inline_img),"base64",mime_content_type($inline_img));
}
}
}
if($Cc){
if($mail->Mailer == "mail"){
$mail->AddCustomHeader("Cc: {$Cc}");
}else{
$tmp = explode(",",$Cc);
foreach($tmp as $addc){
$mail->AddCC($addc);
}
}
}
if($Bcc){
if($mail->Mailer == "mail"){
$mail->AddCustomHeader("Bcc: {$Bcc}");
}else{
$tmp = explode(",",$Bcc);
foreach($tmp as $addbc){
$mail->AddBCC($addbc);
}
}
}
if (isset($returnpath) && ($returnpath != ""))
{ // Passed parameter overrides any system default
$mail->Sender = $returnpath;
}
elseif($pref['mail_bounce_email'] !=''){
$mail->Sender = $pref['mail_bounce_email'];
}
if (!$mail->Send()) {
// echo "There has been a mail error sending to " . $row["email"] . "<br>";
return FALSE;
// Clear all addresses and attachments for next loop
$mail->ClearAddresses();
$mail->ClearAttachments();
} else {
// Clear all addresses and attachments for next loop
$mail->ClearAddresses();
$mail->ClearAttachments();
return TRUE;
}
}
/* Deprecated.
Use mail_validation_class.php instead.
function validatemail($Email) {
}
*/
?>