From 8ee95ff7ab46b6c7b13b218ae4e290f09524433e Mon Sep 17 00:00:00 2001 From: Or Ozeri Date: Sun, 2 Apr 2017 10:27:43 +0300 Subject: [PATCH] fix multipart upload handling without cache --- src/curl.cpp | 44 +++++++++++++++++++++++--------------------- src/curl.h | 1 + 2 files changed, 24 insertions(+), 21 deletions(-) diff --git a/src/curl.cpp b/src/curl.cpp index 7d61341..b28732f 100644 --- a/src/curl.cpp +++ b/src/curl.cpp @@ -1148,18 +1148,8 @@ bool S3fsCurl::UploadMultipartPostCallback(S3fsCurl* s3fscurl) if(!s3fscurl){ return false; } - headers_t::iterator it = s3fscurl->responseHeaders.find("ETag"); - if (it == s3fscurl->responseHeaders.end()) { - return false; - } - // check etag(md5); - if(S3fsCurl::is_content_md5 && !etag_equals(it->second, s3fscurl->partdata.etag)){ - return false; - } - s3fscurl->partdata.etaglist->at(s3fscurl->partdata.etagpos).assign(it->second); - s3fscurl->partdata.uploaded = true; - return true; + return s3fscurl->UploadMultipartPostComplete(); } S3fsCurl* S3fsCurl::UploadMultipartPostRetryCallback(S3fsCurl* s3fscurl) @@ -3431,12 +3421,8 @@ int S3fsCurl::UploadMultipartPostRequest(const char* tpath, int part_num, const // request if(0 == (result = RequestPerform())){ - // check etag - if(NULL != strstr(headdata->str(), partdata.etag.c_str())){ - partdata.uploaded = true; - }else{ - result = -1; - } + // UploadMultipartPostComplete returns true on success -> convert to 0 + result = !UploadMultipartPostComplete(); } // closing @@ -3557,6 +3543,22 @@ int S3fsCurl::CopyMultipartPostRequest(const char* from, const char* to, int par return result; } +bool S3fsCurl::UploadMultipartPostComplete() +{ + headers_t::iterator it = responseHeaders.find("ETag"); + if (it == responseHeaders.end()) { + return false; + } + // check etag(md5); + if(S3fsCurl::is_content_md5 && !etag_equals(it->second, partdata.etag)){ + return false; + } + partdata.etaglist->at(partdata.etagpos).assign(it->second); + partdata.uploaded = true; + + return true; +} + int S3fsCurl::MultipartHeadRequest(const char* tpath, off_t size, headers_t& meta, bool is_copy) { int result; @@ -3637,14 +3639,14 @@ int S3fsCurl::MultipartUploadRequest(const char* tpath, headers_t& meta, int fd, partdata.size = chunk; b_partdata_startpos = partdata.startpos; b_partdata_size = partdata.size; + partdata.add_etag_list(&list); // upload part - if(0 != (result = UploadMultipartPostRequest(tpath, (list.size() + 1), upload_id))){ + if(0 != (result = UploadMultipartPostRequest(tpath, list.size(), upload_id))){ S3FS_PRN_ERR("failed uploading part(%d)", result); close(fd2); return result; } - list.push_back(partdata.etag); DestroyCurlHandle(); } close(fd2); @@ -3675,15 +3677,15 @@ int S3fsCurl::MultipartUploadRequest(const string& upload_id, const char* tpath, partdata.size = size; b_partdata_startpos = partdata.startpos; b_partdata_size = partdata.size; + partdata.add_etag_list(&list); // upload part int result; - if(0 != (result = UploadMultipartPostRequest(tpath, (list.size() + 1), upload_id))){ + if(0 != (result = UploadMultipartPostRequest(tpath, list.size(), upload_id))){ S3FS_PRN_ERR("failed uploading part(%d)", result); close(fd2); return result; } - list.push_back(partdata.etag); DestroyCurlHandle(); close(fd2); diff --git a/src/curl.h b/src/curl.h index 4fa3726..a314787 100644 --- a/src/curl.h +++ b/src/curl.h @@ -319,6 +319,7 @@ class S3fsCurl int UploadMultipartPostSetup(const char* tpath, int part_num, const std::string& upload_id); int CopyMultipartPostRequest(const char* from, const char* to, int part_num, std::string& upload_id, headers_t& meta); + bool UploadMultipartPostComplete(); public: // class methods