aboutsummaryrefslogtreecommitdiffstats
path: root/phpBB/includes/emailer.php
diff options
context:
space:
mode:
authorPaul S. Owen <psotfx@users.sourceforge.net>2003-03-25 14:19:23 +0000
committerPaul S. Owen <psotfx@users.sourceforge.net>2003-03-25 14:19:23 +0000
commitb0545e7636dd88a53cb54dd84fc8951fd8b7488e (patch)
treef771813d8d542cb34902d1c63ddf5d827e821522 /phpBB/includes/emailer.php
parent3d43169b2a46f84fc9bf36b87d95bc7b666dafaa (diff)
downloadforums-b0545e7636dd88a53cb54dd84fc8951fd8b7488e.tar
forums-b0545e7636dd88a53cb54dd84fc8951fd8b7488e.tar.gz
forums-b0545e7636dd88a53cb54dd84fc8951fd8b7488e.tar.bz2
forums-b0545e7636dd88a53cb54dd84fc8951fd8b7488e.tar.xz
forums-b0545e7636dd88a53cb54dd84fc8951fd8b7488e.zip
Tidy up and simplify emailer class, add generate_board_url function ... note changes to emailer setup! Example will be adm/index.php remind
git-svn-id: file:///svn/phpbb/trunk@3718 89ea8834-ac86-4346-8a33-228a782c2dd0
Diffstat (limited to 'phpBB/includes/emailer.php')
-rwxr-xr-xphpBB/includes/emailer.php163
1 files changed, 67 insertions, 96 deletions
diff --git a/phpBB/includes/emailer.php b/phpBB/includes/emailer.php
index 5e2ca54f07..49fcd215b1 100755
--- a/phpBB/includes/emailer.php
+++ b/phpBB/includes/emailer.php
@@ -19,52 +19,28 @@
*
***************************************************************************/
-//
-// NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE
-//
-// Bug fixes in 2.0.x should be ported to this, particularly the header changes
-//
-// NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE
-//
-
-//
-// The emailer class has support for attaching files, that isn't implemented
-// in the 2.0 release but we can probable find some way of using it in a future
-// release
-//
class emailer
{
- var $tpl_file;
- var $use_smtp;
- var $msg;
- var $mimeOut;
- var $arrPlaceHolders = array(); // an associative array that has the key = placeHolderName and val = placeHolderValue.
- var $subject, $extra_headers, $address;
-
- function emailer($use_smtp)
+ var $msg, $subject, $extra_headers, $address;
+ var $tpl_msg = array();
+
+ function emailer()
{
- $this->use_smtp = $use_smtp;
- $this->tpl_file = NULL;
- $this->address = NULL;
- $this->msg = '';
- $this->mimeOut = '';
+ $this->reset();
}
// Resets all the data (address, template file, etc etc to default
function reset()
{
- $this->tpl_file = '';
$this->address = '';
$this->msg = '';
- $this->memOut = '';
$this->vars = '';
}
// Sets an email address to send to
function email_address($address)
{
- $this->address = '';
- $this->address .= $address;
+ $this->address = $address;
}
// set up subject for mail
@@ -83,62 +59,78 @@ class emailer
{
global $config, $phpbb_root_path;
- if ($template_lang == '')
+ if (trim($template_file) == '')
{
- $template_lang = $config['default_lang'];
+ trigger_error('No template file set', E_USER_ERROR);
}
- $this->tpl_file = $phpbb_root_path . 'language/' . $template_lang . '/email/' . $template_file . '.txt';
- if (!file_exists($this->tpl_file))
+ if (trim($template_lang) == '')
{
- trigger_error('Could not find email template file ' . $template_file);
+ $template_lang = $config['default_lang'];
}
- if (!$this->load_msg())
+ if (empty($this->tpl_msg[$template_lang . $template_file]))
{
- trigger_error('Could not load email template file ' . $template_file);
- }
+ $tpl_file = $phpbb_root_path . 'language/' . $template_lang . '/email/' . $template_file . '.txt';
- return true;
- }
+ if (!file_exists($tpl_file))
+ {
+ $tpl_file = $phpbb_root_path . 'language/' . $config['default_lang'] . '/email/' . $template_file . '.txt';
- // Open the template file and read in the message
- function load_msg()
- {
- if ($this->tpl_file == NULL)
- {
- trigger_error('No template file set');
- }
+ if (!file_exists($tpl_file))
+ {
+ trigger_error('Could not find email template file :: ' . $template_file, E_USER_ERROR);
+ }
+ }
- if (!($fd = fopen($this->tpl_file, 'r')))
- {
- trigger_error('Failed opening template file');
+ if (!($fd = @fopen($tpl_file, 'r')))
+ {
+ trigger_error('Failed opening template file', E_USER_ERROR);
+ }
+
+ $this->tpl_msg[$template_lang . $template_file] = fread($fd, filesize($tpl_file));
+ fclose($fd);
}
- $this->msg .= fread($fd, filesize($this->tpl_file));
- fclose($fd);
+ $this->msg = $this->tpl_msg[$template_lang . $template_file];
return true;
}
+ // assign variables
function assign_vars($vars)
{
$this->vars = (empty($this->vars)) ? $vars : $this->vars . $vars;
}
- function parse_email()
+ // Send the mail out to the recipients set previously in var $this->address
+ function send()
{
- foreach ($this->vars as $key => $val)
+ global $config, $phpEx, $phpbb_root_path;
+
+ if (empty($config['email_enable']))
{
- $$key = $val;
+ return false;
}
// Escape all quotes, else the eval will fail.
$this->msg = str_replace ("'", "\'", $this->msg);
$this->msg = preg_replace('#\{([a-z0-9\-_]*?)\}#is', "' . $\\1 . '", $this->msg);
+ // Set vars
+ foreach ($this->vars as $key => $val)
+ {
+ $$key = $val;
+ }
+
eval("\$this->msg = '$this->msg';");
+ // Clear vars
+ foreach ($this->vars as $key => $val)
+ {
+ unset($$key);
+ }
+
// We now try and pull a subject from the email body ... if it exists,
// do this here because the subject may contain a variable
$drop_header = '';
@@ -169,34 +161,18 @@ class emailer
}
// Split up message into 76 chars as per RFC2045
- // $this->msg = chunk_split($this->msg);
-
- return true;
- }
-
- // Send the mail out to the recipients set previously in var $this->address
- function send()
- {
- global $phpEx, $phpbb_root_path;
-
- if ($this->address == NULL)
- {
- trigger_error('No email address set');
- }
-
- if (!$this->parse_email())
- {
- return false;
- }
+// $this->msg = chunk_split($this->msg);
- $universal_extra = "MIME-Version: 1.0\nContent-type: text/plain; charset=" . $this->encoding . "\nContent-transfer-encoding: 8bit\nDate: " . gmdate('D, d M Y H:i:s', time()) . " UT\nX-Priority: 3\nX-MSMail-Priority: Normal\nX-Mailer: PHP\n";
- $this->extra_headers = $universal_extra . trim($this->extra_headers);
+ // Build header
+ $this->extra_headers = "From: " . $config['board_email'] . "\nReturn-Path: " . $config['board_email'] . "\nMIME-Version: 1.0\nContent-type: text/plain; charset=" . $this->encoding . "\nContent-transfer-encoding: 7bit\nDate: " . gmdate('D, d M Y H:i:s', time()) . " UT\nX-Priority: 3\nX-MSMail-Priority: Normal\nX-Mailer: PHP\n" . trim($this->extra_headers);
- $result = ($this->use_smtp) ? smtpmail($this->address, $this->subject, $this->msg, $this->extra_headers) : @mail($this->address, $this->subject, $this->msg, $this->extra_headers);
+ // Send message
+ $result = ($config['smtp_delivery']) ? smtpmail($this->address, $this->subject, $this->msg, $this->extra_headers) : @mail($this->address, $this->subject, $this->msg, $this->extra_headers);
if (!$result)
{
- trigger_error('Failed sending email :: ' . $result);
+ $message = '<u>EMAIL ERROR</u> [ ' . (($config['smtp_delivery']) ? 'SMTP' : 'PHP') . ' ]<br /><br />' . $result . '<br /><br /><u>CALLING PAGE</u><br /><br />' . ((!empty($_SERVER['PHP_SELF'])) ? $_SERVER['PHP_SELF'] : $_ENV['PHP_SELF']) . '<br />';
+ trigger_error($message, E_USER_ERROR);
}
return true;
@@ -207,17 +183,17 @@ class emailer
// using SMTP Extensions
function server_parse($socket, $response)
{
- while (substr($server_response,3,1) != ' ')
+ while (substr($server_response, 3, 1) != ' ')
{
if (!($server_response = fgets($socket, 256)))
{
- trigger_error('Could not get mail server response codes');
+ trigger_error('Could not get mail server response codes', E_USER_ERROR);
}
}
if (!(substr($server_response, 0, 3) == $response))
{
- trigger_error("Ran into problems sending Mail. Response: $server_response");
+ trigger_error("Ran into problems sending Mail. Response: $server_response", E_USER_ERROR);
}
}
@@ -245,7 +221,7 @@ function smtpmail($mail_to, $subject, $message, $headers = '')
$headers = chop($headers);
// Make sure there are no bare linefeeds in the headers
- $headers = preg_replace("#(?<!\r)\n#si", "\r\n", $headers);
+ $headers = preg_replace('#(?<!\r)\n#si', "\r\n", $headers);
// Ok this is rather confusing all things considered,
// but we have to grab bcc and cc headers and treat them differently
@@ -253,17 +229,17 @@ function smtpmail($mail_to, $subject, $message, $headers = '')
$header_array = explode("\r\n", $headers);
@reset($header_array);
- $headers = "";
+ $headers = '';
while(list(, $header) = each($header_array))
{
- if (preg_match("#^cc:#si", $header))
+ if (preg_match('#^cc:#si', $header))
{
- $cc = preg_replace("#^cc:(.*)#si", "\\1", $header);
+ $cc = preg_replace('#^cc:(.*)#si', '\1', $header);
}
- else if (preg_match("#^bcc:/si", $header))
+ else if (preg_match('#^bcc:/si', $header))
{
- $bcc = preg_replace("#^bcc:(.*)#si", "\\1", $header);
- $header = "";
+ $bcc = preg_replace('#^bcc:(.*)#si', '\1', $header);
+ $header = '';
}
$headers .= $header . "\r\n";
}
@@ -273,19 +249,14 @@ function smtpmail($mail_to, $subject, $message, $headers = '')
$bcc = explode(',', $bcc);
}
- if (trim($mail_to) == '')
- {
- trigger_error('No email address specified');
- }
-
if (trim($subject) == '')
{
- trigger_error('No email Subject specified');
+ trigger_error('No email Subject specified', E_USER_ERROR);
}
if (trim($message) == '')
{
- trigger_error('Email message was blank');
+ trigger_error('Email message was blank', E_USER_ERROR);
}
$mail_to_array = explode(',', $mail_to);
@@ -294,7 +265,7 @@ function smtpmail($mail_to, $subject, $message, $headers = '')
// it already.
if (!$socket = fsockopen($config['smtp_host'], $config['smtp_port'], $errno, $errstr, 20))
{
- trigger_error("Could not connect to smtp host : $errno : $errstr");
+ trigger_error("Could not connect to smtp host : $errno : $errstr", E_USER_ERROR);
}
// Wait for reply