The CUE Central Registry provides a well-known location for well-known schemas, including those for the YAML configuration files used by GoReleaser. This guide shows you how to get started defining your GoReleaser configurations using a curated module from the schema library.
The latest pre-release of the cue
command is required – please
upgrade to this version if it’s not already installed:
$ cue version
cue version v0.13.0-alpha.3
...
Login to the Central Registry
$ cue login # only during beta
The Central Registry requires authentication while it’s in beta testing, so you need to login before you can use its schemas.
Initialise your local CUE module
CUE that uses schemas and modules from the Central Registry needs to exist within its own CUE module.
$ cue mod init cue.example
You can choose any module name you like - it’s easy to change it later. It makes sense for your CUE module to exist at the root of a source code repository, but the commands in this guide will work in any setup.
Create a configuration file
Declare a configuration file in CUE. This one is taken from
goreleaser/example
:
// filepath: goreleaser.cue
package cicd
import "test.cue.works/x1/goreleaser"
files: example: goreleaser.#Project & {
project_name: "example"
builds: [{
env: ["CGO_ENABLED=0"]
goos: ["linux", "windows", "darwin"]
goarch: ["amd64", "arm64"]
}]
dockers: [{
image_templates: ["ghcr.io/goreleaser/example:{{ .Version }}"]
dockerfile: "Dockerfile"
build_flag_templates: [
"--label=org.opencontainers.image.title={{ .ProjectName }}",
"--label=org.opencontainers.image.description={{ .ProjectName }}",
"--label=org.opencontainers.image.url=https://github.com/goreleaser/example",
"--label=org.opencontainers.image.source=https://github.com/goreleaser/example",
"--label=org.opencontainers.image.version={{ .Version }}",
"--label=org.opencontainers.image.created={{ time \"2006-01-02T15:04:05Z07:00\" }}",
"--label=org.opencontainers.image.revision={{ .FullCommit }}",
"--label=org.opencontainers.image.licenses=MIT",
]
}]
nfpms: [{
maintainer: "Carlos A Becker <root@carlosbecker.dev>"
description: "Sample project."
homepage: "https://github.com/caarlos0/tasktimer"
license: "MIT"
formats: ["deb", "rpm", "apk"]
}]
}
In later guides we’ll add more entries to the files
struct.
The import
at the top references the appropriate curated module for the file.
Its path is currently temporary, but only while its proper location is being decided.
The temporary path isn’t a problem because one important property of the
Central Registry
is that, once a schema is published, it will always be
available at that location.
When the curated module’s location is finalised and versions are published
under the new path, you can use the
cue refactor imports
command to update your CUE easily, so it reflects the new location.
Tidy your local CUE module
$ cue mod tidy
Tidying a module is an important part of using curated modules from the
Central Registry.
Always use
cue mod tidy
when you use a curated module for the first time.
Validate your configuration file
$ cue vet -c
Because cue vet
doesn’t display any errors, you know that the curated schema has validated your configuration file.
Export your configuration file as YAML
$ cue export --outfile .goreleaser.yaml -e files.example
If you chose to export the files.example
shown above,
your validated YAML file will look like this:
# filepath: .goreleaser.yaml
project_name: example
builds:
- goos:
- linux
- windows
- darwin
goarch:
- amd64
- arm64
env:
- CGO_ENABLED=0
dockers:
- dockerfile: Dockerfile
image_templates:
- ghcr.io/goreleaser/example:{{ .Version }}
build_flag_templates:
- --label=org.opencontainers.image.title={{ .ProjectName }}
- --label=org.opencontainers.image.description={{ .ProjectName }}
- --label=org.opencontainers.image.url=https://github.com/goreleaser/example
- --label=org.opencontainers.image.source=https://github.com/goreleaser/example
- --label=org.opencontainers.image.version={{ .Version }}
- --label=org.opencontainers.image.created={{ time "2006-01-02T15:04:05Z07:00" }}
- --label=org.opencontainers.image.revision={{ .FullCommit }}
- --label=org.opencontainers.image.licenses=MIT
nfpms:
- formats:
- deb
- rpm
- apk
homepage: https://github.com/caarlos0/tasktimer
maintainer: Carlos A Becker <root@carlosbecker.dev>
description: Sample project.
license: MIT
Use your configuration file
Your validated .goreleaser.yml
file can now be used by
the various commands provided by the
goreleaser
tool.
The cue.mod
directory should be stored in your source code repository,
along with your goreleaser.cue
and .goreleaser.yaml
files.
Whenever you update your CUE file, re-run the cue export
command shown above,
and then record any changes to these files and directories.