From c33b310b48a6b0467f25f89aa941ec4e453460d4 Mon Sep 17 00:00:00 2001 From: Tonis Tiigi Date: Sun, 29 Jan 2023 22:45:45 -0800 Subject: [PATCH] build: fix multi-node merge to read descriptor from result Signed-off-by: Tonis Tiigi --- build/build.go | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/build/build.go b/build/build.go index 876245e0..67acb8d1 100644 --- a/build/build.go +++ b/build/build.go @@ -6,6 +6,7 @@ import ( "context" "crypto/rand" _ "crypto/sha256" // ensure digests can be computed + "encoding/base64" "encoding/hex" "encoding/json" "fmt" @@ -1157,7 +1158,24 @@ func BuildWithResultHandler(ctx context.Context, nodes []builder.Node, opt map[s descs := make([]specs.Descriptor, 0, len(res)) for _, r := range res { - s, ok := r.ExporterResponse[exptypes.ExporterImageDigestKey] + s, ok := r.ExporterResponse[exptypes.ExporterImageDescriptorKey] + if ok { + dt, err := base64.StdEncoding.DecodeString(s) + if err != nil { + return err + } + var desc specs.Descriptor + if err := json.Unmarshal(dt, &desc); err != nil { + return errors.Wrapf(err, "failed to unmarshal descriptor %s", s) + } + descs = append(descs, desc) + continue + } + // This is fallback for some very old buildkit versions. + // Note that the mediatype isn't really correct as most of the time it is image manifest and + // not manifest list but actually both are handled because for Docker mediatypes the + // mediatype value in the Accpet header does not seem to matter. + s, ok = r.ExporterResponse[exptypes.ExporterImageDigestKey] if ok { descs = append(descs, specs.Descriptor{ Digest: digest.Digest(s),