1
mirror of https://github.com/rclone/rclone synced 2025-01-22 03:47:28 +01:00

azureblob: Enable MD5 checksums when uploading files bigger than the "Cutoff"

This enables MD5 checksum calculation and publication when uploading file above the "Cutoff" limit.
It was explictely ignored in case of multi-block (a.k.a. multipart) uploads to Azure Blob Storage.
This commit is contained in:
Dr.Rx 2019-02-28 16:31:07 -05:00 committed by Nick Craig-Wood
parent b353c730d8
commit 0ea3a57ecb

View File

@ -1386,9 +1386,10 @@ func (o *Object) Update(in io.Reader, src fs.ObjectInfo, options ...fs.OpenOptio
blob := o.getBlobReference() blob := o.getBlobReference()
httpHeaders := azblob.BlobHTTPHeaders{} httpHeaders := azblob.BlobHTTPHeaders{}
httpHeaders.ContentType = fs.MimeType(o) httpHeaders.ContentType = fs.MimeType(o)
// Multipart upload doesn't support MD5 checksums at put block calls, hence calculate // Compute the Content-MD5 of the file, for multiparts uploads it
// MD5 only for PutBlob requests // will be set in PutBlockList API call using the 'x-ms-blob-content-md5' header
if size < int64(o.fs.opt.UploadCutoff) { // Note: If multipart, a MD5 checksum will also be computed for each uploaded block
// in order to validate its integrity during transport
if sourceMD5, _ := src.Hash(hash.MD5); sourceMD5 != "" { if sourceMD5, _ := src.Hash(hash.MD5); sourceMD5 != "" {
sourceMD5bytes, err := hex.DecodeString(sourceMD5) sourceMD5bytes, err := hex.DecodeString(sourceMD5)
if err == nil { if err == nil {
@ -1397,7 +1398,6 @@ func (o *Object) Update(in io.Reader, src fs.ObjectInfo, options ...fs.OpenOptio
fs.Debugf(o, "Failed to decode %q as MD5: %v", sourceMD5, err) fs.Debugf(o, "Failed to decode %q as MD5: %v", sourceMD5, err)
} }
} }
}
putBlobOptions := azblob.UploadStreamToBlockBlobOptions{ putBlobOptions := azblob.UploadStreamToBlockBlobOptions{
BufferSize: int(o.fs.opt.ChunkSize), BufferSize: int(o.fs.opt.ChunkSize),