mirror of
https://github.com/nextcloud/server.git
synced 2026-02-03 20:41:22 -05:00
To continue this formatting madness, here's a tiny patch that adds unified formatting for control structures like if and loops as well as classes, their methods and anonymous functions. This basically forces the constructs to start on the same line. This is not exactly what PSR2 wants, but I think we can have a few exceptions with "our" style. The starting of braces on the same line is pracrically standard for our code. This also removes and empty lines from method/function bodies at the beginning and end. Signed-off-by: Christoph Wurst <christoph@winzerhof-wurst.at>
306 lines
8.1 KiB
PHP
306 lines
8.1 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
/**
|
|
* @copyright Copyright (c) 2016, ownCloud GmbH.
|
|
*
|
|
* @author Christoph Wurst <christoph@winzerhof-wurst.at>
|
|
* @author Georg Ehrke <oc.list@georgehrke.com>
|
|
* @author Julius Härtl <jus@bitgrid.net>
|
|
* @author Roeland Jago Douma <roeland@famdouma.nl>
|
|
* @author Vincent Petry <pvince81@owncloud.com>
|
|
*
|
|
* @license AGPL-3.0
|
|
*
|
|
* This code 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.
|
|
*
|
|
* 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, version 3,
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>
|
|
*
|
|
*/
|
|
|
|
namespace OCA\DAV\AppInfo;
|
|
|
|
use OC\ServerContainer;
|
|
use OCA\DAV\CalDAV\Integration\ICalendarProvider;
|
|
use OCA\DAV\CardDAV\Integration\IAddressBookProvider;
|
|
use OCP\App\IAppManager;
|
|
use OCP\AppFramework\QueryException;
|
|
use function array_map;
|
|
use function class_exists;
|
|
use function is_array;
|
|
|
|
/**
|
|
* Manager for DAV plugins from apps, used to register them
|
|
* to the Sabre server.
|
|
*/
|
|
class PluginManager {
|
|
|
|
/**
|
|
* @var ServerContainer
|
|
*/
|
|
private $container;
|
|
|
|
/**
|
|
* @var IAppManager
|
|
*/
|
|
private $appManager;
|
|
|
|
/**
|
|
* App plugins
|
|
*
|
|
* @var array
|
|
*/
|
|
private $plugins = null;
|
|
|
|
/**
|
|
* App collections
|
|
*
|
|
* @var array
|
|
*/
|
|
private $collections = null;
|
|
|
|
/**
|
|
* Address book plugins
|
|
*
|
|
* @var IAddressBookProvider[]|null
|
|
*/
|
|
private $addressBookPlugins = null;
|
|
|
|
/**
|
|
* Calendar plugins
|
|
*
|
|
* @var array
|
|
*/
|
|
private $calendarPlugins = null;
|
|
|
|
/**
|
|
* Contstruct a PluginManager
|
|
*
|
|
* @param ServerContainer $container server container for resolving plugin classes
|
|
* @param IAppManager $appManager app manager to loading apps and their info
|
|
*/
|
|
public function __construct(ServerContainer $container, IAppManager $appManager) {
|
|
$this->container = $container;
|
|
$this->appManager = $appManager;
|
|
}
|
|
|
|
/**
|
|
* Returns an array of app-registered plugins
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getAppPlugins() {
|
|
if (null === $this->plugins) {
|
|
$this->populate();
|
|
}
|
|
return $this->plugins;
|
|
}
|
|
|
|
/**
|
|
* Returns an array of app-registered collections
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getAppCollections() {
|
|
if (null === $this->collections) {
|
|
$this->populate();
|
|
}
|
|
return $this->collections;
|
|
}
|
|
|
|
/**
|
|
* @return IAddressBookProvider[]
|
|
*/
|
|
public function getAddressBookPlugins(): array {
|
|
if ($this->addressBookPlugins === null) {
|
|
$this->populate();
|
|
}
|
|
return $this->addressBookPlugins;
|
|
}
|
|
|
|
/**
|
|
* Returns an array of app-registered calendar plugins
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getCalendarPlugins():array {
|
|
if (null === $this->calendarPlugins) {
|
|
$this->populate();
|
|
}
|
|
return $this->calendarPlugins;
|
|
}
|
|
|
|
/**
|
|
* Retrieve plugin and collection list and populate attributes
|
|
*/
|
|
private function populate() {
|
|
$this->plugins = [];
|
|
$this->addressBookPlugins = [];
|
|
$this->calendarPlugins = [];
|
|
$this->collections = [];
|
|
foreach ($this->appManager->getInstalledApps() as $app) {
|
|
// load plugins and collections from info.xml
|
|
$info = $this->appManager->getAppInfo($app);
|
|
if (!isset($info['types']) || !in_array('dav', $info['types'], true)) {
|
|
continue;
|
|
}
|
|
$this->loadSabrePluginsFromInfoXml($this->extractPluginList($info));
|
|
$this->loadSabreCollectionsFromInfoXml($this->extractCollectionList($info));
|
|
$this->loadSabreAddressBookPluginsFromInfoXml($this->extractAddressBookPluginList($info));
|
|
$this->loadSabreCalendarPluginsFromInfoXml($this->extractCalendarPluginList($info));
|
|
}
|
|
}
|
|
|
|
private function extractPluginList(array $array) {
|
|
if (isset($array['sabre']) && is_array($array['sabre'])) {
|
|
if (isset($array['sabre']['plugins']) && is_array($array['sabre']['plugins'])) {
|
|
if (isset($array['sabre']['plugins']['plugin'])) {
|
|
$items = $array['sabre']['plugins']['plugin'];
|
|
if (!is_array($items)) {
|
|
$items = [$items];
|
|
}
|
|
return $items;
|
|
}
|
|
}
|
|
}
|
|
return [];
|
|
}
|
|
|
|
private function extractCollectionList(array $array) {
|
|
if (isset($array['sabre']) && is_array($array['sabre'])) {
|
|
if (isset($array['sabre']['collections']) && is_array($array['sabre']['collections'])) {
|
|
if (isset($array['sabre']['collections']['collection'])) {
|
|
$items = $array['sabre']['collections']['collection'];
|
|
if (!is_array($items)) {
|
|
$items = [$items];
|
|
}
|
|
return $items;
|
|
}
|
|
}
|
|
}
|
|
return [];
|
|
}
|
|
|
|
/**
|
|
* @param array $array
|
|
*
|
|
* @return string[]
|
|
*/
|
|
private function extractAddressBookPluginList(array $array): array {
|
|
if (!isset($array['sabre']) || !is_array($array['sabre'])) {
|
|
return [];
|
|
}
|
|
if (!isset($array['sabre']['address-book-plugins']) || !is_array($array['sabre']['address-book-plugins'])) {
|
|
return [];
|
|
}
|
|
if (!isset($array['sabre']['address-book-plugins']['plugin'])) {
|
|
return [];
|
|
}
|
|
|
|
$items = $array['sabre']['address-book-plugins']['plugin'];
|
|
if (!is_array($items)) {
|
|
$items = [$items];
|
|
}
|
|
return $items;
|
|
}
|
|
|
|
private function extractCalendarPluginList(array $array):array {
|
|
if (isset($array['sabre']) && is_array($array['sabre'])) {
|
|
if (isset($array['sabre']['calendar-plugins']) && is_array($array['sabre']['calendar-plugins'])) {
|
|
if (isset($array['sabre']['calendar-plugins']['plugin'])) {
|
|
$items = $array['sabre']['calendar-plugins']['plugin'];
|
|
if (!is_array($items)) {
|
|
$items = [$items];
|
|
}
|
|
return $items;
|
|
}
|
|
}
|
|
}
|
|
return [];
|
|
}
|
|
|
|
private function loadSabrePluginsFromInfoXml(array $plugins) {
|
|
foreach ($plugins as $plugin) {
|
|
try {
|
|
$this->plugins[] = $this->container->query($plugin);
|
|
} catch (QueryException $e) {
|
|
if (class_exists($plugin)) {
|
|
$this->plugins[] = new $plugin();
|
|
} else {
|
|
throw new \Exception("Sabre plugin class '$plugin' is unknown and could not be loaded");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
private function loadSabreCollectionsFromInfoXml(array $collections) {
|
|
foreach ($collections as $collection) {
|
|
try {
|
|
$this->collections[] = $this->container->query($collection);
|
|
} catch (QueryException $e) {
|
|
if (class_exists($collection)) {
|
|
$this->collections[] = new $collection();
|
|
} else {
|
|
throw new \Exception("Sabre collection class '$collection' is unknown and could not be loaded");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
private function createPluginInstance(string $className) {
|
|
try {
|
|
return $this->container->query($className);
|
|
} catch (QueryException $e) {
|
|
if (class_exists($className)) {
|
|
return new $className();
|
|
}
|
|
}
|
|
|
|
throw new \Exception("Sabre plugin class '$className' is unknown and could not be loaded");
|
|
}
|
|
|
|
/**
|
|
* @param string[] $plugin
|
|
*/
|
|
private function loadSabreAddressBookPluginsFromInfoXml(array $plugins): void {
|
|
$providers = array_map(function (string $className): IAddressBookProvider {
|
|
$instance = $this->createPluginInstance($className);
|
|
if (!($instance instanceof IAddressBookProvider)) {
|
|
throw new \Exception("Sabre address book plugin class '$className' does not implement the \OCA\DAV\CardDAV\Integration\IAddressBookProvider interface");
|
|
}
|
|
return $instance;
|
|
}, $plugins);
|
|
foreach ($providers as $provider) {
|
|
$this->addressBookPlugins[] = $provider;
|
|
}
|
|
}
|
|
|
|
private function loadSabreCalendarPluginsFromInfoXml(array $calendarPlugins):void {
|
|
foreach ($calendarPlugins as $calendarPlugin) {
|
|
try {
|
|
$instantiatedCalendarPlugin = $this->container->query($calendarPlugin);
|
|
} catch (QueryException $e) {
|
|
if (class_exists($calendarPlugin)) {
|
|
$instantiatedCalendarPlugin = new $calendarPlugin();
|
|
} else {
|
|
throw new \Exception("Sabre calendar-plugin class '$calendarPlugin' is unknown and could not be loaded");
|
|
}
|
|
}
|
|
|
|
if (!($instantiatedCalendarPlugin instanceof ICalendarProvider)) {
|
|
throw new \Exception("Sabre calendar-plugin class '$calendarPlugin' does not implement ICalendarProvider interface");
|
|
}
|
|
|
|
$this->calendarPlugins[] = $instantiatedCalendarPlugin;
|
|
}
|
|
}
|
|
}
|