Упрощение emailer (удаление неиспользуемых функций прикрепления файлов к письму) с некоторыми заделами на будущее. git-svn-id: https://torrentpier2.googlecode.com/svn/trunk@545 a8ac35ab-4ca4-ca47-4c2d-a49a94f06293
This commit is contained in:
glix08 2013-08-09 21:18:05 +00:00
commit b0eadd11b0
2 changed files with 53 additions and 144 deletions

View file

@ -56,7 +56,7 @@ $domain_name = (!empty($_SERVER['SERVER_NAME'])) ? $_SERVER['SERVER_NAME'] : $do
// Increase number of revision after update // Increase number of revision after update
$bb_cfg['tp_version'] = '2.5 (unstable)'; $bb_cfg['tp_version'] = '2.5 (unstable)';
$bb_cfg['tp_release_date'] = '10-08-2013'; $bb_cfg['tp_release_date'] = '10-08-2013';
$bb_cfg['tp_release_state'] = 'R544'; $bb_cfg['tp_release_state'] = 'R545';
// Database // Database
$charset = 'utf8'; $charset = 'utf8';
@ -306,9 +306,19 @@ $bb_cfg['new_user_reg_restricted'] = false;
// Email // Email
$bb_cfg['emailer_disabled'] = false; $bb_cfg['emailer_disabled'] = false;
$bb_cfg['smtp_host'] = '';
$bb_cfg['smtp_password'] = '';
$bb_cfg['smtp_username'] = '';
$bb_cfg['board_email'] = 'admin@' . $domain_name;
$bb_cfg['board_email_sig'] = '';
$bb_cfg['sitename'] = $domain_name;
$bb_cfg['topic_notify_enabled'] = true; $bb_cfg['topic_notify_enabled'] = true;
$bb_cfg['pm_notify_enabled'] = true; $bb_cfg['pm_notify_enabled'] = true;
$bb_cfg['groupcp_send_email'] = true; $bb_cfg['groupcp_send_email'] = true;
$bb_cfg['email_change_disabled'] = false; // disable changing email by user
$bb_cfg['tech_admin_email'] = 'admin@' . $domain_name; // email for sending error reports $bb_cfg['tech_admin_email'] = 'admin@' . $domain_name; // email for sending error reports
$bb_cfg['abuse_email'] = 'abuse@' . $domain_name; $bb_cfg['abuse_email'] = 'abuse@' . $domain_name;

View file

@ -9,60 +9,80 @@ class emailer
var $use_smtp; var $use_smtp;
var $tpl_msg = array(); var $tpl_msg = array();
var $vars = array();
function emailer($use_smtp) function emailer ($use_smtp/*$tpl_name, $sbj, $to_address*/)
{ {
global $bb_cfg;
$this->reset(); $this->reset();
$this->use_smtp = $use_smtp; $this->from = $bb_cfg['board_email'];
$this->reply_to = $this->from = ''; $this->reply_to = $bb_cfg['board_email'];
$this->use_smtp = $use_smtp; /*!empty($bb_cfg['smtp_host']);
$this->use_template($tpl_name);
$this->set_subject($sbj);
$this->email_address($to_address);*/
}
function set_default_vars ()
{
global $bb_cfg;
$this->vars = array(
'SITENAME' => $bb_cfg['sitename'],
'BOARD_EMAIL' => $bb_cfg['board_email'],
'EMAIL_SIG' => !empty($bb_cfg['board_email_sig']) ? "-- \n{$bb_cfg['board_email_sig']}" : '',
);
} }
// Resets all the data (address, template file, etc etc to default // Resets all the data (address, template file, etc etc to default
function reset() function reset ()
{ {
$this->addresses = array(); $this->addresses = array();
$this->vars = $this->msg = $this->extra_headers = ''; $this->msg = $this->extra_headers = '';
$this->set_default_vars();
} }
// Sets an email address to send to // Sets an email address to send to
function email_address($address) function email_address ($address)
{ {
$this->addresses['to'] = trim($address); $this->addresses['to'] = trim($address);
} }
function cc($address) function cc ($address)
{ {
$this->addresses['cc'][] = trim($address); $this->addresses['cc'][] = trim($address);
} }
function bcc($address) function bcc ($address)
{ {
$this->addresses['bcc'][] = trim($address); $this->addresses['bcc'][] = trim($address);
} }
function replyto($address) function replyto ($address)
{ {
$this->reply_to = trim($address); $this->reply_to = trim($address);
} }
function from($address) function from ($address)
{ {
$this->from = trim($address); $this->from = trim($address);
} }
// set up subject for mail // set up subject for mail
function set_subject($subject = '') function set_subject ($subject = '')
{ {
$this->subject = trim(preg_replace('#[\n\r]+#s', '', $subject)); $this->subject = trim(preg_replace('#[\n\r]+#s', '', $subject));
} }
// set up extra mail headers // set up extra mail headers
function extra_headers($headers) function extra_headers ($headers)
{ {
$this->extra_headers .= trim($headers) . "\n"; $this->extra_headers .= trim($headers) . "\n";
} }
function use_template($template_file, $template_lang = '') function use_template ($template_file, $template_lang = '')
{ {
global $bb_cfg; global $bb_cfg;
@ -105,13 +125,13 @@ class emailer
} }
// assign variables // assign variables
function assign_vars($vars) function assign_vars ($vars)
{ {
$this->vars = (empty($this->vars)) ? $vars : $this->vars . $vars; $this->vars = array_merge($this->vars, $vars);
} }
// Send the mail out to the recipients set previously in var $this->address // Send the mail out to the recipients set previously in var $this->address
function send() function send ()
{ {
global $bb_cfg, $lang; global $bb_cfg, $lang;
@ -120,7 +140,7 @@ class emailer
return; return;
} }
// Escape all quotes, else the eval will fail. // Escape all quotes
$this->msg = str_replace ("'", "\'", $this->msg); $this->msg = str_replace ("'", "\'", $this->msg);
$this->msg = preg_replace('#\{([a-z0-9\-_]*?)\}#is', "' . $\\1 . '", $this->msg); $this->msg = preg_replace('#\{([a-z0-9\-_]*?)\}#is', "' . $\\1 . '", $this->msg);
@ -178,10 +198,10 @@ class emailer
// Build header // Build header
$this->extra_headers = (($this->reply_to != '') ? "Reply-to: $this->reply_to\n" : '') . (($this->from != '') ? "From: $this->from\n" : "From: " . $bb_cfg['board_email'] . "\n") . "Return-Path: " . $bb_cfg['board_email'] . "\nMessage-ID: <" . md5(uniqid(TIMENOW)) . "@" . $bb_cfg['server_name'] . ">\nMIME-Version: 1.0\nContent-type: text/plain; charset=" . $this->encoding . "\nContent-transfer-encoding: 8bit\nDate: " . date('r', TIMENOW) . "\nX-Priority: 0\nX-MSMail-Priority: Normal\nX-Mailer: Microsoft Office Outlook, Build 11.0.5510\nX-MimeOLE: Produced By Microsoft MimeOLE V6.00.2800.1441\nX-Sender: " . $bb_cfg['board_email'] . "\n" . $this->extra_headers . (($cc != '') ? "Cc: $cc\n" : '') . (($bcc != '') ? "Bcc: $bcc\n" : ''); $this->extra_headers = (($this->reply_to != '') ? "Reply-to: $this->reply_to\n" : '') . (($this->from != '') ? "From: $this->from\n" : "From: " . $bb_cfg['board_email'] . "\n") . "Return-Path: " . $bb_cfg['board_email'] . "\nMessage-ID: <" . md5(uniqid(TIMENOW)) . "@" . $bb_cfg['server_name'] . ">\nMIME-Version: 1.0\nContent-type: text/plain; charset=" . $this->encoding . "\nContent-transfer-encoding: 8bit\nDate: " . date('r', TIMENOW) . "\nX-Priority: 0\nX-MSMail-Priority: Normal\nX-Mailer: Microsoft Office Outlook, Build 11.0.5510\nX-MimeOLE: Produced By Microsoft MimeOLE V6.00.2800.1441\nX-Sender: " . $bb_cfg['board_email'] . "\n" . $this->extra_headers . (($cc != '') ? "Cc: $cc\n" : '') . (($bcc != '') ? "Bcc: $bcc\n" : '');
// Send message ... removed $this->encode() from subject for time being // Send message
if ( $this->use_smtp ) if ($this->use_smtp)
{ {
if ( !defined('SMTP_INCLUDED') ) if (!defined('SMTP_INCLUDED'))
{ {
include(INC_DIR .'smtp.php'); include(INC_DIR .'smtp.php');
} }
@ -190,20 +210,9 @@ class emailer
} }
else else
{ {
$empty_to_header = ($to == '') ? TRUE : FALSE; $to = ($to == '') ? ' ' : $to;
$to = ($to == '') ? (($bb_cfg['sendmail_fix']) ? ' ' : 'Undisclosed-recipients:;') : $to;
$result = @mail($to, $this->subject, preg_replace("#(?<!\r)\n#s", "\n", $this->msg), $this->extra_headers); $result = @mail($to, $this->subject, preg_replace("#(?<!\r)\n#s", "\n", $this->msg), $this->extra_headers);
if (!$result && !$bb_cfg['sendmail_fix'] && $empty_to_header)
{
$to = ' ';
bb_update_config(array('sendmail_fix' => 1));
$bb_cfg['sendmail_fix'] = 1;
$result = @mail($to, $this->subject, preg_replace("#(?<!\r)\n#s", "\n", $this->msg), $this->extra_headers);
}
} }
// Did it work? // Did it work?
@ -215,11 +224,7 @@ class emailer
return true; return true;
} }
// Encodes the given string for proper display for this encoding ... nabbed function encode ($str)
// from php.net and modified. There is an alternative encoding method which
// may produce lesd output but it's questionable as to its worth in this
// scenario IMO
function encode($str)
{ {
if ($this->encoding == '') if ($this->encoding == '')
{ {
@ -235,110 +240,4 @@ class emailer
return $start . $str . $end; return $start . $str . $end;
} }
//
// Attach files via MIME.
//
function attachFile($filename, $mimetype = "application/octet-stream", $szFromAddress, $szFilenameToDisplay)
{
global $lang;
$mime_boundary = "--==================_846811060==_";
$this->msg = '--' . $mime_boundary . "\nContent-Type: text/plain;\n\tcharset=\"" . $lang['CONTENT_ENCODING'] . "\"\n\n" . $this->msg;
if ($mime_filename)
{
$filename = $mime_filename;
$encoded = $this->encode_file($filename);
}
$fd = fopen($filename, "r");
$contents = fread($fd, filesize($filename));
$this->mimeOut = "--" . $mime_boundary . "\n";
$this->mimeOut .= "Content-Type: " . $mimetype . ";\n\tname=\"$szFilenameToDisplay\"\n";
$this->mimeOut .= "Content-Transfer-Encoding: quoted-printable\n";
$this->mimeOut .= "Content-Disposition: attachment;\n\tfilename=\"$szFilenameToDisplay\"\n\n";
if ( $mimetype == "message/rfc822" )
{
$this->mimeOut .= "From: ".$szFromAddress."\n";
$this->mimeOut .= "To: ".$this->emailAddress."\n";
$this->mimeOut .= "Date: ".date("D, d M Y H:i:s") . " UT\n";
$this->mimeOut .= "Reply-To:".$szFromAddress."\n";
$this->mimeOut .= "Subject: ".$this->mailSubject."\n";
// $this->mimeOut .= "X-Mailer: PHP/".phpversion()."\n";
$this->mimeOut .= "X-Priority: 0\n";
$this->mimeOut .= "X-Mailer: Microsoft Office Outlook, Build 11.0.5510\n";
$this->mimeOut .= "X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2800.1441\n";
$this->mimeOut .= "X-Sender: " . $bb_cfg['board_email'] . " \n";
$this->mimeOut .= "MIME-Version: 1.0\n";
}
$this->mimeOut .= $contents."\n";
$this->mimeOut .= "--" . $mime_boundary . "--" . "\n";
return $out;
// added -- to notify email client attachment is done
}
function getMimeHeaders($filename, $mime_filename="")
{
$mime_boundary = "--==================_846811060==_";
if ($mime_filename)
{
$filename = $mime_filename;
}
$out = "MIME-Version: 1.0\n";
$out .= "Content-Type: multipart/mixed;\n\tboundary=\"$mime_boundary\"\n\n";
$out .= "This message is in MIME format. Since your mail reader does not understand\n";
$out .= "this format, some or all of this message may not be legible.";
return $out;
}
//
// Split string by RFC 2045 semantics (76 chars per line, end with \r\n).
//
function myChunkSplit($str)
{
$stmp = $str;
$len = strlen($stmp);
$out = "";
while ($len > 0)
{
if ($len >= 76)
{
$out .= substr($stmp, 0, 76) . "\r\n";
$stmp = substr($stmp, 76);
$len = $len - 76;
}
else
{
$out .= $stmp . "\r\n";
$stmp = "";
$len = 0;
}
}
return $out;
}
//
// Split the specified file up into a string and return it
//
function encode_file($sourcefile)
{
if (is_readable(phpbb_realpath($sourcefile)))
{
$fd = fopen($sourcefile, "r");
$contents = fread($fd, filesize($sourcefile));
$encoded = $this->myChunkSplit(base64_encode($contents));
fclose($fd);
}
return $encoded;
}
} }