From e720ac84f96aad39bde0f36de8a9261206e1a6c1 Mon Sep 17 00:00:00 2001 From: joyqi Date: Sun, 31 Dec 2023 17:04:31 +0800 Subject: [PATCH] remove php 7.3, 8.0, add php 8.2 --- .github/workflows/build.yml | 288 ++++-------------------------------- build.sh | 4 +- make-workflows.sh | 2 +- 3 files changed, 29 insertions(+), 265 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index f486814..3e316b7 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -8,141 +8,6 @@ on: required: true jobs: - build_73_php_debian: - concurrency: build_debian_73 - runs-on: ubuntu-latest - - steps: - - name: Checkout the repo - uses: actions/checkout@v2 - - name: Set up QEMU - uses: docker/setup-qemu-action@v1 - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v1 - - name: Login to DockerHub - uses: docker/login-action@v1 - with: - username: ${{ secrets.DOCKERHUB_USERNAME }} - password: ${{ secrets.DOCKERHUB_TOKEN }} - - name: Generate Dockerfile - id: generate - run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 7.3 -o debian php - - name: Build and push - uses: docker/build-push-action@v2 - with: - context: . - platforms: ${{ steps.generate.outputs.PLATFORM }} - push: true - tags: ${{ steps.generate.outputs.VERSION }} - build-args: | - TAG=${{ steps.generate.outputs.TAG }} - URL=${{ steps.generate.outputs.URL }} - CONFIG=${{ steps.generate.outputs.CONFIG }} - PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} - PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_73_cli_debian: - concurrency: build_debian_73 - runs-on: ubuntu-latest - needs: - - build_73_php_debian - steps: - - name: Checkout the repo - uses: actions/checkout@v2 - - name: Set up QEMU - uses: docker/setup-qemu-action@v1 - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v1 - - name: Login to DockerHub - uses: docker/login-action@v1 - with: - username: ${{ secrets.DOCKERHUB_USERNAME }} - password: ${{ secrets.DOCKERHUB_TOKEN }} - - name: Generate Dockerfile - id: generate - run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 7.3 -o debian cli - - name: Build and push - uses: docker/build-push-action@v2 - with: - context: . - platforms: ${{ steps.generate.outputs.PLATFORM }} - push: true - tags: ${{ steps.generate.outputs.VERSION }} - build-args: | - TAG=${{ steps.generate.outputs.TAG }} - URL=${{ steps.generate.outputs.URL }} - CONFIG=${{ steps.generate.outputs.CONFIG }} - PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} - PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_73_fpm_debian: - concurrency: build_debian_73 - runs-on: ubuntu-latest - needs: - - build_73_cli_debian - steps: - - name: Checkout the repo - uses: actions/checkout@v2 - - name: Set up QEMU - uses: docker/setup-qemu-action@v1 - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v1 - - name: Login to DockerHub - uses: docker/login-action@v1 - with: - username: ${{ secrets.DOCKERHUB_USERNAME }} - password: ${{ secrets.DOCKERHUB_TOKEN }} - - name: Generate Dockerfile - id: generate - run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 7.3 -o debian fpm - - name: Build and push - uses: docker/build-push-action@v2 - with: - context: . - platforms: ${{ steps.generate.outputs.PLATFORM }} - push: true - tags: ${{ steps.generate.outputs.VERSION }} - build-args: | - TAG=${{ steps.generate.outputs.TAG }} - URL=${{ steps.generate.outputs.URL }} - CONFIG=${{ steps.generate.outputs.CONFIG }} - PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} - PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_73_apache_debian: - concurrency: build_debian_73 - runs-on: ubuntu-latest - needs: - - build_73_fpm_debian - steps: - - name: Checkout the repo - uses: actions/checkout@v2 - - name: Set up QEMU - uses: docker/setup-qemu-action@v1 - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v1 - - name: Login to DockerHub - uses: docker/login-action@v1 - with: - username: ${{ secrets.DOCKERHUB_USERNAME }} - password: ${{ secrets.DOCKERHUB_TOKEN }} - - name: Generate Dockerfile - id: generate - run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 7.3 -o debian apache - - name: Build and push - uses: docker/build-push-action@v2 - with: - context: . - platforms: ${{ steps.generate.outputs.PLATFORM }} - push: true - tags: ${{ steps.generate.outputs.VERSION }} - build-args: | - TAG=${{ steps.generate.outputs.TAG }} - URL=${{ steps.generate.outputs.URL }} - CONFIG=${{ steps.generate.outputs.CONFIG }} - PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} - PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} build_74_php_debian: concurrency: build_debian_74 runs-on: ubuntu-latest @@ -278,8 +143,8 @@ jobs: CONFIG=${{ steps.generate.outputs.CONFIG }} PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_80_php_debian: - concurrency: build_debian_80 + build_82_php_debian: + concurrency: build_debian_82 runs-on: ubuntu-latest steps: @@ -297,7 +162,7 @@ jobs: - name: Generate Dockerfile id: generate run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.0 -o debian php + ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.2 -o debian php - name: Build and push uses: docker/build-push-action@v2 with: @@ -311,112 +176,11 @@ jobs: CONFIG=${{ steps.generate.outputs.CONFIG }} PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_80_cli_debian: - concurrency: build_debian_80 + build_82_cli_debian: + concurrency: build_debian_82 runs-on: ubuntu-latest needs: - - build_80_php_debian - steps: - - name: Checkout the repo - uses: actions/checkout@v2 - - name: Set up QEMU - uses: docker/setup-qemu-action@v1 - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v1 - - name: Login to DockerHub - uses: docker/login-action@v1 - with: - username: ${{ secrets.DOCKERHUB_USERNAME }} - password: ${{ secrets.DOCKERHUB_TOKEN }} - - name: Generate Dockerfile - id: generate - run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.0 -o debian cli - - name: Build and push - uses: docker/build-push-action@v2 - with: - context: . - platforms: ${{ steps.generate.outputs.PLATFORM }} - push: true - tags: ${{ steps.generate.outputs.VERSION }} - build-args: | - TAG=${{ steps.generate.outputs.TAG }} - URL=${{ steps.generate.outputs.URL }} - CONFIG=${{ steps.generate.outputs.CONFIG }} - PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} - PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_80_fpm_debian: - concurrency: build_debian_80 - runs-on: ubuntu-latest - needs: - - build_80_cli_debian - steps: - - name: Checkout the repo - uses: actions/checkout@v2 - - name: Set up QEMU - uses: docker/setup-qemu-action@v1 - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v1 - - name: Login to DockerHub - uses: docker/login-action@v1 - with: - username: ${{ secrets.DOCKERHUB_USERNAME }} - password: ${{ secrets.DOCKERHUB_TOKEN }} - - name: Generate Dockerfile - id: generate - run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.0 -o debian fpm - - name: Build and push - uses: docker/build-push-action@v2 - with: - context: . - platforms: ${{ steps.generate.outputs.PLATFORM }} - push: true - tags: ${{ steps.generate.outputs.VERSION }} - build-args: | - TAG=${{ steps.generate.outputs.TAG }} - URL=${{ steps.generate.outputs.URL }} - CONFIG=${{ steps.generate.outputs.CONFIG }} - PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} - PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_80_apache_debian: - concurrency: build_debian_80 - runs-on: ubuntu-latest - needs: - - build_80_fpm_debian - steps: - - name: Checkout the repo - uses: actions/checkout@v2 - - name: Set up QEMU - uses: docker/setup-qemu-action@v1 - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v1 - - name: Login to DockerHub - uses: docker/login-action@v1 - with: - username: ${{ secrets.DOCKERHUB_USERNAME }} - password: ${{ secrets.DOCKERHUB_TOKEN }} - - name: Generate Dockerfile - id: generate - run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.0 -o debian apache - - name: Build and push - uses: docker/build-push-action@v2 - with: - context: . - platforms: ${{ steps.generate.outputs.PLATFORM }} - push: true - tags: ${{ steps.generate.outputs.VERSION }} - build-args: | - TAG=${{ steps.generate.outputs.TAG }} - URL=${{ steps.generate.outputs.URL }} - CONFIG=${{ steps.generate.outputs.CONFIG }} - PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} - PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_73_php_alpine: - concurrency: build_alpine_73 - runs-on: ubuntu-latest - + - build_82_php_debian steps: - name: Checkout the repo uses: actions/checkout@v2 @@ -432,7 +196,7 @@ jobs: - name: Generate Dockerfile id: generate run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 7.3 -o alpine php + ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.2 -o debian cli - name: Build and push uses: docker/build-push-action@v2 with: @@ -446,11 +210,11 @@ jobs: CONFIG=${{ steps.generate.outputs.CONFIG }} PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_73_cli_alpine: - concurrency: build_alpine_73 + build_82_fpm_debian: + concurrency: build_debian_82 runs-on: ubuntu-latest needs: - - build_73_php_alpine + - build_82_cli_debian steps: - name: Checkout the repo uses: actions/checkout@v2 @@ -466,7 +230,7 @@ jobs: - name: Generate Dockerfile id: generate run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 7.3 -o alpine cli + ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.2 -o debian fpm - name: Build and push uses: docker/build-push-action@v2 with: @@ -480,11 +244,11 @@ jobs: CONFIG=${{ steps.generate.outputs.CONFIG }} PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_73_fpm_alpine: - concurrency: build_alpine_73 + build_82_apache_debian: + concurrency: build_debian_82 runs-on: ubuntu-latest needs: - - build_73_cli_alpine + - build_82_fpm_debian steps: - name: Checkout the repo uses: actions/checkout@v2 @@ -500,7 +264,7 @@ jobs: - name: Generate Dockerfile id: generate run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 7.3 -o alpine fpm + ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.2 -o debian apache - name: Build and push uses: docker/build-push-action@v2 with: @@ -615,8 +379,8 @@ jobs: CONFIG=${{ steps.generate.outputs.CONFIG }} PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_80_php_alpine: - concurrency: build_alpine_80 + build_82_php_alpine: + concurrency: build_alpine_82 runs-on: ubuntu-latest steps: @@ -634,7 +398,7 @@ jobs: - name: Generate Dockerfile id: generate run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.0 -o alpine php + ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.2 -o alpine php - name: Build and push uses: docker/build-push-action@v2 with: @@ -648,11 +412,11 @@ jobs: CONFIG=${{ steps.generate.outputs.CONFIG }} PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_80_cli_alpine: - concurrency: build_alpine_80 + build_82_cli_alpine: + concurrency: build_alpine_82 runs-on: ubuntu-latest needs: - - build_80_php_alpine + - build_82_php_alpine steps: - name: Checkout the repo uses: actions/checkout@v2 @@ -668,7 +432,7 @@ jobs: - name: Generate Dockerfile id: generate run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.0 -o alpine cli + ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.2 -o alpine cli - name: Build and push uses: docker/build-push-action@v2 with: @@ -682,11 +446,11 @@ jobs: CONFIG=${{ steps.generate.outputs.CONFIG }} PHP_EXTENSION=${{ steps.generate.outputs.PHP_EXTENSION }} PHP8_SOCKETS_WORKAROUND=${{ steps.generate.outputs.PHP8_SOCKETS_WORKAROUND }} - build_80_fpm_alpine: - concurrency: build_alpine_80 + build_82_fpm_alpine: + concurrency: build_alpine_82 runs-on: ubuntu-latest needs: - - build_80_cli_alpine + - build_82_cli_alpine steps: - name: Checkout the repo uses: actions/checkout@v2 @@ -702,7 +466,7 @@ jobs: - name: Generate Dockerfile id: generate run: | - ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.0 -o alpine fpm + ./build.sh -g -v ${{ github.event.inputs.version }} -p 8.2 -o alpine fpm - name: Build and push uses: docker/build-push-action@v2 with: diff --git a/build.sh b/build.sh index b3c0d8f..ae8d614 100755 --- a/build.sh +++ b/build.sh @@ -78,12 +78,12 @@ if [ ${php} != "7.3" ]; then fi # add workaround for php 8 build error -if [[ ${php} == "8.0" || ${php} == "8.1" ]]; then +if [[ ${php} == "8.0" || ${php} == "8.1" || ${php} == "8.2" ]]; then PHP8_SOCKETS_WORKAROUND="-D_GNU_SOURCE" fi # disable tokenzier extension for php 8.1 -if [ ${php} == "8.1" ]; then +if [[ ${php} == "8.1" || ${php} == "8.2" ]]; then PHP_EXTENSION="bcmath exif gd zip mysqli pdo_mysql pdo_pgsql opcache" fi diff --git a/make-workflows.sh b/make-workflows.sh index 665440e..22b0827 100755 --- a/make-workflows.sh +++ b/make-workflows.sh @@ -16,7 +16,7 @@ EOF fi os=("debian" "alpine") -php=("7.3" "7.4" "8.0") +php=("7.4" "8.2") platform=("php" "cli" "fpm" "apache") for o in ${os[@]}