48 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
| <?php
 | |
| 
 | |
| namespace Sabre\CalDAV\Backend;
 | |
| 
 | |
| /**
 | |
|  * Adds caldav notification support to a backend.
 | |
|  *
 | |
|  * Note: This feature is experimental, and may change in between different
 | |
|  * SabreDAV versions.
 | |
|  *
 | |
|  * Notifications are defined at:
 | |
|  * http://svn.calendarserver.org/repository/calendarserver/CalendarServer/trunk/doc/Extensions/caldav-notifications.txt
 | |
|  *
 | |
|  * These notifications are basically a list of server-generated notifications
 | |
|  * displayed to the user. Users can dismiss notifications by deleting them.
 | |
|  *
 | |
|  * The primary usecase is to allow for calendar-sharing.
 | |
|  *
 | |
|  * @copyright Copyright (C) 2007-2015 fruux GmbH (https://fruux.com/).
 | |
|  * @author Evert Pot (http://evertpot.com/)
 | |
|  * @license http://sabre.io/license/ Modified BSD License
 | |
|  */
 | |
| interface NotificationSupport extends BackendInterface {
 | |
| 
 | |
|     /**
 | |
|      * Returns a list of notifications for a given principal url.
 | |
|      *
 | |
|      * The returned array should only consist of implementations of
 | |
|      * \Sabre\CalDAV\Notifications\INotificationType.
 | |
|      *
 | |
|      * @param string $principalUri
 | |
|      * @return array
 | |
|      */
 | |
|     public function getNotificationsForPrincipal($principalUri);
 | |
| 
 | |
|     /**
 | |
|      * This deletes a specific notifcation.
 | |
|      *
 | |
|      * This may be called by a client once it deems a notification handled.
 | |
|      *
 | |
|      * @param string $principalUri
 | |
|      * @param \Sabre\CalDAV\Notifications\INotificationType $notification
 | |
|      * @return void
 | |
|      */
 | |
|     public function deleteNotification($principalUri, \Sabre\CalDAV\Notifications\INotificationType $notification);
 | |
| 
 | |
| }
 |