mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-07 12:30:28 +01:00
66 lines
2.0 KiB
PHP
66 lines
2.0 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace Sabre\CalDAV\Backend;
|
||
|
|
||
|
/**
|
||
|
* Implementing this interface adds CalDAV Scheduling support to your caldav
|
||
|
* server, as defined in rfc6638.
|
||
|
*
|
||
|
* @copyright Copyright (C) fruux GmbH (https://fruux.com/)
|
||
|
* @author Evert Pot (http://evertpot.com/)
|
||
|
* @license http://sabre.io/license/ Modified BSD License
|
||
|
*/
|
||
|
interface SchedulingSupport extends BackendInterface {
|
||
|
|
||
|
/**
|
||
|
* Returns a single scheduling object for the inbox collection.
|
||
|
*
|
||
|
* The returned array should contain the following elements:
|
||
|
* * uri - A unique basename for the object. This will be used to
|
||
|
* construct a full uri.
|
||
|
* * calendardata - The iCalendar object
|
||
|
* * lastmodified - The last modification date. Can be an int for a unix
|
||
|
* timestamp, or a PHP DateTime object.
|
||
|
* * etag - A unique token that must change if the object changed.
|
||
|
* * size - The size of the object, in bytes.
|
||
|
*
|
||
|
* @param string $principalUri
|
||
|
* @param string $objectUri
|
||
|
* @return array
|
||
|
*/
|
||
|
function getSchedulingObject($principalUri, $objectUri);
|
||
|
|
||
|
/**
|
||
|
* Returns all scheduling objects for the inbox collection.
|
||
|
*
|
||
|
* These objects should be returned as an array. Every item in the array
|
||
|
* should follow the same structure as returned from getSchedulingObject.
|
||
|
*
|
||
|
* The main difference is that 'calendardata' is optional.
|
||
|
*
|
||
|
* @param string $principalUri
|
||
|
* @return array
|
||
|
*/
|
||
|
function getSchedulingObjects($principalUri);
|
||
|
|
||
|
/**
|
||
|
* Deletes a scheduling object from the inbox collection.
|
||
|
*
|
||
|
* @param string $principalUri
|
||
|
* @param string $objectUri
|
||
|
* @return void
|
||
|
*/
|
||
|
function deleteSchedulingObject($principalUri, $objectUri);
|
||
|
|
||
|
/**
|
||
|
* Creates a new scheduling object. This should land in a users' inbox.
|
||
|
*
|
||
|
* @param string $principalUri
|
||
|
* @param string $objectUri
|
||
|
* @param string $objectData
|
||
|
* @return void
|
||
|
*/
|
||
|
function createSchedulingObject($principalUri, $objectUri, $objectData);
|
||
|
|
||
|
}
|