Skip to content

Commit

Permalink
added release workflow
Browse files Browse the repository at this point in the history
  • Loading branch information
johnstonematt committed Feb 24, 2025
1 parent 11812e4 commit d702764
Showing 1 changed file with 66 additions and 0 deletions.
66 changes: 66 additions & 0 deletions .github/workflows/release.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
name: Build and Publish Release

on:
workflow_dispatch:
inputs:
tag:
description: "Release tag (e.g., v1.0.0)"
required: true
type: string

jobs:
build:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write

steps:
# TODO: pin these with digests
- uses: actions/checkout@v4

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3

- name: Install cosign
uses: sigstore/[email protected]

- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: Extract metadata for Docker
id: meta
uses: docker/metadata-action@v5
with:
images: ghcr.io/${{ github.repository }}
tags: |
type=raw,value=${{ inputs.tag }}
type=raw,value=latest
- name: Build and push Docker image
uses: docker/build-push-action@v5
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
provenance: true
sbom: true

- name: Sign the images
env:
TAGS: ${{ steps.meta.outputs.tags }}
run: |
cosign sign --yes "${TAGS}"
- name: Generate SBOM attestation
env:
TAGS: ${{ steps.meta.outputs.tags }}
run: |
cosign attest --yes --type spdx --predicate sbom.spdx.json "${TAGS}"

0 comments on commit d702764

Please sign in to comment.