diff options
author | Roeland Jago Douma <roeland@famdouma.nl> | 2016-08-09 10:21:20 +0200 |
---|---|---|
committer | Roeland Jago Douma <roeland@famdouma.nl> | 2016-08-09 20:56:31 +0200 |
commit | 575875e8d03e1396bcdb1fac75a7c6076fd92287 (patch) | |
tree | ffac7dadcef7ade1014bdc072a30408e9e8262bd | |
parent | 5214b62d55b3907eb2da7c8e51a3c0c6cd09a00f (diff) | |
download | nextcloud-server-575875e8d03e1396bcdb1fac75a7c6076fd92287.tar.gz nextcloud-server-575875e8d03e1396bcdb1fac75a7c6076fd92287.zip |
Allow OCS routes in Core and Settings
-rw-r--r-- | core/Controller/OCSController.php | 44 | ||||
-rw-r--r-- | lib/private/Route/Router.php | 5 |
2 files changed, 49 insertions, 0 deletions
diff --git a/core/Controller/OCSController.php b/core/Controller/OCSController.php new file mode 100644 index 00000000000..278a16186bf --- /dev/null +++ b/core/Controller/OCSController.php @@ -0,0 +1,44 @@ +<?php + +namespace OC\Core\Controller; + +use OC\CapabilitiesManager; +use OCP\AppFramework\Http\DataResponse; +use OCP\IRequest; + +class OCSController extends \OCP\AppFramework\OCSController { + + /** @var CapabilitiesManager */ + private $capabilitiesManager; + + /** + * OCSController constructor. + * + * @param string $appName + * @param IRequest $request + * @param CapabilitiesManager $capabilitiesManager + */ + public function __construct($appName, + IRequest $request, + CapabilitiesManager $capabilitiesManager) { + parent::__construct($appName, $request); + + $this->capabilitiesManager = $capabilitiesManager; + } + + public function getCapabilities() { + $result = []; + list($major, $minor, $micro) = \OCP\Util::getVersion(); + $result['version'] = array( + 'major' => $major, + 'minor' => $minor, + 'micro' => $micro, + 'string' => \OC_Util::getVersionString(), + 'edition' => \OC_Util::getEditionString(), + ); + + $result['capabilities'] = $this->capabilitiesManager->getCapabilities(); + + return new DataResponse(['data' => $result]); + } +}
\ No newline at end of file diff --git a/lib/private/Route/Router.php b/lib/private/Route/Router.php index 9df74184448..59f403d66e8 100644 --- a/lib/private/Route/Router.php +++ b/lib/private/Route/Router.php @@ -163,6 +163,11 @@ class Router implements IRouter { $this->useCollection('root'); require_once __DIR__ . '/../../../settings/routes.php'; require_once __DIR__ . '/../../../core/routes.php'; + + // Also add the OCS collection + $collection = $this->getCollection('root.ocs'); + $collection->addPrefix('/ocsapp'); + $this->root->addCollection($collection); } if ($this->loaded) { // include ocs routes, must be loaded last for /ocs prefix |