summaryrefslogtreecommitdiffstats
path: root/lib/connector/sabre
diff options
context:
space:
mode:
authorBart Visscher <bartv@thisnet.nl>2012-08-03 15:58:17 +0200
committerBart Visscher <bartv@thisnet.nl>2012-08-03 15:58:17 +0200
commite36e00dc00eaecddd184d27a61acdefe880f6336 (patch)
treed542c025b0378dab9dcd7598d7172918684c9879 /lib/connector/sabre
parentc5d5ca88a87dcad5df8af77fd4c6c9bc6ba2282e (diff)
parent896d27de36dd26515f30fa3b0748c9c6089600af (diff)
downloadnextcloud-server-e36e00dc00eaecddd184d27a61acdefe880f6336.tar.gz
nextcloud-server-e36e00dc00eaecddd184d27a61acdefe880f6336.zip
Merge branch 'chunked_upload'
Diffstat (limited to 'lib/connector/sabre')
-rw-r--r--lib/connector/sabre/directory.php20
1 files changed, 16 insertions, 4 deletions
diff --git a/lib/connector/sabre/directory.php b/lib/connector/sabre/directory.php
index 7f8434c7151..09c65f19b80 100644
--- a/lib/connector/sabre/directory.php
+++ b/lib/connector/sabre/directory.php
@@ -48,11 +48,23 @@ class OC_Connector_Sabre_Directory extends OC_Connector_Sabre_Node implements Sa
* @return null|string
*/
public function createFile($name, $data = null) {
+ if (isset($_SERVER['HTTP_OC_CHUNKED'])) {
+ $info = OC_FileChunking::decodeName($name);
+ $chunk_handler = new OC_FileChunking($info);
+ $chunk_handler->store($info['index'], $data);
+ if ($chunk_handler->isComplete()) {
+ $newPath = $this->path . '/' . $info['name'];
+ $f = OC_Filesystem::fopen($newPath, 'w');
+ $chunk_handler->assemble($f);
+ return OC_Connector_Sabre_Node::getETagPropertyForPath($newPath);
+ }
+ } else {
+ $newPath = $this->path . '/' . $name;
+ OC_Filesystem::file_put_contents($newPath,$data);
+ return OC_Connector_Sabre_Node::getETagPropertyForPath($newPath);
+ }
- $newPath = $this->path . '/' . $name;
- OC_Filesystem::file_put_contents($newPath,$data);
-
- return OC_Connector_Sabre_Node::getETagPropertyForPath($newPath);
+ return null;
}
/**