2012-06-03 14:19:28 -04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
2018-01-20 11:01:59 -05:00
|
|
|
* The baseclass for all server addons.
|
2012-06-03 14:19:28 -04:00
|
|
|
*
|
|
|
|
* Plugins can modify or extend the servers behaviour.
|
|
|
|
*
|
|
|
|
* @package Sabre
|
|
|
|
* @subpackage DAV
|
|
|
|
* @copyright Copyright (C) 2007-2012 Rooftop Solutions. All rights reserved.
|
|
|
|
* @author Evert Pot (http://www.rooftopsolutions.nl/)
|
|
|
|
* @license http://code.google.com/p/sabredav/wiki/License Modified BSD License
|
|
|
|
*/
|
|
|
|
abstract class Sabre_DAV_ServerPlugin {
|
|
|
|
|
|
|
|
/**
|
2018-01-20 11:01:59 -05:00
|
|
|
* This initializes the addon.
|
2012-06-03 14:19:28 -04:00
|
|
|
*
|
|
|
|
* This function is called by Sabre_DAV_Server, after
|
|
|
|
* addPlugin is called.
|
|
|
|
*
|
|
|
|
* This method should set up the requires event subscriptions.
|
|
|
|
*
|
|
|
|
* @param Sabre_DAV_Server $server
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
abstract public function initialize(Sabre_DAV_Server $server);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method should return a list of server-features.
|
|
|
|
*
|
|
|
|
* This is for example 'versioning' and is added to the DAV: header
|
|
|
|
* in an OPTIONS response.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getFeatures() {
|
|
|
|
|
|
|
|
return array();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2018-01-20 11:01:59 -05:00
|
|
|
* Use this method to tell the server this addon defines additional
|
2012-06-03 14:19:28 -04:00
|
|
|
* HTTP methods.
|
|
|
|
*
|
|
|
|
* This method is passed a uri. It should only return HTTP methods that are
|
|
|
|
* available for the specified uri.
|
|
|
|
*
|
|
|
|
* @param string $uri
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getHTTPMethods($uri) {
|
|
|
|
|
|
|
|
return array();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2018-01-20 11:01:59 -05:00
|
|
|
* Returns a addon name.
|
2012-06-03 14:19:28 -04:00
|
|
|
*
|
2018-01-20 11:01:59 -05:00
|
|
|
* Using this name other addons will be able to access other addons
|
2012-06-03 14:19:28 -04:00
|
|
|
* using Sabre_DAV_Server::getPlugin
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getPluginName() {
|
|
|
|
|
|
|
|
return get_class($this);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2018-01-20 11:01:59 -05:00
|
|
|
* Returns a list of reports this addon supports.
|
2012-06-03 14:19:28 -04:00
|
|
|
*
|
|
|
|
* This will be used in the {DAV:}supported-report-set property.
|
|
|
|
* Note that you still need to subscribe to the 'report' event to actually
|
|
|
|
* implement them
|
|
|
|
*
|
|
|
|
* @param string $uri
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getSupportedReportSet($uri) {
|
|
|
|
|
|
|
|
return array();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|