/usr/share/z-push/lib/request/gethierarchy.php is in z-push-common 2.3.8-2ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 | <?php
/***********************************************
* File : gethierarchy.php
* Project : Z-Push
* Descr : Provides the GETHIERARCHY command
*
* Created : 16.02.2012
*
* Copyright 2007 - 2016 Zarafa Deutschland GmbH
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License, version 3,
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* Consult LICENSE file for details
************************************************/
class GetHierarchy extends RequestProcessor {
/**
* Handles the GetHierarchy command
* simply returns current hierarchy of all folders
*
* @param int $commandCode
*
* @access public
* @return boolean
*/
public function Handle($commandCode) {
try {
$folders = self::$backend->GetHierarchy();
if (!$folders || empty($folders))
throw new StatusException("GetHierarchy() did not return any data.");
// TODO execute $data->Check() to see if SyncObject is valid
}
catch (StatusException $ex) {
return false;
}
self::$encoder->StartWBXML();
self::$encoder->startTag(SYNC_FOLDERHIERARCHY_FOLDERS);
foreach ($folders as $folder) {
self::$encoder->startTag(SYNC_FOLDERHIERARCHY_FOLDER);
$folder->Encode(self::$encoder);
self::$encoder->endTag();
}
self::$encoder->endTag();
// save hierarchy for upcoming syncing
return self::$deviceManager->InitializeFolderCache($folders);
}
}
|