123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258 |
- ---
- name: Build binary releases
- on:
- pull_request:
- branches:
- - main
- push:
- branches:
- - main
- tags:
- - v*.*.*
- workflow_dispatch:
- inputs:
- version:
- description: 'FrankenPHP version'
- required: false
- type: string
- schedule:
- - cron: '0 0 * * *'
- env:
- IMAGE_NAME: ${{ (github.event_name == 'schedule' || (github.event_name == 'workflow_dispatch' && inputs.version) || startsWith(github.ref, 'refs/tags/')) && 'dunglas/frankenphp' || 'dunglas/frankenphp-dev' }}
- LATEST: ${{ (github.event_name == 'schedule' || (github.event_name == 'workflow_dispatch' && inputs.version) || startsWith(github.ref, 'refs/tags/')) && '0' || '1' }}
- jobs:
- prepare:
- runs-on: ubuntu-latest
- outputs:
- push: ${{ toJson((steps.check.outputs.ref || (github.event_name == 'workflow_dispatch' && inputs.version) || startsWith(github.ref, 'refs/tags/') || (github.ref == 'refs/heads/main' && github.event_name != 'pull_request')) && true || false) }}
- platforms: ${{ steps.matrix.outputs.platforms }}
- metadata: ${{ steps.matrix.outputs.metadata }}
- ref: ${{ steps.check.outputs.ref }}
- steps:
- -
- name: Get version
- id: check
- if: github.event_name == 'schedule'
- run: |
- ref="${{ (github.ref_type == 'tag' && github.ref_name) || (github.event_name == 'workflow_dispatch' && inputs.version) || '' }}"
- if [[ -z "${ref}" ]]; then
- ref="$(gh release view --repo dunglas/frankenphp --json tagName --jq '.tagName')"
- fi
- echo "ref=${ref}" >> "${GITHUB_OUTPUT}"
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- -
- uses: actions/checkout@v4
- with:
- ref: ${{ steps.check.outputs.ref }}
- -
- name: Set up Docker Buildx
- uses: docker/setup-buildx-action@v3
- with:
- version: latest
- -
- name: Create platforms matrix
- id: matrix
- run: |
- METADATA="$(docker buildx bake --print static-builder | jq -c)"
- {
- echo metadata="${METADATA}"
- echo platforms="$(jq -c 'first(.target[]) | .platforms' <<< "${METADATA}")"
- } >> "${GITHUB_OUTPUT}"
- env:
- SHA: ${{ github.sha }}
- VERSION: ${{ steps.check.outputs.ref || github.sha }}
- build-linux:
- strategy:
- fail-fast: false
- matrix:
- platform: ${{ fromJson(needs.prepare.outputs.platforms) }}
- include:
- - race: ""
- qemu: true
- - platform: linux/amd64
- qemu: false
- name: Build ${{ matrix.platform }} static binary
- runs-on: ubuntu-latest
- needs: [ prepare ]
- steps:
- -
- uses: actions/checkout@v4
- with:
- ref: ${{ needs.prepare.outputs.ref }}
- -
- name: Set up QEMU
- if: matrix.qemu
- uses: docker/setup-qemu-action@v3
- with:
- platforms: ${{ matrix.platform }}
- -
- name: Set up Docker Buildx
- uses: docker/setup-buildx-action@v3
- with:
- platforms: ${{ matrix.platform }}
- version: latest
- -
- name: Login to DockerHub
- if: ${{ fromJson(needs.prepare.outputs.push) }}
- uses: docker/login-action@v3
- with:
- username: ${{ secrets.REGISTRY_USERNAME }}
- password: ${{ secrets.REGISTRY_PASSWORD }}
- -
- name: Build
- id: build
- uses: docker/bake-action@v4
- with:
- pull: true
- load: ${{ !fromJson(needs.prepare.outputs.push) }}
- targets: static-builder
- set: |
- *.tags=
- *.platform=${{ matrix.platform }}
- *.cache-from=type=gha,scope=${{ needs.prepare.outputs.ref || github.ref }}-static-builder
- *.cache-from=type=gha,scope=refs/heads/main-static-builder
- *.cache-to=type=gha,scope=${{ needs.prepare.outputs.ref || github.ref }}-static-builder,ignore-error=true
- ${{ fromJson(needs.prepare.outputs.push) && '*.output=type=image,name=dunglas/frankenphp,push-by-digest=true,name-canonical=true,push=true' || '' }}
- env:
- SHA: ${{ github.sha }}
- VERSION: ${{ (github.ref_type == 'tag' && github.ref_name) || needs.prepare.outputs.ref || github.sha}}
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- -
- # Workaround for https://github.com/actions/runner/pull/2477#issuecomment-1501003600
- name: Export metadata
- if: fromJson(needs.prepare.outputs.push)
- run: |
- mkdir -p /tmp/metadata
- # shellcheck disable=SC2086
- digest=$(jq -r '."static-builder"."containerimage.digest"' <<< ${METADATA})
- touch "/tmp/metadata/${digest#sha256:}"
- env:
- METADATA: ${{ steps.build.outputs.metadata }}
- -
- name: Upload metadata
- if: fromJson(needs.prepare.outputs.push)
- uses: actions/upload-artifact@v3
- with:
- name: metadata-static-builder
- path: /tmp/metadata/*
- if-no-files-found: error
- retention-days: 1
- -
- name: Copy binary
- if: ${{ !fromJson(needs.prepare.outputs.push) }}
- run: |
- digest=$(jq -r '."static-builder"."containerimage.config.digest"' <<< "${METADATA}")
- docker create --platform=${{ matrix.platform }} --name static-builder "${digest}"
- docker cp "static-builder:/go/src/app/dist/${BINARY}" "${BINARY}"
- env:
- METADATA: ${{ steps.build.outputs.metadata }}
- BINARY: frankenphp-linux-${{ matrix.platform == 'linux/amd64' && 'x86_64' || 'aarch64' }}
- -
- name: Upload artifact
- if: ${{ !fromJson(needs.prepare.outputs.push) }}
- uses: actions/upload-artifact@v3
- with:
- name: frankenphp-linux-${{ matrix.platform == 'linux/amd64' && 'x86_64' || 'aarch64' }}
- path: frankenphp-linux-${{ matrix.platform == 'linux/amd64' && 'x86_64' || 'aarch64' }}
- # Adapted from https://docs.docker.com/build/ci/github-actions/multi-platform/
- push:
- runs-on: ubuntu-latest
- needs:
- - prepare
- - build-linux
- if: fromJson(needs.prepare.outputs.push)
- #if: fromJson(needs.prepare.outputs.push) && (needs.prepare.outputs.ref || github.ref_type == 'tag')
- steps:
- -
- name: Download metadata
- uses: actions/download-artifact@v3
- with:
- name: metadata-static-builder
- path: /tmp/metadata
- -
- name: Set up Docker Buildx
- uses: docker/setup-buildx-action@v3
- with:
- version: latest
- -
- name: Login to DockerHub
- uses: docker/login-action@v3
- with:
- username: ${{ secrets.REGISTRY_USERNAME }}
- password: ${{ secrets.REGISTRY_PASSWORD }}
- -
- name: Create manifest list and push
- working-directory: /tmp/metadata
- run: |
- # shellcheck disable=SC2046,SC2086
- docker buildx imagetools create $(jq -cr '.target."static-builder".tags | map("-t " + .) | join(" ")' <<< "${METADATA}") \
- $(printf 'dunglas/frankenphp@sha256:%s ' *)
- env:
- METADATA: ${{ needs.prepare.outputs.metadata }}
- -
- name: Inspect image
- run: |
- # shellcheck disable=SC2046,SC2086
- docker buildx imagetools inspect "$(jq -cr '.target."static-builder".tags | first' <<< "${METADATA}")"
- env:
- METADATA: ${{ needs.prepare.outputs.metadata }}
- -
- name: Copy binary
- run: |
- tag=$(jq -cr '.target."static-builder".tags | first' <<< "${METADATA}")
- docker cp "$(docker create --platform=linux/amd64 --name static-builder "${tag}"):/go/src/app/dist/frankenphp-linux-x86_64" frankenphp-linux-x86_64 ; docker rm static-builder
- docker cp "$(docker create --platform=linux/arm64 --name static-builder "${tag}"):/go/src/app/dist/frankenphp-linux-aarch64" frankenphp-linux-aarch64 ; docker rm static-builder
- env:
- METADATA: ${{ needs.prepare.outputs.metadata }}
- -
- name: Upload asset
- if: needs.prepare.outputs.ref || github.ref_type == 'tag'
- run: gh release upload "${{ (github.ref_type == 'tag' && github.ref_name) || needs.prepare.outputs.ref }}" frankenphp-linux-x86_64 frankenphp-linux-aarch64 --repo dunglas/frankenphp --clobber
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- build-mac:
- name: Build macOS x86_64 binaries
- runs-on: macos-latest
- needs: [ prepare ]
- env:
- HOMEBREW_NO_AUTO_UPDATE: 1
- steps:
- -
- uses: actions/checkout@v4
- with:
- ref: ${{ needs.prepare.outputs.ref }}
- -
- uses: actions/setup-go@v5
- with:
- go-version: '1.21'
- cache-dependency-path: |
- go.sum
- caddy/go.sum
- -
- name: Set FRANKENPHP_VERSION
- run: |
- if [ "${GITHUB_REF_TYPE}" == "tag" ]; then
- export FRANKENPHP_VERSION=${GITHUB_REF_NAME:1}
- elif [ "${GITHUB_EVENT_NAME}" == "schedule" ]; then
- export FRANKENPHP_VERSION="${{ needs.prepare.outputs.ref }}"
- else
- export FRANKENPHP_VERSION=${GITHUB_SHA}
- fi
- echo "FRANKENPHP_VERSION=${FRANKENPHP_VERSION}" >> "${GITHUB_ENV}"
- -
- name: Build FrankenPHP
- run: ./build-static.sh
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- RELEASE: ${{ (needs.prepare.outputs.ref || github.ref_type == 'tag') && '1' || '' }}
- -
- name: Upload artifact
- if: github.ref_type == 'branch'
- uses: actions/upload-artifact@v3
- with:
- name: frankenphp-mac-x86_64
- path: dist/frankenphp-mac-x86_64
|