forked from extern/egroupware
replacement for broken (and now deprecated) send->msg;
This commit is contained in:
parent
9b9313026f
commit
3a3fea946b
@ -103,7 +103,15 @@ class egw_mailer extends Horde_Mime_Mail
|
|||||||
{
|
{
|
||||||
$this->account = emailadmin_account::get_default(true); // true = need an SMTP (not just IMAP) account
|
$this->account = emailadmin_account::get_default(true); // true = need an SMTP (not just IMAP) account
|
||||||
}
|
}
|
||||||
$identity = emailadmin_account::read_identity($this->account->ident_id, true, null, $this->account);
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
$identity = emailadmin_account::read_identity($this->account->ident_id, true, null, $this->account);
|
||||||
|
} catch(Exception $e) {
|
||||||
|
error_log(__METHOD__.__LINE__.' Could not read_identity for account:'.$account['acc_id'].' with IdentID:'.$account['ident_id']);
|
||||||
|
$identity['ident_email'] = $this->account->ident_email;
|
||||||
|
$identity['ident_realname'] = $this->account->ident_realname ? $this->account->ident_realname : $this->account->ident_email;
|
||||||
|
}
|
||||||
|
|
||||||
// use smpt-username as sender/return-path, if available, but only if it is a full email address
|
// use smpt-username as sender/return-path, if available, but only if it is a full email address
|
||||||
$sender = $this->account->acc_smtp_username && strpos($this->account->acc_smtp_username, '@') !== false ?
|
$sender = $this->account->acc_smtp_username && strpos($this->account->acc_smtp_username, '@') !== false ?
|
||||||
@ -170,7 +178,7 @@ class egw_mailer extends Horde_Mime_Mail
|
|||||||
if ($return_array)
|
if ($return_array)
|
||||||
{
|
{
|
||||||
$addresses = array();
|
$addresses = array();
|
||||||
foreach($this->$type as $addr)
|
foreach((array)$this->$type as $addr)
|
||||||
{
|
{
|
||||||
$addresses[] = (string)$addr;
|
$addresses[] = (string)$addr;
|
||||||
}
|
}
|
||||||
@ -408,6 +416,95 @@ class egw_mailer extends Horde_Mime_Mail
|
|||||||
return $this->addMimePart($part);
|
return $this->addMimePart($part);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* static method to send messages e.g. when login failed to configured admins.
|
||||||
|
*
|
||||||
|
* this method is to replace $GLOBALS['egw']->send->msg(...)
|
||||||
|
*
|
||||||
|
* @param string $service String must be email for compatibility with send->msg
|
||||||
|
* @param mixed $to address to send to; array or string
|
||||||
|
* @param string $subject subject to use
|
||||||
|
* @param string $body body to use for message. plain text
|
||||||
|
* @param string $msgtype text to use for X-eGW-Type
|
||||||
|
* @param mixed $cc address to cc to; array or string
|
||||||
|
* @param mixed $bcc address to bcc to; array or string
|
||||||
|
* @param string $from from address to use
|
||||||
|
* @param string $sender sender information to use
|
||||||
|
* @param string $content_type ignored; compatibility; could cause issues regarding html content
|
||||||
|
* @param string $boundary ignored; compatibility
|
||||||
|
* @return boolean or exeption
|
||||||
|
*/
|
||||||
|
public static function sendWithDefaultSmtpProfile($service, $to, $subject, $body, $msgtype='', $cc='', $bcc='', $from='', $sender='', $content_type='', $boundary='Message-Boundary')
|
||||||
|
{
|
||||||
|
if ($service != 'email')
|
||||||
|
{
|
||||||
|
return False;
|
||||||
|
}
|
||||||
|
unset($boundary); // not used, but required by function signature
|
||||||
|
try
|
||||||
|
{
|
||||||
|
$smtpAcc = emailadmin_account::get_default(true,false,false);
|
||||||
|
//error_log(__METHOD__.__LINE__.'#'.array2string($smtpAcc));
|
||||||
|
$mail = new egw_mailer($smtpAcc);
|
||||||
|
$method = array();
|
||||||
|
foreach(array('to','cc','bcc') as $adr)
|
||||||
|
{
|
||||||
|
if ($$adr && !is_array($$adr))
|
||||||
|
{
|
||||||
|
if (is_string($$adr) && preg_match_all('/"?(.+)"?<(.+)>,?/',$$adr,$matches))
|
||||||
|
{
|
||||||
|
$names = $matches[1];
|
||||||
|
$addresses = $matches[2];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$addresses = is_string($$adr) ? explode(',',trim($$adr)) : explode(',',trim(array_shift($$adr)));
|
||||||
|
$names = array();
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach($addresses as $n => $address)
|
||||||
|
{
|
||||||
|
$method[$adr][] =$address;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (is_array($method['to'])&& !empty($method['to'])) $to = $method['to'];
|
||||||
|
foreach ((array)$to as $x => $toElem)
|
||||||
|
{
|
||||||
|
if (!empty($toElem)) $mail->addAddress($toElem, $toElem);
|
||||||
|
}
|
||||||
|
if (is_array($method['cc'])&& !empty($method['cc'])) $cc = $method['cc'];
|
||||||
|
foreach ((array)$cc as $y => $ccElem)
|
||||||
|
{
|
||||||
|
if (!empty($ccElem)) $mail->addCc($ccElem);
|
||||||
|
}
|
||||||
|
if (is_array($method['bcc'])&& !empty($method['bcc'])) $bcc = $method['bcc'];
|
||||||
|
foreach ((array)$bcc as $z => $bccElem)
|
||||||
|
{
|
||||||
|
if (!empty($bccElem)) $mail->addBcc($bccElem);
|
||||||
|
}
|
||||||
|
//error_log(__METHOD__.__LINE__."preparing notification message via email.".array2string($mail));
|
||||||
|
if ($from)
|
||||||
|
{
|
||||||
|
$matches = null;
|
||||||
|
if (preg_match('/"?(.+)"?<(.+)>/',$from,$matches))
|
||||||
|
{
|
||||||
|
list(,$FromName,$from) = $matches;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail->setFrom($from, $FromName);
|
||||||
|
$mail->addHeader('Subject', trim($subject)); // trim the subject to avoid strange wrong encoding problem
|
||||||
|
if ($sender) $mail->addHeader('Return-Path', '<'.$sender.'>', true);
|
||||||
|
if ($msgtype) $mail->addHeader('X-eGW-Type',$msgtype);
|
||||||
|
$mail->setBody($body);
|
||||||
|
$mail->send();
|
||||||
|
} catch(Exception $e) {
|
||||||
|
throw $e;
|
||||||
|
}
|
||||||
|
return True;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send mail, injecting mail transport from account
|
* Send mail, injecting mail transport from account
|
||||||
*
|
*
|
||||||
|
@ -758,9 +758,9 @@ class egw_session
|
|||||||
foreach($admin_mails as $to)
|
foreach($admin_mails as $to)
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
$GLOBALS['egw']->send->msg('email',$to,$subject,$body,'','','',$from,$from);
|
//$GLOBALS['egw']->send->msg('email',$to,$subject,$body,'','','',$from,$from); // deprecated old method
|
||||||
}
|
egw_mailer::sendWithDefaultSmtpProfile('email',$to,$subject,$body,'','','',$from);
|
||||||
catch(Exception $e) {
|
} catch(Exception $e) {
|
||||||
// ignore exception, but log it, to block the account and give a correct error-message to user
|
// ignore exception, but log it, to block the account and give a correct error-message to user
|
||||||
error_log(__METHOD__."('$login', '$ip') ".$e->getMessage());
|
error_log(__METHOD__."('$login', '$ip') ".$e->getMessage());
|
||||||
}
|
}
|
||||||
|
@ -25,7 +25,7 @@ class send extends egw_mailer
|
|||||||
*/
|
*/
|
||||||
function send()
|
function send()
|
||||||
{
|
{
|
||||||
if ($this->Subject || $this->Body || count($this->to))
|
if ($this->getHeader('Subject') || $this->Body || count($this->getAddresses('to', true)))
|
||||||
{
|
{
|
||||||
return parent::send();
|
return parent::send();
|
||||||
}
|
}
|
||||||
@ -55,14 +55,13 @@ class send extends egw_mailer
|
|||||||
* Emulating the old send::msg interface for compatibility with existing code
|
* Emulating the old send::msg interface for compatibility with existing code
|
||||||
*
|
*
|
||||||
* You can either use that code or the PHPMailer variables and methods direct.
|
* You can either use that code or the PHPMailer variables and methods direct.
|
||||||
|
* @deprecated use egw_mailer::sendWithDefaultSmtpProfile
|
||||||
*/
|
*/
|
||||||
function msg($service, $to, $subject, $body, $msgtype='', $cc='', $bcc='', $from='', $sender='', $content_type='', $boundary='Message-Boundary')
|
function msg($service, $to, $subject, $body, $msgtype='', $cc='', $bcc='', $from='', $sender='', $content_type='', $boundary='Message-Boundary')
|
||||||
{
|
{
|
||||||
if ($this->debug) error_log(__METHOD__." to='$to',subject='$subject',,'$msgtype',cc='$cc',bcc='$bcc',from='$from',sender='$sender'");
|
//error_log(__METHOD__." to='$to',subject='$subject',,'$msgtype',cc='$cc',bcc='$bcc',from='$from',sender='$sender'");
|
||||||
unset($boundary); // not used, but required by function signature
|
unset($boundary); // not used, but required by function signature
|
||||||
//echo "<p>send::msg(,to='$to',subject='$subject',,'$msgtype',cc='$cc',bcc='$bcc',from='$from',sender='$sender','$content_type','$boundary')<pre>$body</pre>\n";
|
//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')
|
if ($service != 'email')
|
||||||
{
|
{
|
||||||
return False;
|
return False;
|
||||||
@ -72,17 +71,8 @@ class send extends egw_mailer
|
|||||||
$matches = null;
|
$matches = null;
|
||||||
if (preg_match('/"?(.+)"?<(.+)>/',$from,$matches))
|
if (preg_match('/"?(.+)"?<(.+)>/',$from,$matches))
|
||||||
{
|
{
|
||||||
list(,$this->FromName,$this->From) = $matches;
|
list(,$FromName,$from) = $matches;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
$this->From = $from;
|
|
||||||
$this->FromName = '';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($sender)
|
|
||||||
{
|
|
||||||
$this->Sender = $sender;
|
|
||||||
}
|
}
|
||||||
foreach(array('to','cc','bcc') as $adr)
|
foreach(array('to','cc','bcc') as $adr)
|
||||||
{
|
{
|
||||||
@ -98,35 +88,21 @@ class send extends egw_mailer
|
|||||||
$addresses = is_string($$adr) ? explode(',',trim($$adr)) : explode(',',trim(array_shift($$adr)));
|
$addresses = is_string($$adr) ? explode(',',trim($$adr)) : explode(',',trim(array_shift($$adr)));
|
||||||
$names = array();
|
$names = array();
|
||||||
}
|
}
|
||||||
$method = 'Add'.($adr == 'to' ? 'Address' : $adr);
|
|
||||||
|
|
||||||
foreach($addresses as $n => $address)
|
foreach($addresses as $n => $address)
|
||||||
{
|
{
|
||||||
$this->$method($address,$names[$n]);
|
$method[$adr][] =$address;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
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";
|
try {
|
||||||
if (!$this->Send())
|
egw_mailer::sendWithDefaultSmtpProfile('email',$method['to'],$subject,$body,'',$method['cc'],$method['bcc'],$from,$sender);
|
||||||
{
|
} catch(Exception $e) {
|
||||||
$this->err = array(
|
// ignore exception, but log it, to block the account and give a correct error-message to user
|
||||||
'code' => 1, // we dont get a numerical code from PHPMailer
|
return false;
|
||||||
'msg' => $this->ErrorInfo,
|
|
||||||
'desc' => $this->ErrorInfo,
|
|
||||||
);
|
|
||||||
return False;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return True;
|
return True;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user