From 106d9759dbe80e7ec2ea61248c4bafb5af6da178 Mon Sep 17 00:00:00 2001 From: Justin Hamade Date: Wed, 17 Jul 2019 11:38:46 -0700 Subject: [PATCH] fix: Do not check ETag for SSE KMS --- lib/index.js | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/lib/index.js b/lib/index.js index d0d44d3..6cbfa5a 100644 --- a/lib/index.js +++ b/lib/index.js @@ -137,6 +137,7 @@ Client.prototype.uploadFile = function(params) { var defaultContentType = params.defaultContentType || 'application/octet-stream'; s3Params.ContentType = mime.getType(localFile, defaultContentType); } + var sse = s3Params.ServerSideEncryption; var fatalError = false; var localFileSlicer = null; var parts = []; @@ -315,7 +316,7 @@ Client.prototype.uploadFile = function(params) { } pend.wait(function() { if (fatalError) return; - if (!compareMultipartETag(data.ETag, multipartETag)) { + if (sse !== 'aws:kms' && !compareMultipartETag(data.ETag, multipartETag)) { errorOccurred = true; uploader.progressAmount -= overallDelta; cb(new Error("ETag does not match MD5 checksum")); @@ -411,7 +412,7 @@ Client.prototype.uploadFile = function(params) { } pend.wait(function() { if (fatalError) return; - if (!compareMultipartETag(data.ETag, localFileStat.multipartETag)) { + if (sse !== 'aws:kms' && !compareMultipartETag(data.ETag, localFileStat.multipartETag)) { cb(new Error("ETag does not match MD5 checksum")); return; } @@ -507,9 +508,11 @@ Client.prototype.downloadFile = function(params) { handleError(new Error("Downloaded size does not match Content-Length")); return; } - if (eTagCount === 1 && !multipartETag.anyMatch(eTag)) { - handleError(new Error("ETag does not match MD5 checksum")); - return; + if (headers['x-amz-server-side-encryption'] !== 'aws:kms' ) { + if (eTagCount === 1 && !multipartETag.anyMatch(eTag)) { + handleError(new Error("ETag does not match MD5 checksum")); + return; + } } cb(); }); @@ -773,6 +776,7 @@ Client.prototype.downloadBuffer = function(s3Params) { var self = this; var downloader = new EventEmitter(); s3Params = extend({}, s3Params); + var sse = s3Params.ServerSideEncryption; downloader.progressAmount = 0; @@ -825,9 +829,11 @@ Client.prototype.downloadBuffer = function(s3Params) { handleError(new Error("Downloaded size does not match Content-Length")); return; } - if (eTagCount === 1 && !multipartETag.anyMatch(eTag)) { - handleError(new Error("ETag does not match MD5 checksum")); - return; + if (headers['x-amz-server-side-encryption'] !== 'aws:kms' ) { + if (eTagCount === 1 && !multipartETag.anyMatch(eTag)) { + handleError(new Error("ETag does not match MD5 checksum")); + return; + } } cb(); });