name: Docker image builds on: workflow_dispatch: push: branches: [ "main" ] tags: [ "v*" ] pull_request: branches: [ "main" ] permissions: contents: read packages: write attestations: write id-token: write jobs: build: runs-on: ubuntu-latest steps: - name: Checkout code uses: actions/checkout@v4 - name: Set up QEMU uses: docker/setup-qemu-action@v3 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - name: Log into registry uses: docker/login-action@v3 with: registry: ghcr.io username: techarohq password: ${{ secrets.GITHUB_TOKEN }} - name: Docker meta id: meta uses: docker/metadata-action@v5 with: images: ghcr.io/techarohq/anubis - name: Build and push id: build uses: docker/build-push-action@v6 with: context: . cache-to: type=gha cache-from: type=gha tags: ${{ steps.meta.outputs.tags }} labels: ${{ steps.meta.outputs.labels }} platforms: linux/arm64/v8,linux/amd64 sbom: true push: true - name: Generate artifact attestation uses: actions/attest-build-provenance@v2 with: subject-name: ghcr.io/techarohq/anubis subject-digest: ${{ steps.build.outputs.digest }} push-to-registry: true