1<?php 2 3namespace Sabre\DAV\Sync; 4 5use Sabre\DAV; 6 7/** 8 * If a class extends ISyncCollection, it supports WebDAV-sync. 9 * 10 * You are responsible for maintaining a changelist for this collection. This 11 * means that if any child nodes in this collection was created, modified or 12 * deleted in any way, you should maintain an updated changelist. 13 * 14 * @copyright Copyright (C) fruux GmbH (https://fruux.com/) 15 * @author Evert Pot (http://evertpot.com/) 16 * @license http://sabre.io/license/ Modified BSD License 17 */ 18interface ISyncCollection extends DAV\ICollection { 19 20 /** 21 * This method returns the current sync-token for this collection. 22 * This can be any string. 23 * 24 * If null is returned from this function, the plugin assumes there's no 25 * sync information available. 26 * 27 * @return string|null 28 */ 29 function getSyncToken(); 30 31 /** 32 * The getChanges method returns all the changes that have happened, since 33 * the specified syncToken and the current collection. 34 * 35 * This function should return an array, such as the following: 36 * 37 * [ 38 * 'syncToken' => 'The current synctoken', 39 * 'added' => [ 40 * 'new.txt', 41 * ], 42 * 'modified' => [ 43 * 'modified.txt', 44 * ], 45 * 'deleted' => array( 46 * 'foo.php.bak', 47 * 'old.txt' 48 * ) 49 * ]; 50 * 51 * The syncToken property should reflect the *current* syncToken of the 52 * collection, as reported getSyncToken(). This is needed here too, to 53 * ensure the operation is atomic. 54 * 55 * If the syncToken is specified as null, this is an initial sync, and all 56 * members should be reported. 57 * 58 * The modified property is an array of nodenames that have changed since 59 * the last token. 60 * 61 * The deleted property is an array with nodenames, that have been deleted 62 * from collection. 63 * 64 * The second argument is basically the 'depth' of the report. If it's 1, 65 * you only have to report changes that happened only directly in immediate 66 * descendants. If it's 2, it should also include changes from the nodes 67 * below the child collections. (grandchildren) 68 * 69 * The third (optional) argument allows a client to specify how many 70 * results should be returned at most. If the limit is not specified, it 71 * should be treated as infinite. 72 * 73 * If the limit (infinite or not) is higher than you're willing to return, 74 * you should throw a Sabre\DAV\Exception\TooMuchMatches() exception. 75 * 76 * If the syncToken is expired (due to data cleanup) or unknown, you must 77 * return null. 78 * 79 * The limit is 'suggestive'. You are free to ignore it. 80 * 81 * @param string $syncToken 82 * @param int $syncLevel 83 * @param int $limit 84 * @return array 85 */ 86 function getChanges($syncToken, $syncLevel, $limit = null); 87 88} 89