From 35115f88c2a23134d41953f5858595d7d5cc039f Mon Sep 17 00:00:00 2001 From: shreddedbacon Date: Mon, 29 Apr 2024 11:01:18 +1000 Subject: [PATCH] docs: update lagoon.yml container-registries documentation --- docs/concepts-basics/lagoon-yml.md | 68 ++++++++++++++++++++++++++---- 1 file changed, 59 insertions(+), 9 deletions(-) diff --git a/docs/concepts-basics/lagoon-yml.md b/docs/concepts-basics/lagoon-yml.md index 21add8f274..f94557b028 100644 --- a/docs/concepts-basics/lagoon-yml.md +++ b/docs/concepts-basics/lagoon-yml.md @@ -517,34 +517,84 @@ With the key `ssh` you can define another SSH endpoint that should be used by th ### `container-registries` -The `container-registries` block allows you to define your own private container registries to pull custom or private images. To use a private container registry, you will need a `username`, `password`, and optionally the `url` for your registry. If you don't specify a `url` in your YAML, it will default to using Docker Hub. +The `container-registries` block allows you to define your own private container registries to pull custom or private images. -There are 2 ways to define the password used for your registry user. +To use a private container registry, you will need a `username`, `password`, and optionally the `url` for your registry. If you don't specify a `url` in your YAML, it will default to using Docker Hub. -Create an environment variable in the Lagoon API with the type `container_registry`: +There are 2 ways to define the username and password used for your registry user. -* `lagoon add variable -p -N -V -S container_registry` -* \(see more on [Environment Variables](../concepts-advanced/environment-variables.md)\) +* Define them as environment variables in the API +* Hardcode them in the `.lagoon.yml` file (we don't recommend this though) + +#### Environment variables method -The name of the variable you create can then be set as the password: +Firstly, define the `container-registries` in your `.lagoon.yml`, you don't need to define the username or password here. If you do use a custom registry, you will still need to provide the `url`, for example: ```yaml title=".lagoon.yml" container-registries: + docker-hub: my-custom-registry: - username: myownregistryuser - password: url: my.own.registry.com + another-custom-registry: + username: myotheruser + url: my.other.registry.com ``` -You can also define the password directly in the `.lagoon.yml` file in plain text: +If you do define a username in the `.lagoon.yml` you don't need to add the associated variable, but if you do add the variable, the value of the variable will be prefered. + +Next, create environment variables in the Lagoon API with the type `container_registry`: + +* `lagoon add variable -p -N -V -S container_registry` +* `lagoon add variable -p -N -V -S container_registry` +* \(see more on [Environment Variables](../concepts-advanced/environment-variables.md)\) + +The name of the variables should be the name of the registry defined in the `.lagoon.yml` file, it should be: + +* uppercase +* replace `-` with `_` +* have the prefix `REGISTRY_` +* have the suffix of `_USERNAME` or `_PASSWORD`. + +Some examples of this are: + +* `dockerhub` would become `REGISTRY_DOCKERHUB_USERNAME` and `REGISTRY_DOCKERHUB_PASSWORD` +* `docker-hub` would become `REGISTRY_DOCKER_HUB_USERNAME` and `REGISTRY_DOCKER_HUB_PASSWORD` +* `my-custom-registry` would become `REGISTRY_MY_CUSTOM_REGISTRY_USERNAME` and `REGISTRY_MY_CUSTOM_REGISTRY_PASSWORD` +* lowercased versions may still work if there are no `-` in them, for example `REGISTRY_dockerhub_USERNAME` + +???+ "Legacy method of defining registry password" + A previous method that allowed for the password to be defined using an environment variable, with the name of the variable to be defined in the `.lagoon.yml` file like so: + ```yaml title=".lagoon.yml" + container-registries: + docker-hub: + username: dockerhubuser + password: MY_DOCKER_HUB_PASSWORD + ``` + > the username needs to be provided in this file too, unless the supported variable for defining the username is provided. + + The variable can then ba added to the API like so + + * `lagoon add variable -p -N MY_DOCKER_HUB_PASSWORD -V -S container_registry` + + While we will continue to support this method, it may be deprecated in the future, we will ensure that warnings are presented within builds to give time for users to change to the supported method. + + If a supported variable password is provided, it will be used instead of the custom named variable. + +#### Hardcoded values method +You can also define the password directly in the `.lagoon.yml` file in plain text, however we do not recommend this. ```yaml title=".lagoon.yml" container-registries: docker-hub: username: dockerhubuser password: MySecretPassword + my-custom-registry: + url: my.own.registry.com + username: mycustomuser + password: MyCustomSecretPassword ``` + ### Consuming a custom or private container registry image To consume a custom or private container registry image, you need to update the service inside your `docker-compose.yml` file to use a build context instead of defining an image: