mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-07 14:39:56 +01:00
work to preserve the ActiveSyncWaitOnFailure state
This commit is contained in:
parent
6b5505e5b8
commit
70ad8ac4c8
@ -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]))
|
||||||
{
|
{
|
||||||
|
@ -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) == ',')
|
||||||
|
Loading…
Reference in New Issue
Block a user