/container-tag-exists

Query the Docker Registry API v2 to check if an image tag exists.

Primary LanguageGoMIT LicenseMIT

container-tag-exists

GoDoc Go Report Card GitHub tag (latest SemVer)

Check whether a container image with the given tag exists by querying the Registry API v2. In principle, any registry implementing the Docker Registry API v2 should be supported, but this has only been confirmed with ghcr.io and quay.io.

Installation

Install from releases or via go install

go install github.com/Hsn723/container-tag-exists@latest

Usage

Usage:
  container-tag-exists IMAGE TAG [flags]
  container-tag-exists [command]

Available Commands:
  completion  Generate the autocompletion script for the specified shell
  help        Help about any command
  version     show version

Flags:
  -h, --help               help for container-tag-exists
  -p, --platform strings   specify platforms in the format os/arch to look for in container images. Default behavior is to look for any platform.

If IMAGE:TAG exists, this simply outputs found. This is intended to be used in CI environments to automate checking for existing container images before pushing. By default, container-tag-exists looks for any existing container image with the given tag.

container-tag-exists ghcr.io/example 0.0.0

If you additionally need to check for specific platforms, specify platform strings, in the format os/arch, to check for.

container-tag-exists ghcr.io/example 0.0.0 -p linux/amd64,linux/arm64
container-tag-exists ghcr.io/example 0.0.0 -p linux/amd64 -p linux/arm64

Configuration

container-tag-exists first tries to retrieve the given tag unauthenticated. For public container images, this is sufficient and no further configuration is needed.

For private container images, container-tag-exists looks for the following environment variable(s) in this order:

Environment variable Description
${REGISTRY_NAME}_TOKEN The base64 encoded bearer token
${REGISTRY_NAME}_AUTH The basic auth token. This is basically the base64 encoded form of $user:$pass
${REGISTRY_NAME}_USER, ${REGISTRY_NAME}_PASSWORD the username/password used to authenticate to the registry
GITHUB_TOKEN As a special case, if the registry is ghcr.io, the GITHUB_TOKEN or PAT can be used with the Registry API, provided it has sufficient permissions (read:packages)

The REGISTRY_NAME value is inferred from the registry URL part of the image name, with some special characters (., :, -) being replaced by _ and capitalized. For instance, ghcr.io becomes GHCR_IO and container-tag-exists therefore looks for GHCR_IO_TOKEN, GHCR_IO_AUTH, etc.