2001-01-11 10:52:33 +01:00
|
|
|
<?php
|
2005-08-23 19:49:49 +02:00
|
|
|
/**************************************************************************\
|
|
|
|
* eGroupWare API - smtp mailer using PHPMailer *
|
|
|
|
* This file written by RalfBecker@outdoor-training.de *
|
|
|
|
* ------------------------------------------------------------------------ *
|
|
|
|
* This library is free software; you can redistribute it and/or modify it *
|
|
|
|
* under the terms of the GNU Lesser General Public License as published by *
|
|
|
|
* the Free Software Foundation; either version 2.1 of the License, *
|
|
|
|
* or any later version. *
|
|
|
|
* This library is distributed in the hope that it will be useful, but *
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of *
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
|
|
|
|
* See the GNU Lesser General Public License for more details. *
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License *
|
|
|
|
* along with this library; if not, write to the Free Software Foundation, *
|
|
|
|
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
|
|
|
|
\**************************************************************************/
|
2004-07-05 12:11:11 +02:00
|
|
|
|
2005-08-23 19:49:49 +02:00
|
|
|
/* $Id$ */
|
2004-07-05 12:11:11 +02:00
|
|
|
|
2005-08-23 19:49:49 +02:00
|
|
|
require_once(EGW_API_INC.'/class.phpmailer.inc.php');
|
2004-07-05 12:11:11 +02:00
|
|
|
|
|
|
|
/**
|
2005-08-23 19:49:49 +02:00
|
|
|
* New eGW send-class. It implements the old interface (msg-method) on top of PHPMailer.
|
|
|
|
*
|
|
|
|
* The configuration is read from Admin >> Site configuration and it does NOT depend on one of the email-apps anymore.
|
|
|
|
*
|
|
|
|
* @author RalfBecker@outdoor-training.de
|
|
|
|
*/
|
|
|
|
class send extends PHPMailer
|
2001-03-26 00:24:19 +02:00
|
|
|
{
|
2010-09-08 18:03:27 +02:00
|
|
|
/**
|
|
|
|
* Log mails to log file specified in $GLOBALS['egw_info']['server']['log_mail']
|
|
|
|
* or regular error_log for true (can be set either in DB or header.inc.php).
|
|
|
|
*
|
|
|
|
* We can NOT supply this method as callback to phpMailer, as phpMailer only accepts
|
|
|
|
* functions (not methods) and from a function we can NOT access $this->ErrorInfo.
|
|
|
|
*
|
|
|
|
* @param boolean $isSent
|
|
|
|
* @param string $to
|
|
|
|
* @param string $cc
|
|
|
|
* @param string $bcc
|
|
|
|
* @param string $subject
|
|
|
|
* @param string $body
|
|
|
|
*/
|
|
|
|
protected function doCallback($isSent,$to,$cc,$bcc,$subject,$body)
|
|
|
|
{
|
|
|
|
if ($GLOBALS['egw_info']['server']['log_mail'])
|
|
|
|
{
|
|
|
|
$msg = $GLOBALS['egw_info']['server']['log_mail'] !== true ? date('Y-m-d H:i:s').': ' : '';
|
|
|
|
$msg .= ($isSent ? 'Mail send' : 'Mail NOT send').
|
|
|
|
' to '.$to.' with subject: "'.trim($subject).'"';
|
|
|
|
|
|
|
|
if ($GLOBALS['egw_info']['user']['account_id'])
|
|
|
|
{
|
|
|
|
$msg .= ' from user #'.$GLOBALS['egw_info']['user']['account_id'].' ('.
|
|
|
|
common::grab_owner_name($GLOBALS['egw_info']['user']['account_id']).')';
|
|
|
|
}
|
|
|
|
if (!$isSent)
|
|
|
|
{
|
|
|
|
$this->SetError(''); // queries error from (private) smtp and stores it in $this->ErrorInfo
|
|
|
|
$msg .= ': ERROR '.str_replace(array('Language string failed to load: smtp_error',"\n","\r"),'',
|
|
|
|
strip_tags($this->ErrorInfo));
|
|
|
|
}
|
|
|
|
error_log($msg,$GLOBALS['egw_info']['server']['log_mail'] === true ? 0 : 1,
|
|
|
|
$GLOBALS['egw_info']['server']['log_mail']);
|
|
|
|
}
|
|
|
|
// calling the orginal callback of phpMailer
|
|
|
|
parent::doCallback($isSent,$to,$cc,$bcc,$subject,$body);
|
|
|
|
}
|
|
|
|
|
2005-08-23 19:49:49 +02:00
|
|
|
var $err = array();
|
|
|
|
var $to_res = array();
|
2008-12-09 15:02:13 +01:00
|
|
|
// switching on debug with a numeric value other than 0, switches debug in PHPMailer/SMTP Class on
|
2010-09-08 18:03:27 +02:00
|
|
|
var $debug = false;
|
|
|
|
|
2005-08-23 19:49:49 +02:00
|
|
|
/**
|
|
|
|
* eGW specific initialisation of the PHPMailer: charset, language, smtp-host, ...
|
|
|
|
*
|
|
|
|
* To be able to call PHPMailer's Send function, we check if a subject, body or address is set and call it in that case,
|
|
|
|
* else we do our constructors work.
|
|
|
|
*/
|
|
|
|
function send()
|
2004-07-05 12:11:11 +02:00
|
|
|
{
|
2010-09-08 18:03:27 +02:00
|
|
|
parent::__construct(true); // throw exceptions instead of echoing errors
|
|
|
|
|
2010-05-21 13:19:29 +02:00
|
|
|
if ($this->debug && is_numeric($this->debug)) $this->SMTPDebug = $this->debug;
|
2005-08-23 19:49:49 +02:00
|
|
|
if ($this->Subject || $this->Body || count($this->to))
|
2003-05-17 22:41:14 +02:00
|
|
|
{
|
2008-12-05 11:26:07 +01:00
|
|
|
if ($this->debug) error_log(__METHOD__." ".print_r($this->Subject,true)." to be send");
|
2005-08-23 19:49:49 +02:00
|
|
|
return PHPMailer::Send();
|
2003-05-17 22:41:14 +02:00
|
|
|
}
|
2005-08-23 19:49:49 +02:00
|
|
|
$this->CharSet = $GLOBALS['egw']->translation->charset();
|
|
|
|
list($lang,$nation) = explode('-',$GLOBALS['egw_info']['user']['preferences']['common']['lang']);
|
|
|
|
$lang_path = EGW_SERVER_ROOT.'/phpgwapi/setup/';
|
|
|
|
if ($nation && file_exists($lang_path."phpmailer.lang-$nation.php")) // atm. only for pt-br => br
|
2003-05-17 22:41:14 +02:00
|
|
|
{
|
2005-08-23 19:49:49 +02:00
|
|
|
$lang = $nation;
|
2003-05-17 22:41:14 +02:00
|
|
|
}
|
2005-08-23 19:49:49 +02:00
|
|
|
$this->SetLanguage($lang,$lang_path);
|
|
|
|
$this->IsSmtp();
|
2010-07-19 09:32:06 +02:00
|
|
|
$restoreSession = $getUserDefinedProfiles = true;
|
|
|
|
// if dontUseUserDefinedProfiles is set to yes/true/1 dont restore the session AND dont retrieve UserdefinedAccount settings
|
|
|
|
$notification_config = config::read('notifications');
|
|
|
|
if ($notification_config['dontUseUserDefinedProfiles']) $restoreSession = $getUserDefinedProfiles = false;
|
|
|
|
$bopreferences =& CreateObject('felamimail.bopreferences',$restoreSession);
|
2008-06-19 13:44:31 +02:00
|
|
|
if ($bopreferences) {
|
2008-12-05 11:26:07 +01:00
|
|
|
if ($this->debug) error_log(__METHOD__." using felamimail preferences for mailing.");
|
2010-07-19 09:32:06 +02:00
|
|
|
// if dontUseUserDefinedProfiles is set to yes/true/1 dont retrieve UserdefinedAccount settings
|
|
|
|
$preferences = $bopreferences->getPreferences($getUserDefinedProfiles);
|
2008-06-19 13:44:31 +02:00
|
|
|
if ($preferences) {
|
|
|
|
$ogServer = $preferences->getOutgoingServer(0);
|
|
|
|
if ($ogServer) {
|
|
|
|
$this->Host = $ogServer->host;
|
|
|
|
$this->Port = $ogServer->port;
|
|
|
|
if($ogServer->smtpAuth) {
|
|
|
|
$this->SMTPAuth = true;
|
2008-10-21 13:57:52 +02:00
|
|
|
list($username,$senderadress) = explode(';', $ogServer->username,2);
|
2009-09-01 09:12:50 +02:00
|
|
|
if (!isset($this->Sender) || empty($this->Sender)) // if there is no Sender info, try to determine one
|
|
|
|
{
|
|
|
|
if (isset($senderadress) && !empty($senderadress)) // thats the senderinfo, that may be part of the
|
|
|
|
{ // SMTP Auth. this one has precedence over other settings
|
|
|
|
$this->Sender = $senderadress;
|
|
|
|
}
|
|
|
|
else // there is no senderinfo with smtp auth, fetch the identities mailaddress, as it should be connected to
|
|
|
|
{ // the active profiles smtp settings
|
|
|
|
$activeMailProfile = $preferences->getIdentity(0); // fetch active identity
|
|
|
|
if (isset($activeMailProfile->emailAddress) && !empty($activeMailProfile->emailAddress))
|
|
|
|
{
|
|
|
|
$this->Sender = $activeMailProfile->emailAddress;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2008-10-21 13:57:52 +02:00
|
|
|
$this->Username = $username;
|
2008-06-19 13:44:31 +02:00
|
|
|
$this->Password = $ogServer->password;
|
|
|
|
}
|
2008-12-05 11:26:07 +01:00
|
|
|
if ($this->debug) error_log(__METHOD__." using Host ".print_r($this->Host,true)." to be send");
|
|
|
|
if ($this->debug) error_log(__METHOD__." using User ".print_r($this->Username,true)." to be send");
|
|
|
|
if ($this->debug) error_log(__METHOD__." using Sender ".print_r($this->Sender,true)." to be send");
|
2008-06-19 13:44:31 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
2008-12-05 11:26:07 +01:00
|
|
|
if ($this->debug) error_log(__METHOD__." using global config to send");
|
2008-06-19 13:44:31 +02:00
|
|
|
$this->Host = $GLOBALS['egw_info']['server']['smtp_server']?$GLOBALS['egw_info']['server']['smtp_server']:'localhost';
|
|
|
|
$this->Port = $GLOBALS['egw_info']['server']['smtp_port']?$GLOBALS['egw_info']['server']['smtp_port']:25;
|
|
|
|
$this->SMTPAuth = !empty($GLOBALS['egw_info']['server']['smtp_auth_user']);
|
2008-10-21 13:57:52 +02:00
|
|
|
list($username,$senderadress) = explode(';', $GLOBALS['egw_info']['server']['smtp_auth_user'],2);
|
|
|
|
if (isset($senderadress) && !empty($senderadress)) $this->Sender = $senderadress;
|
|
|
|
$this->Username = $username;
|
2008-06-19 13:44:31 +02:00
|
|
|
$this->Password = $GLOBALS['egw_info']['server']['smtp_auth_passwd'];
|
2008-12-05 11:26:07 +01:00
|
|
|
if ($this->debug) error_log(__METHOD__." using Host ".print_r($this->Host,true)." to be send");
|
|
|
|
if ($this->debug) error_log(__METHOD__." using User ".print_r($this->Username,true)." to be send");
|
|
|
|
if ($this->debug) error_log(__METHOD__." using Sender ".print_r($this->Sender,true)." to be send");
|
2008-06-19 13:44:31 +02:00
|
|
|
}
|
2005-08-23 19:49:49 +02:00
|
|
|
$this->Hostname = $GLOBALS['egw_info']['server']['hostname'];
|
2003-05-17 22:41:14 +02:00
|
|
|
}
|
2005-08-23 19:49:49 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Reset all Settings to send multiple Messages
|
|
|
|
*/
|
|
|
|
function ClearAll()
|
2004-07-05 12:11:11 +02:00
|
|
|
{
|
2005-08-23 19:49:49 +02:00
|
|
|
$this->err = array();
|
|
|
|
|
|
|
|
$this->Subject = $this->Body = $this->AltBody = '';
|
|
|
|
$this->IsHTML(False);
|
|
|
|
$this->ClearAllRecipients();
|
|
|
|
$this->ClearAttachments();
|
|
|
|
$this->ClearCustomHeaders();
|
|
|
|
|
|
|
|
$this->FromName = $GLOBALS['egw_info']['user']['fullname'];
|
|
|
|
$this->From = $GLOBALS['egw_info']['user']['email'];
|
|
|
|
$this->Sender = '';
|
|
|
|
|
|
|
|
$this->AddCustomHeader('X-Mailer:eGroupWare (http://www.eGroupWare.org)');
|
2004-07-05 12:11:11 +02:00
|
|
|
}
|
2005-08-23 19:49:49 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Emulating the old send::msg interface for compatibility with existing code
|
|
|
|
*
|
|
|
|
* You can either use that code or the PHPMailer variables and methods direct.
|
|
|
|
*/
|
|
|
|
function msg($service, $to, $subject, $body, $msgtype='', $cc='', $bcc='', $from='', $sender='', $content_type='', $boundary='Message-Boundary')
|
2001-09-28 23:38:29 +02:00
|
|
|
{
|
2008-12-05 11:26:07 +01:00
|
|
|
if ($this->debug) error_log(__METHOD__." to='$to',subject='$subject',,'$msgtype',cc='$cc',bcc='$bcc',from='$from',sender='$sender'");
|
2005-08-23 19:49:49 +02:00
|
|
|
//echo "<p>send::msg(,to='$to',subject='$subject',,'$msgtype',cc='$cc',bcc='$bcc',from='$from',sender='$sender','$content_type','$boundary')<pre>$body</pre>\n";
|
|
|
|
$this->ClearAll(); // reset everything to its default, we might be called more then once !!!
|
|
|
|
|
|
|
|
if ($service != 'email')
|
|
|
|
{
|
|
|
|
return False;
|
|
|
|
}
|
|
|
|
if ($from)
|
2001-03-26 00:24:19 +02:00
|
|
|
{
|
2005-08-23 19:49:49 +02:00
|
|
|
if (preg_match('/"?(.+)"?<(.+)>/',$from,$matches))
|
2001-09-28 23:38:29 +02:00
|
|
|
{
|
2005-08-23 19:49:49 +02:00
|
|
|
list(,$this->FromName,$this->From) = $matches;
|
2001-09-28 23:38:29 +02:00
|
|
|
}
|
2004-07-05 12:11:11 +02:00
|
|
|
else
|
2001-09-28 23:38:29 +02:00
|
|
|
{
|
2005-08-23 19:49:49 +02:00
|
|
|
$this->From = $from;
|
|
|
|
$this->FromName = '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($sender)
|
|
|
|
{
|
|
|
|
$this->Sender = $sender;
|
|
|
|
}
|
|
|
|
foreach(array('to','cc','bcc') as $adr)
|
|
|
|
{
|
|
|
|
if ($$adr)
|
2001-03-26 00:24:19 +02:00
|
|
|
{
|
2005-08-23 19:49:49 +02:00
|
|
|
if (preg_match_all('/"?(.+)"?<(.+)>,?/',$$adr,$matches))
|
|
|
|
{
|
|
|
|
$names = $matches[1];
|
|
|
|
$addresses = $matches[2];
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2006-04-24 22:20:48 +02:00
|
|
|
$addresses = explode(',',trim($$adr));
|
2005-08-23 19:49:49 +02:00
|
|
|
$names = array();
|
|
|
|
}
|
|
|
|
$method = 'Add'.($adr == 'to' ? 'Address' : $adr);
|
|
|
|
|
|
|
|
foreach($addresses as $n => $address)
|
|
|
|
{
|
|
|
|
$this->$method($address,$names[$n]);
|
|
|
|
}
|
2001-03-26 00:24:19 +02:00
|
|
|
}
|
|
|
|
}
|
2005-08-23 19:49:49 +02:00
|
|
|
if (!empty($msgtype))
|
|
|
|
{
|
|
|
|
$this->AddCustomHeader('X-eGW-Type: '.$msgtype);
|
|
|
|
}
|
|
|
|
if ($content_type)
|
|
|
|
{
|
|
|
|
$this->ContentType = $content_type;
|
|
|
|
}
|
|
|
|
$this->Subject = $subject;
|
|
|
|
$this->Body = $body;
|
|
|
|
|
|
|
|
//echo "PHPMailer = <pre>".print_r($this,True)."</pre>\n";
|
|
|
|
if (!$this->Send())
|
|
|
|
{
|
|
|
|
$this->err = array(
|
|
|
|
'code' => 1, // we dont get a numerical code from PHPMailer
|
|
|
|
'msg' => $this->ErrorInfo,
|
|
|
|
'desc' => $this->ErrorInfo,
|
|
|
|
);
|
|
|
|
return False;
|
|
|
|
}
|
|
|
|
return True;
|
2001-09-28 23:38:29 +02:00
|
|
|
}
|
2005-08-23 19:49:49 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* encode 8-bit chars in subject-line
|
|
|
|
*
|
|
|
|
* This is not needed any more, as it is done be PHPMailer, but older code depend on it.
|
|
|
|
*/
|
|
|
|
function encode_subject($subject)
|
2001-05-30 21:47:13 +02:00
|
|
|
{
|
2005-08-23 19:49:49 +02:00
|
|
|
return $subject;
|
2001-05-30 21:47:13 +02:00
|
|
|
}
|
2004-07-05 12:11:11 +02:00
|
|
|
}
|