1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/z-push_ynh.git synced 2024-09-03 18:05:58 +02:00
z-push_ynh/sources/lib/core/contentparameters.php
2014-12-17 15:40:48 +00:00

141 lines
No EOL
5 KiB
PHP

<?php
/***********************************************
* File : contentparameters.php
* Project : Z-Push
* Descr : Simple transportation class for
* requested content parameter options
*
* Created : 11.04.2011
*
* Copyright 2007 - 2013 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 with the following additional
* term according to sec. 7:
*
* According to sec. 7 of the GNU Affero General Public License, version 3,
* the terms of the AGPL are supplemented with the following terms:
*
* "Zarafa" is a registered trademark of Zarafa B.V.
* "Z-Push" is a registered trademark of Zarafa Deutschland GmbH
* The licensing of the Program under the AGPL does not imply a trademark license.
* Therefore any rights, title and interest in our trademarks remain entirely with us.
*
* However, if you propagate an unmodified version of the Program you are
* allowed to use the term "Z-Push" to indicate that you distribute the Program.
* Furthermore you may use our trademarks where it is necessary to indicate
* the intended purpose of a product or service provided you use it in accordance
* with honest practices in industrial or commercial matters.
* If you want to propagate modified versions of the Program under the name "Z-Push",
* you may only do so if you have a written permission by Zarafa Deutschland GmbH
* (to acquire a permission please contact Zarafa at trademark@zarafa.com).
*
* 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 ContentParameters extends StateObject {
protected $unsetdata = array( 'contentclass' => false,
'foldertype' => '',
'conflict' => false,
'deletesasmoves' => true,
'filtertype' => false,
'truncation' => false,
'rtftruncation' => false,
'mimesupport' => false,
'conversationmode' => false,
);
private $synckeyChanged = false;
/**
* Expected magic getters and setters
*
* GetContentClass() + SetContentClass()
* GetConflict() + SetConflict()
* GetDeletesAsMoves() + SetDeletesAsMoves()
* GetFilterType() + SetFilterType()
* GetTruncation() + SetTruncation
* GetRTFTruncation() + SetRTFTruncation()
* GetMimeSupport () + SetMimeSupport()
* GetMimeTruncation() + SetMimeTruncation()
* GetConversationMode() + SetConversationMode()
*/
/**
* Overwrite StateObject->__call so we are able to handle ContentParameters->BodyPreference()
*
* @access public
* @return mixed
*/
public function __call($name, $arguments) {
if ($name === "BodyPreference")
return $this->BodyPreference($arguments[0]);
return parent::__call($name, $arguments);
}
/**
* Instantiates/returns the bodypreference object for a type
*
* @param int $type
*
* @access public
* @return int/boolean returns false if value is not defined
*/
public function BodyPreference($type) {
if (!isset($this->bodypref))
$this->bodypref = array();
if (isset($this->bodypref[$type]))
return $this->bodypref[$type];
else {
$asb = new BodyPreference();
$arr = (array)$this->bodypref;
$arr[$type] = $asb;
$this->bodypref = $arr;
return $asb;
}
}
/**
* Returns available body preference objects
*
* @access public
* @return array/boolean returns false if the client's body preference is not available
*/
public function GetBodyPreference() {
if (!isset($this->bodypref) || !(is_array($this->bodypref) || empty($this->bodypref))) {
ZLog::Write(LOGLEVEL_DEBUG, sprintf("ContentParameters->GetBodyPreference(): bodypref is empty or not set"));
return false;
}
return array_keys($this->bodypref);
}
/**
* Called before the StateObject is serialized
*
* @access protected
* @return boolean
*/
protected function preSerialize() {
parent::preSerialize();
if ($this->changed === true && $this->synckeyChanged)
$this->lastsynctime = time();
return true;
}
}
?>