GitHub Action to install and setup ko
⚠️ Note:ko
recently moved to its own GitHub org, which broke[email protected]
if theko
version wasn't specified.To fix this, either upgrade to
[email protected]
or specifyversion
name: Publish
on:
push:
branches: ['main']
jobs:
publish:
name: Publish
runs-on: ubuntu-latest
steps:
- uses: actions/setup-go@v4
with:
go-version: '1.20.x'
- uses: actions/checkout@v3
- uses: ko-build/[email protected]
- run: ko build
That's it! This workflow will build and publish your code to GitHub Container Regsitry.
By default, the action sets KO_DOCKER_REPO=ghcr.io/[owner]/[repo]
for all subsequent steps, and uses the ${{ github.token }}
to authorize pushes to GHCR.
See documentation for ko
to learn more about configuring ko
.
The action works on Linux and macOS runners. If you'd like support for Windows runners, let us know!
By default, ko-build/setup-ko
installs the latest released version of ko
.
You can select a version with the version
parameter:
- uses: ko-build/[email protected]
with:
version: v0.14.1
To build and install ko
from source using go install
, specify version: tip
.
By default, ko-build/setup-ko
configures ko
to push images to GitHub Container Registry, but you can configure it to push to other registries as well.
If KO_DOCKER_REPO
is already set when setup-ko
runs, it will skip logging in to ghcr.io and will propagate KO_DOCKER_REPO
for subsequent steps.
To do this, you should provide credentials to authorize the push.
You can use encrypted secrets to store the authorization token, and pass it to ko login
before pushing:
steps:
...
- uses: ko-build/[email protected]
env:
KO_DOCKER_REPO: my.registry/my-repo
- env:
auth_token: ${{ secrets.auth_token }}
run: |
echo "${auth_token}" | ko login https://my.registry --username my-username --password-stdin
ko build
In addition to publishing images, ko
can produce YAML files containing references to built images, using ko resolve
With this action, you can use ko resolve
to produce output YAML that you then attach to a GitHub Release using the GitHub CLI.
For example:
name: Publish Release YAML
on:
release:
types:
- 'created'
jobs:
publish-release-yaml:
name: Publish Release YAML
runs-on: ubuntu-latest
steps:
- uses: actions/setup-go@v4
with:
go-version: '1.20'
- uses: actions/checkout@v3
- uses: ko-build/[email protected]
- name: Generate and upload release.yaml
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
tag=$(echo ${{ github.ref }} | cut -c11-) # get tag name without tags/refs/ prefix.
ko resolve -t ${tag} -f config/ > release.yaml
gh release upload ${tag} release.yaml
The @v0.X
in the uses
statement refers to the version of the action definition in this repo.
Regardless of what version of the action definition you use, ko-build/setup-ko
will install the latest released version of ko
unless otherwise specified with version:
.