|
|
5dd126 |
# For more information on this configuration file, see containers-registries.conf(5).
|
|
|
5dd126 |
#
|
|
|
5dd126 |
# NOTE: RISK OF USING UNQUALIFIED IMAGE NAMES
|
|
|
5dd126 |
# We recommend always using fully qualified image names including the registry
|
|
|
5dd126 |
# server (full dns name), namespace, image name, and tag
|
|
|
5dd126 |
# (e.g., registry.redhat.io/ubi8/ubi:latest). Pulling by digest (i.e.,
|
|
|
5dd126 |
# quay.io/repository/name@digest) further eliminates the ambiguity of tags.
|
|
|
5dd126 |
# When using short names, there is always an inherent risk that the image being
|
|
|
5dd126 |
# pulled could be spoofed. For example, a user wants to pull an image named
|
|
|
5dd126 |
# `foobar` from a registry and expects it to come from myregistry.com. If
|
|
|
5dd126 |
# myregistry.com is not first in the search list, an attacker could place a
|
|
|
5dd126 |
# different `foobar` image at a registry earlier in the search list. The user
|
|
|
5dd126 |
# would accidentally pull and run the attacker's image and code rather than the
|
|
|
5dd126 |
# intended content. We recommend only adding registries which are completely
|
|
|
5dd126 |
# trusted (i.e., registries which don't allow unknown or anonymous users to
|
|
|
5dd126 |
# create accounts with arbitrary names). This will prevent an image from being
|
|
|
5dd126 |
# spoofed, squatted or otherwise made insecure. If it is necessary to use one
|
|
|
5dd126 |
# of these registries, it should be added at the end of the list.
|
|
|
5dd126 |
#
|
|
|
5dd126 |
# # An array of host[:port] registries to try when pulling an unqualified image, in order.
|
|
|
5dd126 |
|
|
|
2b1b9b |
unqualified-search-registries = ["registry.access.redhat.com", "registry.redhat.io", "docker.io"]
|
|
|
5dd126 |
|
|
|
5dd126 |
# [[registry]]
|
|
|
5dd126 |
# # The "prefix" field is used to choose the relevant [[registry]] TOML table;
|
|
|
5dd126 |
# # (only) the TOML table with the longest match for the input image name
|
|
|
5dd126 |
# # (taking into account namespace/repo/tag/digest separators) is used.
|
|
|
5dd126 |
# #
|
|
|
5dd126 |
# # The prefix can also be of the form: *.example.com for wildcard subdomain
|
|
|
5dd126 |
# # matching.
|
|
|
5dd126 |
# #
|
|
|
5dd126 |
# # If the prefix field is missing, it defaults to be the same as the "location" field.
|
|
|
5dd126 |
# prefix = "example.com/foo"
|
|
|
5dd126 |
#
|
|
|
5dd126 |
# # If true, unencrypted HTTP as well as TLS connections with untrusted
|
|
|
5dd126 |
# # certificates are allowed.
|
|
|
5dd126 |
# insecure = false
|
|
|
5dd126 |
#
|
|
|
5dd126 |
# # If true, pulling images with matching names is forbidden.
|
|
|
5dd126 |
# blocked = false
|
|
|
5dd126 |
#
|
|
|
5dd126 |
# # The physical location of the "prefix"-rooted namespace.
|
|
|
5dd126 |
# #
|
|
|
5dd126 |
# # By default, this is equal to "prefix" (in which case "prefix" can be omitted
|
|
|
5dd126 |
# # and the [[registry]] TOML table can only specify "location").
|
|
|
5dd126 |
# #
|
|
|
5dd126 |
# # Example: Given
|
|
|
5dd126 |
# # prefix = "example.com/foo"
|
|
|
5dd126 |
# # location = "internal-registry-for-example.net/bar"
|
|
|
5dd126 |
# # requests for the image example.com/foo/myimage:latest will actually work with the
|
|
|
5dd126 |
# # internal-registry-for-example.net/bar/myimage:latest image.
|
|
|
5dd126 |
#
|
|
|
5dd126 |
# # The location can be empty iff prefix is in a
|
|
|
5dd126 |
# # wildcarded format: "*.example.com". In this case, the input reference will
|
|
|
5dd126 |
# # be used as-is without any rewrite.
|
|
|
5dd126 |
# location = internal-registry-for-example.com/bar"
|
|
|
5dd126 |
#
|
|
|
5dd126 |
# # (Possibly-partial) mirrors for the "prefix"-rooted namespace.
|
|
|
5dd126 |
# #
|
|
|
5dd126 |
# # The mirrors are attempted in the specified order; the first one that can be
|
|
|
5dd126 |
# # contacted and contains the image will be used (and if none of the mirrors contains the image,
|
|
|
5dd126 |
# # the primary location specified by the "registry.location" field, or using the unmodified
|
|
|
5dd126 |
# # user-specified reference, is tried last).
|
|
|
5dd126 |
# #
|
|
|
5dd126 |
# # Each TOML table in the "mirror" array can contain the following fields, with the same semantics
|
|
|
5dd126 |
# # as if specified in the [[registry]] TOML table directly:
|
|
|
5dd126 |
# # - location
|
|
|
5dd126 |
# # - insecure
|
|
|
5dd126 |
# [[registry.mirror]]
|
|
|
5dd126 |
# location = "example-mirror-0.local/mirror-for-foo"
|
|
|
5dd126 |
# [[registry.mirror]]
|
|
|
5dd126 |
# location = "example-mirror-1.local/mirrors/foo"
|
|
|
5dd126 |
# insecure = true
|
|
|
5dd126 |
# # Given the above, a pull of example.com/foo/image:latest will try:
|
|
|
5dd126 |
# # 1. example-mirror-0.local/mirror-for-foo/image:latest
|
|
|
5dd126 |
# # 2. example-mirror-1.local/mirrors/foo/image:latest
|
|
|
5dd126 |
# # 3. internal-registry-for-example.net/bar/image:latest
|
|
|
5dd126 |
# # in order, and use the first one that exists.
|
|
|
5dd126 |
short-name-mode = "permissive"
|