WIP implementing ChangeFolder (rename or create folder) for mail

This commit is contained in:
Ralf Becker 2016-08-11 16:20:30 +02:00
parent 955ba34599
commit 39c2e399d4

View File

@ -1910,16 +1910,20 @@ class mail_zpush implements activesync_plugin_write, activesync_plugin_sendmail,
public function ChangeFolder($id, $oldid, $displayname, $type) public function ChangeFolder($id, $oldid, $displayname, $type)
{ {
ZLog::Write(LOGLEVEL_DEBUG,__METHOD__."('$id', '$oldid', '$displayname', $type)"); ZLog::Write(LOGLEVEL_DEBUG,__METHOD__."('$id', '$oldid', '$displayname', $type)");
$this->splitID($id, $account, $parentFolder); $account = $parent_id = null;
$this->splitID($id, $account, $parent_id);
$parentFolder = $this->hash2folder($account, $parent_id);
$old_hash = $oldFolder = null;
if (empty($oldid)) if (empty($oldid))
{ {
$action = 'create'; $action = 'create';
} elseif (!empty($oldid)) { }
else
{
$action = 'rename'; $action = 'rename';
$this->splitID($oldid, $account, $oldFolder); $this->splitID($oldid, $account, $oldFolder, $old_hash);
} else {
ZLog::Write(LOGLEVEL_DEBUG,__METHOD__."('$id'=>($parentFolder), '$oldid'".($oldid?"=>($oldFolder)":'').", '$displayname', $type) NOT supported!");
return false;
} }
ZLog::Write(LOGLEVEL_DEBUG,__METHOD__.":{$action}Folder('$id'=>($parentFolder), '$oldid'".($oldid?"=>($oldFolder)":'').", '$displayname', $type)"); ZLog::Write(LOGLEVEL_DEBUG,__METHOD__.":{$action}Folder('$id'=>($parentFolder), '$oldid'".($oldid?"=>($oldFolder)":'').", '$displayname', $type)");
$this->_connect($this->account); $this->_connect($this->account);
@ -1928,7 +1932,8 @@ class mail_zpush implements activesync_plugin_write, activesync_plugin_sendmail,
if ($action=='rename') if ($action=='rename')
{ {
$newFolderName = $this->mail->renameFolder($oldFolder, $parentFolder, $displayname); $newFolderName = $this->mail->renameFolder($oldFolder, $parentFolder, $displayname);
} elseif ($action=='create') }
elseif ($action=='create')
{ {
$error=null; $error=null;
$newFolderName = $this->mail->createFolder($parentFolder, $displayname, $error); $newFolderName = $this->mail->createFolder($parentFolder, $displayname, $error);
@ -1936,11 +1941,14 @@ class mail_zpush implements activesync_plugin_write, activesync_plugin_sendmail,
} }
catch (\Exception $e) catch (\Exception $e)
{ {
throw new Exception(__METHOD__." $action failed for $oldFolder ($action: $newFolderName) with error:".$e->getMessage());; //throw new Exception(__METHOD__." $action failed for $oldFolder ($action: $displayname) with error:".$e->getMessage());
return false;
} }
$newID = $this->createID($account,$newFolderName); $newHash = $this->rename_folder_hash($account, $old_hash, $newFolderName);
$newID = $this->createID($account, $newHash);
ZLog::Write(LOGLEVEL_DEBUG,":{$action}Folder('$id'=>($parentFolder), '$oldid'".($oldid?"=>($oldFolder)":'').", '$displayname' => $newFolderName (ID:$newID))"); ZLog::Write(LOGLEVEL_DEBUG,":{$action}Folder('$id'=>($parentFolder), '$oldid'".($oldid?"=>($oldFolder)":'').", '$displayname' => $newFolderName (ID:$newID))");
return (bool)$newFolderName; return $this->StatFolder($newID);
} }
/** /**
@ -2068,6 +2076,25 @@ class mail_zpush implements activesync_plugin_write, activesync_plugin_sendmail,
return isset($this->folderHashes[$account]) ? $this->folderHashes[$account][$index] : null; return isset($this->folderHashes[$account]) ? $this->folderHashes[$account][$index] : null;
} }
/**
* Rename or create a folder in hash table
*
* @param int $account
* @param int $index or null to create
* @param string $new_name
* @return int $index or new hash if $index is not found
*/
private function rename_folder_hash($account, $index, $new_name)
{
if ((string)$index === '' || !$this->hash2folder($account, $index))
{
return $this->folder2hash($account, $new_name);
}
$this->folderHashes[$account][$index] = $new_name;
return $index;
}
private $folderHashes; private $folderHashes;
/** /**