|
@@ -7,34 +7,103 @@ on:
|
|
|
paths:
|
|
|
- "ci.Dockerfile"
|
|
|
- "**/builder-image.yml"
|
|
|
+
|
|
|
+env:
|
|
|
+ REGISTRY_IMAGE: jguer/yay-builder
|
|
|
+
|
|
|
jobs:
|
|
|
build:
|
|
|
- name: Push builder image to Docker Hub
|
|
|
runs-on: ubuntu-latest
|
|
|
+ strategy:
|
|
|
+ fail-fast: true
|
|
|
+ matrix:
|
|
|
+ platform:
|
|
|
+ - linux/amd64
|
|
|
+ - linux/arm/v7
|
|
|
+ - linux/arm64
|
|
|
steps:
|
|
|
- name: Checkout
|
|
|
- uses: actions/checkout@v2
|
|
|
+ uses: actions/checkout@v3
|
|
|
+ - name: Docker meta
|
|
|
+ id: meta
|
|
|
+ uses: docker/metadata-action@v4
|
|
|
+ with:
|
|
|
+ images: ${{ env.REGISTRY_IMAGE }}
|
|
|
+ tags: |
|
|
|
+ type=raw,value=latest
|
|
|
- name: Set up QEMU
|
|
|
- uses: docker/setup-qemu-action@v1
|
|
|
+ uses: docker/setup-qemu-action@v2
|
|
|
- name: Set up Docker Buildx
|
|
|
- uses: docker/setup-buildx-action@v1
|
|
|
- - name: Login to DockerHub
|
|
|
- uses: docker/login-action@v1
|
|
|
- with:
|
|
|
- username: ${{ secrets.DOCKER_USERNAME }}
|
|
|
- password: ${{ secrets.DOCKER_PASSWORD }}
|
|
|
- - name: Push to Docker Hub
|
|
|
- uses: docker/build-push-action@v2
|
|
|
- env:
|
|
|
- DOCKER_BUILDKIT: 0
|
|
|
- COMPOSE_DOCKER_CLI_BUILD: 0
|
|
|
- with:
|
|
|
- platforms: linux/amd64,linux/arm/v7,linux/arm64
|
|
|
+ uses: docker/setup-buildx-action@v2
|
|
|
+ - name: Login to Docker Hub
|
|
|
+ uses: docker/login-action@v2
|
|
|
+ with:
|
|
|
+ username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
|
+ password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
|
+ - name: Login to GitHub Container Registry
|
|
|
+ uses: docker/login-action@v2
|
|
|
+ with:
|
|
|
+ registry: ghcr.io
|
|
|
+ username: ${{ github.repository_owner }}
|
|
|
+ password: ${{ secrets.GITHUB_TOKEN }}
|
|
|
+ - name: Build and push by digest
|
|
|
+ id: build
|
|
|
+ uses: docker/build-push-action@v4
|
|
|
+ with:
|
|
|
+ context: .
|
|
|
file: ci.Dockerfile
|
|
|
- push: true
|
|
|
- tags: jguer/yay-builder:latest
|
|
|
- secrets: |
|
|
|
- DOCKER_BUILDKIT=0
|
|
|
- COMPOSE_DOCKER_CLI_BUILD=0
|
|
|
- cache-from: type=registry,ref=jguer/yay-builder:latest
|
|
|
- cache-to: type=inline
|
|
|
+ platforms: ${{ matrix.platform }}
|
|
|
+ labels: ${{ steps.meta.outputs.labels }}
|
|
|
+ outputs: |
|
|
|
+ type=image,name=${{ env.REGISTRY_IMAGE }},push-by-digest=true,name-canonical=true,push=true
|
|
|
+ - name: Export digest
|
|
|
+ run: |
|
|
|
+ mkdir -p /tmp/digests
|
|
|
+ digest="${{ steps.build.outputs.digest }}"
|
|
|
+ touch "/tmp/digests/${digest#sha256:}"
|
|
|
+ - name: Upload digest
|
|
|
+ uses: actions/upload-artifact@v3
|
|
|
+ with:
|
|
|
+ name: digests
|
|
|
+ path: /tmp/digests/*
|
|
|
+ if-no-files-found: error
|
|
|
+ retention-days: 1
|
|
|
+
|
|
|
+ merge:
|
|
|
+ runs-on: ubuntu-latest
|
|
|
+ needs:
|
|
|
+ - build
|
|
|
+ steps:
|
|
|
+ - name: Download digests
|
|
|
+ uses: actions/download-artifact@v3
|
|
|
+ with:
|
|
|
+ name: digests
|
|
|
+ path: /tmp/digests
|
|
|
+ - name: Set up Docker Buildx
|
|
|
+ uses: docker/setup-buildx-action@v2
|
|
|
+ - name: Docker meta
|
|
|
+ id: meta
|
|
|
+ uses: docker/metadata-action@v4
|
|
|
+ with:
|
|
|
+ images: ${{ env.REGISTRY_IMAGE }}
|
|
|
+ tags: |
|
|
|
+ type=raw,value=latest
|
|
|
+ - name: Login to Docker Hub
|
|
|
+ uses: docker/login-action@v2
|
|
|
+ with:
|
|
|
+ username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
|
+ password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
|
+ - name: Login to GitHub Container Registry
|
|
|
+ uses: docker/login-action@v2
|
|
|
+ with:
|
|
|
+ registry: ghcr.io
|
|
|
+ username: ${{ github.repository_owner }}
|
|
|
+ password: ${{ secrets.GITHUB_TOKEN }}
|
|
|
+ - name: Create manifest list and push
|
|
|
+ working-directory: /tmp/digests
|
|
|
+ run: |
|
|
|
+ docker buildx imagetools create $(jq -cr '.tags | map("-t " + .) | join(" ")' <<< "$DOCKER_METADATA_OUTPUT_JSON") \
|
|
|
+ $(printf '${{ env.REGISTRY_IMAGE }}@sha256:%s ' *)
|
|
|
+ - name: Inspect image
|
|
|
+ run: |
|
|
|
+ docker buildx imagetools inspect ${{ env.REGISTRY_IMAGE }}:${{ steps.meta.outputs.version }}
|