ci(tools): update determinatesystems/update-flake-lock action to v24 #148
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: docker | |
"on": | |
push: | |
branches: | |
- master | |
tags: | |
- v* | |
jobs: | |
docker: | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
include: | |
- platform: linux/386 | |
goos: linux | |
goarch: 386 | |
- platform: linux/amd64 | |
goos: linux | |
goarch: amd64 | |
- platform: linux/arm64 | |
goos: linux | |
goarch: arm64 | |
- platform: linux/arm/6 | |
goos: linux | |
goarch: arm | |
goarm: 6 | |
steps: | |
- name: Checkout source | |
id: source | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- name: Setup golang | |
id: golang | |
uses: actions/setup-go@v5 | |
with: | |
go-version: ^1.23.0 | |
- name: Run generate | |
id: generate | |
env: | |
GOOS: ${{ matrix.goos }} | |
GOARCH: ${{ matrix.goarch }} | |
GOARM: ${{ matrix.goarm }} | |
run: make generate | |
- name: Run build | |
id: build | |
env: | |
GOOS: ${{ matrix.goos }} | |
GOARCH: ${{ matrix.goarch }} | |
GOARM: ${{ matrix.goarm }} | |
run: make build | |
- name: Docker meta | |
id: meta | |
uses: docker/metadata-action@v5 | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
images: | | |
webhippie/redirects | |
quay.io/webhippie/redirects | |
ghcr.io/webhippie/redirects | |
labels: | | |
org.opencontainers.image.vendor=Webhippie | |
maintainer=Thomas Boerger <thomas@webhippie.de> | |
tags: | | |
type=ref,event=pr | |
type=raw,value=latest,enable=${{ github.ref == 'refs/heads/master' }} | |
type=semver,pattern={{version}} | |
type=semver,pattern={{major}}.{{minor}} | |
type=semver,pattern={{major}} | |
flavor: | | |
suffix=-${{ matrix.goos }}-${{ matrix.goarch }} | |
- name: Setup qemu | |
id: qemu | |
uses: docker/setup-qemu-action@v3 | |
- name: Setup buildx | |
id: buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Hub login | |
id: login1 | |
uses: docker/login-action@v3 | |
if: github.event_name != 'pull_request' | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- name: Quay login | |
id: login2 | |
uses: docker/login-action@v3 | |
if: github.event_name != 'pull_request' | |
with: | |
registry: quay.io | |
username: ${{ secrets.QUAY_USERNAME }} | |
password: ${{ secrets.QUAY_PASSWORD }} | |
- name: Ghcr login | |
id: login3 | |
uses: docker/login-action@v3 | |
if: github.event_name != 'pull_request' | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Build image | |
id: publish | |
uses: docker/build-push-action@v6 | |
with: | |
builder: ${{ steps.buildx.outputs.name }} | |
context: . | |
provenance: false | |
file: docker/Dockerfile.${{ matrix.goos }}.${{ matrix.goarch }} | |
platforms: ${{ matrix.platform }} | |
push: ${{ github.event_name != 'pull_request' }} | |
labels: ${{ steps.meta.outputs.labels }} | |
tags: ${{ steps.meta.outputs.tags }} | |
manifest: | |
runs-on: ubuntu-latest | |
needs: docker | |
steps: | |
- name: Checkout source | |
id: source | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- name: Hub tags | |
id: hubTags | |
uses: docker/metadata-action@v5 | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
images: webhippie/redirects | |
tags: | | |
type=raw,value=latest,enable=${{ github.ref == 'refs/heads/master' }} | |
type=semver,pattern={{version}} | |
type=semver,pattern={{major}}.{{minor}} | |
type=semver,pattern={{major}} | |
- name: Hub manifest | |
id: hub | |
uses: actionhippie/manifest@v1 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
platforms: linux/amd64,linux/386,linux/arm64,linux/arm/v6 | |
template: webhippie/redirects:VERSION-OS-ARCH | |
target: ${{ steps.hubTags.outputs.tags }} | |
ignore_missing: true | |
- name: Quay tags | |
id: quayTags | |
uses: docker/metadata-action@v5 | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
images: quay.io/webhippie/redirects | |
tags: | | |
type=raw,value=latest,enable=${{ github.ref == 'refs/heads/master' }} | |
type=semver,pattern={{version}} | |
type=semver,pattern={{major}}.{{minor}} | |
type=semver,pattern={{major}} | |
- name: Quay manifest | |
id: quay | |
uses: actionhippie/manifest@v1 | |
with: | |
username: ${{ secrets.QUAY_USERNAME }} | |
password: ${{ secrets.QUAY_PASSWORD }} | |
platforms: linux/amd64,linux/386,linux/arm64,linux/arm/v6 | |
template: quay.io/webhippie/redirects:VERSION-OS-ARCH | |
target: ${{ steps.quayTags.outputs.tags }} | |
ignore_missing: true | |
- name: Ghcr tags | |
id: ghcrTags | |
uses: docker/metadata-action@v5 | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
images: ghcr.io/webhippie/redirects | |
tags: | | |
type=raw,value=latest,enable=${{ github.ref == 'refs/heads/master' }} | |
type=semver,pattern={{version}} | |
type=semver,pattern={{major}}.{{minor}} | |
type=semver,pattern={{major}} | |
- name: Ghcr manifest | |
id: ghcr | |
uses: actionhippie/manifest@v1 | |
with: | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
platforms: linux/amd64,linux/386,linux/arm64,linux/arm/v6 | |
template: ghcr.io/webhippie/redirects:VERSION-OS-ARCH | |
target: ${{ steps.ghcrTags.outputs.tags }} | |
ignore_missing: true | |
readme: | |
runs-on: ubuntu-latest | |
needs: docker | |
steps: | |
- name: Checkout source | |
id: source | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
- name: Hub readme | |
id: hub | |
uses: actionhippie/pushrm@v1 | |
with: | |
provider: dockerhub | |
target: webhippie/redirects | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
description: Redirects | |
readme: README.md | |
- name: Quay readme | |
id: quay | |
uses: actionhippie/pushrm@v1 | |
with: | |
provider: quay | |
target: quay.io/webhippie/redirects | |
apikey: ${{ secrets.QUAY_APIKEY }} | |
readme: README.md | |
... |