From 83320d657d1961062f82189371788021bc8551a8 Mon Sep 17 00:00:00 2001 From: thesayyn Date: Mon, 18 Sep 2023 16:03:23 -0700 Subject: [PATCH] feat: add custom no_match_error to oci_alias --- oci/private/pull.bzl | 29 +++++++++++++++++------------ 1 file changed, 17 insertions(+), 12 deletions(-) diff --git a/oci/private/pull.bzl b/oci/private/pull.bzl index 5388bf1a..49ead4b7 100644 --- a/oci/private/pull.bzl +++ b/oci/private/pull.bzl @@ -471,7 +471,8 @@ _MULTI_PLATFORM_IMAGE_ALIAS_TMPL = """\ alias( name = "{target_name}", actual = select( - {platform_map} + {platform_map}, + no_match_error = \"\"\"could not find an image matching the target platform. \\navailable platforms are {available_platforms} \"\"\", ), visibility = ["//visibility:public"], ) @@ -493,22 +494,25 @@ def _oci_alias_impl(rctx): downloader = _create_downloader(rctx) + available_platforms = [] + + manifest, _ = downloader.download_manifest(rctx.attr.identifier, "mf.json") + + if manifest["mediaType"] in _SUPPORTED_MEDIA_TYPES["index"]: + for submanifest in manifest["manifests"]: + parts = [submanifest["platform"]["os"], submanifest["platform"]["architecture"]] + if "variant" in submanifest["platform"]: + parts.append(submanifest["platform"]["variant"]) + available_platforms.append('"{}"'.format("/".join(parts))) + if _is_tag(rctx.attr.identifier) and rctx.attr.reproducible: - manifest, _ = downloader.download_manifest(rctx.attr.identifier, "mf.json") + is_bzlmod = hasattr(rctx.attr, "bzlmod_repository") and rctx.attr.bzlmod_repository digest = util.sha256(rctx, "mf.json") - optional_platforms = "" - if manifest["mediaType"] in _SUPPORTED_MEDIA_TYPES["index"]: - platforms = [] - for submanifest in manifest["manifests"]: - parts = [submanifest["platform"]["os"], submanifest["platform"]["architecture"]] - if "variant" in submanifest["platform"]: - parts.append(submanifest["platform"]["variant"]) - platforms.append('"{}"'.format("/".join(parts))) - optional_platforms = "'add platforms {}'".format(" ".join(platforms)) + if len(available_platforms): + optional_platforms = "'add platforms {}'".format(" ".join(available_platforms)) - is_bzlmod = hasattr(rctx.attr, "bzlmod_repository") and rctx.attr.bzlmod_repository util.warning(rctx, """\ for reproducible builds, a digest is recommended. Either set 'reproducible = False' to silence this warning, @@ -529,6 +533,7 @@ buildozer 'set digest "sha256:{digest}"' 'remove tag' 'remove platforms' {option build = _MULTI_PLATFORM_IMAGE_ALIAS_TMPL.format( name = rctx.attr.name, target_name = rctx.attr.target_name, + available_platforms = ", ".join(available_platforms), platform_map = { str(k): v for k, v in rctx.attr.platforms.items()