Update Dockerfile #334
This file contains 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 Docker Image | |
on: | |
# schedule: | |
# - cron: "0 0 */6 * *" | |
push: | |
branches: | |
- latest | |
- develop | |
paths: | |
- Dockerfile | |
- python.Dockerfile | |
- .github/workflows/docker.yml | |
pull_request: | |
paths: | |
- Dockerfile | |
- python.Dockerfile | |
- .github/workflows/docker.yml | |
workflow_dispatch: | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v3 | |
with: | |
platforms: arm64 #all | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
with: | |
driver-opts: env.BUILDKIT_STEP_LOG_MAX_SIZE=-1 | |
- name: Login to DockerHub | |
if: ${{ github.event_name != 'pull_request' }} | |
uses: docker/login-action@v3 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- name: Convert Username | |
id: un | |
run: echo "un=$(echo "${{ github.repository_owner }}" | tr '[:upper:]' '[:lower:]')" >> $GITHUB_OUTPUT | |
- name: Login to GitHub Container Registry | |
uses: docker/login-action@v3 | |
with: | |
registry: ghcr.io | |
username: ${{ steps.un.outputs.un }} | |
password: ${{ github.token }} | |
- name: Build | |
uses: docker/build-push-action@v6 | |
if: ${{ github.event_name != 'pull_request' }} | |
with: | |
context: . | |
file: ./Dockerfile | |
platforms: linux/amd64,linux/arm64 #,linux/amd64/v2,linux/amd64/v3,linux/amd64/v4 #,linux/ppc64le,linux/s390x,linux/386,linux/arm/v7,linux/arm/v6 | |
push: ${{ github.event_name != 'pull_request' }} | |
tags: | | |
${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.ref_name }} | |
${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.run_number }} | |
ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.ref_name }} | |
ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.run_number }} | |
- name: Build | |
uses: docker/build-push-action@v6 | |
if: ${{ github.event_name != 'pull_request' }} | |
with: | |
context: . | |
file: ./python.Dockerfile | |
platforms: linux/amd64,linux/arm64 #,linux/amd64/v2,linux/amd64/v3,linux/amd64/v4 #,linux/ppc64le,linux/s390x,linux/386,linux/arm/v7,linux/arm/v6 | |
push: ${{ github.event_name != 'pull_request' }} | |
tags: | | |
${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.ref_name }}-python | |
${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.run_number }}-python | |
ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.ref_name }}-python | |
ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.run_number }}-python | |
- name: show version | |
if: ${{ github.event_name != 'pull_request' }} | |
run: | | |
docker run --rm ${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.ref_name }} -V | |
docker run --rm ${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.run_number }} -V | |
docker run --rm ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.ref_name }} -V | |
docker run --rm ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.run_number }} -V | |
docker run --rm ${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.ref_name }}-python -V | |
docker run --rm ${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.run_number }}-python -V | |
docker run --rm ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.ref_name }}-python -V | |
docker run --rm ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.run_number }}-python -V | |
- name: copy nginx | |
if: ${{ github.event_name != 'pull_request' }} | |
run: | | |
docker run -d --pull always --platform amd64 --name nginx-x86_64 ${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.ref_name }} | |
docker cp nginx-x86_64:/usr/local/nginx nginx | |
docker cp nginx-x86_64:/usr/local/nginx/sbin/nginx nginx-x86_64 | |
docker cp nginx-x86_64:/usr/local/modsecurity/lib/libmodsecurity.so.3 nginx/libmodsecurity.so.3 | |
tar -cJf nginx-x86_64.tar.xz nginx | |
rm -r nginx | |
docker run -d --pull always --platform arm64 --name nginx-aarch64 ${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ github.ref_name }} | |
docker cp nginx-aarch64:/usr/local/nginx nginx | |
docker cp nginx-aarch64:/usr/local/nginx/sbin/nginx nginx-aarch64 | |
docker cp nginx-aarch64:/usr/local/modsecurity/lib/libmodsecurity.so.3 nginx/libmodsecurity.so.3 | |
tar -cJf nginx-aarch64.tar.xz nginx | |
rm -r nginx | |
- uses: actions/upload-artifact@v4 | |
if: ${{ github.event_name != 'pull_request' }} | |
with: | |
name: artifacts | |
path: | | |
nginx-x86_64 | |
nginx-x86_64.tar.xz | |
nginx-aarch64 | |
nginx-aarch64.tar.xz | |
- uses: crowbarmaster/GH-Automatic-Releases@latest | |
if: ${{ github.event_name != 'pull_request' }} | |
with: | |
prerelease: false | |
repo_token: ${{ github.token }} | |
title: ${{ github.run_number }} | |
automatic_release_tag: ${{ github.run_number }} | |
files: | | |
nginx-x86_64 | |
nginx-x86_64.tar.xz | |
nginx-aarch64 | |
nginx-aarch64.tar.xz | |
- name: Set PR-Number (PR) | |
if: ${{ github.event_name == 'pull_request' }} | |
id: pr | |
run: echo "pr=$(echo pr-${{ github.ref_name }} | sed "s|refs/pull/:||g" | sed "s|/merge||g")" >> $GITHUB_OUTPUT | |
- name: Build (PR) | |
uses: docker/build-push-action@v6 | |
if: ${{ github.event_name == 'pull_request' }} | |
with: | |
context: . | |
file: ./Dockerfile | |
platforms: linux/amd64,linux/arm64 #,linux/amd64/v2,linux/amd64/v3,linux/amd64/v4 #,linux/ppc64le,linux/s390x,linux/386,linux/arm/v7,linux/arm/v6 | |
push: ${{ github.event_name == 'pull_request' }} | |
tags: ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ steps.pr.outputs.pr }} | |
- name: Build (PR) | |
uses: docker/build-push-action@v6 | |
if: ${{ github.event_name == 'pull_request' }} | |
with: | |
context: . | |
file: ./python.Dockerfile | |
platforms: linux/amd64,linux/arm64 #,linux/amd64/v2,linux/amd64/v3,linux/amd64/v4 #,linux/ppc64le,linux/s390x,linux/386,linux/arm/v7,linux/arm/v6 | |
push: ${{ github.event_name == 'pull_request' }} | |
tags: ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ steps.pr.outputs.pr }}-python | |
- name: show version (PR) | |
if: ${{ github.event_name == 'pull_request' }} | |
run: | | |
docker run --rm ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ steps.pr.outputs.pr }} -V | |
docker run --rm ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ steps.pr.outputs.pr }}-python -V | |
- name: copy nginx (PR) | |
if: ${{ github.event_name == 'pull_request' }} | |
run: | | |
docker run -d --pull always --platform amd64 --name nginx-x86_64 ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ steps.pr.outputs.pr }} | |
docker cp nginx-x86_64:/usr/local/nginx nginx | |
docker cp nginx-x86_64:/usr/local/nginx/sbin/nginx nginx-x86_64 | |
docker cp nginx-x86_64:/usr/local/modsecurity/lib/libmodsecurity.so.3 nginx/libmodsecurity.so.3 | |
tar -cJf nginx-x86_64.tar.xz nginx | |
rm -r nginx | |
docker run -d --pull always --platform arm64 --name nginx-aarch64 ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ steps.pr.outputs.pr }} | |
docker cp nginx-aarch64:/usr/local/nginx nginx | |
docker cp nginx-aarch64:/usr/local/nginx/sbin/nginx nginx-aarch64 | |
docker cp nginx-aarch64:/usr/local/modsecurity/lib/libmodsecurity.so.3 nginx/libmodsecurity.so.3 | |
tar -cJf nginx-aarch64.tar.xz nginx | |
rm -r nginx | |
- uses: actions/upload-artifact@v4 | |
if: ${{ github.event_name == 'pull_request' }} | |
with: | |
name: artifacts | |
path: | | |
nginx-x86_64 | |
nginx-x86_64.tar.xz | |
nginx-aarch64 | |
nginx-aarch64.tar.xz | |
- name: add comment (PR) | |
uses: mshick/add-pr-comment@v2 | |
if: ${{ github.event_name == 'pull_request' }} | |
with: | |
message: "The Docker Image can now be found here: `ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ steps.pr.outputs.pr }}` and `ghcr.io/${{ steps.un.outputs.un }}/${{ github.event.repository.name }}:${{ steps.pr.outputs.pr }}-python`" | |
repo-token: ${{ github.token }} |