Skip to content

Commit 1e83983

Browse files
committed
Final updates for 1.18.1 wizard changes
1 parent 66cc19d commit 1e83983

7 files changed

Lines changed: 61 additions & 65 deletions

File tree

.github/workflows/external_trigger.yml

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -29,8 +29,8 @@ jobs:
2929
echo "> [!NOTE]" >> $GITHUB_STEP_SUMMARY
3030
echo "> External trigger running off of master branch. To disable this trigger, add \`kasm_master\` into the Github organizational variable \`SKIP_EXTERNAL_TRIGGER\`." >> $GITHUB_STEP_SUMMARY
3131
printf "\n## Retrieving external version\n\n" >> $GITHUB_STEP_SUMMARY
32-
EXT_RELEASE=$(echo 1.18.1)
33-
echo "Type is \`custom_version_command\`" >> $GITHUB_STEP_SUMMARY
32+
EXT_RELEASE=$(curl -u "${{ secrets.CR_USER }}:${{ secrets.CR_PAT }}" -sX GET "https://api.github.com/repos/kasmtech/kasm-install-wizard/releases/latest" | jq -r '. | .tag_name')
33+
echo "Type is \`github_stable\`" >> $GITHUB_STEP_SUMMARY
3434
if grep -q "^kasm_master_${EXT_RELEASE}" <<< "${SKIP_EXTERNAL_TRIGGER}"; then
3535
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
3636
echo "> Github organizational variable \`SKIP_EXTERNAL_TRIGGER\` matches current external release; skipping trigger." >> $GITHUB_STEP_SUMMARY

Dockerfile

Lines changed: 17 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -17,20 +17,23 @@ ENV DEBIAN_FRONTEND=noninteractive
1717
#Add needed nvidia environment variables for https://github.com/NVIDIA/nvidia-docker
1818
ENV NVIDIA_DRIVER_CAPABILITIES="compute,graphics,video,utility"
1919

20-
# Container setup
2120
RUN \
2221
echo "**** install packages ****" && \
2322
install -m 0755 -d /etc/apt/keyrings && \
23+
# Docker
2424
curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc && \
25-
chmod a+r /etc/apt/keyrings/docker.asc && \
2625
printf "Types: deb\nURIs: https://download.docker.com/linux/ubuntu\nSuites: $(. /etc/os-release && echo ${UBUNTU_CODENAME:-$VERSION_CODENAME})\nComponents: stable\nArchitectures: $(dpkg --print-architecture)\nSigned-By: /etc/apt/keyrings/docker.asc" > /etc/apt/sources.list.d/docker.sources && \
27-
cat /etc/apt/sources.list.d/docker.sources && \
28-
curl -fsSL https://nvidia.github.io/libnvidia-container/gpgkey | gpg --dearmor -o /usr/share/keyrings/nvidia-container-toolkit-keyring.gpg \
26+
printf "Package: docker-ce docker-ce-cli docker-ce-rootless-extras\nPin: version 5:29.*\nPin-Priority: 1001" > /etc/apt/preferences.d/docker && \
27+
# Nvidia CTK
28+
curl -fsSL https://nvidia.github.io/libnvidia-container/gpgkey | gpg --dearmor -o /etc/apt/keyrings/nvidia-container-toolkit-keyring.gpg \
2929
&& curl -s -L https://nvidia.github.io/libnvidia-container/stable/deb/nvidia-container-toolkit.list | \
30-
sed 's#deb https://#deb [signed-by=/usr/share/keyrings/nvidia-container-toolkit-keyring.gpg] https://#g' | \
30+
sed 's#deb https://#deb [signed-by=/etc/apt/keyrings/nvidia-container-toolkit-keyring.gpg] https://#g' | \
3131
tee /etc/apt/sources.list.d/nvidia-container-toolkit.list && \
32-
curl -fsSL https://deb.nodesource.com/setup_20.x | bash - && \
33-
printf "Package: docker-ce docker-ce-cli docker-ce-rootless-extras\nPin: version 5:29.* \nPin-Priority: 1001" > /etc/apt/preferences.d/docker && \
32+
# NodeJS
33+
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg && \
34+
printf "Types: deb\nURIs: https://deb.nodesource.com/node_20.x\nSuites: nodistro\nComponents: main\nArchitectures: $(dpkg --print-architecture)\nSigned-By: /etc/apt/keyrings/nodesource.gpg" > /etc/apt/sources.list.d/nodesource.sources && \
35+
printf "Package: nodejs\nPin: origin deb.nodesource.com\nPin-Priority: 600" > /etc/apt/preferences.d/nodejs && \
36+
chmod a+r /etc/apt/keyrings/{*.gpg,*.asc}
3437
apt-get update && \
3538
apt-get install -y --no-install-recommends \
3639
btrfs-progs \
@@ -57,7 +60,7 @@ RUN \
5760
usermod -G dockremap dockremap && \
5861
echo 'dockremap:165536:65536' >> /etc/subuid && \
5962
echo 'dockremap:165536:65536' >> /etc/subgid && \
60-
curl -w "%{response_code}" -o \
63+
curl -o \
6164
/usr/local/bin/dind -L \
6265
https://raw.githubusercontent.com/moby/moby/master/hack/dind && \
6366
chmod +x /usr/local/bin/dind && \
@@ -71,8 +74,7 @@ RUN \
7174
echo "**** add wizard ****" && \
7275
curl -o \
7376
/tmp/wizard.tar.gz -L \
74-
# "https://github.com/kasmtech/kasm-install-wizard/archive/refs/tags/${KASM_VERSION}.tar.gz" && \
75-
"https://github.com/KodeStar/kasm-install-wizard/archive/refs/heads/feature/KASM-8264-registry-based-wizard-installer.tar.gz" && \
77+
"https://github.com/kasmtech/kasm-install-wizard/archive/refs/tags/${KASM_VERSION}.tar.gz" && \
7678
tar xf \
7779
/tmp/wizard.tar.gz -C \
7880
/wizard --strip-components=1 && \
@@ -85,9 +87,10 @@ RUN \
8587
tar xf \
8688
/tmp/kasm.tar.gz -C \
8789
/ && \
88-
# Don't check for open ports
90+
# Don't check for open ports during upgrades
8991
sed -i 's/-N -e -H/-N -B -e -H/g' /kasm_release/upgrade.sh && \
9092
echo "exit 0" > /kasm_release/install_dependencies.sh && \
93+
# Fix dependencies so containers start in the right order
9194
/kasm_release/bin/utils/yq_$(uname -m) -i \
9295
'.services.proxy.depends_on = {"kasm_manager":{"condition": "service_healthy"},"kasm_api":{"condition": "service_healthy"},"kasm_agent":{"condition": "service_started"},"kasm_guac":{"condition": "service_started"}}' \
9396
/kasm_release/docker/docker-compose-all.yaml && \
@@ -103,6 +106,9 @@ RUN \
103106
/kasm_release/bin/utils/yq_$(uname -m) -i \
104107
'.services.kasm_rdp_https_gateway.depends_on = {"proxy":{"condition": "service_started"}}' \
105108
/kasm_release/docker/docker-compose-all.yaml && \
109+
# Disable containerd snapshotter
110+
jq '. += {"features": {"containerd-snapshotter": false}}' /etc/docker/daemon.json > /tmp/daemon.json && mv /tmp/daemon.json /etc/docker/daemon.json && \
111+
# Add Kasm and db users
106112
useradd -u 70 kasm_db && \
107113
useradd kasm && \
108114
printf "Linuxserver.io version: ${VERSION}\nBuild-date: ${BUILD_DATE}" > /build_version && \

Dockerfile.aarch64

Lines changed: 21 additions & 37 deletions
Original file line numberDiff line numberDiff line change
@@ -17,18 +17,24 @@ ENV DEBIAN_FRONTEND=noninteractive
1717
#Add needed nvidia environment variables for https://github.com/NVIDIA/nvidia-docker
1818
ENV NVIDIA_DRIVER_CAPABILITIES="compute,graphics,video,utility"
1919

20-
# Container setup
2120
RUN \
2221
echo "**** install packages ****" && \
23-
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | apt-key add - && \
24-
echo "deb [arch=arm64] https://download.docker.com/linux/ubuntu noble stable" > \
25-
/etc/apt/sources.list.d/docker.list && \
26-
curl -fsSL https://nvidia.github.io/libnvidia-container/gpgkey | gpg --dearmor -o /usr/share/keyrings/nvidia-container-toolkit-keyring.gpg \
22+
install -m 0755 -d /etc/apt/keyrings && \
23+
# Docker
24+
curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc && \
25+
printf "Types: deb\nURIs: https://download.docker.com/linux/ubuntu\nSuites: $(. /etc/os-release && echo ${UBUNTU_CODENAME:-$VERSION_CODENAME})\nComponents: stable\nArchitectures: $(dpkg --print-architecture)\nSigned-By: /etc/apt/keyrings/docker.asc" > /etc/apt/sources.list.d/docker.sources && \
26+
printf "Package: docker-ce docker-ce-cli docker-ce-rootless-extras\nPin: version 5:29.*\nPin-Priority: 1001" > /etc/apt/preferences.d/docker && \
27+
# Nvidia CTK
28+
curl -fsSL https://nvidia.github.io/libnvidia-container/gpgkey | gpg --dearmor -o /etc/apt/keyrings/nvidia-container-toolkit-keyring.gpg \
2729
&& curl -s -L https://nvidia.github.io/libnvidia-container/stable/deb/nvidia-container-toolkit.list | \
28-
sed 's#deb https://#deb [signed-by=/usr/share/keyrings/nvidia-container-toolkit-keyring.gpg] https://#g' | \
30+
sed 's#deb https://#deb [signed-by=/etc/apt/keyrings/nvidia-container-toolkit-keyring.gpg] https://#g' | \
2931
tee /etc/apt/sources.list.d/nvidia-container-toolkit.list && \
30-
curl -fsSL https://deb.nodesource.com/setup_20.x | bash - && \
31-
printf "Package: docker-ce docker-ce-cli docker-ce-rootless-extras\nPin: version 5:29.* \nPin-Priority: 1001" > /etc/apt/preferences.d/docker && \
32+
# NodeJS
33+
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg && \
34+
printf "Types: deb\nURIs: https://deb.nodesource.com/node_20.x\nSuites: nodistro\nComponents: main\nArchitectures: $(dpkg --print-architecture)\nSigned-By: /etc/apt/keyrings/nodesource.gpg" > /etc/apt/sources.list.d/nodesource.sources && \
35+
printf "Package: nodejs\nPin: origin deb.nodesource.com\nPin-Priority: 600" > /etc/apt/preferences.d/nodejs && \
36+
chmod a+r /etc/apt/keyrings/{*.gpg,*.asc}
37+
apt-get update && \
3238
apt-get install -y --no-install-recommends \
3339
btrfs-progs \
3440
build-essential \
@@ -68,41 +74,23 @@ RUN \
6874
echo "**** add wizard ****" && \
6975
curl -o \
7076
/tmp/wizard.tar.gz -L \
71-
# "https://github.com/kasmtech/kasm-install-wizard/archive/refs/tags/${KASM_VERSION}.tar.gz" && \
72-
"https://github.com/kasmtech/kasm-install-wizard/archive/refs/tags/1.18.0.tar.gz" && \
77+
"https://github.com/kasmtech/kasm-install-wizard/archive/refs/tags/${KASM_VERSION}.tar.gz" && \
7378
tar xf \
7479
/tmp/wizard.tar.gz -C \
7580
/wizard --strip-components=1 && \
76-
# Enable rolling service images
77-
sed -i "/installFlags = \[.*/a \ installFlags.push('-O');" /wizard/index.js && \
7881
cd /wizard && \
7982
npm install && \
80-
echo "**** add image definitions ****" && \
81-
curl -o \
82-
/tmp/images.tar.gz -L \
83-
#"https://kasm-ci.s3.amazonaws.com/${KASM_VERSION}-images-combined.tar.gz" && \
84-
"https://kasm-ci.s3.amazonaws.com/1.18.0-images-combined.tar.gz" && \
85-
tar xf \
86-
/tmp/images.tar.gz -C \
87-
/ && \
8883
echo "**** add installer ****" && \
8984
curl -o \
9085
/tmp/kasm.tar.gz -L \
9186
"https://kasm-static-content.s3.amazonaws.com/kasm_release_${KASM_VERSION}.tar.gz" && \
9287
tar xf \
9388
/tmp/kasm.tar.gz -C \
9489
/ && \
95-
ALVERSION=$(cat /kasm_release/conf/database/seed_data/default_properties.yaml |awk '/alembic_version/ {print $2}') && \
96-
sed -i \
97-
'/alembic_version/s/.*/alembic_version: '${ALVERSION}'/' \
98-
/kasm_release/conf/database/seed_data/default_images_a* && \
99-
# Don't check for open ports
90+
# Don't check for open ports during upgrades
10091
sed -i 's/-N -e -H/-N -B -e -H/g' /kasm_release/upgrade.sh && \
10192
echo "exit 0" > /kasm_release/install_dependencies.sh && \
102-
# Add our customisations
103-
/kasm_release/bin/utils/yq_$(uname -m) -i \
104-
'.services.proxy.volumes += "/kasm_release/www/img/thumbnails:/srv/www/img/thumbnails"' \
105-
/kasm_release/docker/docker-compose-all.yaml && \
93+
# Fix dependencies so containers start in the right order
10694
/kasm_release/bin/utils/yq_$(uname -m) -i \
10795
'.services.proxy.depends_on = {"kasm_manager":{"condition": "service_healthy"},"kasm_api":{"condition": "service_healthy"},"kasm_agent":{"condition": "service_started"},"kasm_guac":{"condition": "service_started"}}' \
10896
/kasm_release/docker/docker-compose-all.yaml && \
@@ -116,15 +104,11 @@ RUN \
116104
'.services.kasm_api.healthcheck += {"start_period": "60s","start_interval": "30s"}' \
117105
/kasm_release/docker/docker-compose-all.yaml && \
118106
/kasm_release/bin/utils/yq_$(uname -m) -i \
119-
'.services.kasm_rdp_https_gateway.depends_on = {"proxy":{"condition": "service_started"},"rdp_gateway":{"condition": "service_healthy"}}' \
107+
'.services.kasm_rdp_https_gateway.depends_on = {"proxy":{"condition": "service_started"}}' \
120108
/kasm_release/docker/docker-compose-all.yaml && \
121-
echo "**** copy assets ****" && \
122-
cp \
123-
/kasm_release/www/img/thumbnails/*.png /kasm_release/www/img/thumbnails/*.svg \
124-
/wizard/public/img/thumbnails/ && \
125-
cp \
126-
/kasm_release/conf/database/seed_data/default_images_a* \
127-
/wizard/ && \
109+
# Disable containerd snapshotter
110+
jq '. += {"features": {"containerd-snapshotter": false}}' /etc/docker/daemon.json > /tmp/daemon.json && mv /tmp/daemon.json /etc/docker/daemon.json && \
111+
# Add Kasm and db users
128112
useradd -u 70 kasm_db && \
129113
useradd kasm && \
130114
printf "Linuxserver.io version: ${VERSION}\nBuild-date: ${BUILD_DATE}" > /build_version && \

Jenkinsfile

Lines changed: 18 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -145,16 +145,23 @@ pipeline {
145145
/* ########################
146146
External Release Tagging
147147
######################## */
148-
// If this is a custom command to determine version use that command
149-
stage("Set tag custom bash"){
150-
steps{
151-
script{
152-
env.EXT_RELEASE = sh(
153-
script: ''' echo 1.18.1 ''',
154-
returnStdout: true).trim()
155-
env.RELEASE_LINK = 'custom_command'
156-
}
157-
}
148+
// If this is a stable github release use the latest endpoint from github to determine the ext tag
149+
stage("Set ENV github_stable"){
150+
steps{
151+
script{
152+
env.EXT_RELEASE = sh(
153+
script: '''curl -H "Authorization: token ${GITHUB_TOKEN}" -s https://api.github.com/repos/${EXT_USER}/${EXT_REPO}/releases/latest | jq -r '. | .tag_name' ''',
154+
returnStdout: true).trim()
155+
}
156+
}
157+
}
158+
// If this is a stable or devel github release generate the link for the build message
159+
stage("Set ENV github_link"){
160+
steps{
161+
script{
162+
env.RELEASE_LINK = 'https://github.com/' + env.EXT_USER + '/' + env.EXT_REPO + '/releases/tag/' + env.EXT_RELEASE
163+
}
164+
}
158165
}
159166
// Sanitize the release tag and strip illegal docker or github characters
160167
stage("Sanitize tag"){
@@ -990,7 +997,7 @@ pipeline {
990997
"type": "commit",\
991998
"tagger": {"name": "LinuxServer-CI","email": "ci@linuxserver.io","date": "'${GITHUB_DATE}'"}}'
992999
echo "Pushing New release for Tag"
993-
echo "Updating to ${EXT_RELEASE_CLEAN}" > releasebody.json
1000+
curl -H "Authorization: token ${GITHUB_TOKEN}" -s https://api.github.com/repos/${EXT_USER}/${EXT_REPO}/releases/latest | jq -r '. |.body' > releasebody.json
9941001
jq -n \
9951002
--arg tag_name "$META_TAG" \
9961003
--arg target_commitish "master" \

README.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -317,7 +317,7 @@ Once registered you can define the dockerfile to use with `-f Dockerfile.aarch64
317317

318318
## Versions
319319

320-
* **22.03.26:** - Update for 1.18.1 release. Use rolling service images.
320+
* **16.04.26:** - Update for 1.18.1 release. Use rolling service images.
321321
* **13.11.25:** - Pin docker to v28 to avoid API deprecation issues.
322322
* **22.10.25:** - Update for 1.18.0 release.
323323
* **08.06.25:** - Deprecate develop branch.

jenkins-vars.yml

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2,8 +2,7 @@
22

33
# jenkins variables
44
project_name: docker-kasm
5-
external_type: na
6-
custom_version_command: "echo 1.18.1"
5+
external_type: github_stable
76
release_type: stable
87
release_tag: latest
98
ls_branch: master

readme-vars.yml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -130,7 +130,7 @@ init_diagram: |
130130
"kasm:latest" <- Base Images
131131
# changelog
132132
changelogs:
133-
- {date: "22.03.26:", desc: "Update for 1.18.1 release. Use rolling service images."}
133+
- {date: "16.04.26:", desc: "Update for 1.18.1 release. Use rolling service images. Bump docker to v29."}
134134
- {date: "13.11.25:", desc: "Pin docker to v28 to avoid API deprecation issues."}
135135
- {date: "22.10.25:", desc: "Update for 1.18.0 release."}
136136
- {date: "08.06.25:", desc: "Deprecate develop branch."}

0 commit comments

Comments
 (0)