Compare commits
1 Commits
main
...
ade3e4293c
| Author | SHA1 | Date | |
|---|---|---|---|
| ade3e4293c |
@@ -2,70 +2,64 @@ name: build-image
|
|||||||
on: [push]
|
on: [push]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
semrel_dryrun:
|
# semrel_dryrun:
|
||||||
name: Semantic Release (Dry-run)
|
# name: Semantic Release (Dry-run)
|
||||||
runs-on: ubuntu-latest
|
# runs-on: ubuntu-latest
|
||||||
outputs:
|
# outputs:
|
||||||
version: ${{ steps.sem_rel.outputs.version }}
|
# version: ${{ steps.sem_rel.outputs.version }}
|
||||||
steps:
|
# steps:
|
||||||
- name: Check out repository code
|
# - name: Check out repository code
|
||||||
uses: actions/checkout@v3
|
# uses: actions/checkout@v3
|
||||||
- name: Install dependencies
|
# - name: Set up Node
|
||||||
run: |
|
# uses: actions/setup-node@v3
|
||||||
npm install \
|
# with:
|
||||||
semantic-release \
|
# node-version: 20
|
||||||
@semantic-release/commit-analyzer \
|
# - name: Install dependencies
|
||||||
@semantic-release/exec
|
# run: |
|
||||||
- name: Semantic Release (dry-run)
|
# npm install \
|
||||||
id: sem_rel
|
# semantic-release \
|
||||||
run: |
|
# @semantic-release/commit-analyzer \
|
||||||
npx semantic-release \
|
# @semantic-release/exec
|
||||||
--package @semantic-release/exec \
|
# - name: Semantic Release (dry-run)
|
||||||
--package semantic-release \
|
# id: sem_rel
|
||||||
--branches ${{ gitea.refname }} \
|
# run: |
|
||||||
--tag-format 'v${version}' \
|
# npx semantic-release \
|
||||||
--dry-run \
|
# --package @semantic-release/exec \
|
||||||
--plugins @semantic-release/commit-analyzer,@semantic-release/exec \
|
# --package semantic-release \
|
||||||
--analyzeCommits @semantic-release/commit-analyzer \
|
# --branches ${{ gitea.refname }} \
|
||||||
--verifyRelease @semantic-release/exec \
|
# --tag-format 'v${version}' \
|
||||||
--verifyReleaseCmd 'echo "version=${nextRelease.version}" >> $GITHUB_OUTPUT'
|
# --dry-run \
|
||||||
- name: Assert semantic release output
|
# --plugins @semantic-release/commit-analyzer,@semantic-release/exec \
|
||||||
run: |
|
# --analyzeCommits @semantic-release/commit-analyzer \
|
||||||
[[ -z "${{ steps.sem_rel.outputs.version }}" ]] && {
|
# --verifyRelease @semantic-release/exec \
|
||||||
echo 'No release tag - exiting'; exit 1
|
# --verifyReleaseCmd 'echo "version=${nextRelease.version}" >> $GITHUB_OUTPUT'
|
||||||
} || {
|
# env:
|
||||||
echo 'Release tag set correctly: ${{ steps.sem_rel.outputs.version }}'; exit 0
|
# GIT_CREDENTIALS: ${{ secrets.GIT_USERNAME }}:${{ secrets.GIT_APIKEY }}
|
||||||
}
|
# - name: Assert semantic release output
|
||||||
|
# run: |
|
||||||
|
# [[ -z "${{ steps.sem_rel.outputs.version }}" ]] && {
|
||||||
|
# echo 'No release tag - exiting'; exit 1
|
||||||
|
# } || {
|
||||||
|
# echo 'Release tag set correctly: ${{ steps.sem_rel.outputs.version }}'; exit 0
|
||||||
|
# }
|
||||||
|
|
||||||
build_image:
|
build_image:
|
||||||
name: Build image
|
name: Build image
|
||||||
container: code.spamasaurus.com/djpbessems/act-runner-extended:1.0.0-cth20250815
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: semrel_dryrun
|
# needs: semrel_dryrun
|
||||||
steps:
|
steps:
|
||||||
- name: Check out repository code
|
- name: Check out repository code
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Set up build container
|
- name: Create folder structure
|
||||||
|
run: |
|
||||||
|
mkdir -p \
|
||||||
|
ubuntu-vm
|
||||||
|
- name: Generate seed ISO
|
||||||
run: |
|
run: |
|
||||||
apt-get update && \
|
apt-get update && \
|
||||||
apt-get install -y \
|
apt-get install -y \
|
||||||
linux-image-generic \
|
genisoimage
|
||||||
linux-modules-extra-$(uname -r) \
|
|
||||||
linux-headers-generic
|
|
||||||
|
|
||||||
mkdir -p \
|
|
||||||
$PWD/ubuntu-vm \
|
|
||||||
/mnt/vmimage
|
|
||||||
- name: Retrieve source Ubuntu image
|
|
||||||
run: |
|
|
||||||
curl -L \
|
|
||||||
https://sn.itch.fyi/Repository/iso/Canonical/Ubuntu%20Server%2024.04/ubuntu-24.04-server-cloudimg-amd64.img \
|
|
||||||
-o ubuntu-vm/ubuntu-24.04-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img \
|
|
||||||
-u ${{ secrets.REPO_USERNAME }}:${{ secrets.REPO_PASSWORD }}
|
|
||||||
|
|
||||||
qemu-img resize ubuntu-vm/ubuntu-24.04-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img +5G
|
|
||||||
- name: Generate seed ISO
|
|
||||||
run: |
|
|
||||||
envsubst < cloud-init/user-data.template > cloud-init/user-data
|
envsubst < cloud-init/user-data.template > cloud-init/user-data
|
||||||
|
|
||||||
genisoimage \
|
genisoimage \
|
||||||
@@ -74,64 +68,33 @@ jobs:
|
|||||||
-joliet \
|
-joliet \
|
||||||
-rock \
|
-rock \
|
||||||
cloud-init/meta-data cloud-init/user-data
|
cloud-init/meta-data cloud-init/user-data
|
||||||
|
|
||||||
|
ls -lash ubuntu-vm
|
||||||
env:
|
env:
|
||||||
ROOT_HASHED_PASSWORD: ${{ secrets.VM_ROOT_HASHED_PASSWORD }}
|
ROOT_HASHED_PASSWORD: ${{ secrets.ROOT_HASHED_PASSWORD }}
|
||||||
PUBLIC_SSHKEY: ${{ secrets.VM_PUBLIC_SSHKEY }}
|
PUBLIC_SSHKEY: ${{ secrets.PUBLIC_SSHKEY }}
|
||||||
- name: Provision template virtual machine
|
- name: Download Ubuntu ISO
|
||||||
run: |
|
run: |
|
||||||
[ -e /dev/kvm ] && kvm_flag="-enable-kvm" || kvm_flag=""
|
if [ ! -f ubuntu-vm/ubuntu-24.04.iso ]; then
|
||||||
|
curl -L -o ubuntu-vm/ubuntu-24.04.iso https://releases.ubuntu.com/24.04/ubuntu-24.04.2-desktop-amd64.iso
|
||||||
qemu-system-x86_64 \
|
|
||||||
$kvm_flag \
|
|
||||||
-m 3072 \
|
|
||||||
-smp 2 \
|
|
||||||
-cpu host \
|
|
||||||
-drive file=ubuntu-vm/ubuntu-24.04-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img,if=virtio,format=qcow2 \
|
|
||||||
-drive file=ubuntu-vm/seed.iso,format=raw,media=cdrom \
|
|
||||||
-nographic \
|
|
||||||
-net nic \
|
|
||||||
-net user \
|
|
||||||
-device virtio-serial-pci,id=virtio-serial0 \
|
|
||||||
-chardev socket,path=qga.sock,server=on,wait=off,id=qga0 \
|
|
||||||
-device virtserialport,chardev=qga0,name=org.qemu.guest_agent.0
|
|
||||||
|
|
||||||
if ! guestfish --ro -a ubuntu-vm/ubuntu-24.04-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img -i stat /var/log/template-generation-success; then
|
|
||||||
echo "VM provisioning encountered errors - exiting"
|
|
||||||
exit 1
|
|
||||||
fi
|
fi
|
||||||
- name: Compress image file
|
- name: Create empty QCOW2 disk
|
||||||
run: |
|
run: |
|
||||||
virt-sparsify --compress \
|
qemu-img create -f qcow2 ubuntu-vm/ubuntu.qcow2 10G
|
||||||
ubuntu-vm/ubuntu-24.04-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img \
|
- name: Run virt-install
|
||||||
ubuntu-vm/ubuntu-24.04-rke2-v${{ needs.semrel_dryrun.outputs.version }}-compacted.img
|
|
||||||
- name: Upload image file
|
|
||||||
run: |
|
run: |
|
||||||
REPO_TOKEN=$(curl -fsSL -X POST \
|
virt-install \
|
||||||
http://filebrowser.filebrowser.svc.cluster.local:80/api/login \
|
--name ubuntu-harvester \
|
||||||
-H "Content-Type: application/json" \
|
--ram 2048 \
|
||||||
-d '{"username": "admin", "password": "${{ secrets.REPO_PASSWORD }}"}' \
|
--vcpus 2 \
|
||||||
)
|
--disk path=ubuntu-vm/ubuntu.qcow2,size=10,format=qcow2 \
|
||||||
curl -fsSL -X POST \
|
--disk path=ubuntu-vm/seed.iso,device=cdrom \
|
||||||
http://filebrowser.filebrowser.svc.cluster.local:80/api/resources/rel/ubuntu-24.04-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img?override=true \
|
--cdrom ubuntu-vm/ubuntu-24.04.iso \
|
||||||
--header "X-Auth: $REPO_TOKEN" \
|
--os-variant ubuntu24.04 \
|
||||||
--upload-file "ubuntu-vm/ubuntu-24.04-rke2-v${{ needs.semrel_dryrun.outputs.version }}-compacted.img"
|
--graphics none \
|
||||||
|
--network network=default \
|
||||||
curl -ksS -X PUT "https://lab-hv-vip.bessems.lan/v1/harvesterhci.io.virtualmachineimages" \
|
--noautoconsole \
|
||||||
-H "Authorization: Bearer ${{ secrets.HV_TOKEN }}" \
|
--wait -1
|
||||||
-H "Content-Type: application/json" \
|
|
||||||
-d @- <<EOF
|
|
||||||
{
|
|
||||||
"type": "harvesterhci.io.virtualmachineimage",
|
|
||||||
"metadata": {
|
|
||||||
"namespace": "default"
|
|
||||||
},
|
|
||||||
"spec": {
|
|
||||||
"displayName": "ubuntu-24.04-rke2-v${{ needs.semrel_dryrun.outputs.version }}",
|
|
||||||
"sourceType": "download",
|
|
||||||
"url": "https://${{ secrets.REPO_USERNAME }}:${{ secrets.REPO_PASSWORD }}@sn.itch.fyi/Repository/rel/ubuntu-24.04-rke2-v${{ needs.semrel_dryrun.outputs.version }}.img"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
EOF
|
|
||||||
|
|
||||||
# semrel:
|
# semrel:
|
||||||
# name: Semantic Release
|
# name: Semantic Release
|
||||||
|
|||||||
@@ -6,22 +6,14 @@ snap:
|
|||||||
00: snap refresh --hold=forever
|
00: snap refresh --hold=forever
|
||||||
package_reboot_if_required: true
|
package_reboot_if_required: true
|
||||||
packages:
|
packages:
|
||||||
- cifs-utils
|
|
||||||
- linux-generic
|
|
||||||
- qemu-guest-agent
|
- qemu-guest-agent
|
||||||
- yq
|
- yq
|
||||||
|
- cifs-utils
|
||||||
|
|
||||||
runcmd:
|
runcmd:
|
||||||
- apt-get install -y linux-modules-extra-$(uname -r)
|
- apt-get install -y linux-modules-extra-$(uname -r)
|
||||||
- sed -i '/"${distro_id}:${distro_codename}-updates"/s|^//||' /etc/apt/apt.conf.d/50unattended-upgrades
|
|
||||||
- sysctl -w net.ipv6.conf.all.disable_ipv6=1
|
- sysctl -w net.ipv6.conf.all.disable_ipv6=1
|
||||||
- systemctl enable --now qemu-guest-agent.service
|
- systemctl enable --now qemu-guest-agent.service
|
||||||
- cloud-init clean --logs
|
|
||||||
- truncate -s 0 /etc/hostname /etc/machine-id
|
|
||||||
- rm -f /etc/ssh/ssh_host_* /var/lib/dbus/machine-id
|
|
||||||
- ln -s /etc/machine-id /var/lib/dbus/machine-id
|
|
||||||
- echo "TEMPLATE_GENERATION_SUCCESS" | tee /var/log/template-generation-success
|
|
||||||
- sync
|
|
||||||
|
|
||||||
disable_root: false
|
disable_root: false
|
||||||
users:
|
users:
|
||||||
@@ -33,8 +25,3 @@ users:
|
|||||||
- ${PUBLIC_SSHKEY}
|
- ${PUBLIC_SSHKEY}
|
||||||
ssh_authorized_keys:
|
ssh_authorized_keys:
|
||||||
- ${PUBLIC_SSHKEY}
|
- ${PUBLIC_SSHKEY}
|
||||||
|
|
||||||
power_state:
|
|
||||||
delay: now
|
|
||||||
mode: poweroff
|
|
||||||
condition: true
|
|
||||||
|
|||||||
Reference in New Issue
Block a user