forked from extern/egroupware
fix for functional folders showing up multiple times
This commit is contained in:
parent
fb037c49a9
commit
c173de3935
@ -3548,9 +3548,10 @@ class Mail
|
||||
* isSentFolder is the given folder the sent folder or at least a subfolder of it
|
||||
* @param string $_folderName folder to perform the check on
|
||||
* @param boolean $_checkexistance trigger check for existance
|
||||
* @param boolean $_exactMatch make the check more strict. return false if folder is subfolder only
|
||||
* @return boolean
|
||||
*/
|
||||
function isSentFolder($_folderName, $_checkexistance=TRUE)
|
||||
function isSentFolder($_folderName, $_checkexistance=TRUE, $_exactMatch=false)
|
||||
{
|
||||
$sentFolder = $this->getSentFolder($_checkexistance);
|
||||
if(empty($sentFolder)) {
|
||||
@ -3561,20 +3562,30 @@ class Mail
|
||||
return false;
|
||||
}
|
||||
|
||||
if ($_exactMatch)
|
||||
{
|
||||
if(false !== stripos($_folderName, $sentFolder)&& strlen($_folderName)==strlen($sentFolder)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
} else {
|
||||
if(false !== stripos($_folderName, $sentFolder)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* checks if the Outbox folder exists and is part of the foldername to be checked
|
||||
* @param string $_folderName folder to perform the check on
|
||||
* @param boolean $_checkexistance trigger check for existance
|
||||
* @param boolean $_exactMatch make the check more strict. return false if folder is subfolder only
|
||||
* @return boolean
|
||||
*/
|
||||
function isOutbox($_folderName, $_checkexistance=TRUE)
|
||||
function isOutbox($_folderName, $_checkexistance=TRUE, $_exactMatch=false)
|
||||
{
|
||||
if (stripos($_folderName, 'Outbox')===false) {
|
||||
return false;
|
||||
@ -3582,12 +3593,21 @@ class Mail
|
||||
// does the folder exist???
|
||||
if ($_checkexistance && $GLOBALS['egw_info']['user']['apps']['activesync'] && !$this->folderExists($_folderName)) {
|
||||
$outboxFolder = $this->getOutboxFolder($_checkexistance);
|
||||
if ($_exactMatch)
|
||||
{
|
||||
if(false !== stripos($_folderName, $outboxFolder)&& strlen($_folderName)==strlen($outboxFolder)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
} else {
|
||||
if(false !== stripos($_folderName, $outboxFolder)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
@ -3595,9 +3615,10 @@ class Mail
|
||||
* isDraftFolder is the given folder the sent folder or at least a subfolder of it
|
||||
* @param string $_folderName folder to perform the check on
|
||||
* @param boolean $_checkexistance trigger check for existance
|
||||
* @param boolean $_exactMatch make the check more strict. return false if folder is subfolder only
|
||||
* @return boolean
|
||||
*/
|
||||
function isDraftFolder($_folderName, $_checkexistance=TRUE)
|
||||
function isDraftFolder($_folderName, $_checkexistance=TRUE, $_exactMatch=false)
|
||||
{
|
||||
$draftFolder = $this->getDraftFolder($_checkexistance);
|
||||
if(empty($draftFolder)) {
|
||||
@ -3608,20 +3629,30 @@ class Mail
|
||||
return false;
|
||||
}
|
||||
if (is_a($_folderName,"Horde_Imap_Client_Mailbox")) $_folderName = $_folderName->utf8;
|
||||
if ($_exactMatch)
|
||||
{
|
||||
if(false !== stripos($_folderName, $draftFolder)&& strlen($_folderName)==strlen($draftFolder)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
} else {
|
||||
if(false !== stripos($_folderName, $draftFolder)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* isTrashFolder is the given folder the sent folder or at least a subfolder of it
|
||||
* @param string $_folderName folder to perform the check on
|
||||
* @param boolean $_checkexistance trigger check for existance
|
||||
* @param boolean $_exactMatch make the check more strict. return false if folder is subfolder only
|
||||
* @return boolean
|
||||
*/
|
||||
function isTrashFolder($_folderName, $_checkexistance=TRUE)
|
||||
function isTrashFolder($_folderName, $_checkexistance=TRUE, $_exactMatch=false)
|
||||
{
|
||||
$trashFolder = $this->getTrashFolder($_checkexistance);
|
||||
if(empty($trashFolder)) {
|
||||
@ -3632,20 +3663,30 @@ class Mail
|
||||
return false;
|
||||
}
|
||||
|
||||
if ($_exactMatch)
|
||||
{
|
||||
if(false !== stripos($_folderName, $trashFolder)&& strlen($_folderName)==strlen($trashFolder)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
} else {
|
||||
if(false !== stripos($_folderName, $trashFolder)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* isTemplateFolder is the given folder the sent folder or at least a subfolder of it
|
||||
* @param string $_folderName folder to perform the check on
|
||||
* @param boolean $_checkexistance trigger check for existance
|
||||
* @param boolean $_exactMatch make the check more strict. return false if folder is subfolder only
|
||||
* @return boolean
|
||||
*/
|
||||
function isTemplateFolder($_folderName, $_checkexistance=TRUE)
|
||||
function isTemplateFolder($_folderName, $_checkexistance=TRUE, $_exactMatch=false)
|
||||
{
|
||||
$templateFolder = $this->getTemplateFolder($_checkexistance);
|
||||
if(empty($templateFolder)) {
|
||||
@ -3655,13 +3696,21 @@ class Mail
|
||||
if ($_checkexistance && !$this->folderExists($_folderName)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if ($_exactMatch)
|
||||
{
|
||||
if(false !== stripos($_folderName, $templateFolder)&& strlen($_folderName)==strlen($templateFolder)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
} else {
|
||||
if(false !== stripos($_folderName, $templateFolder)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* folderExists checks for existance of a given folder
|
||||
|
@ -1643,27 +1643,27 @@ class mail_zpush implements activesync_plugin_write, activesync_plugin_sendmail,
|
||||
{
|
||||
$folderObj->type = SYNC_FOLDER_TYPE_INBOX;
|
||||
}
|
||||
elseif($this->mail->isDraftFolder($folder, false))
|
||||
elseif($this->mail->isDraftFolder($folder, false, true))
|
||||
{
|
||||
//ZLog::Write(LOGLEVEL_DEBUG,__METHOD__.' isDraft');
|
||||
$folderObj->type = SYNC_FOLDER_TYPE_DRAFTS;
|
||||
$folderObj->parentid = 0; // required by devices
|
||||
}
|
||||
elseif($this->mail->isTrashFolder($folder, false))
|
||||
elseif($this->mail->isTrashFolder($folder, false, true))
|
||||
{
|
||||
$folderObj->type = SYNC_FOLDER_TYPE_WASTEBASKET;
|
||||
$this->_wasteID = $folder;
|
||||
//error_log(__METHOD__.__LINE__.' TrashFolder:'.$this->_wasteID);
|
||||
$folderObj->parentid = 0; // required by devices
|
||||
}
|
||||
elseif($this->mail->isSentFolder($folder, false))
|
||||
elseif($this->mail->isSentFolder($folder, false, true))
|
||||
{
|
||||
$folderObj->type = SYNC_FOLDER_TYPE_SENTMAIL;
|
||||
$folderObj->parentid = 0; // required by devices
|
||||
$this->_sentID = $folder;
|
||||
//error_log(__METHOD__.__LINE__.' SentFolder:'.$this->_sentID);
|
||||
}
|
||||
elseif($this->mail->isOutbox($folder, false))
|
||||
elseif($this->mail->isOutbox($folder, false, true))
|
||||
{
|
||||
//ZLog::Write(LOGLEVEL_DEBUG,__METHOD__.' isOutbox');
|
||||
$folderObj->type = SYNC_FOLDER_TYPE_OUTBOX;
|
||||
|
Loading…
Reference in New Issue
Block a user