docker-build-and-publish
ActionsThis action will build a docker image from a given directory.
- You can give a docker image multiple tags.
- You can specify for which branch it should push to a docker registry (
docker.io
by default ). - Each docker image contains information about the exact context in which the image is build.
- When pushing to docker.io, the description is updated with the
readme.md
file. - If required, the image is signed with cosign.
- If required, a provenance file is created according to the SLSA.dev specifications.
- If required, the provenance file is attached to the container.
- If required, a SBOM file is created according to the SPDX specifications. We're using syft for that.
- If required, the SBOM file is attached to the container.
In every docker image two files are added to the build context:
TAGS
- contains all tags associated with the image at time it was build.REPO
- contains a link to the github repository with the commit sha.
This information can also be found in the provenance file. Using the provenance file is more secure, because you don't need to download and run the image in order to get the information.
- Description
- Inputs
- Environment Variables
- Outputs
- Runs
- Example Usage
- Example Projects
- Contributors
- License
Builds docker images and publish them on request
parameter | description | required | default |
---|---|---|---|
dockerfile | Path to Dockerfile | true |
|
image-name | The name of the image | true |
|
tags | String with tags, separated by a space | true |
|
push-branches | Specifies branches to push, separated by a space | false |
master main |
push-on-git-tag | Push when a git tag is created | false |
false |
base-dir | Base directory to perform the build | false |
. |
slsa-provenance | Create SLSA Provenance json | false |
|
sbom | Create Software Bill Of Material in SPDX format | false |
|
sign | Sign image with Cosign. Requires COSIGN environment variables to be set. When used in combination with slsa-provenance / sbom it will also attach the results to the image. | false |
|
github_context | internal (do not set): the "github" context object in json | true |
${{ toJSON(github) }} |
runner_context | internal (do not set): the "runner" context object in json | true |
${{ toJSON(runner) }} |
These variables can be set in the github repository secret vault.
Required Registry username
Required Registry token
Optional Registry to push the docker image to. Defaults to Docker hub.
Required for Docker hub Container will be pushed in this organization. Example: philipssoftware
No need to put this in GitHub Secret vault. This will be public anyway.
Optional Github organization. Defaults to DOCKER_ORGANIZATION. Example: philips-software
No need to put this in GitHub Secret vault. This will be public anyway.
Optional The build arguments for a docker build.
Examples: Using environment variables (make sure to have these environment variables exported when using!)
- Single environment build argument:
--build-arg FOO
- Multiple environment build arguments:
--build-arg FOO --build-arg BAR
Examples: Using explicit variables
- Single explicit build arguments:
--build-arg FOO=foo
- Multiple explicit build arguments:
--build-arg FOO=foo --build-arg BAR=bar
Optional Set to true
when you want to use keyless signing with SigStore's Rekor and Fulcio.
Warning This is a PUBLIC transparancy log, this means you will reveal information about your OCI images publically. DO NOT USE THIS FOR PRIVATE IMAGES.
You can use KEYLESS
to start using SigStore's Rekor and Fulcio together with GitHub OIDC. When set, you don't need to specify the three COSIGN Arguments.
Optional Cosign Private Key used to attach provenance file. Please make sure this is a GitHub Secret.
Optional Cosign Password used to attach provenance file. Please make sure this is a GitHub Secret.
Optional Cosign Public Key used to attach provenance file.
No need to put this in GitHub Secret vault. Good practice is to put this also in a repo as cosign.pub
.
Optional Cosign supports older MEDIA_TYPES.
You can set this to 1
with this environment variable. Can be used for Artifactory for example.
parameter | description |
---|---|
container-digest | Container digest. Can be used for generating provenance and signing |
container-tags | Container tags. Can be used for generating provenance and signing |
push-indicator | Is set to true when containers have been pushed to the container repository |
slsa-provenance-file | SLSA provenance filename if created |
sbom-file | SBOM filename if created |
This action is a docker
action.
- uses: philips-software/docker-ci-scripts@v4.5.0
with:
dockerfile: "./docker/Dockerfile"
image-name: "node"
tags: "latest 12 12.1 12.1.4"
env:
REGISTRY_USERNAME: ${{ secrets.REGISTRY_USERNAME }}
REGISTRY_TOKEN: "${{ secrets.REGISTRY_TOKEN }}"
DOCKER_ORGANIZATION: myDockerOrganization
- uses: philips-software/docker-ci-scripts@v4.5.0
with:
dockerfile: "./docker/Dockerfile"
image-name: "node"
tags: "latest 12 12.1 12.1.4"
env:
REGISTRY_USERNAME: ${{ secrets.REGISTRY_USERNAME }}
REGISTRY_TOKEN: "${{ secrets.REGISTRY_TOKEN }}"
DOCKER_ORGANIZATION: myDockerOrganization
FOO_BUILD_ARG: "foo"
BAR_BUILD_ARG: ${{ secrets.SECRET_BAR_BUILD_ARG }}
DOCKER_BUILD_ARGS: "--build-arg FOO_BUILD_ARG --build-arg BAR_BUILD_ARG"
- name: Build Docker Images
uses: philips-software/docker-ci-scripts@v4.5.0
with:
dockerfile: .
image-name: image-name-here
tags: latest 0.1
push-branches: main develop
env:
REGISTRY_USERNAME: ${{ github.actor }}
REGISTRY_TOKEN: ${{ secrets.GITHUB_TOKEN }}
REGISTRY_URL: ghcr.io/organization-here
GITHUB_ORGANIZATION: organization-here
We can automatically sign the image with Cosign if you pass the sign
argument.
This can be done in keyless mode with GitHub OIDC, or you can specify your own keys.
Keyless uses Sigstores Rekor and Fulcio. These are PUBLIC transparancy logs. This means you should NOT use this when dealing with Private Images.
You need to provide the COSIGN environment variables in order to actually sign it. You can create a key pair by installing Cosign on your local machine and run:
$ cosign generate-key-pair
Store the content of cosign.pub
, cosign.key
and the password in GitHub Secrets.
- name: Build Docker Images
uses: philips-software/docker-ci-scripts@v4.5.0
with:
dockerfile: .
image-name: image-name-here
tags: latest 0.1
push-branches: main develop
sign: true
env:
REGISTRY_USERNAME: ${{ github.actor }}
REGISTRY_TOKEN: ${{ secrets.GITHUB_TOKEN }}
REGISTRY_URL: ghcr.io/organization-here
GITHUB_ORGANIZATION: organization-here
COSIGN_PRIVATE_KEY: ${{ secrets.COSIGN_PRIVATE_KEY }}
COSIGN_PASSWORD: ${{ secrets.COSIGN_PASSWORD }}
COSIGN_PUBLIC_KEY: ${{ secrets.COSIGN_PUBLIC_KEY }}
Now you can verify the image f.e. jeroenknoops/test-image:latest
:
$ cosign verify --key cosign.pub jeroenknoops/test-image:latest
You will get a result when the image is valid.
You don't need to provide the COSIGN environment variables in order to actually sign it.
Instead we're using GitHub OIDC. This means you have to given the workflow premission to use
the id-token
.
permissions:
id-token: write
Now you can start signing and adding the attestations without using keys.
- name: Build Docker Images
uses: philips-software/docker-ci-scripts@v4.5.0
with:
dockerfile: .
image-name: image-name-here
tags: latest 0.1
push-branches: main develop
sign: true
sbom: true
slsa: true
env:
REGISTRY_USERNAME: ${{ github.actor }}
REGISTRY_TOKEN: ${{ secrets.GITHUB_TOKEN }}
REGISTRY_URL: ghcr.io/organization-here
GITHUB_ORGANIZATION: organization-here
KEYLESS: true
Now you can verify the image f.e. jeroenknoops/test-image:latest
:
Keyless siging is still an expermental feature of cosign, so you need to set the flag.
$ export COSIGN_EXPERIMENTAL=1
$ cosign verify --key cosign.pub jeroenknoops/test-image:latest
You will get a result when the image is valid.
In the log you will also find a tlog index, which can be used in a web UI to view the attestations. This is an example: signature test-docker-ci-scripts image
For all the examples below we assume you bring your own keys.. obviously you can also use keyless signing there.
- name: Build Docker Images
id: docker
uses: philips-software/docker-ci-scripts@v4.5.0
with:
dockerfile: .
image-name: image-name-here
tags: latest 0.1
push-branches: main develop
slsa-provenance: true
env:
REGISTRY_USERNAME: ${{ github.actor }}
REGISTRY_TOKEN: ${{ secrets.GITHUB_TOKEN }}
REGISTRY_URL: ghcr.io/organization-here
GITHUB_ORGANIZATION: organization-here
- name: Show provenance
run: |
cat ${{ steps.docker.outputs.slsa-provenance-file }}
You can use Cosign to attach the Provenance file to the image. Obviously you will need to set the COSIGN environment variables. (see #sign how to generate the key-pair)
- name: Build Docker Images
uses: philips-software/docker-ci-scripts@v4.5.0
with:
dockerfile: .
image-name: image-name-here
tags: latest 0.1
push-branches: main develop
slsa-provenance: true
sign: true
env:
REGISTRY_USERNAME: ${{ github.actor }}
REGISTRY_TOKEN: ${{ secrets.GITHUB_TOKEN }}
REGISTRY_URL: ghcr.io/organization-here
GITHUB_ORGANIZATION: organization-here
COSIGN_PRIVATE_KEY: ${{ secrets.COSIGN_PRIVATE_KEY }}
COSIGN_PASSWORD: ${{ secrets.COSIGN_PASSWORD }}
COSIGN_PUBLIC_KEY: ${{ secrets.COSIGN_PUBLIC_KEY }}
Now you can verify the attestation for a certain docker-repo f.e. jeroenknoops/test-image:latest
:
$ cosign verify-attestation --key cosign.pub jeroenknoops/test-image:latest | jq '.payload |= @base64d | .payload | fromjson | select(.predicateType=="https://slsa.dev/provenance/v0.2" ) | .'
This is nice, because you can see how and when the image was build, without downloading it! You can inspect the provenance and decide on whether you want use the image.
- name: Build Docker Images
id: docker
uses: philips-software/docker-ci-scripts@v4.5.0
with:
dockerfile: .
image-name: image-name-here
tags: latest 0.1
push-branches: main develop
sbom: true
env:
REGISTRY_USERNAME: ${{ github.actor }}
REGISTRY_TOKEN: ${{ secrets.GITHUB_TOKEN }}
REGISTRY_URL: ghcr.io/organization-here
GITHUB_ORGANIZATION: organization-here
- name: Show SBOM
run: |
cat ${{ steps.docker.outputs.sbom-file }}
You can use Cosign to attach the SBOM file to the image. Obviously you will need to set the COSIGN environment variables. (see #sign how to generate the key-pair)
- name: Build Docker Images
uses: philips-software/docker-ci-scripts@v4.5.0
with:
dockerfile: .
image-name: image-name-here
tags: latest 0.1
push-branches: main develop
sbom: true
sign: true
env:
REGISTRY_USERNAME: ${{ github.actor }}
REGISTRY_TOKEN: ${{ secrets.GITHUB_TOKEN }}
REGISTRY_URL: ghcr.io/organization-here
GITHUB_ORGANIZATION: organization-here
COSIGN_PRIVATE_KEY: ${{ secrets.COSIGN_PRIVATE_KEY }}
COSIGN_PASSWORD: ${{ secrets.COSIGN_PASSWORD }}
COSIGN_PUBLIC_KEY: ${{ secrets.COSIGN_PUBLIC_KEY }}
Now you can verify the attestation for a certain docker-repo f.e. jeroenknoops/test-image:latest
:
$ cosign verify-attestation --key cosign.pub jeroenknoops/test-image:latest | jq '.payload |= @base64d | .payload | fromjson | select( .predicateType=="https://spdx.dev/Document" ) | .predicate.Data | fromjson | .'
You can use Cosign to attach the SBOM file and the SLSA-provenance file to the image. Obviously you will need to set the COSIGN environment variables. (see #sign how to generate the key-pair)
- name: Build Docker Images
uses: philips-software/docker-ci-scripts@v4.5.0
with:
dockerfile: .
image-name: image-name-here
tags: latest 0.1
push-branches: main develop
sbom: true
sign: true
slsa-provenance: true
env:
REGISTRY_USERNAME: ${{ github.actor }}
REGISTRY_TOKEN: ${{ secrets.GITHUB_TOKEN }}
REGISTRY_URL: ghcr.io/organization-here
GITHUB_ORGANIZATION: organization-here
COSIGN_PRIVATE_KEY: ${{ secrets.COSIGN_PRIVATE_KEY }}
COSIGN_PASSWORD: ${{ secrets.COSIGN_PASSWORD }}
COSIGN_PUBLIC_KEY: ${{ secrets.COSIGN_PUBLIC_KEY }}
Now you can verify the attestation for a certain docker-repo f.e. jeroenknoops/test-image:latest
:
$ cosign verify-attestation --key cosign.pub jeroenknoops/test-image:latest | jq '.payload |= @base64d | .payload | fromjson | select( .predicateType=="https://spdx.dev/Document" ) | .predicate.Data | fromjson | .'
$ cosign verify-attestation --key cosign.pub jeroenknoops/test-image:latest | jq '.payload |= @base64d | .payload | fromjson | select(.predicateType=="https://slsa.dev/provenance/v0.2" ) | .'
This is nice, because you can see the SBOM of the image, without downloading it! You can inspect the SBOM and decide on whether you want use the image.
Sometimes you want to automatically create major, minor and patch releases for certain tags in the repository.
For example when you create a git tag: v2.32.1
you might want to automatically create versions: 2
, 2.32
, and 2.32.1
.
This can be done with a small snippet:
- name: SplitTag
if: startsWith(github.ref, 'refs/tags/v')
run: |
refIN=${GITHUB_REF##*/}
arrIN=(${refIN//./ })
echo "major=${arrIN[0]}" >> $GITHUB_ENV
echo "minor=${arrIN[0]}.${arrIN[1]}" >> $GITHUB_ENV
echo "patch=${arrIN[0]}.${arrIN[1]}.${arrIN[2]}" >> $GITHUB_ENV
- name: Set no tag
if: startsWith(github.ref, 'refs/tags/v') == false
run: |
echo "major=" >> $GITHUB_ENV
echo "minor=" >> $GITHUB_ENV
echo "patch=" >> $GITHUB_ENV
- uses: philips-software/docker-ci-scripts@v4.2.0
with:
dockerfile: "./docker/Dockerfile"
image-name: "node"
tags: "latest ${{ env.major }} ${{ env.minor }} ${{ env.patch }}"
push-on-git-tag: "true"
env:
REGISTRY_USERNAME: ${{ secrets.REGISTRY_USERNAME }}
REGISTRY_TOKEN: "${{ secrets.REGISTRY_TOKEN }}"
DOCKER_ORGANIZATION: myDockerOrganization
Thanks to @daantimmer to provide this snippet.
- philips-software/docker-node
- philips-software/docker-blackduck
- philips-software/docker-openjdk
- philips-software/docker-goss
- philips-software/docker-bats
- philips-software/docker-scala
The docker build
command is now being called from the root of the project
instead of the directory.
This has impact when your project has these two things:
- Directories with dockerfiles
- The dockerfile contains an
ADD
or aCOPY
command.
You now need to change the path to include the directory.
Example:
ADD /scripts/entrypoint.sh entrypoint.sh
becomes:ADD /6/java/scripts/entrypoint.sh entrypoint
docker-build-and-publish is not certified by GitHub. It is provided by a third-party and is governed by separate terms of service, privacy policy, and support documentation.