mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-26 07:49:28 +01:00
do NOT connect to previous imap server, if user triggers a change of server
This commit is contained in:
parent
4d5f5677e1
commit
c670d879d5
@ -10,10 +10,19 @@
|
|||||||
* @version $Id$
|
* @version $Id$
|
||||||
*/
|
*/
|
||||||
|
|
||||||
include_once(EGW_INCLUDE_ROOT.'/etemplate/inc/class.etemplate.inc.php');
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Mail Interface class
|
* Mail User Interface
|
||||||
|
*
|
||||||
|
* As we do NOT want to connect to previous imap server, when a profile change is triggered
|
||||||
|
* by user get_rows and ajax_changeProfile are not static methods and instanciates there own
|
||||||
|
* mail_ui object.
|
||||||
|
*
|
||||||
|
* If they detect a profile change is to be triggered they call:
|
||||||
|
* $mail_ui = new mail_ui(false); // not call constructor / connect to imap server
|
||||||
|
* $mail_ui->changeProfile($_profileID);
|
||||||
|
* If no profile change is needed they just call:
|
||||||
|
* $mail_ui = new mail_ui();
|
||||||
|
* Afterwards they use $mail_ui instead of $this.
|
||||||
*/
|
*/
|
||||||
class mail_ui
|
class mail_ui
|
||||||
{
|
{
|
||||||
@ -98,9 +107,12 @@ class mail_ui
|
|||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
*
|
*
|
||||||
|
* @param boolean $run_constructor =true false: no not run constructor and therefore do NOT connect to imap server
|
||||||
*/
|
*/
|
||||||
function __construct()
|
function __construct($run_constructor=true)
|
||||||
{
|
{
|
||||||
|
if (!$run_constructor) return;
|
||||||
|
|
||||||
if (mail_bo::$debugTimes) $starttime = microtime (true);
|
if (mail_bo::$debugTimes) $starttime = microtime (true);
|
||||||
if (!isset($GLOBALS['egw_info']['flags']['js_link_registry']))
|
if (!isset($GLOBALS['egw_info']['flags']['js_link_registry']))
|
||||||
{
|
{
|
||||||
@ -128,10 +140,7 @@ class mail_ui
|
|||||||
//error_log(__METHOD__.__LINE__.array2string($this->mail_bo->icServer));
|
//error_log(__METHOD__.__LINE__.array2string($this->mail_bo->icServer));
|
||||||
|
|
||||||
// RegEx to minimize extra openConnection
|
// RegEx to minimize extra openConnection
|
||||||
$needle = '/mail.etemplate_widget_nextmatch.ajax_get_rows.etemplate|'
|
$needle = '^(?!mail)/';
|
||||||
// . 'mail.mail_ui.ajax_refreshQuotaDisplay|'
|
|
||||||
. 'mail.mail_ui.ajax_changeProfile|'
|
|
||||||
. '^(?!mail)/';
|
|
||||||
if (!preg_match($needle,$_GET['menuaction']) && !egw_json_request::isJSONRequest())
|
if (!preg_match($needle,$_GET['menuaction']) && !egw_json_request::isJSONRequest())
|
||||||
{
|
{
|
||||||
//error_log(__METHOD__.__LINE__.' Fetched IC Server openConnection:'.self::$icServerID.'/'.$this->mail_bo->profileID.':'.function_backtrace());
|
//error_log(__METHOD__.__LINE__.' Fetched IC Server openConnection:'.self::$icServerID.'/'.$this->mail_bo->profileID.':'.function_backtrace());
|
||||||
@ -375,7 +384,7 @@ class mail_ui
|
|||||||
if (!is_array($content[self::$nm_index]))
|
if (!is_array($content[self::$nm_index]))
|
||||||
{
|
{
|
||||||
$content[self::$nm_index] = array(
|
$content[self::$nm_index] = array(
|
||||||
'get_rows' => 'mail.mail_ui.get_rows', // I method/callback to request the data for the rows eg. 'notes.bo.get_rows'
|
'get_rows' => 'mail_ui::get_rows', // I method/callback to request the data for the rows eg. 'notes.bo.get_rows'
|
||||||
'filter' => 'any', // filter is used to choose the mailbox
|
'filter' => 'any', // filter is used to choose the mailbox
|
||||||
'no_filter2' => false, // I disable the 2. filter (params are the same as for filter)
|
'no_filter2' => false, // I disable the 2. filter (params are the same as for filter)
|
||||||
'no_cat' => true, // I disable the cat-selectbox
|
'no_cat' => true, // I disable the cat-selectbox
|
||||||
@ -1405,61 +1414,67 @@ class mail_ui
|
|||||||
/**
|
/**
|
||||||
* Callback to fetch the rows for the nextmatch widget
|
* Callback to fetch the rows for the nextmatch widget
|
||||||
*
|
*
|
||||||
|
* Function is static to not automatic call constructor in case profile is changed.
|
||||||
|
*
|
||||||
* @param array $query
|
* @param array $query
|
||||||
* @param array &$rows
|
* @param array &$rows
|
||||||
* @param array &$readonlys
|
* @param array &$readonlys
|
||||||
*/
|
*/
|
||||||
function get_rows(&$query,&$rows,&$readonlys)
|
public static function get_rows(&$query,&$rows,&$readonlys)
|
||||||
{
|
{
|
||||||
// unset($query['actions']);
|
// handle possible profile change in get_rows
|
||||||
//error_log(__METHOD__.__LINE__.' SelectedFolder:'.$query['selectedFolder'].' Start:'.$query['start'].' NumRows:'.$query['num_rows'].array2string($query['order']).'->'.array2string($query['sort']));
|
if (!empty($query['selectedFolder']))
|
||||||
if (mail_bo::$debugTimes) $starttime = microtime(true);
|
|
||||||
//$query['search'] is the phrase in the searchbox
|
|
||||||
|
|
||||||
$this->mail_bo->restoreSessionData();
|
|
||||||
$maxMessages = 50; // match the hardcoded setting for data retrieval as inital value
|
|
||||||
if (isset($query['selectedFolder'])) $this->mail_bo->sessionData['mailbox']=$query['selectedFolder'];
|
|
||||||
$this->mail_bo->saveSessionData();
|
|
||||||
|
|
||||||
$sRToFetch = null;
|
|
||||||
$_folderName=(!empty($query['selectedFolder'])?$query['selectedFolder']:$this->mail_bo->profileID.self::$delimiter.'INBOX');
|
|
||||||
list($_profileID,$folderName) = explode(self::$delimiter,$_folderName,2);
|
|
||||||
if (strpos($folderName,self::$delimiter)!==false)
|
|
||||||
{
|
{
|
||||||
list($app,$_profileID,$folderName) = explode(self::$delimiter,$_folderName,3);
|
list($_profileID,$folderName) = explode(self::$delimiter, $query['selectedFolder'], 2);
|
||||||
unset($app);
|
if (is_numeric(($_profileID)) && $_profileID != $GLOBALS['egw_info']['user']['preferences']['mail']['ActiveProfileID'])
|
||||||
}
|
|
||||||
if (is_numeric($_profileID))
|
|
||||||
{
|
{
|
||||||
if ($_profileID && $_profileID != $this->mail_bo->profileID)
|
try {
|
||||||
{
|
$mail_ui = new mail_ui(false); // do NOT run constructor, as we change profile anyway
|
||||||
//error_log(__METHOD__.__LINE__.' change Profile to ->'.$_profileID);
|
$mail_ui->changeProfile($_profileID);
|
||||||
try
|
$query['actions'] = $mail_ui->get_actions();
|
||||||
{
|
|
||||||
$this->changeProfile($_profileID);
|
|
||||||
$query['actions'] = $this->get_actions();
|
|
||||||
}
|
}
|
||||||
catch(Exception $e)
|
catch(Exception $e)
|
||||||
{
|
{
|
||||||
$rows=array();
|
$rows=array();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
if (empty($folderName)) $query['selectedFolder'] = $_profileID.self::$delimiter.'INBOX';
|
||||||
}
|
}
|
||||||
$_folderName = (!empty($folderName)?$folderName:'INBOX');
|
}
|
||||||
|
if (!isset($mail_ui))
|
||||||
|
{
|
||||||
|
$mail_ui = new mail_ui(true); // run constructor for current profile
|
||||||
|
if (empty($query['selectedFolder'])) $query['selectedFolder'] = $mail_ui->mail_bo->profileID.self::$delimiter.'INBOX';
|
||||||
|
}
|
||||||
|
|
||||||
|
//error_log(__METHOD__.__LINE__.' SelectedFolder:'.$query['selectedFolder'].' Start:'.$query['start'].' NumRows:'.$query['num_rows'].array2string($query['order']).'->'.array2string($query['sort']));
|
||||||
|
if (mail_bo::$debugTimes) $starttime = microtime(true);
|
||||||
|
//$query['search'] is the phrase in the searchbox
|
||||||
|
|
||||||
|
$mail_ui->mail_bo->restoreSessionData();
|
||||||
|
if (isset($query['selectedFolder'])) $mail_ui->mail_bo->sessionData['mailbox']=$query['selectedFolder'];
|
||||||
|
$mail_ui->mail_bo->saveSessionData();
|
||||||
|
|
||||||
|
$sRToFetch = null;
|
||||||
|
list($_profileID,$_folderName) = explode(self::$delimiter,$query['selectedFolder'],2);
|
||||||
|
if (strpos($_folderName,self::$delimiter)!==false)
|
||||||
|
{
|
||||||
|
list($app,$_profileID,$_folderName) = explode(self::$delimiter,$_folderName,3);
|
||||||
|
unset($app);
|
||||||
}
|
}
|
||||||
//save selected Folder to sessionData (mailbox)->currentFolder
|
//save selected Folder to sessionData (mailbox)->currentFolder
|
||||||
if (isset($query['selectedFolder'])) $this->mail_bo->sessionData['mailbox']=$_folderName;
|
if (isset($query['selectedFolder'])) $mail_ui->mail_bo->sessionData['mailbox']=$_folderName;
|
||||||
$toSchema = false;//decides to select list schema with column to selected (if false fromaddress is default)
|
$toSchema = false;//decides to select list schema with column to selected (if false fromaddress is default)
|
||||||
if ($this->mail_bo->folderExists($_folderName))
|
if ($mail_ui->mail_bo->folderExists($_folderName))
|
||||||
{
|
{
|
||||||
$toSchema = $this->mail_bo->isDraftFolder($_folderName,false)||$this->mail_bo->isSentFolder($_folderName,false)||$this->mail_bo->isTemplateFolder($_folderName,false);
|
$toSchema = $mail_ui->mail_bo->isDraftFolder($_folderName,false)||$mail_ui->mail_bo->isSentFolder($_folderName,false)||$mail_ui->mail_bo->isTemplateFolder($_folderName,false);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
//error_log(__METHOD__.__LINE__.' Test on Folder:'.$_folderName.' failed; Using INBOX instead');
|
//error_log(__METHOD__.__LINE__.' Test on Folder:'.$_folderName.' failed; Using INBOX instead');
|
||||||
$query['selectedFolder']=$this->mail_bo->sessionData['mailbox']=$_folderName='INBOX';
|
$query['selectedFolder']=$mail_ui->mail_bo->sessionData['mailbox']=$_folderName='INBOX';
|
||||||
}
|
}
|
||||||
$this->mail_bo->saveSessionData();
|
$mail_ui->mail_bo->saveSessionData();
|
||||||
$rowsFetched['messages'] = null;
|
$rowsFetched['messages'] = null;
|
||||||
$offset = $query['start']+1; // we always start with 1
|
$offset = $query['start']+1; // we always start with 1
|
||||||
$maxMessages = $query['num_rows'];
|
$maxMessages = $query['num_rows'];
|
||||||
@ -1467,17 +1482,17 @@ class mail_ui
|
|||||||
$sort = ($query['order']=='address'?($toSchema?'toaddress':'fromaddress'):$query['order']);
|
$sort = ($query['order']=='address'?($toSchema?'toaddress':'fromaddress'):$query['order']);
|
||||||
if (!empty($query['search']))
|
if (!empty($query['search']))
|
||||||
{
|
{
|
||||||
if (is_null(emailadmin_imapbase::$supportsORinQuery) || !isset(emailadmin_imapbase::$supportsORinQuery[$this->mail_bo->profileID]))
|
if (is_null(emailadmin_imapbase::$supportsORinQuery) || !isset(emailadmin_imapbase::$supportsORinQuery[$mail_ui->mail_bo->profileID]))
|
||||||
{
|
{
|
||||||
emailadmin_imapbase::$supportsORinQuery = egw_cache::getCache(egw_cache::INSTANCE,'email','supportsORinQuery'.trim($GLOBALS['egw_info']['user']['account_id']), null, array(), 60*60*10);
|
emailadmin_imapbase::$supportsORinQuery = egw_cache::getCache(egw_cache::INSTANCE,'email','supportsORinQuery'.trim($GLOBALS['egw_info']['user']['account_id']), null, array(), 60*60*10);
|
||||||
if (!isset(emailadmin_imapbase::$supportsORinQuery[$this->mail_bo->profileID]))
|
if (!isset(emailadmin_imapbase::$supportsORinQuery[$mail_ui->mail_bo->profileID]))
|
||||||
{
|
{
|
||||||
emailadmin_imapbase::$supportsORinQuery[$this->mail_bo->profileID]=true;
|
emailadmin_imapbase::$supportsORinQuery[$mail_ui->mail_bo->profileID]=true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$filter = array(
|
$filter = array(
|
||||||
'filterName' => (emailadmin_imapbase::$supportsORinQuery[$this->mail_bo->profileID]?lang('quicksearch'):lang('subject')),
|
'filterName' => (emailadmin_imapbase::$supportsORinQuery[$mail_ui->mail_bo->profileID]?lang('quicksearch'):lang('subject')),
|
||||||
'type' => ($query['filter2']?$query['filter2']:(emailadmin_imapbase::$supportsORinQuery[$this->mail_bo->profileID]?'quick':'subject')),
|
'type' => ($query['filter2']?$query['filter2']:(emailadmin_imapbase::$supportsORinQuery[$mail_ui->mail_bo->profileID]?'quick':'subject')),
|
||||||
'string' => $query['search'],
|
'string' => $query['search'],
|
||||||
'status' => 'any');
|
'status' => 'any');
|
||||||
}
|
}
|
||||||
@ -1490,12 +1505,12 @@ class mail_ui
|
|||||||
$filter['status'] = $query['filter'];
|
$filter['status'] = $query['filter'];
|
||||||
}
|
}
|
||||||
$reverse = ($query['sort']=='ASC'?false:true);
|
$reverse = ($query['sort']=='ASC'?false:true);
|
||||||
//error_log(__METHOD__.__LINE__.' maxMessages:'.$maxMessages.' Offset:'.$offset.' Filter:'.array2string($this->sessionData['messageFilter']));
|
//error_log(__METHOD__.__LINE__.' maxMessages:'.$maxMessages.' Offset:'.$offset.' Filter:'.array2string($mail_ui->sessionData['messageFilter']));
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if ($maxMessages > 75)
|
if ($maxMessages > 75)
|
||||||
{
|
{
|
||||||
$_sR = $this->mail_bo->getSortedList(
|
$_sR = $mail_ui->mail_bo->getSortedList(
|
||||||
$_folderName,
|
$_folderName,
|
||||||
$sort,
|
$sort,
|
||||||
$reverse,
|
$reverse,
|
||||||
@ -1516,7 +1531,7 @@ class mail_ui
|
|||||||
//error_log(__METHOD__.__LINE__.' Headers to fetch with UIDs:'.count($sRToFetch).' Data:'.array2string($sRToFetch));
|
//error_log(__METHOD__.__LINE__.' Headers to fetch with UIDs:'.count($sRToFetch).' Data:'.array2string($sRToFetch));
|
||||||
$sortResult = array();
|
$sortResult = array();
|
||||||
// fetch headers
|
// fetch headers
|
||||||
$sortResultwH = $this->mail_bo->getHeaders(
|
$sortResultwH = $mail_ui->mail_bo->getHeaders(
|
||||||
$_folderName,
|
$_folderName,
|
||||||
$offset,
|
$offset,
|
||||||
$maxMessages,
|
$maxMessages,
|
||||||
@ -1531,7 +1546,7 @@ class mail_ui
|
|||||||
{
|
{
|
||||||
$sortResult = array();
|
$sortResult = array();
|
||||||
// fetch headers
|
// fetch headers
|
||||||
$sortResultwH = $this->mail_bo->getHeaders(
|
$sortResultwH = $mail_ui->mail_bo->getHeaders(
|
||||||
$_folderName,
|
$_folderName,
|
||||||
$offset,
|
$offset,
|
||||||
$maxMessages,
|
$maxMessages,
|
||||||
@ -1580,7 +1595,7 @@ class mail_ui
|
|||||||
//error_log(__METHOD__.__LINE__.' Rows fetched:'.$rowsFetched.' Data:'.array2string($sortResult));
|
//error_log(__METHOD__.__LINE__.' Rows fetched:'.$rowsFetched.' Data:'.array2string($sortResult));
|
||||||
$cols = array('row_id','uid','status','attachments','subject','address','toaddress','fromaddress','ccaddress','additionaltoaddress','date','size','modified');
|
$cols = array('row_id','uid','status','attachments','subject','address','toaddress','fromaddress','ccaddress','additionaltoaddress','date','size','modified');
|
||||||
if ($GLOBALS['egw_info']['user']['preferences']['common']['select_mode']=='EGW_SELECTMODE_TOGGLE') unset($cols[0]);
|
if ($GLOBALS['egw_info']['user']['preferences']['common']['select_mode']=='EGW_SELECTMODE_TOGGLE') unset($cols[0]);
|
||||||
$rows = $this->header2gridelements($sortResult['header'],$cols, $_folderName, $folderType=$toSchema);
|
$rows = $mail_ui->header2gridelements($sortResult['header'],$cols, $_folderName, $folderType=$toSchema);
|
||||||
//error_log(__METHOD__.__LINE__.array2string($rows));
|
//error_log(__METHOD__.__LINE__.array2string($rows));
|
||||||
|
|
||||||
if (mail_bo::$debugTimes) mail_bo::logRunTimes($starttime,null,'Folder:'.$_folderName.' Start:'.$query['start'].' NumRows:'.$query['num_rows'],__METHOD__.__LINE__);
|
if (mail_bo::$debugTimes) mail_bo::logRunTimes($starttime,null,'Folder:'.$_folderName.' Start:'.$query['start'].' NumRows:'.$query['num_rows'],__METHOD__.__LINE__);
|
||||||
@ -3835,22 +3850,26 @@ class mail_ui
|
|||||||
/**
|
/**
|
||||||
* empty changeProfile - its called via json, so the function must start with ajax (or the class-name must contain ajax)
|
* empty changeProfile - its called via json, so the function must start with ajax (or the class-name must contain ajax)
|
||||||
*
|
*
|
||||||
|
* Made static to NOT call __construct, as it would connect to old server, before going to new one
|
||||||
|
*
|
||||||
* @param int $icServerID New profile / server ID
|
* @param int $icServerID New profile / server ID
|
||||||
* @param bool $getFolders The client needs the folders for the profile
|
* @param bool $getFolders The client needs the folders for the profile
|
||||||
* @return nothing
|
* @return nothing
|
||||||
*/
|
*/
|
||||||
function ajax_changeProfile($icServerID, $getFolders = true, $exec_id=null)
|
public static function ajax_changeProfile($icServerID, $getFolders = true, $exec_id=null)
|
||||||
{
|
{
|
||||||
$response = egw_json_response::get();
|
$response = egw_json_response::get();
|
||||||
|
|
||||||
if ($icServerID && $icServerID != $this->mail_bo->profileID)
|
$previous_id = $GLOBALS['egw_info']['user']['preferences']['mail']['ActiveProfileID'];
|
||||||
|
|
||||||
|
if ($icServerID && $icServerID != $previous_id)
|
||||||
{
|
{
|
||||||
|
$mail_ui = new mail_ui(false); // do NOT run constructor, as we call changeProfile anyway
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if ($exec_id) $old_actions = $this->get_actions();
|
$mail_ui->changeProfile($icServerID);
|
||||||
$this->changeProfile($icServerID);
|
|
||||||
// if we have an eTemplate exec_id, also send changed actions
|
// if we have an eTemplate exec_id, also send changed actions
|
||||||
if ($exec_id && ($actions = $this->get_actions()) != $old_actions)
|
if ($exec_id && ($actions = $mail_ui->get_actions()))
|
||||||
{
|
{
|
||||||
$response->generic('assign', array(
|
$response->generic('assign', array(
|
||||||
'etemplate_exec_id' => $exec_id,
|
'etemplate_exec_id' => $exec_id,
|
||||||
@ -3863,7 +3882,10 @@ class mail_ui
|
|||||||
catch (Exception $e) {
|
catch (Exception $e) {
|
||||||
self::callWizard($e->getMessage(),true, 'error');
|
self::callWizard($e->getMessage(),true, 'error');
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$mail_ui = new mail_ui(true); // run constructor
|
||||||
}
|
}
|
||||||
|
|
||||||
// Send full info back in the response
|
// Send full info back in the response
|
||||||
@ -3872,7 +3894,7 @@ class mail_ui
|
|||||||
translation::add_app('mail');
|
translation::add_app('mail');
|
||||||
|
|
||||||
$refreshData = array(
|
$refreshData = array(
|
||||||
$icServerID => $this->getFolderTree(true, $icServerID, !$this->mail_bo->mailPreferences['showAllFoldersInFolderPane'],true)
|
$icServerID => $mail_ui->getFolderTree(true, $icServerID, !$mail_ui->mail_bo->mailPreferences['showAllFoldersInFolderPane'],true)
|
||||||
);
|
);
|
||||||
$response->call('app.mail.mail_reloadNode',$refreshData);
|
$response->call('app.mail.mail_reloadNode',$refreshData);
|
||||||
}
|
}
|
||||||
|
@ -1601,7 +1601,7 @@ app.classes.mail = AppJS.extend(
|
|||||||
this.egw.message(this.egw.lang('Connect to Profile %1',_widget.getSelectedLabel().replace(this._unseen_regexp, '')));
|
this.egw.message(this.egw.lang('Connect to Profile %1',_widget.getSelectedLabel().replace(this._unseen_regexp, '')));
|
||||||
|
|
||||||
this.lock_tree();
|
this.lock_tree();
|
||||||
egw.json('mail.mail_ui.ajax_changeProfile',[folder, getFolders, this.et2._inst.etemplate_exec_id], jQuery.proxy(function() {
|
egw.json('mail_ui::ajax_changeProfile',[folder, getFolders, this.et2._inst.etemplate_exec_id], jQuery.proxy(function() {
|
||||||
// Profile changed, select inbox
|
// Profile changed, select inbox
|
||||||
var inbox = folder + '::INBOX';
|
var inbox = folder + '::INBOX';
|
||||||
_widget.reSelectItem(inbox);
|
_widget.reSelectItem(inbox);
|
||||||
|
Loading…
Reference in New Issue
Block a user