mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-24 14:58:43 +01:00
catch possible failure on examineMailbox call; more debug; handle uid reported but no data to be gathered: as a message is deleted from server but cache still reporting its existance ; may happen on QRESYNC with No permanent modsequences
This commit is contained in:
parent
a8fb9082e9
commit
f46358f45a
@ -172,7 +172,6 @@ class emailadmin_imap extends Horde_Imap_Client_Socket implements defaultimap
|
|||||||
$username = $this->getMailBoxUserName($username);
|
$username = $this->getMailBoxUserName($username);
|
||||||
}
|
}
|
||||||
if ($_adminConnection) $this->adminConnection($username);
|
if ($_adminConnection) $this->adminConnection($username);
|
||||||
|
|
||||||
$parent_params = array(
|
$parent_params = array(
|
||||||
'username' => $this->params[$_adminConnection ? 'acc_imap_admin_username' : 'acc_imap_username'],
|
'username' => $this->params[$_adminConnection ? 'acc_imap_admin_username' : 'acc_imap_username'],
|
||||||
'password' => $this->params[$_adminConnection ? 'acc_imap_admin_password' : 'acc_imap_password'],
|
'password' => $this->params[$_adminConnection ? 'acc_imap_admin_password' : 'acc_imap_password'],
|
||||||
@ -825,7 +824,15 @@ class emailadmin_imap extends Horde_Imap_Client_Socket implements defaultimap
|
|||||||
// if pseudo-flag is not set, call examineMailbox now to set it (no STATUS_ALL = counters necessary)
|
// if pseudo-flag is not set, call examineMailbox now to set it (no STATUS_ALL = counters necessary)
|
||||||
if (!isset(self::$supports_keywords[$this->ImapServerId]))
|
if (!isset(self::$supports_keywords[$this->ImapServerId]))
|
||||||
{
|
{
|
||||||
$this->examineMailbox('INBOX', Horde_Imap_Client::STATUS_FLAGS|Horde_Imap_Client::STATUS_PERMFLAGS);
|
try
|
||||||
|
{
|
||||||
|
$this->examineMailbox('INBOX', Horde_Imap_Client::STATUS_FLAGS|Horde_Imap_Client::STATUS_PERMFLAGS);
|
||||||
|
}
|
||||||
|
catch (Exception $e)
|
||||||
|
{
|
||||||
|
error_log(__METHOD__.__LINE__.' (examineServer for detection) '.$capability.'->'.array2string(self::$supports_keywords).' failed '.function_backtrace());
|
||||||
|
self::$supports_keywords[$this->ImapServerId]=false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
//error_log(__METHOD__.__LINE__.' '.$capability.'->'.array2string(self::$supports_keywords).' '.function_backtrace());
|
//error_log(__METHOD__.__LINE__.' '.$capability.'->'.array2string(self::$supports_keywords).' '.function_backtrace());
|
||||||
return self::$supports_keywords[$this->ImapServerId];
|
return self::$supports_keywords[$this->ImapServerId];
|
||||||
|
@ -1436,7 +1436,17 @@ class emailadmin_imapbase
|
|||||||
|
|
||||||
// Get already cached headers, 'fetchHeaders' is a label matchimg above
|
// Get already cached headers, 'fetchHeaders' is a label matchimg above
|
||||||
$headerForPrio = array_change_key_case($_headerObject->getHeaders('fetchHeaders',Horde_Imap_Client_Data_Fetch::HEADER_PARSE)->toArray(), CASE_UPPER);
|
$headerForPrio = array_change_key_case($_headerObject->getHeaders('fetchHeaders',Horde_Imap_Client_Data_Fetch::HEADER_PARSE)->toArray(), CASE_UPPER);
|
||||||
//error_log(__METHOD__.' ('.__LINE__.') '.array2string($headerForPrio));
|
if (self::$debug) {
|
||||||
|
error_log(__METHOD__.__LINE__.array2string($_headerObject).'UID:'.$_headerObject->getUid().' Size:'.$_headerObject->getSize().' Date:'.$_headerObject->getImapDate());
|
||||||
|
error_log(__METHOD__.' ('.__LINE__.') '.array2string($headerForPrio));
|
||||||
|
}
|
||||||
|
|
||||||
|
// message deleted from server but cache still reporting its existence ; may happen on QRESYNC with No permanent modsequences
|
||||||
|
if (empty($headerForPrio))
|
||||||
|
{
|
||||||
|
$total--;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if ( isset($headerForPrio['DISPOSITION-NOTIFICATION-TO']) ) {
|
if ( isset($headerForPrio['DISPOSITION-NOTIFICATION-TO']) ) {
|
||||||
$headerObject['DISPOSITION-NOTIFICATION-TO'] = self::decode_header(trim($headerForPrio['DISPOSITION-NOTIFICATION-TO']));
|
$headerObject['DISPOSITION-NOTIFICATION-TO'] = self::decode_header(trim($headerForPrio['DISPOSITION-NOTIFICATION-TO']));
|
||||||
} else if ( isset($headerForPrio['RETURN-RECEIPT-TO']) ) {
|
} else if ( isset($headerForPrio['RETURN-RECEIPT-TO']) ) {
|
||||||
@ -1699,7 +1709,7 @@ class emailadmin_imapbase
|
|||||||
if (self::$debugTimes) $starttime = microtime(true);
|
if (self::$debugTimes) $starttime = microtime(true);
|
||||||
if (is_null($eMailListContainsDeletedMessages) || empty($eMailListContainsDeletedMessages[$this->profileID]) || empty($eMailListContainsDeletedMessages[$this->profileID][$_folderName])) $eMailListContainsDeletedMessages = egw_cache::getCache(egw_cache::INSTANCE,'email','eMailListContainsDeletedMessages'.trim($GLOBALS['egw_info']['user']['account_id']),$callback=null,$callback_params=array(),$expiration=60*60*1);
|
if (is_null($eMailListContainsDeletedMessages) || empty($eMailListContainsDeletedMessages[$this->profileID]) || empty($eMailListContainsDeletedMessages[$this->profileID][$_folderName])) $eMailListContainsDeletedMessages = egw_cache::getCache(egw_cache::INSTANCE,'email','eMailListContainsDeletedMessages'.trim($GLOBALS['egw_info']['user']['account_id']),$callback=null,$callback_params=array(),$expiration=60*60*1);
|
||||||
$deletedMessages = $this->getSortedList($_folderName, 0, $three=1, array('status'=>array('DELETED')),$five=true,false);
|
$deletedMessages = $this->getSortedList($_folderName, 0, $three=1, array('status'=>array('DELETED')),$five=true,false);
|
||||||
//error_log(__METHOD__.' ('.__LINE__.') '.array2string($deletedMessages));
|
if (self::$debug) error_log(__METHOD__.' ('.__LINE__.') Found DeletedMessages:'.array2string($sortResult['match']->ids));
|
||||||
$eMailListContainsDeletedMessages[$this->profileID][$_folderName] =$deletedMessages['count'];
|
$eMailListContainsDeletedMessages[$this->profileID][$_folderName] =$deletedMessages['count'];
|
||||||
egw_cache::setCache(egw_cache::INSTANCE,'email','eMailListContainsDeletedMessages'.trim($GLOBALS['egw_info']['user']['account_id']),$eMailListContainsDeletedMessages, $expiration=60*60*1);
|
egw_cache::setCache(egw_cache::INSTANCE,'email','eMailListContainsDeletedMessages'.trim($GLOBALS['egw_info']['user']['account_id']),$eMailListContainsDeletedMessages, $expiration=60*60*1);
|
||||||
if (self::$debugTimes) self::logRunTimes($starttime,null,'setting eMailListContainsDeletedMessages for Profile:'.$this->profileID.' Folder:'.$_folderName.' to '.$eMailListContainsDeletedMessages[$this->profileID][$_folderName],__METHOD__.' ('.__LINE__.') '); //error_log(__METHOD__.' ('.__LINE__.') '.' Profile:'.$this->profileID.' Folder:'.$_folderName.' -> EXISTS/SessStat:'.array2string($folderStatus['MESSAGES']).'/'.self::$folderStatusCache[$this->profileID][$_folderName]['messages'].' ListContDelMsg/SessDeleted:'.$eMailListContainsDeletedMessages[$this->profileID][$_folderName].'/'.self::$folderStatusCache[$this->profileID][$_folderName]['deleted']);
|
if (self::$debugTimes) self::logRunTimes($starttime,null,'setting eMailListContainsDeletedMessages for Profile:'.$this->profileID.' Folder:'.$_folderName.' to '.$eMailListContainsDeletedMessages[$this->profileID][$_folderName],__METHOD__.' ('.__LINE__.') '); //error_log(__METHOD__.' ('.__LINE__.') '.' Profile:'.$this->profileID.' Folder:'.$_folderName.' -> EXISTS/SessStat:'.array2string($folderStatus['MESSAGES']).'/'.self::$folderStatusCache[$this->profileID][$_folderName]['messages'].' ListContDelMsg/SessDeleted:'.$eMailListContainsDeletedMessages[$this->profileID][$_folderName].'/'.self::$folderStatusCache[$this->profileID][$_folderName]['deleted']);
|
||||||
@ -1713,6 +1723,11 @@ class emailadmin_imapbase
|
|||||||
}
|
}
|
||||||
//error_log(__METHOD__.' ('.__LINE__.') '.array2string($_filter).' SupportsOrInQuery:'.self::$supportsORinQuery[$this->profileID]);
|
//error_log(__METHOD__.' ('.__LINE__.') '.array2string($_filter).' SupportsOrInQuery:'.self::$supportsORinQuery[$this->profileID]);
|
||||||
$filter = $this->createIMAPFilter($_folderName, $_filter,self::$supportsORinQuery[$this->profileID]);
|
$filter = $this->createIMAPFilter($_folderName, $_filter,self::$supportsORinQuery[$this->profileID]);
|
||||||
|
if (self::$debug)
|
||||||
|
{
|
||||||
|
$query_str = $filter->build();
|
||||||
|
error_log(__METHOD__.' ('.__LINE__.') '.' '.$query_str['query']);
|
||||||
|
}
|
||||||
//_debug_array($filter);
|
//_debug_array($filter);
|
||||||
//error_log(__METHOD__.' ('.__LINE__.') '.array2string($filter));
|
//error_log(__METHOD__.' ('.__LINE__.') '.array2string($filter));
|
||||||
if($this->icServer->hasCapability('SORT')) {
|
if($this->icServer->hasCapability('SORT')) {
|
||||||
|
Loading…
Reference in New Issue
Block a user