| | name: 'Docker Release' |
| |
|
| | on: |
| | push: |
| | branches: |
| | - master |
| | paths: |
| | - '.github/workflows/docker-release.yml' |
| | - 'lib/**' |
| | - '!lib/**/*.test.ts' |
| | - 'Dockerfile' |
| | workflow_dispatch: {} |
| |
|
| | jobs: |
| | check-env: |
| | permissions: |
| | contents: none |
| | runs-on: ubuntu-slim |
| | timeout-minutes: 5 |
| | outputs: |
| | check-docker: ${{ steps.check-docker.outputs.defined }} |
| | steps: |
| | - id: check-docker |
| | env: |
| | DOCKER_USERNAME: ${{ vars.DOCKER_USERNAME }} |
| | if: ${{ env.DOCKER_USERNAME != '' }} |
| | run: echo "defined=true" >> $GITHUB_OUTPUT |
| | release: |
| | runs-on: ${{ matrix.runner }} |
| | needs: check-env |
| | if: needs.check-env.outputs.check-docker == 'true' |
| | timeout-minutes: 30 |
| | outputs: |
| | repo-name: ${{ steps.repo-name.outputs.repo-name }} |
| | strategy: |
| | fail-fast: false |
| | matrix: |
| | include: |
| | - platform: linux/amd64 |
| | runner: ubuntu-latest |
| | - platform: linux/arm64 |
| | runner: ubuntu-24.04-arm |
| | permissions: |
| | packages: write |
| | id-token: write |
| | attestations: write |
| | steps: |
| | - name: Enable ZRAM |
| | |
| | |
| | run: | |
| | sudo apt-get update -yq |
| | sudo apt-get install -yq "linux-modules-extra-$(uname -r)" zram-tools |
| | echo -e 'ALGO=zstd\nPERCENT=100' | sudo tee -a /etc/default/zramswap |
| | sudo systemctl restart zramswap |
| | swapon |
| | |
| | - name: Prepare |
| | run: | |
| | platform=${{ matrix.platform }} |
| | echo "PLATFORM_PAIR=${platform//\//-}" >> $GITHUB_ENV |
| | |
| | - name: Checkout |
| | uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd |
| |
|
| | - name: Extract repository name |
| | id: repo-name |
| | run: | |
| | REPO_NAME="${GITHUB_REPOSITORY#*/}" |
| | REPO_NAME_LOWER="${REPO_NAME,,}" |
| | echo "repo-name=$REPO_NAME_LOWER" >> "$GITHUB_OUTPUT" |
| | |
| | - name: Set up Docker Buildx |
| | uses: docker/setup-buildx-action@8d2750c68a42422c14e847fe6c8ac0403b4cbd6f |
| |
|
| | - name: Log in to Docker Hub |
| | uses: docker/login-action@c94ce9fb468520275223c153574b00df6fe4bcc9 |
| | with: |
| | username: ${{ vars.DOCKER_USERNAME }} |
| | password: ${{ secrets.DOCKER_PASSWORD }} |
| |
|
| | - name: Log in to the Container registry |
| | uses: docker/login-action@c94ce9fb468520275223c153574b00df6fe4bcc9 |
| | with: |
| | registry: ghcr.io |
| | username: ${{ github.actor }} |
| | password: ${{ secrets.GITHUB_TOKEN }} |
| |
|
| | - name: Extract Docker metadata (ordinary version) |
| | id: meta-ordinary |
| | uses: docker/metadata-action@c299e40c65443455700f0fdfc63efafe5b349051 |
| | with: |
| | images: | |
| | ${{ vars.DOCKER_USERNAME }}/${{ steps.repo-name.outputs.repo-name }} |
| | ghcr.io/${{ github.repository }} |
| | tags: | |
| | type=raw,value=latest,enable=true |
| | type=raw,value={{date 'YYYY-MM-DD'}},enable=true |
| | type=sha,format=long,prefix=,enable=true |
| | flavor: latest=false |
| |
|
| | - name: Extract image names (ordinary version) |
| | id: image-name-ordinary |
| | run: | |
| | tags=$(jq -r '.target["docker-metadata-action"].args.DOCKER_META_IMAGES' "$DOCKER_METADATA_OUTPUT_BAKE_FILE_TAGS") |
| | echo "tags=$tags" >> "$GITHUB_OUTPUT" |
| | |
| | - name: Build and push Docker image (ordinary version) |
| | id: build-and-push |
| | uses: docker/build-push-action@10e90e3645eae34f1e60eeb005ba3a3d33f178e8 |
| | with: |
| | context: . |
| | tags: ${{ steps.image-name-ordinary.outputs.tags }} |
| | labels: ${{ steps.meta-ordinary.outputs.labels }} |
| | platforms: ${{ matrix.platform }} |
| | cache-from: type=gha,scope=docker-release-${{ env.PLATFORM_PAIR }} |
| | cache-to: type=gha,mode=max,scope=docker-release-${{ env.PLATFORM_PAIR }} |
| | outputs: type=image,compression=zstd,force-compression=true,push-by-digest=true,name-canonical=true,push=true |
| |
|
| | - name: Attest (ordinary version) |
| | uses: actions/attest-build-provenance@96278af6caaf10aea03fd8d33a09a777ca52d62f |
| | with: |
| | subject-name: | |
| | ${{ vars.DOCKER_USERNAME }}/${{ steps.repo-name.outputs.repo-name }} |
| | ghcr.io/${{ github.repository }} |
| | subject-digest: ${{ steps.build-and-push.outputs.digest }} |
| |
|
| | - name: Export digest (ordinary version) |
| | run: | |
| | mkdir -p ${{ runner.temp }}/digests/ordinary |
| | digest="${{ steps.build-and-push.outputs.digest }}" |
| | touch "${{ runner.temp }}/digests/ordinary/${digest#sha256:}" |
| | |
| | - name: Upload digest (ordinary version) |
| | uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f |
| | with: |
| | name: digests-ordinary-${{ env.PLATFORM_PAIR }} |
| | path: ${{ runner.temp }}/digests/ordinary/* |
| | if-no-files-found: error |
| | retention-days: 1 |
| |
|
| | - name: Extract Docker metadata (Chromium-bundled version) |
| | id: meta-chromium-bundled |
| | uses: docker/metadata-action@c299e40c65443455700f0fdfc63efafe5b349051 |
| | with: |
| | images: | |
| | ${{ vars.DOCKER_USERNAME }}/${{ steps.repo-name.outputs.repo-name }} |
| | ghcr.io/${{ github.repository }} |
| | tags: | |
| | type=raw,value=chromium-bundled,enable=true |
| | type=raw,value=chromium-bundled-{{date 'YYYY-MM-DD'}},enable=true |
| | type=sha,format=long,prefix=chromium-bundled-,enable=true |
| | flavor: latest=false |
| |
|
| | - name: Extract image names (Chromium-bundled version) |
| | id: image-name-chromium-bundled |
| | run: | |
| | tags=$(jq -r '.target["docker-metadata-action"].args.DOCKER_META_IMAGES' "$DOCKER_METADATA_OUTPUT_BAKE_FILE_TAGS") |
| | echo "tags=$tags" >> "$GITHUB_OUTPUT" |
| | |
| | - name: Build and push Docker image (Chromium-bundled version) |
| | id: build-and-push-chromium |
| | uses: docker/build-push-action@10e90e3645eae34f1e60eeb005ba3a3d33f178e8 |
| | with: |
| | context: . |
| | build-args: PUPPETEER_SKIP_DOWNLOAD=0 |
| | tags: ${{ steps.image-name-chromium-bundled.outputs.tags }} |
| | labels: ${{ steps.meta-chromium-bundled.outputs.labels }} |
| | platforms: ${{ matrix.platform }} |
| | cache-from: | |
| | type=registry,ref=${{ vars.DOCKER_USERNAME }}/${{ steps.repo-name.outputs.repo-name }}:chromium-bundled |
| | cache-to: type=inline,ref=${{ vars.DOCKER_USERNAME }}/${{ steps.repo-name.outputs.repo-name }}:chromium-bundled |
| | outputs: type=image,compression=zstd,force-compression=true,push-by-digest=true,name-canonical=true,push=true |
| |
|
| | - name: Attest (Chromium-bundled version) |
| | uses: actions/attest-build-provenance@96278af6caaf10aea03fd8d33a09a777ca52d62f |
| | with: |
| | subject-name: | |
| | ${{ vars.DOCKER_USERNAME }}/${{ steps.repo-name.outputs.repo-name }} |
| | ghcr.io/${{ github.repository }} |
| | subject-digest: ${{ steps.build-and-push-chromium.outputs.digest }} |
| |
|
| | - name: Export digest (Chromium-bundled version) |
| | run: | |
| | mkdir -p ${{ runner.temp }}/digests/chromium |
| | digest="${{ steps.build-and-push-chromium.outputs.digest }}" |
| | touch "${{ runner.temp }}/digests/chromium/${digest#sha256:}" |
| | |
| | - name: Upload digest (Chromium-bundled version) |
| | uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f |
| | with: |
| | name: digests-chromium-${{ env.PLATFORM_PAIR }} |
| | path: ${{ runner.temp }}/digests/chromium/* |
| | if-no-files-found: error |
| | retention-days: 1 |
| |
|
| | merge: |
| | runs-on: ubuntu-latest |
| | needs: [check-env, release] |
| | if: needs.check-env.outputs.check-docker == 'true' |
| | timeout-minutes: 5 |
| | permissions: |
| | packages: write |
| | id-token: write |
| | steps: |
| | - name: Set up Docker Buildx |
| | uses: docker/setup-buildx-action@8d2750c68a42422c14e847fe6c8ac0403b4cbd6f |
| |
|
| | - name: Log in to Docker Hub |
| | uses: docker/login-action@c94ce9fb468520275223c153574b00df6fe4bcc9 |
| | with: |
| | username: ${{ vars.DOCKER_USERNAME }} |
| | password: ${{ secrets.DOCKER_PASSWORD }} |
| |
|
| | - name: Log in to the Container registry |
| | uses: docker/login-action@c94ce9fb468520275223c153574b00df6fe4bcc9 |
| | with: |
| | registry: ghcr.io |
| | username: ${{ github.actor }} |
| | password: ${{ secrets.GITHUB_TOKEN }} |
| |
|
| | - name: Download digests (ordinary version) |
| | uses: actions/download-artifact@37930b1c2abaa49bbe596cd826c3c89aef350131 |
| | with: |
| | path: ${{ runner.temp }}/digests/ordinary |
| | pattern: digests-ordinary-* |
| | merge-multiple: true |
| |
|
| | - name: Extract Docker metadata (ordinary version) |
| | id: meta-ordinary-merge |
| | uses: docker/metadata-action@c299e40c65443455700f0fdfc63efafe5b349051 |
| | with: |
| | images: | |
| | ${{ vars.DOCKER_USERNAME }}/${{ needs.release.outputs.repo-name }} |
| | ghcr.io/${{ github.repository }} |
| | tags: | |
| | type=raw,value=latest,enable=true |
| | type=raw,value={{date 'YYYY-MM-DD'}},enable=true |
| | type=sha,format=long,prefix=,enable=true |
| | flavor: latest=false |
| |
|
| | - name: Create manifest list and push (ordinary version) |
| | working-directory: ${{ runner.temp }}/digests/ordinary |
| | run: | |
| | docker buildx imagetools create $(jq -cr '.tags | map("-t " + .) | join(" ")' <<< "$DOCKER_METADATA_OUTPUT_JSON") \ |
| | $(printf '${{ vars.DOCKER_USERNAME }}/${{ needs.release.outputs.repo-name }}@sha256:%s ' *) |
| | |
| | - name: Download digests (Chromium-bundled version) |
| | uses: actions/download-artifact@37930b1c2abaa49bbe596cd826c3c89aef350131 |
| | with: |
| | path: ${{ runner.temp }}/digests/chromium |
| | pattern: digests-chromium-* |
| | merge-multiple: true |
| |
|
| | - name: Extract Docker metadata (Chromium-bundled version) |
| | id: meta-chromium-bundled-merge |
| | uses: docker/metadata-action@c299e40c65443455700f0fdfc63efafe5b349051 |
| | with: |
| | images: | |
| | ${{ vars.DOCKER_USERNAME }}/${{ needs.release.outputs.repo-name }} |
| | ghcr.io/${{ github.repository }} |
| | tags: | |
| | type=raw,value=chromium-bundled,enable=true |
| | type=raw,value=chromium-bundled-{{date 'YYYY-MM-DD'}},enable=true |
| | type=sha,format=long,prefix=chromium-bundled-,enable=true |
| | flavor: latest=false |
| |
|
| | - name: Create manifest list and push (Chromium-bundled version) |
| | working-directory: ${{ runner.temp }}/digests/chromium |
| | run: | |
| | docker buildx imagetools create $(jq -cr '.tags | map("-t " + .) | join(" ")' <<< "$DOCKER_METADATA_OUTPUT_JSON") \ |
| | $(printf '${{ vars.DOCKER_USERNAME }}/${{ needs.release.outputs.repo-name }}@sha256:%s ' *) |
| | |
| | description: |
| | runs-on: ubuntu-slim |
| | needs: [check-env, release] |
| | if: needs.check-env.outputs.check-docker == 'true' |
| | timeout-minutes: 5 |
| | steps: |
| | - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd |
| |
|
| | - name: Docker Hub Description |
| | uses: peter-evans/dockerhub-description@1b9a80c056b620d92cedb9d9b5a223409c68ddfa |
| | with: |
| | username: ${{ vars.DOCKER_USERNAME }} |
| | password: ${{ secrets.DOCKER_PASSWORD }} |
| | repository: ${{ vars.DOCKER_USERNAME }}/${{ needs.release.outputs.repo-name }} |
| |
|