Skip to content

fixed setup

fixed setup #102

Workflow file for this run

name: Build and Release k4all ISO
'on':
push:
tags:
- '*'
branches:
- release
workflow_dispatch: null
jobs:
build-iso:
runs-on: ubuntu-latest
env:
ROLES: "bootstrap control worker" # Defining roles as a space-separated string
COREOS_URL: "https://builds.coreos.fedoraproject.org/prod/streams/stable/builds/40.20240701.3.0/x86_64/fedora-coreos-40.20240701.3.0-live.x86_64.iso"
ARCH: "x86_64"
steps:
- name: Check out the repository
uses: actions/checkout@v4
- name: Set up Docker
uses: docker/setup-buildx-action@v3
- name: Extract branch or tag version
id: version
run: |
if [ "${GITHUB_REF_TYPE}" = "tag" ]; then
VERSION="${GITHUB_REF_NAME}"
# Determine prerelease status based on tag format "vX.Y.Z-<alpha or beta>"
if [[ "$VERSION" =~ v[0-9]+\.[0-9]+\.[0-9]+-(alpha|beta) ]]; then
echo "prerelease=true" >> $GITHUB_ENV
else
echo "prerelease=false" >> $GITHUB_ENV
fi
echo "draft=false" >> $GITHUB_ENV
else
VERSION="${GITHUB_REF_NAME:-main}"
echo "draft=true" >> $GITHUB_ENV
echo "prerelease=false" >> $GITHUB_ENV
fi
echo "version=$VERSION" >> $GITHUB_ENV
- name: Download Fedora CoreOS ISO
run: |
FCOS_PATH="./k4all"
ARCH=${{ env.ARCH }}
mkdir -p $FCOS_PATH
COREOS_JSON=https://builds.coreos.fedoraproject.org/streams/stable.json
ISO_URL=$(curl $COREOS_JSON | jq -r ".architectures.$ARCH.artifacts.metal.formats.iso.disk.location")
FCOS_IMAGE=$(basename "$ISO_URL")
# Check if the file exists
if [ -f "$FCOS_PATH/$FCOS_IMAGE" ]; then
echo "The file $FCOS_IMAGE already exists."
else
echo "The file $FCOS_IMAGE does not exist. Downloading..."
curl -o "$FCOS_PATH/$FCOS_IMAGE" "$ISO_URL"
echo "Download completed."
fi
mv $FCOS_PATH/$FCOS_IMAGE $FCOS_PATH/fedora-coreos.iso
shell: bash
- name: Make scripts executable
run: |
chmod -R +x ./install-scripts/*
chmod -R +x ./scripts/*
- name: Generate ISOs for Multiple Roles
run: |
docker run --interactive -v "$(pwd):/data/" --rm quay.io/coreos/butane:release --pretty --strict -d /data/ < "k8s-base.bu" > "k8s-base.ign"
IFS=' ' read -ra ROLE_ARRAY <<< "${{ env.ROLES }}"
for role in "${ROLE_ARRAY[@]}"; do
docker run --interactive -v "$(pwd):/data/" --rm quay.io/coreos/butane:release --pretty --strict -d /data/ < "k8s-$role.bu" > "k8s.ign"
docker run --interactive -v $(pwd):/data/ --rm quay.io/coreos/butane:release --pretty --strict -d /data/ < install.bu > install.ign
docker run --privileged --rm -v /dev:/dev -v "$(pwd):/data" -w /data -v ./k4all:/k4all/ quay.io/coreos/coreos-installer:release iso ignition embed -i "/data/install.ign" -o "/k4all/k4all-$role-${{ env.version }}-${{ env.ARCH }}.iso" "/k4all/fedora-coreos.iso"
docker run --privileged --rm -v ./k4all:/k4all/ quay.io/coreos/coreos-installer:release iso kargs modify -a coreos.liveiso.fromram "/k4all/k4all-$role-${{ env.version }}-${{ env.ARCH }}.iso"
done
- name: Check ISO directory and Fix file permissions
run: |
sudo chown -R 1001:127 ./k4all
ls -lan ./k4all
- name: Install qemu-img
run: sudo apt-get -qq update && sudo apt-get -qq install -y qemu-utils
- name: Create k4all QCOW2 / VDI image
run: |
IFS=' ' read -ra ROLE_ARRAY <<< "${{ env.ROLES }}"
for role in "${ROLE_ARRAY[@]}"; do
qemu-img convert -O qcow2 ./k4all/k4all-$role-${{ env.version }}-${{ env.ARCH }}.iso ./k4all/k4all-$role-${{ env.version }}-${{ env.ARCH }}.qcow2
qemu-img resize ./k4all/k4all-$role-${{ env.version }}-${{ env.ARCH }}.qcow2 60G
qemu-img convert -O vdi ./k4all/k4all-$role-${{ env.version }}-${{ env.ARCH }}.qcow2 ./k4all/k4all-$role-${{ env.version }}-${{ env.ARCH }}.vdi
done
shell: bash
- name: Create a GitHub Release
id: create_release_bootstrap
uses: softprops/action-gh-release@v2
with:
tag_name: '${{ env.version }}'
name: 'Release ${{ env.version }}'
draft: '${{ env.draft }}'
prerelease: '${{ env.prerelease }}'
files: |
./k4all/k4all-bootstrap-${{ env.version }}-${{ env.ARCH }}.iso
./k4all/k4all-bootstrap-${{ env.version }}-${{ env.ARCH }}.qcow2
./k4all/k4all-bootstrap-${{ env.version }}-${{ env.ARCH }}.vdi
env:
GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}'
- name: Create a GitHub Release
id: create_release_control
uses: softprops/action-gh-release@v2
with:
tag_name: '${{ env.version }}'
name: 'Release ${{ env.version }}'
draft: '${{ env.draft }}'
prerelease: '${{ env.prerelease }}'
files: |
./k4all/k4all-control-${{ env.version }}-${{ env.ARCH }}.iso
./k4all/k4all-control-${{ env.version }}-${{ env.ARCH }}.qcow2
./k4all/k4all-control-${{ env.version }}-${{ env.ARCH }}.vdi
env:
GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}'
- name: Create a GitHub Release
id: create_release_worker
uses: softprops/action-gh-release@v2
with:
tag_name: '${{ env.version }}'
name: 'Release ${{ env.version }}'
draft: '${{ env.draft }}'
prerelease: '${{ env.prerelease }}'
files: |
./k4all/k4all-worker-${{ env.version }}-${{ env.ARCH }}.iso
./k4all/k4all-worker-${{ env.version }}-${{ env.ARCH }}.qcow2
./k4all/k4all-worker-${{ env.version }}-${{ env.ARCH }}.vdi
env:
GITHUB_TOKEN: '${{ secrets.GITHUB_TOKEN }}'