mirror of
https://github.com/lukaszraczylo/talos-builder.git
synced 2026-06-09 23:59:41 +00:00
130 lines
4.9 KiB
YAML
130 lines
4.9 KiB
YAML
on:
|
|
push:
|
|
tags:
|
|
- 'v*.*.*'
|
|
|
|
env:
|
|
RPI_MODEL: rpi5
|
|
REGISTRY: ghcr.io
|
|
REGISTRY_USERNAME: ${{ github.repository_owner }}
|
|
# Extensions to bake into the installer image.
|
|
# Format: space-separated list of image:tag references (digests resolved at build time).
|
|
EXTENSION_ISCSI_IMAGE: ghcr.io/siderolabs/iscsi-tools:v0.2.0
|
|
EXTENSION_UTIL_LINUX_IMAGE: ghcr.io/siderolabs/util-linux-tools:2.41.2
|
|
|
|
jobs:
|
|
build:
|
|
permissions:
|
|
contents: write
|
|
packages: write
|
|
attestations: write
|
|
id-token: write
|
|
runs-on: ubuntu-24.04-arm
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- uses: imjasonh/setup-crane@v0.4
|
|
with:
|
|
version: v0.20.5
|
|
- uses: docker/setup-buildx-action@v3
|
|
- uses: docker/login-action@v3
|
|
with:
|
|
registry: ghcr.io
|
|
username: ${{ github.actor }}
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
|
- name: Set up GitHub Actions bot user
|
|
run: |
|
|
git config --global user.name "github-actions[bot]"
|
|
git config --global user.email "github-actions[bot]@users.noreply.github.com"
|
|
|
|
- name: Resolve extension image digests
|
|
run: |
|
|
EXTENSIONS=""
|
|
while IFS= read -r line; do
|
|
IMAGE="${line#*=}"
|
|
DIGEST=$(crane digest "$IMAGE")
|
|
EXTENSIONS="$EXTENSIONS $IMAGE@$DIGEST"
|
|
done < <(env | grep '^EXTENSION_')
|
|
echo "EXTENSIONS=${EXTENSIONS# }" >> $GITHUB_ENV
|
|
|
|
- name: Prepare (checkouts & patches)
|
|
run: make RPI_MODEL=${{ env.RPI_MODEL }} checkouts patches-pi5
|
|
|
|
- name: Kernel
|
|
run: make RPI_MODEL=${{ env.RPI_MODEL }} REGISTRY=${{ env.REGISTRY }} REGISTRY_USERNAME=${{ env.REGISTRY_USERNAME }} kernel
|
|
|
|
- name: Kernel initramfs
|
|
run: make RPI_MODEL=${{ env.RPI_MODEL }} REGISTRY=${{ env.REGISTRY }} REGISTRY_USERNAME=${{ env.REGISTRY_USERNAME }} kern_initramfs
|
|
|
|
- name: Installer base
|
|
run: make RPI_MODEL=${{ env.RPI_MODEL }} REGISTRY=${{ env.REGISTRY }} REGISTRY_USERNAME=${{ env.REGISTRY_USERNAME }} installer-base
|
|
|
|
- name: Imager
|
|
run: make RPI_MODEL=${{ env.RPI_MODEL }} REGISTRY=${{ env.REGISTRY }} REGISTRY_USERNAME=${{ env.REGISTRY_USERNAME }} imager
|
|
|
|
- name: Overlay
|
|
run: make RPI_MODEL=${{ env.RPI_MODEL }} REGISTRY=${{ env.REGISTRY }} REGISTRY_USERNAME=${{ env.REGISTRY_USERNAME }} overlay
|
|
|
|
- name: Build installer image (with extensions)
|
|
run: |
|
|
make RPI_MODEL=${{ env.RPI_MODEL }} \
|
|
REGISTRY=${{ env.REGISTRY }} \
|
|
REGISTRY_USERNAME=${{ env.REGISTRY_USERNAME }} \
|
|
ASSET_TYPE=installer \
|
|
EXTENSIONS="${{ env.EXTENSIONS }}" \
|
|
installer-pi5
|
|
# Push the installer OCI tarball so it can be used for upgrades
|
|
crane push \
|
|
./checkouts/talos/_out/installer-arm64.tar \
|
|
${{ env.REGISTRY }}/${{ env.REGISTRY_USERNAME }}/installer:$(cd checkouts/talos && git describe --tag --always --dirty --match v[0-9]*)
|
|
|
|
- name: Build metal disk image (for fresh installs)
|
|
run: |
|
|
make RPI_MODEL=${{ env.RPI_MODEL }} \
|
|
REGISTRY=${{ env.REGISTRY }} \
|
|
REGISTRY_USERNAME=${{ env.REGISTRY_USERNAME }} \
|
|
ASSET_TYPE=metal \
|
|
EXTENSIONS="${{ env.EXTENSIONS }}" \
|
|
installer-pi5
|
|
|
|
- name: Release (tag installer image with git tag)
|
|
if: startsWith(github.ref, 'refs/tags/v')
|
|
run: make RPI_MODEL=${{ env.RPI_MODEL }} REGISTRY=${{ env.REGISTRY }} REGISTRY_USERNAME=${{ env.REGISTRY_USERNAME }} release
|
|
|
|
- name: Create GitHub Release
|
|
env:
|
|
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
run: |
|
|
NOTES=$(cat <<EOF
|
|
> ⚠️ Experimental build, use at your own risk.
|
|
|
|
This is a patched version of Talos tailored for the Raspberry Pi 5, including NVMe, NIC and USB support.
|
|
|
|
### Extensions included
|
|
|
|
- \`iscsi-tools\` ${{ env.EXTENSION_ISCSI_IMAGE }}
|
|
- \`util-linux-tools\` ${{ env.EXTENSION_UTIL_LINUX_IMAGE }}
|
|
|
|
### What's available
|
|
|
|
- 📦 **Raw disk image** (\`metal-arm64.raw.zst\`) for fresh installs
|
|
- ⚙️ **Installer image** (\`${{ env.REGISTRY }}/${{ env.REGISTRY_USERNAME }}/installer:${{ github.ref_name }}\`) for upgrades
|
|
|
|
### Install
|
|
|
|
- **Fresh install**
|
|
- Download the raw disk image from this release
|
|
- Flash with \`dd\` or your favorite tool
|
|
|
|
- **Upgrade existing node**
|
|
\`\`\`bash
|
|
talosctl upgrade --nodes <NODE_IP> --image ${{ env.REGISTRY }}/${{ env.REGISTRY_USERNAME }}/installer:${{ github.ref_name }}
|
|
\`\`\`
|
|
|
|
EOF
|
|
)
|
|
gh release create \
|
|
${{ github.ref_name }} \
|
|
./checkouts/talos/_out/metal-arm64.raw.zst \
|
|
--title "${{ github.ref_name }}" \
|
|
--notes "$NOTES"
|