Skip to content

Commit

Permalink
Merge branch 'master' into native_package_fedora
Browse files Browse the repository at this point in the history
  • Loading branch information
bruhhgnik committed Oct 4, 2024
2 parents 0115876 + 0a9c307 commit 6c50be1
Showing 1 changed file with 84 additions and 0 deletions.
84 changes: 84 additions & 0 deletions .github/workflows/docker-publish.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
name: Build and Publish image to Docker Hub
on:
repository_dispatch:
types: [prover-update]
push:
tags:
- 'v*.*.*'

jobs:
build_and_push:
env:
DOCKER_HUB: ${{ secrets.DOCKER_LOGIN }}
DOCKER_TAGS: latest
DOCKER_REGISTRY: docker.io
runs-on: ubuntu-22.04
permissions:
id-token: write
attestations: write
contents: read
packages: write

strategy:
matrix:
target:
- name: stone-prover
dockerfile: Dockerfile
- name: cpu_air_prover
dockerfile: air_prover/Dockerfile
- name: cpu_air_verifier
dockerfile: air_verifier/Dockerfile
continue-on-error: true

steps:
- name: Checkout
uses: actions/checkout@v4

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

- name: Log in to Docker Hub
uses: docker/login-action@v3
with:
registry: ${{ env.DOCKER_REGISTRY }}
username: ${{ secrets.DOCKER_LOGIN }}
password: ${{ secrets.DOCKERHUB_TOKEN }}

- name: Determine Docker Tags
id: set-tag
run: |
if [[ "${GITHUB_EVENT_NAME}" == "repository_dispatch" ]]; then
echo "Latest version tags..."
elif [[ "${GITHUB_REF}" == refs/tags/* ]]; then
TAG_NAME=$(echo ${GITHUB_REF} | sed 's/refs\/tags\///')
echo "DOCKER_TAGS=${TAG_NAME}" >> $GITHUB_ENV
else
echo "No valid ref for tagging. Exiting..."
exit 1
fi
shell: bash

- name: Set image tags & labels
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.DOCKER_REGISTRY }}/bakingbad/${{ matrix.target.name }}
tags: ${{ env.DOCKER_TAGS }}

- name: Build And Push Image
id: push
uses: docker/build-push-action@v6
with:
context: .
file: ${{ matrix.target.dockerfile }}
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}

- name: Generate artifact attestation
uses: actions/attest-build-provenance@v1
with:
subject-name: ${{ env.DOCKER_REGISTRY }}/bakingbad/${{ matrix.target.name }}
subject-digest: ${{ steps.push.outputs.digest }}
push-to-registry: true

0 comments on commit 6c50be1

Please sign in to comment.