Fix mail notification fatal error because of etemplate1

This commit is contained in:
Hadi Nategh 2017-03-15 19:20:29 +01:00
parent 7a6d977b42
commit 9cda411c4f

View File

@ -456,19 +456,16 @@ class mail_hooks
$currentTime = time(); $currentTime = time();
if (!empty($lastRun) && $lastRun>$currentTime-3*60) if (!empty($lastRun) && $lastRun>$currentTime-3*60)
{ {
//error_log(__METHOD__.__LINE__." Job should not run too often; we limit this to once every 3 Minutes :". ($currentTime-$lastRun). " Seconds to go!");
return true; return true;
} }
$accountsToSearchObj = Mail\Account::search(true, true); $accountsToSearchObj = Mail\Account::search(true, true);
foreach($accountsToSearchObj as $acc_id => $identity_name) foreach($accountsToSearchObj as $acc_id => $identity_name)
{ {
//error_log(__METHOD__.__LINE__.' '.$acc_id.':'.$identity_name);
$folders2notify[$acc_id] = Mail\Notifications::read($acc_id);// read all, even those set for acc_id 0 (folders for all acounts?) $folders2notify[$acc_id] = Mail\Notifications::read($acc_id);// read all, even those set for acc_id 0 (folders for all acounts?)
$accountsToSearchArray[$acc_id] = str_replace(array('<','>'),array('[',']'),$identity_name); $accountsToSearchArray[$acc_id] = str_replace(array('<','>'),array('[',']'),$identity_name);
} }
$notified_mail_uidsCache = Api\Cache::getCache(Api\Cache::INSTANCE,'email','notified_mail_uids'.trim($GLOBALS['egw_info']['user']['account_id']),null,array(),$expiration=60*60*24*2); $notified_mail_uidsCache = Api\Cache::getCache(Api\Cache::INSTANCE,'email','notified_mail_uids'.trim($GLOBALS['egw_info']['user']['account_id']),null,array(),$expiration=60*60*24*2);
//error_log(__METHOD__.__LINE__.array2string($notified_mail_uidsCache));
if (!is_array($folders2notify)) return true; if (!is_array($folders2notify)) return true;
foreach ($folders2notify as $nFKey =>$notifyfolders) foreach ($folders2notify as $nFKey =>$notifyfolders)
{ {
@ -479,9 +476,7 @@ class mail_hooks
if(count($notify_folders) == 0) { if(count($notify_folders) == 0) {
continue; //no folders configured for notifying continue; //no folders configured for notifying
} }
//error_log(__METHOD__.__LINE__.' '.$nFKey.' =>'.array2string($notifyfolders));
$activeProfile = $nFKey; $activeProfile = $nFKey;
//error_log(__METHOD__.__LINE__.' (user: '.$currentRecipient->account_lid.') Active Profile:'.$activeProfile);
try try
{ {
$bomail = Mail::getInstance(false, $activeProfile,false); $bomail = Mail::getInstance(false, $activeProfile,false);
@ -490,7 +485,6 @@ class mail_hooks
error_log(__METHOD__.__LINE__.' (user: '.$currentRecipient->account_lid.') notification for Profile:'.$activeProfile.' failed.'.$e->getMessage()); error_log(__METHOD__.__LINE__.' (user: '.$currentRecipient->account_lid.') notification for Profile:'.$activeProfile.' failed.'.$e->getMessage());
continue; //fail silently continue; //fail silently
} }
//error_log(__METHOD__.__LINE__.' '.$nFKey.' =>'.array2string($bomail->icServer->params));
$icServerParams=$bomail->icServer->params; $icServerParams=$bomail->icServer->params;
if (empty($icServerParams['acc_imap_host'])) if (empty($icServerParams['acc_imap_host']))
{ {
@ -508,7 +502,6 @@ class mail_hooks
error_log(__METHOD__.__LINE__.' # Instance='.$GLOBALS['egw_info']['user']['domain'].', User='.$GLOBALS['egw_info']['user']['account_lid']); error_log(__METHOD__.__LINE__.' # Instance='.$GLOBALS['egw_info']['user']['domain'].', User='.$GLOBALS['egw_info']['user']['account_lid']);
return false; // cannot connect to mailbox return false; // cannot connect to mailbox
} }
//error_log(__METHOD__.__LINE__.array2string($notified_mail_uidsCache[$activeProfile][$notify_folder]));
//$notified_mail_uidsCache = array(); //$notified_mail_uidsCache = array();
$recent_messages = array(); $recent_messages = array();
$folder_status = array(); $folder_status = array();
@ -520,12 +513,10 @@ class mail_hooks
$folder_status[$notify_folder] = $bomail->getFolderStatus($notify_folder); $folder_status[$notify_folder] = $bomail->getFolderStatus($notify_folder);
$cutoffdate = time() - (60*60*24*14); // last 14 days $cutoffdate = time() - (60*60*24*14); // last 14 days
$_filter = array('status'=>array('UNSEEN','UNDELETED'),'type'=>"SINCE",'string'=> date("d-M-Y", $cutoffdate)); $_filter = array('status'=>array('UNSEEN','UNDELETED'),'type'=>"SINCE",'string'=> date("d-M-Y", $cutoffdate));
//error_log(__METHOD__.__LINE__.' (user: '.$currentRecipient->account_lid.') Mailbox:'.$notify_folder.' filter:'.array2string($_filter));
// $_folderName, $_startMessage, $_numberOfMessages, $_sort, $_reverse, $_filter, $_thisUIDOnly=null, $_cacheResult=true // $_folderName, $_startMessage, $_numberOfMessages, $_sort, $_reverse, $_filter, $_thisUIDOnly=null, $_cacheResult=true
$headers = $bomail->getHeaders($notify_folder, 1, 999, 0, true, $_filter,null,false); $headers = $bomail->getHeaders($notify_folder, 1, 999, 0, true, $_filter,null,false);
if(is_array($headers['header']) && count($headers['header']) > 0) { if(is_array($headers['header']) && count($headers['header']) > 0) {
foreach($headers['header'] as $id=>$header) { foreach($headers['header'] as $id=>$header) {
//error_log(__METHOD__.__LINE__.' Found Message:'.$header['uid'].' Subject:'.$header['subject']);
// check if unseen mail has already been notified // check if unseen mail has already been notified
$headerrowid = mail_ui::generateRowID($activeProfile, $notify_folder, $header['uid'], $_prependApp=false); $headerrowid = mail_ui::generateRowID($activeProfile, $notify_folder, $header['uid'], $_prependApp=false);
if(!in_array($headerrowid, $notified_mail_uidsCache[$activeProfile][$notify_folder])) { if(!in_array($headerrowid, $notified_mail_uidsCache[$activeProfile][$notify_folder])) {
@ -538,14 +529,12 @@ class mail_hooks
} }
} }
} }
//error_log(__METHOD__.__LINE__.' Found Messages for Profile'.$activeProfile.':'.array2string($recent_messages).'<->'.array2string($notified_mail_uidsCache[$activeProfile]));
if(count($recent_messages) > 0) { if(count($recent_messages) > 0) {
// create notify message // create notify message
$notification_subject = lang("You've got new mail").':'.$accountsToSearchArray[$activeProfile]; $notification_subject = lang("You've got new mail").':'.$accountsToSearchArray[$activeProfile];
$values = array(); $values = array();
$values[] = array(); // content array starts at index 1 $values[] = array(); // content array starts at index 1
foreach($recent_messages as $id=>$recent_message) { foreach($recent_messages as $id=>$recent_message) {
//error_log(__METHOD__.__LINE__.' Found Message for Profile '.$activeProfile.':'.array2string($recent_message));
$values[] = array( $values[] = array(
'mail_uid' => $recent_message['uid'], 'mail_uid' => $recent_message['uid'],
'mail_folder' => $recent_message['folder_display_name'], 'mail_folder' => $recent_message['folder_display_name'],
@ -557,15 +546,20 @@ class mail_hooks
// save notification status // save notification status
$notified_mail_uidsCache[$activeProfile][$recent_message['folder']][] = mail_ui::generateRowID($activeProfile, $recent_message['folder'], $recent_message['uid'], $_prependApp=false); $notified_mail_uidsCache[$activeProfile][$recent_message['folder']][] = mail_ui::generateRowID($activeProfile, $recent_message['folder'], $recent_message['uid'], $_prependApp=false);
} }
// create etemplate foreach ($values as &$mail)
$tpl = new etemplate('mail.checkmailbox'); {
$notification_message = $tpl->exec(false, $values, array(), array(), array(), 1); if ($mail['mail_from'])
//error_log(__METHOD__.__LINE__.array2string($notification_message)); {
$notification_message .= "<br/><strong>".lang("From").':</strong>'. $mail["mail_from"].
"<br/><strong>".lang("To").':</strong>'. $mail["recieved"].
"<br/><strong>".lang ("subject"). ':</strong>' . $mail["mail_subject"].
"<br/><br/> -------------------------------------------------------- </br>";
}
}
// send notification // send notification
$notification = new notifications(); $notification = new notifications();
$notification->set_receivers(array($currentRecipient->account_id)); $notification->set_receivers(array($currentRecipient->account_id));
$notification->set_message($notification_message); $notification->set_message($notification_message);
//$notification->set_popupmessage($notification_message);
$notification->set_sender($currentRecipient->account_id); $notification->set_sender($currentRecipient->account_id);
$notification->set_subject($notification_subject); $notification->set_subject($notification_subject);
$notification->set_skip_backends(array('email')); $notification->set_skip_backends(array('email'));
@ -578,7 +572,6 @@ class mail_hooks
} }
} }
Api\Cache::setCache(Api\Cache::INSTANCE,'email','mailNotifyLastRun'.trim($GLOBALS['egw_info']['user']['account_id']),time(), $expiration=60*60*24*2); Api\Cache::setCache(Api\Cache::INSTANCE,'email','mailNotifyLastRun'.trim($GLOBALS['egw_info']['user']['account_id']),time(), $expiration=60*60*24*2);
//error_log(__METHOD__.__LINE__.array2string($notified_mail_uidsCache));
return true; return true;
} }