Merge tag 'v2.6.2' into release/polygon-2.x-fh3.0 #430
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: Build, push and release (if tag) | |
| on: | |
| push: | |
| tags: | |
| - "*-v*" | |
| branches: | |
| - "firehose-fh3.0" | |
| - "release/*" | |
| env: | |
| REGISTRY: ghcr.io | |
| IMAGE_NAME: ${{ github.repository }} | |
| jobs: | |
| build: | |
| strategy: | |
| matrix: | |
| include: | |
| - platform: linux/amd64 | |
| platform_suffix: amd64 | |
| runner: ubuntu-22.04 | |
| - platform: linux/arm64 | |
| platform_suffix: arm64 | |
| runner: ubuntu-22.04-arm | |
| runs-on: ["${{ matrix.runner }}"] | |
| steps: | |
| - name: Checkout repository | |
| uses: actions/checkout@v4 | |
| - name: Set up Docker Buildx | |
| uses: docker/setup-buildx-action@v3 | |
| - name: Log in to the Container registry | |
| uses: docker/login-action@v3 | |
| with: | |
| registry: ${{ env.REGISTRY }} | |
| username: ${{ github.actor }} | |
| password: ${{ secrets.GITHUB_TOKEN }} | |
| - name: Extract version | |
| id: extract-version | |
| run: | | |
| version="edge" | |
| if [[ "${GITHUB_REF}" == refs/tags/* ]]; then | |
| version=${GITHUB_REF#refs/tags/} | |
| fi | |
| echo "VERSION=${version}" >> "$GITHUB_OUTPUT" | |
| - name: Generate docker tags/labels from github build context | |
| id: meta | |
| uses: docker/metadata-action@v5 | |
| with: | |
| images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} | |
| # The second sha tag is defined to uniquely identify the image and the platform, | |
| # we append extract version, either edge or <tag>, this is necessary to avoid a | |
| # race condition when pushing a tag and its related branches. In this case, three | |
| # build are launched, but only one, the tag, will get it's version set to the tag. | |
| # | |
| # What happened is that non-tag Docker built image like `3b14725-amd64` was | |
| # overwriting the tag Docker image also labeled `3b14725-amd64`. The `push` action | |
| # was then merging an image that didn't have the version labels correctly set. | |
| # | |
| # Our image more looks like `3b14725-edge-amd64` or `3b14725-geth-v1.15.10-fh3.0-amd64` | |
| # which mean the `push` can now pick the correct image depending on the type of build. | |
| tags: | | |
| type=ref,event=tag,prefix= | |
| type=sha,prefix= | |
| type=sha,prefix=,suffix=-${{ steps.extract-version.outputs.VERSION }}-${{ matrix.platform_suffix }} | |
| type=edge,branch=firehose-fh3.0,priority=1 | |
| type=edge,branch=release/*,priority=1 | |
| flavor: | | |
| latest=${{ startsWith(github.ref, 'refs/tags/') && !contains(github.ref, 'beta') && !contains(github.ref, 'rc') }} | |
| prefix=polygon-,onlatest=true | |
| - name: Build and push Docker image (${{ matrix.platform }}) | |
| uses: docker/build-push-action@v6 | |
| with: | |
| context: . | |
| file: ./Dockerfile.sf | |
| platforms: ${{ matrix.platform }} | |
| push: true | |
| tags: ${{ steps.meta.outputs.tags }} | |
| labels: ${{ steps.meta.outputs.labels }} | |
| provenance: false | |
| push: | |
| needs: build | |
| runs-on: ubuntu-22.04 | |
| permissions: | |
| contents: read | |
| packages: write | |
| steps: | |
| - name: Docker login | |
| uses: docker/login-action@v3 | |
| with: | |
| registry: ${{ env.REGISTRY }} | |
| username: ${{ github.actor }} | |
| password: ${{ secrets.GITHUB_TOKEN }} | |
| - name: Generate docker tags/labels from github build context | |
| id: meta | |
| uses: docker/metadata-action@v5 | |
| with: | |
| images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} | |
| tags: | | |
| type=ref,event=tag,prefix= | |
| type=sha,prefix= | |
| type=edge,branch=firehose-fh3.0,priority=1 | |
| type=edge,branch=release/*,priority=1 | |
| flavor: | | |
| latest=${{ startsWith(github.ref, 'refs/tags/') && !contains(github.ref, 'beta') && !contains(github.ref, 'rc') }} | |
| prefix=polygon-,onlatest=true | |
| sep-tags: "," | |
| - name: Extract image | |
| id: image | |
| run: | | |
| version="edge" | |
| if [[ "${GITHUB_REF}" == refs/tags/* ]]; then | |
| version=${GITHUB_REF#refs/tags/} | |
| fi | |
| echo "ID=${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${GITHUB_SHA::7}-${version}" >> "$GITHUB_OUTPUT" | |
| - name: Create and push manifest images | |
| uses: Noelware/docker-manifest-action@0.4.3 | |
| with: | |
| inputs: "${{ steps.meta.outputs.tags }}" | |
| images: "${{ steps.image.outputs.ID }}-amd64, ${{ steps.image.outputs.ID }}-arm64" | |
| push: true | |
| release: | |
| if: startsWith(github.ref, 'refs/tags/') | |
| needs: build | |
| runs-on: ubuntu-22.04 | |
| permissions: | |
| contents: write | |
| steps: | |
| - name: Extract image | |
| id: image | |
| run: | | |
| version="edge" | |
| if [[ "${GITHUB_REF}" == refs/tags/* ]]; then | |
| version=${GITHUB_REF#refs/tags/} | |
| fi | |
| echo "ID=${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${GITHUB_SHA::7}-${version}" >> "$GITHUB_OUTPUT" | |
| - name: Extract assets | |
| if: startsWith(github.ref, 'refs/tags/') | |
| run: | | |
| # The --platform are not really needed here, but it removes the warning | |
| docker cp $(docker create --platform=linux/amd64 ${{ steps.image.outputs.ID }}-amd64):/usr/local/bin/bor ./bor_linux | |
| docker cp $(docker create --platform=linux/arm64 ${{ steps.image.outputs.ID }}-arm64):/usr/local/bin/bor ./bor_linux_arm64 | |
| - name: Release | |
| uses: softprops/action-gh-release@v2 | |
| with: | |
| prerelease: ${{ contains(github.ref, 'beta') || contains(github.ref, 'rc') }} | |
| files: | | |
| ./bor_linux | |
| ./bor_linux_arm64 |