work to preserve the ActiveSyncWaitOnFailure state

This commit is contained in:
Klaus Leithoff 2014-03-13 09:09:04 +00:00
parent 6b5505e5b8
commit 70ad8ac4c8
2 changed files with 13 additions and 7 deletions

View File

@ -481,7 +481,7 @@ class emailadmin_bo extends so_sql
//error_log(__METHOD__.__LINE__.' called with ProfileID:'.$_profileID.' from '.function_backtrace()); //error_log(__METHOD__.__LINE__.' called with ProfileID:'.$_profileID.' from '.function_backtrace());
if (!is_array($_profileID) && (is_numeric($_profileID) || !(stripos($_profileID,'tracker_')===false))) if (!is_array($_profileID) && (is_numeric($_profileID) || !(stripos($_profileID,'tracker_')===false)))
{ {
felamimail_bo::resetConnectionErrorCache($_profileID); felamimail_bo::resetConnectionErrorCache($_profileID,$doActiveSyncWaitOnFailure=false);
$structure = egw_cache::getCache(egw_cache::INSTANCE,'email','structureCache'.trim($GLOBALS['egw_info']['user']['account_id']),$callback=null,$callback_params=array(),$expiration=60*60*1); $structure = egw_cache::getCache(egw_cache::INSTANCE,'email','structureCache'.trim($GLOBALS['egw_info']['user']['account_id']),$callback=null,$callback_params=array(),$expiration=60*60*1);
if (isset($structure[$_profileID])) if (isset($structure[$_profileID]))
{ {

View File

@ -201,8 +201,9 @@ class felamimail_bo
if (!is_null($_icServerObject)&&(!isset(self::$instances[$_profileID]) || $_restoreSession===false)) if (!is_null($_icServerObject)&&(!isset(self::$instances[$_profileID]) || $_restoreSession===false))
{ {
self::unsetInstance($_profileID); //make sure we reconstruct it self::unsetInstance($_profileID); //make sure we reconstruct it
emailadmin_bo::unsetCachedObjects($_profileID); // emailadmin_bo::unsetCachedObjects is calling felamimail_bo::resetConnectionErrorCache
self::$instances[$_profileID] = new felamimail_bo('utf-8',$_restoreSession,$_profileID,$_icServerObject); if (!$_reuseCache) emailadmin_bo::unsetCachedObjects($_profileID);
self::$instances[$_profileID] = new felamimail_bo('utf-8',$_restoreSession,$_profileID,$_icServerObject,$_reuseCache);
//error_log(__METHOD__.__LINE__.array2string(self::$instances[$_profileID]->mailPreferences->getIncomingServer($_profileID))); //error_log(__METHOD__.__LINE__.array2string(self::$instances[$_profileID]->mailPreferences->getIncomingServer($_profileID)));
return self::$instances[$_profileID]; return self::$instances[$_profileID];
} }
@ -313,7 +314,7 @@ class felamimail_bo
public static function validateProfileID($_restoreSession=true, $_profileID=0) public static function validateProfileID($_restoreSession=true, $_profileID=0)
{ {
$identities = array(); $identities = array();
$mail = felamimail_bo::getInstance($_restoreSession, $_profileID, $validate=false); // we need an instance of felamimail_bo $mail = felamimail_bo::getInstance($_restoreSession, $_profileID, $validate=false, null, true); // we need an instance of felamimail_bo
$selectedID = $mail->getIdentitiesWithAccounts($identities); $selectedID = $mail->getIdentitiesWithAccounts($identities);
if (is_object($mail->mailPreferences)) $activeIdentity =& $mail->mailPreferences->getIdentity($_profileID, true); if (is_object($mail->mailPreferences)) $activeIdentity =& $mail->mailPreferences->getIdentity($_profileID, true);
// if you use user defined accounts you may want to access the profile defined with the emailadmin available to the user // if you use user defined accounts you may want to access the profile defined with the emailadmin available to the user
@ -397,7 +398,11 @@ class felamimail_bo
$firstMessage = $this->sessionData['previewMessage']; $firstMessage = $this->sessionData['previewMessage'];
$this->sessionData = array(); $this->sessionData = array();
} }
if (!$_reuseCache) $this->forcePrefReload(); if (!$_reuseCache)
{
$this->forcePrefReload();
felamimail_bo::resetConnectionErrorCache($this->profileID,$doActiveSyncWaitOnFailure=true);
}
//error_log(array2string(array($firstMessage,$lv_mailbox))); //error_log(array2string(array($firstMessage,$lv_mailbox)));
// FIXME: this->foldername seems to be unused // FIXME: this->foldername seems to be unused
//$this->foldername = $this->sessionData['mailbox']; //$this->foldername = $this->sessionData['mailbox'];
@ -1962,7 +1967,7 @@ class felamimail_bo
return $retValue; return $retValue;
} }
static function resetConnectionErrorCache($_ImapServerId=null) static function resetConnectionErrorCache($_ImapServerId=null, $_doActiveSyncWaitOnFailure=true)
{ {
//error_log(__METHOD__.__LINE__.' for Profile:'.array2string($_ImapServerId) .' for user:'.trim($GLOBALS['egw_info']['user']['account_id'])); //error_log(__METHOD__.__LINE__.' for Profile:'.array2string($_ImapServerId) .' for user:'.trim($GLOBALS['egw_info']['user']['account_id']));
$account_id = $GLOBALS['egw_info']['user']['account_id']; $account_id = $GLOBALS['egw_info']['user']['account_id'];
@ -1999,7 +2004,7 @@ class felamimail_bo
} }
egw_cache::setCache(egw_cache::INSTANCE,'email','icServerIMAP_connectionError'.trim($account_id),$buff,$expiration=60*15); egw_cache::setCache(egw_cache::INSTANCE,'email','icServerIMAP_connectionError'.trim($account_id),$buff,$expiration=60*15);
egw_cache::setCache(egw_cache::INSTANCE,'email','icServerSIEVE_connectionError'.trim($account_id),$isConError,$expiration=60*15); egw_cache::setCache(egw_cache::INSTANCE,'email','icServerSIEVE_connectionError'.trim($account_id),$isConError,$expiration=60*15);
egw_cache::setCache(egw_cache::INSTANCE,'email','ActiveSyncWaitOnFailure'.trim($GLOBALS['egw_info']['user']['account_id']),$waitOnFailure,$expiration=60*60*2); if ($_doActiveSyncWaitOnFailure) egw_cache::setCache(egw_cache::INSTANCE,'email','ActiveSyncWaitOnFailure'.trim($GLOBALS['egw_info']['user']['account_id']),$waitOnFailure,$expiration=60*60*2);
} }
static function resetFolderObjectCache($_ImapServerId=null) static function resetFolderObjectCache($_ImapServerId=null)
@ -4175,6 +4180,7 @@ class felamimail_bo
if ($_icServerID==0 && !empty($this->profileID))$_icServerID = $this->profileID; if ($_icServerID==0 && !empty($this->profileID))$_icServerID = $this->profileID;
//error_log(__METHOD__.__LINE__.'->'.$_icServerID.' called from '.function_backtrace()); //error_log(__METHOD__.__LINE__.'->'.$_icServerID.' called from '.function_backtrace());
if (is_null($isError)) $isError = egw_cache::getCache(egw_cache::INSTANCE,'email','icServerIMAP_connectionError'.trim($GLOBALS['egw_info']['user']['account_id']),null,array(),$expiration=60*5); if (is_null($isError)) $isError = egw_cache::getCache(egw_cache::INSTANCE,'email','icServerIMAP_connectionError'.trim($GLOBALS['egw_info']['user']['account_id']),null,array(),$expiration=60*5);
//if ($_icServerID<0) unset($isError[$_icServerID]);
if ( isset($isError[$_icServerID]) || (($this->icServer instanceof defaultimap) && PEAR::isError($this->icServer->_connectionErrorObject))) if ( isset($isError[$_icServerID]) || (($this->icServer instanceof defaultimap) && PEAR::isError($this->icServer->_connectionErrorObject)))
{ {
if (trim($isError[$_icServerID])==',' || trim($this->icServer->_connectionErrorObject->message) == ',') if (trim($isError[$_icServerID])==',' || trim($this->icServer->_connectionErrorObject->message) == ',')