-
Notifications
You must be signed in to change notification settings - Fork 1
75 lines (62 loc) · 2.94 KB
/
publish-gardenlinux.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
name: Publish GardenLinux Image
on:
push:
branches:
- main
jobs:
publish:
runs-on: ubuntu-latest
steps:
- name: Checkout Repository
uses: actions/checkout@v2
- name: Install yq (YAML Processor)
run: sudo snap install yq
- name: Setup ORAS
uses: oras-project/setup-oras@v1
- name: Read Config Files and Extract OS Version
id: read-config
run: |
GARDENLINUX_KVM_ARTIFACT_URL=$(yq e '.gardenlinux_kvm_artifact_url' .github/os_image_artifacts.yml)
GARDENLINUX_METAL_ARTIFACT_URL=$(yq e '.gardenlinux_metal_artifact_url' .github/os_image_artifacts.yml)
echo "GARDENLINUX_KVM_ARTIFACT_URL=$GARDENLINUX_KVM_ARTIFACT_URL" >> $GITHUB_ENV
echo "GARDENLINUX_METAL_ARTIFACT_URL=$GARDENLINUX_METAL_ARTIFACT_URL" >> $GITHUB_ENV
OS_VERSION=$(echo $GARDENLINUX_KVM_ARTIFACT_URL | cut -d '/' -f 8)
echo "OS_VERSION=$OS_VERSION" >> $GITHUB_ENV
ARTIFACT_FOLDER=$(basename $GARDENLINUX_KVM_ARTIFACT_URL | sed 's/.tar.xz//')
echo "ARTIFACT_FOLDER=$ARTIFACT_FOLDER" >> $GITHUB_ENV
- name: Download and Extract Gardenlinux KVM Artifact
run: |
curl -L ${{ env.GARDENLINUX_KVM_ARTIFACT_URL }} -o gardenlinux.tar.xz
tar -xf gardenlinux.tar.xz
- name: Download and Extract Gardenlinux Metal Artifact
run: |
# Download the outer tarball
curl -L ${{ env.GARDENLINUX_METAL_ARTIFACT_URL }} -o gardenlinux-metal.tar.xz
tar -xf gardenlinux-metal.tar.xz
# Extract the nested tarball to get the initrd, vmlinuz, and root.squashfs files
NESTED_TARBALL=$(find . -name "*pxe.tar.gz")
tar -xzf $NESTED_TARBALL
- name: Create Config JSON
run: |
echo "{\"commandLine\": \"\", \"os-release\": \"$OS_VERSION\"}" > config.json
- name: Login to GitHub Container Registry
uses: docker/login-action@v1
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Push Image with ORAS (Version Tag)
run: |
KVM_RAW_FILE=$(ls ${{ env.ARTIFACT_FOLDER }}/*.raw)
METAL_SQUASHFS_FILE=root.squashfs
METAL_INITRD_FILE=initrd
METAL_VMLINUZ_FILE=vmlinuz
oras push ghcr.io/ironcore-dev/os-images/gardenlinux:$OS_VERSION \
$KVM_RAW_FILE:application/vnd.ironcore.image.rootfs.v1alpha1.rootfs \
$METAL_SQUASHFS_FILE:application/vnd.ironcore.image.squashfs.v1alpha1.squashfs \
$METAL_INITRD_FILE:application/vnd.ironcore.image.initramfs.v1alpha1.initramfs \
$METAL_VMLINUZ_FILE:application/vnd.ironcore.image.vmlinuz.v1alpha1.vmlinuz \
--config config.json:application/vnd.ironcore.image.config.v1alpha1+json
- name: Push Image with ORAS (Latest Tag)
run: |
oras tag ghcr.io/ironcore-dev/os-images/gardenlinux:$OS_VERSION latest