aboutsummaryrefslogtreecommitdiffstats
path: root/Zotlabs/Storage/Browser.php
diff options
context:
space:
mode:
authorzottel <github@zottel.net>2016-07-27 09:31:20 +0200
committerzottel <github@zottel.net>2016-07-27 09:31:20 +0200
commite5a3179468c84ab78ffa655353bc068508e8cdfd (patch)
tree24d27705ad197ea1769f906404d6e14071f5599d /Zotlabs/Storage/Browser.php
parent11b97af250d8c5db015a736e9349f29efb6662d7 (diff)
parent672c3d7c6df2bf4667546c4376318d8684568014 (diff)
downloadvolse-hubzilla-e5a3179468c84ab78ffa655353bc068508e8cdfd.tar.gz
volse-hubzilla-e5a3179468c84ab78ffa655353bc068508e8cdfd.tar.bz2
volse-hubzilla-e5a3179468c84ab78ffa655353bc068508e8cdfd.zip
Merge remote-tracking branch 'upstream/dev' into dev
Diffstat (limited to 'Zotlabs/Storage/Browser.php')
-rw-r--r--Zotlabs/Storage/Browser.php75
1 files changed, 75 insertions, 0 deletions
diff --git a/Zotlabs/Storage/Browser.php b/Zotlabs/Storage/Browser.php
index 93c55bd4c..0d1d4e791 100644
--- a/Zotlabs/Storage/Browser.php
+++ b/Zotlabs/Storage/Browser.php
@@ -70,6 +70,81 @@ class Browser extends DAV\Browser\Plugin {
}
/**
+ * Extend from parent to add our own listeners
+ */
+ function initialize(DAV\Server $server) {
+ parent::initialize($server);
+ if ($this->enablePost) {
+ $this->server->on('onBrowserPostAction', [$this, 'cloudPostAction']);
+ }
+ }
+
+ /**
+ * Handles POST requests for tree operations.
+ *
+ * @param string $uri
+ * @param string $action
+ * @param array $postVars
+ * @return boolean false will stop other events in the beforeMethod chain to execute
+ */
+ function cloudPostAction($uri, $action, $postVars) {
+ switch ($postVars['sabreAction']) {
+ case 'mkcol' :
+ if (isset($postVars['name']) && trim($postVars['name'])) {
+ // Using basename() because we won't allow slashes
+ list(, $folderName) = \Sabre\HTTP\URLUtil::splitPath(trim($postVars['name']));
+
+ if (isset($postVars['resourceType'])) {
+ $resourceType = explode(',', $postVars['resourceType']);
+ } else {
+ $resourceType = ['{DAV:}collection'];
+ }
+
+ $properties = [];
+ foreach ($postVars as $varName => $varValue) {
+ // Any _POST variable in clark notation is treated
+ // like a property.
+ if ($varName[0] === '{') {
+ // PHP will convert any dots to underscores.
+ // This leaves us with no way to differentiate
+ // the two.
+ // Therefore we replace the string *DOT* with a
+ // real dot. * is not allowed in uris so we
+ // should be good.
+ $varName = str_replace('*DOT*', '.', $varName);
+ $properties[$varName] = $varValue;
+ }
+ }
+
+ $mkCol = new DAV\MkCol(
+ $resourceType,
+ $properties
+ );
+ $this->server->createCollection($uri . '/' . $folderName, $mkCol);
+ }
+ break;
+
+ case 'put' :
+
+ if ($_FILES)
+ $file = current($_FILES);
+ else
+ break;
+
+ for ($i = 0; $i < count($file['name']); $i++) {
+ list(, $newName) = \Sabre\HTTP\URLUtil::splitPath(trim($file['name'][$i]));
+
+ if (is_uploaded_file($file['tmp_name'][$i])) {
+ $this->server->createFile($uri . '/' . $newName, fopen($file['tmp_name'][$i], 'r'));
+ }
+ }
+ break;
+
+ }
+ return false;
+ }
+
+ /**
* @brief Creates the directory listing for the given path.
*
* @param string $path which should be displayed