summaryrefslogtreecommitdiffstats
path: root/lib/util.php
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2013-02-09 05:13:33 -0800
committerThomas Müller <thomas.mueller@tmit.eu>2013-02-09 05:13:33 -0800
commit279cbeb001c9d8e917838ffb6a1b10394f27cf79 (patch)
tree2a88f2ebb5b693ad74e1ec36255c63180c8a43c4 /lib/util.php
parentec829bd345045df985f623fa2fe6587d0ce68eb2 (diff)
parentea42014ba4e7ad44a290f968b1a1439f78c1117c (diff)
downloadnextcloud-server-279cbeb001c9d8e917838ffb6a1b10394f27cf79.tar.gz
nextcloud-server-279cbeb001c9d8e917838ffb6a1b10394f27cf79.zip
Merge pull request #1481 from owncloud/fixing-1354-master
basic WebDAV test in place now
Diffstat (limited to 'lib/util.php')
-rwxr-xr-xlib/util.php34
1 files changed, 34 insertions, 0 deletions
diff --git a/lib/util.php b/lib/util.php
index 9ce974619bc..49d914e5fbd 100755
--- a/lib/util.php
+++ b/lib/util.php
@@ -516,6 +516,40 @@ class OC_Util {
}
}
+ /**
+ * we test if webDAV is working properly
+ *
+ * The basic assumption is that if the server returns 401/Not Authenticated for an unauthenticated PROPFIND
+ * the web server it self is setup properly.
+ *
+ * Why not an authenticated PROFIND and other verbs?
+ * - We don't have the password available
+ * - We have no idea about other auth methods implemented (e.g. OAuth with Bearer header)
+ *
+ */
+ public static function isWebDAVWorking() {
+ if (!function_exists('curl_init')) {
+ return;
+ }
+
+ $settings = array(
+ 'baseUri' => OC_Helper::linkToRemote('webdav'),
+ );
+
+ $client = new \Sabre_DAV_Client($settings);
+
+ $return = true;
+ try {
+ // test PROPFIND
+ $client->propfind('', array('{DAV:}resourcetype'));
+ } catch(\Sabre_DAV_Exception_NotAuthenticated $e) {
+ $return = true;
+ } catch(\Exception $e) {
+ $return = false;
+ }
+
+ return $return;
+ }
/**
* Check if the setlocal call doesn't work. This can happen if the right local packages are not available on the server.