diff options
author | Michael Gapczynski <GapczynskiM@gmail.com> | 2012-06-14 20:56:48 -0400 |
---|---|---|
committer | Michael Gapczynski <GapczynskiM@gmail.com> | 2012-06-14 20:57:08 -0400 |
commit | 92083aa20cd0367d5b1643a4c98580769e5d57ca (patch) | |
tree | 97c24f977b12e5ab910f734f385ed951a99c3841 /apps/files_external/lib | |
parent | f6aa366857a28da302461d1c426288b23d49b7af (diff) | |
download | nextcloud-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/lib')
-rw-r--r-- | apps/files_external/lib/google.php | 16 |
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; |