build-publish.yml 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. name: Build and publish Docker images
  2. on:
  3. workflow_dispatch:
  4. schedule:
  5. - cron: "0 0 * * 1"
  6. push:
  7. branches:
  8. - main
  9. tags:
  10. - "*.*.*"
  11. paths-ignore:
  12. - "test/*"
  13. - ".gitignore"
  14. - "docker-compose-separate-containers.yml"
  15. - "docker-compose.yml"
  16. - "LICENSE"
  17. - "Makefile"
  18. - "*.md"
  19. jobs:
  20. multiarch-build:
  21. name: Build and publish image
  22. strategy:
  23. matrix:
  24. flavor: [alpine, debian, dockergen]
  25. runs-on: ubuntu-latest
  26. steps:
  27. - name: Checkout
  28. uses: actions/checkout@v4
  29. with:
  30. fetch-depth: 0
  31. - name: Retrieve nginx-proxy version
  32. id: nginx-proxy_version
  33. run: echo "VERSION=$(git describe --tags)" >> "$GITHUB_OUTPUT"
  34. - name: Retrieve docker-gen version
  35. id: docker-gen_version
  36. run: sed -n -e 's;^FROM docker.io/nginxproxy/docker-gen:\([0-9.]*\).*;VERSION=\1;p' Dockerfile.${{ matrix.flavor }} >> "$GITHUB_OUTPUT"
  37. - name: Get Docker tags
  38. id: docker_meta
  39. uses: docker/metadata-action@v5
  40. with:
  41. images: |
  42. ghcr.io/nginx-proxy/nginx-proxy
  43. nginxproxy/nginx-proxy
  44. jwilder/nginx-proxy
  45. tags: |
  46. type=semver,pattern={{version}},enable=${{ matrix.flavor == 'debian' }}
  47. type=semver,pattern={{major}}.{{minor}},enable=${{ matrix.flavor == 'debian' }}
  48. type=semver,suffix=-alpine,pattern={{version}},enable=${{ matrix.flavor == 'alpine' }}
  49. type=semver,suffix=-alpine,pattern={{major}}.{{minor}},enable=${{ matrix.flavor == 'alpine' }}
  50. type=semver,suffix=-dockergen,pattern={{version}},enable=${{ matrix.flavor == 'dockergen' }}
  51. type=semver,suffix=-dockergen,pattern={{major}}.{{minor}},enable=${{ matrix.flavor == 'dockergen' }}
  52. type=raw,value=latest,enable=${{ github.ref == 'refs/heads/main' && matrix.flavor == 'debian' }}
  53. type=raw,value=alpine,enable=${{ github.ref == 'refs/heads/main' && matrix.flavor == 'alpine' }}
  54. type=raw,value=dockergen,enable=${{ github.ref == 'refs/heads/main' && matrix.flavor == 'dockergen' }}
  55. labels: |
  56. org.opencontainers.image.authors=Nicolas Duchon <nicolas.duchon@gmail.com> (@buchdag), Jason Wilder
  57. org.opencontainers.image.version=${{ steps.nginx-proxy_version.outputs.VERSION }}
  58. flavor: |
  59. latest=false
  60. - name: Set up QEMU
  61. uses: docker/setup-qemu-action@v3
  62. - name: Set up Docker Buildx
  63. uses: docker/setup-buildx-action@v3
  64. - name: Login to DockerHub
  65. uses: docker/login-action@v3
  66. with:
  67. username: ${{ secrets.DOCKERHUB_USERNAME }}
  68. password: ${{ secrets.DOCKERHUB_TOKEN }}
  69. - name: Log in to GitHub Container Registry
  70. uses: docker/login-action@v3
  71. with:
  72. registry: ghcr.io
  73. username: ${{ github.actor }}
  74. password: ${{ secrets.GITHUB_TOKEN }}
  75. - name: Build and push the image
  76. id: docker_build
  77. uses: docker/build-push-action@v6
  78. with:
  79. context: .
  80. file: Dockerfile.${{ matrix.flavor }}
  81. build-args: |
  82. NGINX_PROXY_VERSION=${{ steps.nginx-proxy_version.outputs.VERSION }}
  83. DOCKER_GEN_VERSION=${{ steps.docker-gen_version.outputs.VERSION }}
  84. platforms: linux/amd64,linux/arm64,linux/s390x,linux/arm/v7
  85. sbom: true
  86. push: true
  87. provenance: mode=max
  88. tags: ${{ steps.docker_meta.outputs.tags }}
  89. labels: ${{ steps.docker_meta.outputs.labels }}
  90. cache-from: type=gha
  91. cache-to: type=gha,mode=max
  92. - name: Images digests
  93. run: echo ${{ steps.docker_build.outputs.digest }}