Bumps the all group with 5 updates: | Package | From | To | | --- | --- | --- | | [actions/setup-go](https://github.com/actions/setup-go) | `5.0.1` | `5.0.2` | | [actions/setup-python](https://github.com/actions/setup-python) | `5.1.0` | `5.1.1` | | [actions/dependency-review-action](https://github.com/actions/dependency-review-action) | `4.3.3` | `4.3.4` | | [github/codeql-action](https://github.com/github/codeql-action) | `3.25.11` | `3.25.12` | | [aquasecurity/trivy-action](https://github.com/aquasecurity/trivy-action) | `0.23.0` | `0.24.0` | Updates `actions/setup-go` from 5.0.1 to 5.0.2 - [Release notes](https://github.com/actions/setup-go/releases) - [Commits](cdcb360436...0a12ed9d6a) Updates `actions/setup-python` from 5.1.0 to 5.1.1 - [Release notes](https://github.com/actions/setup-python/releases) - [Commits](82c7e631bb...39cd14951b) Updates `actions/dependency-review-action` from 4.3.3 to 4.3.4 - [Release notes](https://github.com/actions/dependency-review-action/releases) - [Commits](72eb03d02c...5a2ce3f5b9) Updates `github/codeql-action` from 3.25.11 to 3.25.12 - [Release notes](https://github.com/github/codeql-action/releases) - [Changelog](https://github.com/github/codeql-action/blob/main/CHANGELOG.md) - [Commits](b611370bb5...4fa2a79536) Updates `aquasecurity/trivy-action` from 0.23.0 to 0.24.0 - [Release notes](https://github.com/aquasecurity/trivy-action/releases) - [Commits](7c2007bcb5...6e7b7d1fd3) --- updated-dependencies: - dependency-name: actions/setup-go dependency-type: direct:production update-type: version-update:semver-patch dependency-group: all - dependency-name: actions/setup-python dependency-type: direct:production update-type: version-update:semver-patch dependency-group: all - dependency-name: actions/dependency-review-action dependency-type: direct:production update-type: version-update:semver-patch dependency-group: all - dependency-name: github/codeql-action dependency-type: direct:production update-type: version-update:semver-patch dependency-group: all - dependency-name: aquasecurity/trivy-action dependency-type: direct:production update-type: version-update:semver-minor dependency-group: all ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
215 lines
6.5 KiB
YAML
215 lines
6.5 KiB
YAML
name: Container Images
|
|
|
|
on:
|
|
pull_request:
|
|
branches:
|
|
- "*"
|
|
paths:
|
|
- 'images/**'
|
|
|
|
push:
|
|
branches:
|
|
- main
|
|
paths:
|
|
- 'images/**'
|
|
|
|
permissions:
|
|
contents: write
|
|
packages: write
|
|
|
|
env:
|
|
PLATFORMS: linux/amd64
|
|
|
|
jobs:
|
|
changes:
|
|
permissions:
|
|
contents: read # for dorny/paths-filter to fetch a list of changed files
|
|
pull-requests: read # for dorny/paths-filter to read pull requests
|
|
runs-on: ubuntu-latest
|
|
outputs:
|
|
custom-error-pages: ${{ steps.filter.outputs.custom-error-pages }}
|
|
cfssl: ${{ steps.filter.outputs.cfssl }}
|
|
fastcgi-helloserver: ${{ steps.filter.outputs.fastcgi-helloserver }}
|
|
e2e-test-echo: ${{ steps.filter.outputs.e2e-test-echo }}
|
|
go-grpc-greeter-server: ${{ steps.filter.outputs.go-grpc-greeter-server }}
|
|
httpbun: ${{ steps.filter.outputs.httpbun }}
|
|
kube-webhook-certgen: ${{ steps.filter.outputs.kube-webhook-certgen }}
|
|
ext-auth-example-authsvc: ${{ steps.filter.outputs.ext-auth-example-authsvc }}
|
|
nginx: ${{ steps.filter.outputs.nginx }}
|
|
nginx125: ${{ steps.filter.outputs.nginx125 }}
|
|
opentelemetry: ${{ steps.filter.outputs.opentelemetry }}
|
|
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
|
|
- uses: dorny/paths-filter@de90cc6fb38fc0963ad72b210f1f284cd68cea36 # v3.0.2
|
|
id: filter
|
|
with:
|
|
token: ${{ secrets.GITHUB_TOKEN }}
|
|
filters: |
|
|
custom-error-pages:
|
|
- 'images/custom-error-pages/**'
|
|
cfssl:
|
|
- 'images/cfssl/**'
|
|
fastcgi-helloserver:
|
|
- 'images/fastcgi-helloserver/**'
|
|
e2e-test-echo:
|
|
- 'images/e2e-test-echo/**'
|
|
go-grpc-greeter-server:
|
|
- 'images/go-grpc-greeter-server/**'
|
|
httpbun:
|
|
- 'images/httpbun/**'
|
|
kube-webhook-certgen:
|
|
- 'images/kube-webhook-certgen/**'
|
|
ext-auth-example-authsvc:
|
|
- 'images/ext-auth-example-authsvc/**'
|
|
nginx:
|
|
- 'images/nginx/**'
|
|
opentelemetry:
|
|
- 'images/opentelemetry/**'
|
|
nginx125:
|
|
- 'images/nginx-1.25/TAG'
|
|
|
|
#### TODO: Make the below jobs 'less dumb' and use the job name as parameter (the github.job context does not work here)
|
|
cfssl:
|
|
needs: changes
|
|
if: |
|
|
(needs.changes.outputs.cfssl == 'true')
|
|
uses: ./.github/workflows/zz-tmpl-images.yaml
|
|
with:
|
|
name: cfssl
|
|
secrets: inherit
|
|
|
|
custom-error-pages:
|
|
needs: changes
|
|
if: |
|
|
(needs.changes.outputs.custom-error-pages == 'true')
|
|
uses: ./.github/workflows/zz-tmpl-images.yaml
|
|
with:
|
|
name: custom-error-pages
|
|
secrets: inherit
|
|
|
|
e2e-test-echo:
|
|
needs: changes
|
|
if: |
|
|
(needs.changes.outputs.e2e-test-echo == 'true')
|
|
uses: ./.github/workflows/zz-tmpl-images.yaml
|
|
with:
|
|
name: e2e-test-echo
|
|
secrets: inherit
|
|
|
|
ext-auth-example-authsvc:
|
|
needs: changes
|
|
if: |
|
|
(needs.changes.outputs.ext-auth-example-authsvc == 'true')
|
|
uses: ./.github/workflows/zz-tmpl-images.yaml
|
|
with:
|
|
name: ext-auth-example-authsvc
|
|
secrets: inherit
|
|
|
|
fastcgi-helloserver:
|
|
needs: changes
|
|
if: |
|
|
(needs.changes.outputs.fastcgi-helloserver == 'true')
|
|
uses: ./.github/workflows/zz-tmpl-images.yaml
|
|
with:
|
|
name: fastcgi-helloserver
|
|
secrets: inherit
|
|
|
|
go-grpc-greeter-server:
|
|
needs: changes
|
|
if: |
|
|
(needs.changes.outputs.go-grpc-greeter-server == 'true')
|
|
uses: ./.github/workflows/zz-tmpl-images.yaml
|
|
with:
|
|
name: go-grpc-greeter-server
|
|
secrets: inherit
|
|
|
|
httpbun:
|
|
needs: changes
|
|
if: |
|
|
(needs.changes.outputs.httpbun == 'true')
|
|
uses: ./.github/workflows/zz-tmpl-images.yaml
|
|
with:
|
|
name: httpbun
|
|
secrets: inherit
|
|
|
|
kube-webhook-certgen:
|
|
runs-on: ubuntu-latest
|
|
needs: changes
|
|
if: |
|
|
(needs.changes.outputs.kube-webhook-certgen == 'true')
|
|
strategy:
|
|
matrix:
|
|
k8s: [v1.26.15, v1.27.13, v1.28.9, v1.29.4, v1.30.0]
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
|
|
|
|
- name: Get go version
|
|
run: echo "GOLANG_VERSION=$(cat GOLANG_VERSION)" >> $GITHUB_ENV
|
|
|
|
- name: Set up Go
|
|
id: go
|
|
uses: actions/setup-go@0a12ed9d6a96ab950c8f026ed9f722fe0da7ef32 # v5.0.2
|
|
with:
|
|
go-version: ${{ env.GOLANG_VERSION }}
|
|
check-latest: true
|
|
- name: image build
|
|
run: |
|
|
cd images/ && make NAME=kube-webhook-certgen build
|
|
- name: Create Kubernetes cluster
|
|
id: kind
|
|
run: |
|
|
kind create cluster --image=kindest/node:${{ matrix.k8s }}
|
|
- name: image test
|
|
run: |
|
|
cd images/ && make NAME=kube-webhook-certgen test test-e2e
|
|
|
|
opentelemetry:
|
|
runs-on: ubuntu-latest
|
|
env:
|
|
PLATFORMS: linux/amd64,linux/arm,linux/arm64
|
|
needs: changes
|
|
if: |
|
|
(needs.changes.outputs.opentelemetry == 'true')
|
|
strategy:
|
|
matrix:
|
|
nginx: ['1.25.3', '1.21.6']
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
|
|
- name: image build
|
|
run: |
|
|
cd images/opentelemetry && make NGINX_VERSION=${{ matrix.nginx }} build
|
|
|
|
nginx125:
|
|
permissions:
|
|
contents: write
|
|
packages: write
|
|
runs-on: ubuntu-latest
|
|
needs: changes
|
|
if: |
|
|
(github.event_name == 'push' && github.ref == 'refs/heads/main' && needs.changes.outputs.nginx125 == 'true')
|
|
env:
|
|
PLATFORMS: linux/amd64,linux/arm,linux/arm64,linux/s390x
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
|
|
- name: Set up QEMU
|
|
uses: docker/setup-qemu-action@5927c834f5b4fdf503fca6f4c7eccda82949e1ee # v3.1.0
|
|
- name: Set up Docker Buildx
|
|
id: buildx
|
|
uses: docker/setup-buildx-action@4fd812986e6c8c2a69e18311145f9371337f27d4 # v3.4.0
|
|
with:
|
|
version: latest
|
|
platforms: ${{ env.PLATFORMS }}
|
|
- name: Login to GitHub Container Registry
|
|
uses: docker/login-action@0d4c9c5ea7693da7b068278f7b52bda2a190a446 # v3.2.0
|
|
with:
|
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
- name: build-image
|
|
run: |
|
|
export TAG=$(cat images/nginx-1.25/TAG)
|
|
cd images/nginx-1.25/rootfs && docker buildx build --platform=${{ env.PLATFORMS }} --push -t ingressnginx/nginx-1.25:${TAG} .
|