mirror of
https://github.com/YunoHost-Apps/z-push_ynh.git
synced 2024-09-03 18:05:58 +02:00
157 lines
No EOL
8.3 KiB
PHP
157 lines
No EOL
8.3 KiB
PHP
<?php
|
|
/***********************************************
|
|
* File : synctaskrecurrence.php
|
|
* Project : Z-Push
|
|
* Descr : WBXML tasl recurrence entities that can
|
|
* be parsed directly (as a stream) from WBXML.
|
|
* It is automatically decoded
|
|
* according to $mapping,
|
|
* and the Sync WBXML mappings.
|
|
*
|
|
* Created : 05.09.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
|
|
************************************************/
|
|
|
|
|
|
// Exactly the same as SyncRecurrence, but then with SYNC_POOMTASKS_*
|
|
class SyncTaskRecurrence extends SyncObject {
|
|
public $start;
|
|
public $type;
|
|
public $until;
|
|
public $occurrences;
|
|
public $interval;
|
|
public $dayofweek;
|
|
public $dayofmonth;
|
|
public $weekofmonth;
|
|
public $monthofyear;
|
|
public $deadoccur;
|
|
|
|
function SyncTaskRecurrence() {
|
|
$mapping = array (
|
|
SYNC_POOMTASKS_START => array ( self::STREAMER_VAR => "start",
|
|
self::STREAMER_TYPE => self::STREAMER_TYPE_DATE),
|
|
|
|
// Recurrence type
|
|
// 0 = Recurs daily
|
|
// 1 = Recurs weekly
|
|
// 2 = Recurs monthly
|
|
// 3 = Recurs monthly on the nth day
|
|
// 5 = Recurs yearly
|
|
// 6 = Recurs yearly on the nth day
|
|
SYNC_POOMTASKS_TYPE => array ( self::STREAMER_VAR => "type",
|
|
self::STREAMER_CHECKS => array( self::STREAMER_CHECK_REQUIRED => self::STREAMER_CHECK_SETZERO,
|
|
self::STREAMER_CHECK_ONEVALUEOF => array(0,1,2,3,5,6) )),
|
|
|
|
SYNC_POOMTASKS_UNTIL => array ( self::STREAMER_VAR => "until",
|
|
self::STREAMER_TYPE => self::STREAMER_TYPE_DATE ),
|
|
|
|
SYNC_POOMTASKS_OCCURRENCES => array ( self::STREAMER_VAR => "occurrences",
|
|
self::STREAMER_CHECKS => array( self::STREAMER_CHECK_CMPHIGHER => 0,
|
|
self::STREAMER_CHECK_CMPLOWER => 1000 )),
|
|
|
|
SYNC_POOMTASKS_INTERVAL => array ( self::STREAMER_VAR => "interval",
|
|
self::STREAMER_CHECKS => array( self::STREAMER_CHECK_CMPHIGHER => 0,
|
|
self::STREAMER_CHECK_CMPLOWER => 1000 )),
|
|
|
|
//TODO: check iOS5 sends deadoccur inside of the recurrence
|
|
SYNC_POOMTASKS_DEADOCCUR => array ( self::STREAMER_VAR => "deadoccur"),
|
|
|
|
// DayOfWeek values
|
|
// 1 = Sunday
|
|
// 2 = Monday
|
|
// 4 = Tuesday
|
|
// 8 = Wednesday
|
|
// 16 = Thursday
|
|
// 32 = Friday
|
|
// 62 = Weekdays // TODO check: value set by WA with daily weekday recurrence
|
|
// 64 = Saturday
|
|
// 127 = The last day of the month. Value valid only in monthly or yearly recurrences.
|
|
SYNC_POOMTASKS_DAYOFWEEK => array ( self::STREAMER_VAR => "dayofweek",
|
|
self::STREAMER_CHECKS => array( self::STREAMER_CHECK_CMPHIGHER => 0,
|
|
self::STREAMER_CHECK_CMPLOWER => 128 )),
|
|
|
|
// DayOfMonth values
|
|
// 1-31 representing the day
|
|
SYNC_POOMTASKS_DAYOFMONTH => array ( self::STREAMER_VAR => "dayofmonth",
|
|
self::STREAMER_CHECKS => array( self::STREAMER_CHECK_CMPHIGHER => 0,
|
|
self::STREAMER_CHECK_CMPLOWER => 32 )),
|
|
|
|
// WeekOfMonth
|
|
// 1-4 = Y st/nd/rd/th week of month
|
|
// 5 = last week of month
|
|
SYNC_POOMTASKS_WEEKOFMONTH => array ( self::STREAMER_VAR => "weekofmonth",
|
|
self::STREAMER_CHECKS => array( self::STREAMER_CHECK_ONEVALUEOF => array(1,2,3,4,5) )),
|
|
|
|
// MonthOfYear
|
|
// 1-12 representing the month
|
|
SYNC_POOMTASKS_MONTHOFYEAR => array ( self::STREAMER_VAR => "monthofyear",
|
|
self::STREAMER_CHECKS => array( self::STREAMER_CHECK_ONEVALUEOF => array(1,2,3,4,5,6,7,8,9,10,11,12) )),
|
|
|
|
);
|
|
parent::SyncObject($mapping);
|
|
}
|
|
|
|
/**
|
|
* Method checks if the object has the minimum of required parameters
|
|
* and fullfills semantic dependencies
|
|
*
|
|
* This overloads the general check() with special checks to be executed
|
|
*
|
|
* @param boolean $logAsDebug (opt) default is false, so messages are logged in WARN log level
|
|
*
|
|
* @access public
|
|
* @return boolean
|
|
*/
|
|
public function Check($logAsDebug = false) {
|
|
$ret = parent::Check($logAsDebug);
|
|
|
|
// semantic checks general "turn off switch"
|
|
if (defined("DO_SEMANTIC_CHECKS") && DO_SEMANTIC_CHECKS === false)
|
|
return $ret;
|
|
|
|
if (!$ret)
|
|
return false;
|
|
|
|
if (isset($this->start) && isset($this->until) && $this->until < $this->start) {
|
|
ZLog::Write(LOGLEVEL_WARN, sprintf("SyncObject->Check(): Unmet condition in object from type %s: parameter 'start' is HIGHER than 'until'. Check failed!", get_class($this) ));
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|
|
|
|
?>
|