diff options
author | Thomas Müller <thomas.mueller@tmit.eu> | 2016-04-06 08:34:37 +0200 |
---|---|---|
committer | Thomas Müller <thomas.mueller@tmit.eu> | 2016-04-06 08:34:37 +0200 |
commit | 01b26d78a034db3917df09358c4dcb52d2761b64 (patch) | |
tree | 1bac81a35618a8f6ccb8da91e879e58a841301b2 | |
parent | d739af3d4a5ee44556ac33a0cc59a5024831b779 (diff) | |
parent | 7bdde98617ad3c7f56dced1add0a155f4a0e5a2e (diff) | |
download | nextcloud-server-01b26d78a034db3917df09358c4dcb52d2761b64.tar.gz nextcloud-server-01b26d78a034db3917df09358c4dcb52d2761b64.zip |
Merge pull request #23793 from owncloud/hard-code-dav-endpoints
All webdav endpoints within remote.php are now hardcoded - helps to p…
-rw-r--r-- | apps/dav/appinfo/info.xml | 11 | ||||
-rw-r--r-- | remote.php | 23 |
2 files changed, 22 insertions, 12 deletions
diff --git a/apps/dav/appinfo/info.xml b/apps/dav/appinfo/info.xml index b7c7267dce8..a8e7df6e8e2 100644 --- a/apps/dav/appinfo/info.xml +++ b/apps/dav/appinfo/info.xml @@ -10,17 +10,6 @@ <types> <filesystem/> </types> - <remote> - <files>appinfo/v1/webdav.php</files> - <webdav>appinfo/v1/webdav.php</webdav> - <dav>appinfo/v2/remote.php</dav> - <!-- carddav endpoints as used before ownCloud 9.0 --> - <contacts>appinfo/v1/carddav.php</contacts> - <carddav>appinfo/v1/carddav.php</carddav> - <!-- caldav endpoints as used before ownCloud 9.0 --> - <calendar>appinfo/v1/caldav.php</calendar> - <caldav>appinfo/v1/caldav.php</caldav> - </remote> <public> <webdav>appinfo/v1/publicwebdav.php</webdav> </public> diff --git a/remote.php b/remote.php index df229eb675a..86b47629d73 100644 --- a/remote.php +++ b/remote.php @@ -84,6 +84,27 @@ function handleException(Exception $e) { } } +/** + * @param $service + * @return string + */ +function resolveService($service) { + $services = [ + 'webdav' => 'dav/appinfo/v1/webdav.php', + 'dav' => 'dav/appinfo/v2/remote.php', + 'caldav' => 'dav/appinfo/v1/caldav.php', + 'calendar' => 'dav/appinfo/v1/caldav.php', + 'carddav' => 'dav/appinfo/v1/carddav.php', + 'contacts' => 'dav/appinfo/v1/carddav.php', + 'files' => 'dav/appinfo/v1/webdav.php', + ]; + if (isset($services[$service])) { + return $services[$service]; + } + + return \OC::$server->getConfig()->getAppValue('core', 'remote_' . $service); +} + try { require_once 'lib/base.php'; @@ -103,7 +124,7 @@ try { } $service=substr($pathInfo, 1, $pos-1); - $file = \OC::$server->getConfig()->getAppValue('core', 'remote_' . $service); + $file = resolveService($service); if(is_null($file)) { throw new RemoteException('Path not found', OC_Response::STATUS_NOT_FOUND); |