From 98f5e5532c0c47d02e80ef7dfb97539bb0b10a95 Mon Sep 17 00:00:00 2001 From: Ethan O'Brien <77750390+ethanaobrien@users.noreply.github.com> Date: Fri, 5 Jul 2024 10:50:41 -0500 Subject: [PATCH] This will probably not work --- .github/workflows/docker.yml | 89 ++++++++++++++++++++++++++++++++++++ 1 file changed, 89 insertions(+) create mode 100644 .github/workflows/docker.yml diff --git a/.github/workflows/docker.yml b/.github/workflows/docker.yml new file mode 100644 index 0000000..d4eb643 --- /dev/null +++ b/.github/workflows/docker.yml @@ -0,0 +1,89 @@ +# GitHub actions workflow which builds and publishes the docker images. + +name: Build docker images + +on: + push: + tags: ["v*"] + branches: [ main ] + workflow_dispatch: + +permissions: + contents: read + packages: write + id-token: write # needed for signing the images with GitHub OIDC Token +jobs: + build: + runs-on: ubuntu-latest + steps: + - name: Set up QEMU + id: qemu + uses: docker/setup-qemu-action@v3 + with: + platforms: arm64 + + - name: Set up Docker Buildx + id: buildx + uses: docker/setup-buildx-action@v3 + + - name: Inspect builder + run: docker buildx inspect + + - name: Install Cosign + uses: sigstore/cosign-installer@v3.5.0 + + - name: Checkout repository + uses: actions/checkout@v4 + + - name: Extract version from Cargo.toml + # Note: explicitly requesting bash will mean bash is invoked with `-eo pipefail`, see + # https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsshell + shell: bash + run: | + echo "EW_VERSION=$(grep "^version" Cargo.toml | sed -E 's/version\s*=\s*["]([^"]*)["]/\1/')" >> $GITHUB_ENV + + - name: Log in to DockerHub + uses: docker/login-action@v3 + with: + username: ${{ secrets.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_TOKEN }} + + - name: Calculate docker image tag + id: set-tag + uses: docker/metadata-action@master + with: + images: | + docker.io/ethanaobrien/ew + flavor: | + latest=false + tags: | + type=raw,value=latest,enable=${{ github.ref == 'refs/heads/main' }} + type=pep440,pattern={{raw}} + + - name: Build and push all platforms + id: build-and-push + uses: docker/build-push-action@v6 + with: + push: true + labels: | + gitsha1=${{ github.sha }} + org.opencontainers.image.version=${{ env.EW_VERSION }} + tags: "${{ steps.set-tag.outputs.tags }}" + file: "docker/Dockerfile" + platforms: linux/amd64,linux/arm64 + + # arm64 builds OOM without the git fetch setting. c.f. + # https://github.com/rust-lang/cargo/issues/10583 + build-args: | + CARGO_NET_GIT_FETCH_WITH_CLI=true + + - name: Sign the images with GitHub OIDC Token + env: + DIGEST: ${{ steps.build-and-push.outputs.digest }} + TAGS: ${{ steps.set-tag.outputs.tags }} + run: | + images="" + for tag in ${TAGS}; do + images+="${tag}@${DIGEST} " + done + cosign sign --yes ${images}