2024-07-20 09:58:32 +00:00
|
|
|
# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json
|
|
|
|
name: "Main"
|
2022-04-26 20:11:31 +00:00
|
|
|
|
|
|
|
on:
|
|
|
|
push:
|
2024-07-20 09:58:32 +00:00
|
|
|
tags: ["*"]
|
|
|
|
branches: ["*"]
|
2022-04-26 20:11:31 +00:00
|
|
|
pull_request:
|
2024-07-20 09:58:32 +00:00
|
|
|
branches: ["*"]
|
2022-04-26 20:11:31 +00:00
|
|
|
workflow_dispatch:
|
|
|
|
|
2022-05-21 15:27:29 +00:00
|
|
|
permissions: {}
|
|
|
|
|
2022-04-26 20:11:31 +00:00
|
|
|
jobs:
|
2022-06-14 21:45:37 +00:00
|
|
|
build-common-stages:
|
2024-07-20 09:58:32 +00:00
|
|
|
name: "Build common stages"
|
|
|
|
runs-on: "ubuntu-latest"
|
2022-06-14 21:45:37 +00:00
|
|
|
permissions:
|
2024-07-20 09:58:32 +00:00
|
|
|
contents: "read"
|
2022-06-14 21:45:37 +00:00
|
|
|
strategy:
|
|
|
|
matrix:
|
2024-07-20 09:58:32 +00:00
|
|
|
stage: ["build"]
|
2022-06-14 21:45:37 +00:00
|
|
|
steps:
|
2024-07-20 09:58:32 +00:00
|
|
|
- name: "Checkout project"
|
|
|
|
uses: "actions/checkout@v4"
|
|
|
|
- name: "Build and save image"
|
2022-06-14 21:45:37 +00:00
|
|
|
run: |
|
|
|
|
make \
|
|
|
|
IMAGE_REGISTRY="localhost" IMAGE_NAMESPACE="stage" IMAGE_PROJECT="${{ matrix.stage }}" \
|
|
|
|
IMAGE_BUILD_OPTS="--pull --target ${{ matrix.stage }} --build-arg BUILDKIT_INLINE_CACHE=1" \
|
|
|
|
build-native-image save-native-image
|
2024-07-20 09:58:32 +00:00
|
|
|
- name: "Upload artifacts"
|
|
|
|
uses: "actions/upload-artifact@v4"
|
2022-06-14 21:45:37 +00:00
|
|
|
with:
|
2024-07-20 09:58:32 +00:00
|
|
|
name: "dist-common-stages"
|
|
|
|
path: "./dist/"
|
2022-06-14 21:45:37 +00:00
|
|
|
retention-days: 1
|
|
|
|
|
2022-04-26 20:11:31 +00:00
|
|
|
build:
|
2024-07-20 09:58:32 +00:00
|
|
|
name: "Build ${{ matrix.arch }} image"
|
|
|
|
needs: ["build-common-stages"]
|
|
|
|
runs-on: "ubuntu-latest"
|
2022-04-26 20:11:31 +00:00
|
|
|
permissions:
|
2024-07-20 09:58:32 +00:00
|
|
|
contents: "read"
|
2022-04-26 20:11:31 +00:00
|
|
|
strategy:
|
|
|
|
matrix:
|
2024-07-20 09:58:32 +00:00
|
|
|
arch: ["native", "amd64", "arm64v8"]
|
2022-04-26 20:11:31 +00:00
|
|
|
steps:
|
2024-07-20 09:58:32 +00:00
|
|
|
- name: "Checkout project"
|
|
|
|
uses: "actions/checkout@v4"
|
|
|
|
- name: "Download artifacts"
|
|
|
|
uses: "actions/download-artifact@v4"
|
2022-06-14 21:45:37 +00:00
|
|
|
with:
|
2024-07-20 09:58:32 +00:00
|
|
|
name: "dist-common-stages"
|
|
|
|
path: "./dist/"
|
|
|
|
- name: "Load common stages"
|
2022-06-14 21:45:37 +00:00
|
|
|
run: |
|
|
|
|
docker system prune --all --force
|
|
|
|
make IMAGE_REGISTRY="localhost" IMAGE_NAMESPACE="stage" IMAGE_PROJECT="build" load-native-image clean
|
2024-07-20 09:58:32 +00:00
|
|
|
- name: "Register binfmt entries"
|
2022-04-26 20:11:31 +00:00
|
|
|
if: "matrix.arch != 'native'"
|
|
|
|
run: |
|
|
|
|
make binfmt-register
|
2024-07-20 09:58:32 +00:00
|
|
|
- name: "Build and save image"
|
2022-04-26 20:11:31 +00:00
|
|
|
run: |
|
2022-06-14 21:45:37 +00:00
|
|
|
make \
|
|
|
|
IMAGE_BUILD_OPTS="--cache-from localhost/stage/build:latest" \
|
|
|
|
"build-${{ matrix.arch }}-image" "save-${{ matrix.arch }}-image"
|
2024-07-20 09:58:32 +00:00
|
|
|
- name: "Upload artifacts"
|
2022-04-28 20:57:59 +00:00
|
|
|
if: "startsWith(github.ref, 'refs/tags/v') && matrix.arch != 'native'"
|
2024-07-20 09:58:32 +00:00
|
|
|
uses: "actions/upload-artifact@v4"
|
2022-04-26 20:11:31 +00:00
|
|
|
with:
|
2024-07-20 09:58:32 +00:00
|
|
|
name: "dist-${{ matrix.arch }}"
|
|
|
|
path: "./dist/"
|
2022-04-26 20:11:31 +00:00
|
|
|
retention-days: 1
|
|
|
|
|
|
|
|
push:
|
2024-07-20 09:58:32 +00:00
|
|
|
name: "Push ${{ matrix.arch }} image"
|
2022-04-26 20:11:31 +00:00
|
|
|
if: "startsWith(github.ref, 'refs/tags/v')"
|
2024-07-20 09:58:32 +00:00
|
|
|
needs: ["build"]
|
|
|
|
runs-on: "ubuntu-latest"
|
2022-04-26 20:11:31 +00:00
|
|
|
permissions:
|
2024-07-20 09:58:32 +00:00
|
|
|
contents: "read"
|
2022-04-26 20:11:31 +00:00
|
|
|
strategy:
|
|
|
|
matrix:
|
2024-07-20 09:58:32 +00:00
|
|
|
arch: ["amd64", "arm64v8"]
|
2022-04-26 20:11:31 +00:00
|
|
|
steps:
|
2024-07-20 09:58:32 +00:00
|
|
|
- name: "Checkout project"
|
|
|
|
uses: "actions/checkout@v4"
|
|
|
|
- name: "Download artifacts"
|
|
|
|
uses: "actions/download-artifact@v4"
|
2022-04-26 20:11:31 +00:00
|
|
|
with:
|
2024-07-20 09:58:32 +00:00
|
|
|
name: "dist-${{ matrix.arch }}"
|
|
|
|
path: "./dist/"
|
|
|
|
- name: "Login to Docker Hub"
|
|
|
|
uses: "docker/login-action@v3"
|
2022-04-26 20:11:31 +00:00
|
|
|
with:
|
2024-07-20 09:58:32 +00:00
|
|
|
registry: "docker.io"
|
|
|
|
username: "${{ secrets.DOCKERHUB_USERNAME }}"
|
|
|
|
password: "${{ secrets.DOCKERHUB_TOKEN }}"
|
|
|
|
- name: "Load and push image"
|
2022-04-26 20:11:31 +00:00
|
|
|
run: |
|
|
|
|
make "load-${{ matrix.arch }}-image" "push-${{ matrix.arch }}-image"
|
|
|
|
|
|
|
|
push-manifest:
|
2024-07-20 09:58:32 +00:00
|
|
|
name: "Push manifest"
|
2022-04-26 20:11:31 +00:00
|
|
|
if: "startsWith(github.ref, 'refs/tags/v')"
|
2024-07-20 09:58:32 +00:00
|
|
|
needs: ["push"]
|
|
|
|
runs-on: "ubuntu-latest"
|
2022-04-26 20:11:31 +00:00
|
|
|
permissions:
|
2024-07-20 09:58:32 +00:00
|
|
|
contents: "read"
|
2022-04-26 20:11:31 +00:00
|
|
|
steps:
|
2024-07-20 09:58:32 +00:00
|
|
|
- name: "Checkout project"
|
|
|
|
uses: "actions/checkout@v4"
|
|
|
|
- name: "Login to Docker Hub"
|
|
|
|
uses: "docker/login-action@v3"
|
2022-04-26 20:11:31 +00:00
|
|
|
with:
|
2024-07-20 09:58:32 +00:00
|
|
|
registry: "docker.io"
|
|
|
|
username: "${{ secrets.DOCKERHUB_USERNAME }}"
|
|
|
|
password: "${{ secrets.DOCKERHUB_TOKEN }}"
|
|
|
|
- name: "Push manifest"
|
2022-04-26 20:11:31 +00:00
|
|
|
run: |
|
|
|
|
make push-cross-manifest
|
|
|
|
|
|
|
|
release-github:
|
2024-07-20 09:58:32 +00:00
|
|
|
name: "Create GitHub release"
|
2022-04-26 20:11:31 +00:00
|
|
|
if: "startsWith(github.ref, 'refs/tags/v')"
|
2024-07-20 09:58:32 +00:00
|
|
|
needs: ["push-manifest"]
|
|
|
|
runs-on: "ubuntu-latest"
|
2022-04-26 20:11:31 +00:00
|
|
|
permissions:
|
2024-07-20 09:58:32 +00:00
|
|
|
contents: "write"
|
2022-04-26 20:11:31 +00:00
|
|
|
steps:
|
2024-07-20 09:58:32 +00:00
|
|
|
- name: "Create release"
|
2022-04-28 20:38:50 +00:00
|
|
|
env:
|
2024-07-20 09:58:32 +00:00
|
|
|
GITHUB_PAT: "${{ secrets.GITHUB_TOKEN }}"
|
2022-04-26 20:11:31 +00:00
|
|
|
run: |
|
|
|
|
RELEASE_STATUS="$(curl -fs --proto '=https' --tlsv1.3 --globoff \
|
|
|
|
--url "https://api.github.com/repos/${GITHUB_REPOSITORY:?}/releases/tags/${GITHUB_REF_NAME:?}" \
|
2022-04-28 20:38:50 +00:00
|
|
|
--header "Authorization: Bearer ${GITHUB_PAT:?}" \
|
2022-04-26 20:11:31 +00:00
|
|
|
--header 'Accept: application/vnd.github.v3+json' \
|
|
|
|
--header 'Content-Type: application/json' \
|
|
|
|
--write-out '%{http_code}' --output /dev/null ||:)"
|
|
|
|
if [ "${RELEASE_STATUS:?}" = '200' ]; then exit 0; fi
|
|
|
|
RELEASE_ID="$(curl -fsS --proto '=https' --tlsv1.3 --globoff \
|
|
|
|
--url "https://api.github.com/repos/${GITHUB_REPOSITORY:?}/releases" \
|
2022-04-28 20:38:50 +00:00
|
|
|
--header "Authorization: Bearer ${GITHUB_PAT:?}" \
|
2022-04-26 20:11:31 +00:00
|
|
|
--header 'Accept: application/vnd.github.v3+json' \
|
|
|
|
--header 'Content-Type: application/json' \
|
|
|
|
--data "$(jq -rn --arg tag "${GITHUB_REF_NAME:?}" '{"name": $tag, "tag_name": $tag, "generate_release_notes": true}')" | jq -r '.id')"
|
|
|
|
if [ -z "${RELEASE_ID-}" ] || [ "${RELEASE_ID:?}" = 'null' ]; then exit 1; fi
|