release.yml 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. name: Create and publish a Docker image
  2. on:
  3. release:
  4. types: [published, prereleased]
  5. env:
  6. REGISTRY: ghcr.io
  7. IMAGE_NAME: ${{ github.repository }}
  8. jobs:
  9. build-and-push-image:
  10. runs-on: ubuntu-latest
  11. permissions:
  12. contents: read
  13. packages: write
  14. steps:
  15. - name: Checkout repository
  16. uses: actions/checkout@v2
  17. - name: Set up QEMU
  18. uses: docker/setup-qemu-action@8b122486cedac8393e77aa9734c3528886e4a1a8
  19. - name: Set up Docker Buildx
  20. id: buildx
  21. uses: docker/setup-buildx-action@dc7b9719a96d48369863986a06765841d7ea23f6
  22. - name: Log in to Docker Hub
  23. uses: docker/login-action@49ed152c8eca782a232dede0303416e8f356c37b
  24. with:
  25. username: ${{ github.actor }}
  26. password: ${{ secrets.DOCKER_PASSWORD }}
  27. - name: Log in to the Container registry
  28. uses: docker/login-action@49ed152c8eca782a232dede0303416e8f356c37b
  29. with:
  30. registry: ${{ env.REGISTRY }}
  31. username: ${{ github.actor }}
  32. password: ${{ secrets.GITHUB_TOKEN }}
  33. - name: Extract metadata (tags, labels) for Docker
  34. id: meta
  35. uses: docker/metadata-action@v4
  36. with:
  37. images: |
  38. zricethezav/gitleaks
  39. ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
  40. tags: |
  41. type=semver,pattern=v{{version}}
  42. type=semver,pattern=v{{major}}
  43. type=semver,pattern=v{{major}}.{{minor}}
  44. - name: Build and push Docker image
  45. uses: docker/build-push-action@v3
  46. with:
  47. platforms: linux/amd64,linux/arm64
  48. context: .
  49. push: true
  50. tags: ${{ steps.meta.outputs.tags }}
  51. labels: ${{ steps.meta.outputs.labels }}