From 34dc725d26f58db7017c816ff2cc5903a239ab8b Mon Sep 17 00:00:00 2001 From: Klaus Post Date: Thu, 25 Nov 2021 09:11:25 -0800 Subject: [PATCH] fix: s3zip in fs mode (#13758) The index was converted directly from bytes to binary. This would fail a roundtrip through json. This would result in `Error: invalid input: magic number mismatch` when reading back. On non-erasure backends store index as base64. --- cmd/s3-zip-handlers.go | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/cmd/s3-zip-handlers.go b/cmd/s3-zip-handlers.go index 9eee461cb..6427dc366 100644 --- a/cmd/s3-zip-handlers.go +++ b/cmd/s3-zip-handlers.go @@ -20,6 +20,7 @@ package cmd import ( "bytes" "context" + "encoding/base64" "errors" "fmt" "io" @@ -142,8 +143,15 @@ func (api objectAPIHandlers) getObjectInArchiveFileHandler(ctx context.Context, var zipInfo []byte if z, ok := zipObjInfo.UserDefined[archiveInfoMetadataKey]; ok { - zipInfo = []byte(z) - } else { + if globalIsErasure { + zipInfo = []byte(z) + } else { + zipInfo, err = base64.StdEncoding.DecodeString(z) + logger.LogIf(ctx, err) + // Will attempt to re-read... + } + } + if len(zipInfo) == 0 { zipInfo, err = updateObjectMetadataWithZipInfo(ctx, objectAPI, bucket, zipPath, opts) } @@ -151,7 +159,6 @@ func (api objectAPIHandlers) getObjectInArchiveFileHandler(ctx context.Context, writeErrorResponse(ctx, w, toAPIError(ctx, err), r.URL) return } - file, err := zipindex.FindSerialized(zipInfo, object) if err != nil { if err == io.EOF { @@ -491,7 +498,11 @@ func updateObjectMetadataWithZipInfo(ctx context.Context, objectAPI ObjectLayer, } srcInfo.UserDefined[archiveTypeMetadataKey] = archiveType - srcInfo.UserDefined[archiveInfoMetadataKey] = string(zipInfo) + if globalIsErasure { + srcInfo.UserDefined[archiveInfoMetadataKey] = string(zipInfo) + } else { + srcInfo.UserDefined[archiveInfoMetadataKey] = base64.StdEncoding.EncodeToString(zipInfo) + } srcInfo.metadataOnly = true // Always update the same version id & modtime