From 43a748fd15c71eb65423ec50a3e9d331803ed8a1 Mon Sep 17 00:00:00 2001 From: Justin Chadwell Date: Fri, 13 Jan 2023 13:41:53 +0000 Subject: [PATCH] build: error when using docker exporter and attestations Signed-off-by: Justin Chadwell --- build/build.go | 40 ++++++++++++++++++++-------------------- 1 file changed, 20 insertions(+), 20 deletions(-) diff --git a/build/build.go b/build/build.go index a4f65b0a..97de5d1f 100644 --- a/build/build.go +++ b/build/build.go @@ -447,6 +447,25 @@ func toSolveOpt(ctx context.Context, node builder.Node, multiDriver bool, opt Op so.FrontendAttrs["multi-platform"] = "true" } + attests := make(map[string]string) + for k, v := range opt.Attests { + if v != nil { + attests[k] = *v + } + } + supportsAttestations := bopts.LLBCaps.Contains(apicaps.CapID("exporter.image.attestations")) + if len(attests) > 0 { + if !supportsAttestations { + return nil, nil, errors.Errorf("attestations are not supported by the current buildkitd") + } + for k, v := range attests { + so.FrontendAttrs[k] = v + } + } + if _, ok := opt.Attests["attest:provenance"]; !ok && supportsAttestations { + so.FrontendAttrs["attest:provenance"] = "mode=min,inline-only=true" + } + switch len(opt.Exports) { case 1: // valid @@ -504,7 +523,7 @@ func toSolveOpt(ctx context.Context, node builder.Node, multiDriver bool, opt Op return nil, nil, notSupported(nodeDriver, driver.OCIExporter) } if e.Type == "docker" { - if len(opt.Platforms) > 1 { + if len(opt.Platforms) > 1 || len(attests) > 0 { return nil, nil, errors.Errorf("docker exporter does not currently support exporting manifest lists") } if e.Output == nil { @@ -588,25 +607,6 @@ func toSolveOpt(ctx context.Context, node builder.Node, multiDriver bool, opt Op } } - attests := make(map[string]string) - for k, v := range opt.Attests { - if v != nil { - attests[k] = *v - } - } - supportsAttestations := bopts.LLBCaps.Contains(apicaps.CapID("exporter.image.attestations")) - if len(attests) > 0 { - if !supportsAttestations { - return nil, nil, errors.Errorf("attestations are not supported by the current buildkitd") - } - for k, v := range attests { - so.FrontendAttrs[k] = v - } - } - if _, ok := opt.Attests["attest:provenance"]; !ok && supportsAttestations { - so.FrontendAttrs["attest:provenance"] = "mode=min,inline-only=true" - } - // set platforms if len(opt.Platforms) != 0 { pp := make([]string, len(opt.Platforms))