summaryrefslogtreecommitdiffstats
path: root/apps/files_external
diff options
context:
space:
mode:
authorMichael Gapczynski <GapczynskiM@gmail.com>2012-06-14 20:56:48 -0400
committerMichael Gapczynski <GapczynskiM@gmail.com>2012-06-14 20:57:08 -0400
commit92083aa20cd0367d5b1643a4c98580769e5d57ca (patch)
tree97c24f977b12e5ab910f734f385ed951a99c3841 /apps/files_external
parentf6aa366857a28da302461d1c426288b23d49b7af (diff)
downloadnextcloud-server-92083aa20cd0367d5b1643a4c98580769e5d57ca.tar.gz
nextcloud-server-92083aa20cd0367d5b1643a4c98580769e5d57ca.zip
Fix upload for Google Drive; Google Documents List API documentation was misleading
Diffstat (limited to 'apps/files_external')
-rw-r--r--apps/files_external/lib/google.php16
1 files changed, 9 insertions, 7 deletions
diff --git a/apps/files_external/lib/google.php b/apps/files_external/lib/google.php
index c2a4af0ff8a..fe60a06629a 100644
--- a/apps/files_external/lib/google.php
+++ b/apps/files_external/lib/google.php
@@ -40,7 +40,7 @@ class OC_Filestorage_Google extends OC_Filestorage_Common {
$this->entries = array();
}
- private function sendRequest($uri, $httpMethod, $postData = null, $extraHeaders = null, $isDownload = false, $returnHeaders = false, $isContentXML = true) {
+ private function sendRequest($uri, $httpMethod, $postData = null, $extraHeaders = null, $isDownload = false, $returnHeaders = false, $isContentXML = true, $returnHTTPCode = false) {
$uri = trim($uri);
// create an associative array from each key/value url query param pair.
$params = array();
@@ -108,6 +108,8 @@ class OC_Filestorage_Google extends OC_Filestorage_Common {
if ($httpCode <= 308) {
if ($isDownload) {
return $tmpFile;
+ } else if ($returnHTTPCode) {
+ return array('result' => $result, 'code' => $httpCode);
} else {
return $result;
}
@@ -425,7 +427,7 @@ class OC_Filestorage_Google extends OC_Filestorage_Common {
$etag = $entry->getAttribute('gd:etag');
$links = $entry->getElementsByTagName('link');
foreach ($links as $link) {
- if ($link->getAttribute('rel') == 'http://schemas.google.com/g/2005#resumable-edit-media') {
+ if ($link->getAttribute('rel') == 'http://schemas.google.com/g/2005#resumable-create-media') {
$uploadUri = $link->getAttribute('href');
break;
}
@@ -461,12 +463,12 @@ class OC_Filestorage_Google extends OC_Filestorage_Common {
}
}
$end = $i + $chunkSize - 1;
- $headers = array('Content-Length: '.$chunkSize, 'Content-Type: '.$mimetype, 'Content Range: bytes '.$i.'-'.$end.'/'.$size);
+ $headers = array('Content-Length: '.$chunkSize, 'Content-Type: '.$mimetype, 'Content-Range: bytes '.$i.'-'.$end.'/'.$size);
$postData = fread($handle, $chunkSize);
- $result = $this->sendRequest($uploadUri, 'PUT', $postData, $headers, false, true, false);
- if ($result) {
- // Get next location to upload file chunk
- if (preg_match('@^Location: (.*)$@m', $result, $matches)) {
+ $result = $this->sendRequest($uploadUri, 'PUT', $postData, $headers, false, true, false, true);
+ if ($result['code'] == '308') {
+ if (preg_match('@^Location: (.*)$@m', $result['result'], $matches)) {
+ // Get next location to upload file chunk
$uploadUri = trim($matches[1]);
}
$i += $chunkSize;