Skip to content

Build and publish Docker images #15

Build and publish Docker images

Build and publish Docker images #15

Workflow file for this run

name: Build and publish Docker images
on:
workflow_dispatch:
inputs:
version:
description: 'The version of zizmor to build against'
required: true
permissions: {}
jobs:
docker-build:
strategy:
fail-fast: false
matrix:
image:
- runner: ubuntu-latest
platform: linux/amd64
- runner: ubuntu-24.04-arm
platform: linux/arm64
name: Build and publish Docker image (${{ matrix.image.runner }})
runs-on: ${{ matrix.image.runner }}
env:
ZIZMOR_IMAGE: ghcr.io/woodruffw/zizmor
environment:
name: docker
permissions:
contents: read
packages: write
steps:
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4
with:
persist-credentials: false
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@6524bf65af31da8d45b59e8c27de4bd072b392f5 # v3
with:
cache-binary: false
- name: Extract Docker metadata
id: docker-metadata
uses: docker/metadata-action@369eb591f429131d6889c46b94e711f089e6ca96 # v5
with:
images: "${{ env.ZIZMOR_IMAGE }}"
tags: |
type=raw,value=${{ github.event.inputs.version }}
- name: Login to GHCR
uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567 # v6
if: github.repository_owner == 'woodruffw'
with:
registry: ghcr.io
username: "${{ github.repository_owner }}"
password: "${{ secrets.GITHUB_TOKEN }}"
- name: Build and push Docker image
uses: docker/build-push-action@ca877d9245402d1537745e0e356eab47c3520991 # v6
with:
context: .
push: true
tags: ${{ steps.docker-metadata.outputs.tags }}
labels: ${{ steps.docker-metadata.outputs.labels }}
build-args: |
ZIZMOR_VERSION=${{ github.event.inputs.version }}
provenance: true
platforms: ${{ matrix.image.platform }}