|
|
@ -118,12 +118,11 @@ pipeline {
|
|
|
|
script: '''echo ${EXT_RELEASE} | sed 's/[~,%@+;:/]//g' ''',
|
|
|
|
script: '''echo ${EXT_RELEASE} | sed 's/[~,%@+;:/]//g' ''',
|
|
|
|
returnStdout: true).trim()
|
|
|
|
returnStdout: true).trim()
|
|
|
|
|
|
|
|
|
|
|
|
env.SEMVER = (new Date()).format('YYYY.MM.dd')
|
|
|
|
def semver = env.EXT_RELEASE_CLEAN =~ /(\d+)\.(\d+)\.(\d+)/
|
|
|
|
def semver = env.EXT_RELEASE_CLEAN =~ /(\d+)\.(\d+)\.(\d+)$/
|
|
|
|
|
|
|
|
if (semver.find()) {
|
|
|
|
if (semver.find()) {
|
|
|
|
env.SEMVER = "${semver[0][1]}.${semver[0][2]}.${semver[0][3]}"
|
|
|
|
env.SEMVER = "${semver[0][1]}.${semver[0][2]}.${semver[0][3]}"
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
semver = env.EXT_RELEASE_CLEAN =~ /(\d+)\.(\d+)(?:\.(\d+))?(.*)$/
|
|
|
|
semver = env.EXT_RELEASE_CLEAN =~ /(\d+)\.(\d+)(?:\.(\d+))?(.*)/
|
|
|
|
if (semver.find()) {
|
|
|
|
if (semver.find()) {
|
|
|
|
if (semver[0][3]) {
|
|
|
|
if (semver[0][3]) {
|
|
|
|
env.SEMVER = "${semver[0][1]}.${semver[0][2]}.${semver[0][3]}"
|
|
|
|
env.SEMVER = "${semver[0][1]}.${semver[0][2]}.${semver[0][3]}"
|
|
|
@ -133,7 +132,15 @@ pipeline {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (env.SEMVER != null) {
|
|
|
|
|
|
|
|
if (BRANCH_NAME != "master" && BRANCH_NAME != "main") {
|
|
|
|
|
|
|
|
env.SEMVER = "${env.SEMVER}-${BRANCH_NAME}"
|
|
|
|
|
|
|
|
}
|
|
|
|
println("SEMVER: ${env.SEMVER}")
|
|
|
|
println("SEMVER: ${env.SEMVER}")
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
println("No SEMVER detected")
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -402,10 +409,10 @@ pipeline {
|
|
|
|
steps{
|
|
|
|
steps{
|
|
|
|
sh '''#! /bin/bash
|
|
|
|
sh '''#! /bin/bash
|
|
|
|
set -e
|
|
|
|
set -e
|
|
|
|
PACKAGE_UUID=$(curl -X GET -H "Authorization: Bearer ${SCARF_TOKEN}" https://scarf.sh/api/v1/packages | jq -r '.[] | select(.name=="linuxserver/ubooquity") | .uuid')
|
|
|
|
PACKAGE_UUID=$(curl -X GET -H "Authorization: Bearer ${SCARF_TOKEN}" https://scarf.sh/api/v1/organizations/linuxserver-ci/packages | jq -r '.[] | select(.name=="linuxserver/ubooquity") | .uuid')
|
|
|
|
if [ -z "${PACKAGE_UUID}" ]; then
|
|
|
|
if [ -z "${PACKAGE_UUID}" ]; then
|
|
|
|
echo "Adding package to Scarf.sh"
|
|
|
|
echo "Adding package to Scarf.sh"
|
|
|
|
PACKAGE_UUID=$(curl -sX POST https://scarf.sh/api/v1/packages \
|
|
|
|
curl -sX POST https://scarf.sh/api/v1/organizations/linuxserver-ci/packages \
|
|
|
|
-H "Authorization: Bearer ${SCARF_TOKEN}" \
|
|
|
|
-H "Authorization: Bearer ${SCARF_TOKEN}" \
|
|
|
|
-H "Content-Type: application/json" \
|
|
|
|
-H "Content-Type: application/json" \
|
|
|
|
-d '{"name":"linuxserver/ubooquity",\
|
|
|
|
-d '{"name":"linuxserver/ubooquity",\
|
|
|
@ -413,22 +420,10 @@ pipeline {
|
|
|
|
"libraryType":"docker",\
|
|
|
|
"libraryType":"docker",\
|
|
|
|
"website":"https://github.com/linuxserver/docker-ubooquity",\
|
|
|
|
"website":"https://github.com/linuxserver/docker-ubooquity",\
|
|
|
|
"backendUrl":"https://ghcr.io/linuxserver/ubooquity",\
|
|
|
|
"backendUrl":"https://ghcr.io/linuxserver/ubooquity",\
|
|
|
|
"publicUrl":"https://lscr.io/linuxserver/ubooquity"}' \
|
|
|
|
"publicUrl":"https://lscr.io/linuxserver/ubooquity"}' || :
|
|
|
|
| jq -r .uuid)
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
echo "Package already exists on Scarf.sh"
|
|
|
|
echo "Package already exists on Scarf.sh"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
echo "Setting permissions on Scarf.sh for package ${PACKAGE_UUID}"
|
|
|
|
|
|
|
|
curl -X POST https://scarf.sh/api/v1/packages/${PACKAGE_UUID}/permissions \
|
|
|
|
|
|
|
|
-H "Authorization: Bearer ${SCARF_TOKEN}" \
|
|
|
|
|
|
|
|
-H "Content-Type: application/json" \
|
|
|
|
|
|
|
|
-d '[{"userQuery":"Spad","permissionLevel":"admin"},\
|
|
|
|
|
|
|
|
{"userQuery":"roxedus","permissionLevel":"admin"},\
|
|
|
|
|
|
|
|
{"userQuery":"nemchik","permissionLevel":"admin"},\
|
|
|
|
|
|
|
|
{"userQuery":"driz","permissionLevel":"admin"},\
|
|
|
|
|
|
|
|
{"userQuery":"aptalca","permissionLevel":"admin"},\
|
|
|
|
|
|
|
|
{"userQuery":"saarg","permissionLevel":"admin"},\
|
|
|
|
|
|
|
|
{"userQuery":"Stark","permissionLevel":"admin"}]'
|
|
|
|
|
|
|
|
'''
|
|
|
|
'''
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -752,11 +747,15 @@ pipeline {
|
|
|
|
docker tag ${IMAGE}:${META_TAG} ${PUSHIMAGE}:${META_TAG}
|
|
|
|
docker tag ${IMAGE}:${META_TAG} ${PUSHIMAGE}:${META_TAG}
|
|
|
|
docker tag ${PUSHIMAGE}:${META_TAG} ${PUSHIMAGE}:latest
|
|
|
|
docker tag ${PUSHIMAGE}:${META_TAG} ${PUSHIMAGE}:latest
|
|
|
|
docker tag ${PUSHIMAGE}:${META_TAG} ${PUSHIMAGE}:${EXT_RELEASE_TAG}
|
|
|
|
docker tag ${PUSHIMAGE}:${META_TAG} ${PUSHIMAGE}:${EXT_RELEASE_TAG}
|
|
|
|
|
|
|
|
if [ -n "${SEMVER}" ]; then
|
|
|
|
docker tag ${PUSHIMAGE}:${META_TAG} ${PUSHIMAGE}:${SEMVER}
|
|
|
|
docker tag ${PUSHIMAGE}:${META_TAG} ${PUSHIMAGE}:${SEMVER}
|
|
|
|
|
|
|
|
fi
|
|
|
|
docker push ${PUSHIMAGE}:latest
|
|
|
|
docker push ${PUSHIMAGE}:latest
|
|
|
|
docker push ${PUSHIMAGE}:${META_TAG}
|
|
|
|
docker push ${PUSHIMAGE}:${META_TAG}
|
|
|
|
docker push ${PUSHIMAGE}:${EXT_RELEASE_TAG}
|
|
|
|
docker push ${PUSHIMAGE}:${EXT_RELEASE_TAG}
|
|
|
|
|
|
|
|
if [ -n "${SEMVER}" ]; then
|
|
|
|
docker push ${PUSHIMAGE}:${SEMVER}
|
|
|
|
docker push ${PUSHIMAGE}:${SEMVER}
|
|
|
|
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
done
|
|
|
|
'''
|
|
|
|
'''
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -765,8 +764,10 @@ pipeline {
|
|
|
|
docker rmi \
|
|
|
|
docker rmi \
|
|
|
|
${DELETEIMAGE}:${META_TAG} \
|
|
|
|
${DELETEIMAGE}:${META_TAG} \
|
|
|
|
${DELETEIMAGE}:${EXT_RELEASE_TAG} \
|
|
|
|
${DELETEIMAGE}:${EXT_RELEASE_TAG} \
|
|
|
|
${DELETEIMAGE}:latest \
|
|
|
|
${DELETEIMAGE}:latest || :
|
|
|
|
${DELETEIMAGE}:${SEMVER} || :
|
|
|
|
if [ -n "${SEMVER}" ]; then
|
|
|
|
|
|
|
|
docker rmi ${DELETEIMAGE}:${SEMVER} || :
|
|
|
|
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
done
|
|
|
|
'''
|
|
|
|
'''
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -816,9 +817,11 @@ pipeline {
|
|
|
|
docker tag ${MANIFESTIMAGE}:amd64-${META_TAG} ${MANIFESTIMAGE}:amd64-${EXT_RELEASE_TAG}
|
|
|
|
docker tag ${MANIFESTIMAGE}:amd64-${META_TAG} ${MANIFESTIMAGE}:amd64-${EXT_RELEASE_TAG}
|
|
|
|
docker tag ${MANIFESTIMAGE}:arm32v7-${META_TAG} ${MANIFESTIMAGE}:arm32v7-${EXT_RELEASE_TAG}
|
|
|
|
docker tag ${MANIFESTIMAGE}:arm32v7-${META_TAG} ${MANIFESTIMAGE}:arm32v7-${EXT_RELEASE_TAG}
|
|
|
|
docker tag ${MANIFESTIMAGE}:arm64v8-${META_TAG} ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG}
|
|
|
|
docker tag ${MANIFESTIMAGE}:arm64v8-${META_TAG} ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG}
|
|
|
|
|
|
|
|
if [ -n "${SEMVER}" ]; then
|
|
|
|
docker tag ${MANIFESTIMAGE}:amd64-${META_TAG} ${MANIFESTIMAGE}:amd64-${SEMVER}
|
|
|
|
docker tag ${MANIFESTIMAGE}:amd64-${META_TAG} ${MANIFESTIMAGE}:amd64-${SEMVER}
|
|
|
|
docker tag ${MANIFESTIMAGE}:arm32v7-${META_TAG} ${MANIFESTIMAGE}:arm32v7-${SEMVER}
|
|
|
|
docker tag ${MANIFESTIMAGE}:arm32v7-${META_TAG} ${MANIFESTIMAGE}:arm32v7-${SEMVER}
|
|
|
|
docker tag ${MANIFESTIMAGE}:arm64v8-${META_TAG} ${MANIFESTIMAGE}:arm64v8-${SEMVER}
|
|
|
|
docker tag ${MANIFESTIMAGE}:arm64v8-${META_TAG} ${MANIFESTIMAGE}:arm64v8-${SEMVER}
|
|
|
|
|
|
|
|
fi
|
|
|
|
docker push ${MANIFESTIMAGE}:amd64-${META_TAG}
|
|
|
|
docker push ${MANIFESTIMAGE}:amd64-${META_TAG}
|
|
|
|
docker push ${MANIFESTIMAGE}:arm32v7-${META_TAG}
|
|
|
|
docker push ${MANIFESTIMAGE}:arm32v7-${META_TAG}
|
|
|
|
docker push ${MANIFESTIMAGE}:arm64v8-${META_TAG}
|
|
|
|
docker push ${MANIFESTIMAGE}:arm64v8-${META_TAG}
|
|
|
@ -828,9 +831,11 @@ pipeline {
|
|
|
|
docker push ${MANIFESTIMAGE}:amd64-${EXT_RELEASE_TAG}
|
|
|
|
docker push ${MANIFESTIMAGE}:amd64-${EXT_RELEASE_TAG}
|
|
|
|
docker push ${MANIFESTIMAGE}:arm32v7-${EXT_RELEASE_TAG}
|
|
|
|
docker push ${MANIFESTIMAGE}:arm32v7-${EXT_RELEASE_TAG}
|
|
|
|
docker push ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG}
|
|
|
|
docker push ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG}
|
|
|
|
|
|
|
|
if [ -n "${SEMVER}" ]; then
|
|
|
|
docker push ${MANIFESTIMAGE}:amd64-${SEMVER}
|
|
|
|
docker push ${MANIFESTIMAGE}:amd64-${SEMVER}
|
|
|
|
docker push ${MANIFESTIMAGE}:arm32v7-${SEMVER}
|
|
|
|
docker push ${MANIFESTIMAGE}:arm32v7-${SEMVER}
|
|
|
|
docker push ${MANIFESTIMAGE}:arm64v8-${SEMVER}
|
|
|
|
docker push ${MANIFESTIMAGE}:arm64v8-${SEMVER}
|
|
|
|
|
|
|
|
fi
|
|
|
|
docker manifest push --purge ${MANIFESTIMAGE}:latest || :
|
|
|
|
docker manifest push --purge ${MANIFESTIMAGE}:latest || :
|
|
|
|
docker manifest create ${MANIFESTIMAGE}:latest ${MANIFESTIMAGE}:amd64-latest ${MANIFESTIMAGE}:arm32v7-latest ${MANIFESTIMAGE}:arm64v8-latest
|
|
|
|
docker manifest create ${MANIFESTIMAGE}:latest ${MANIFESTIMAGE}:amd64-latest ${MANIFESTIMAGE}:arm32v7-latest ${MANIFESTIMAGE}:arm64v8-latest
|
|
|
|
docker manifest annotate ${MANIFESTIMAGE}:latest ${MANIFESTIMAGE}:arm32v7-latest --os linux --arch arm
|
|
|
|
docker manifest annotate ${MANIFESTIMAGE}:latest ${MANIFESTIMAGE}:arm32v7-latest --os linux --arch arm
|
|
|
@ -843,14 +848,18 @@ pipeline {
|
|
|
|
docker manifest create ${MANIFESTIMAGE}:${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:amd64-${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm32v7-${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG}
|
|
|
|
docker manifest create ${MANIFESTIMAGE}:${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:amd64-${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm32v7-${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG}
|
|
|
|
docker manifest annotate ${MANIFESTIMAGE}:${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm32v7-${EXT_RELEASE_TAG} --os linux --arch arm
|
|
|
|
docker manifest annotate ${MANIFESTIMAGE}:${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm32v7-${EXT_RELEASE_TAG} --os linux --arch arm
|
|
|
|
docker manifest annotate ${MANIFESTIMAGE}:${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG} --os linux --arch arm64 --variant v8
|
|
|
|
docker manifest annotate ${MANIFESTIMAGE}:${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG} --os linux --arch arm64 --variant v8
|
|
|
|
|
|
|
|
if [ -n "${SEMVER}" ]; then
|
|
|
|
docker manifest push --purge ${MANIFESTIMAGE}:${SEMVER} || :
|
|
|
|
docker manifest push --purge ${MANIFESTIMAGE}:${SEMVER} || :
|
|
|
|
docker manifest create ${MANIFESTIMAGE}:${SEMVER} ${MANIFESTIMAGE}:amd64-${SEMVER} ${MANIFESTIMAGE}:arm32v7-${SEMVER} ${MANIFESTIMAGE}:arm64v8-${SEMVER}
|
|
|
|
docker manifest create ${MANIFESTIMAGE}:${SEMVER} ${MANIFESTIMAGE}:amd64-${SEMVER} ${MANIFESTIMAGE}:arm32v7-${SEMVER} ${MANIFESTIMAGE}:arm64v8-${SEMVER}
|
|
|
|
docker manifest annotate ${MANIFESTIMAGE}:${SEMVER} ${MANIFESTIMAGE}:arm32v7-${SEMVER} --os linux --arch arm
|
|
|
|
docker manifest annotate ${MANIFESTIMAGE}:${SEMVER} ${MANIFESTIMAGE}:arm32v7-${SEMVER} --os linux --arch arm
|
|
|
|
docker manifest annotate ${MANIFESTIMAGE}:${SEMVER} ${MANIFESTIMAGE}:arm64v8-${SEMVER} --os linux --arch arm64 --variant v8
|
|
|
|
docker manifest annotate ${MANIFESTIMAGE}:${SEMVER} ${MANIFESTIMAGE}:arm64v8-${SEMVER} --os linux --arch arm64 --variant v8
|
|
|
|
|
|
|
|
fi
|
|
|
|
docker manifest push --purge ${MANIFESTIMAGE}:latest
|
|
|
|
docker manifest push --purge ${MANIFESTIMAGE}:latest
|
|
|
|
docker manifest push --purge ${MANIFESTIMAGE}:${META_TAG}
|
|
|
|
docker manifest push --purge ${MANIFESTIMAGE}:${META_TAG}
|
|
|
|
docker manifest push --purge ${MANIFESTIMAGE}:${EXT_RELEASE_TAG}
|
|
|
|
docker manifest push --purge ${MANIFESTIMAGE}:${EXT_RELEASE_TAG}
|
|
|
|
|
|
|
|
if [ -n "${SEMVER}" ]; then
|
|
|
|
docker manifest push --purge ${MANIFESTIMAGE}:${SEMVER}
|
|
|
|
docker manifest push --purge ${MANIFESTIMAGE}:${SEMVER}
|
|
|
|
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
done
|
|
|
|
'''
|
|
|
|
'''
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -860,15 +869,18 @@ pipeline {
|
|
|
|
${DELETEIMAGE}:amd64-${META_TAG} \
|
|
|
|
${DELETEIMAGE}:amd64-${META_TAG} \
|
|
|
|
${DELETEIMAGE}:amd64-latest \
|
|
|
|
${DELETEIMAGE}:amd64-latest \
|
|
|
|
${DELETEIMAGE}:amd64-${EXT_RELEASE_TAG} \
|
|
|
|
${DELETEIMAGE}:amd64-${EXT_RELEASE_TAG} \
|
|
|
|
${DELETEIMAGE}:amd64-${SEMVER} \
|
|
|
|
|
|
|
|
${DELETEIMAGE}:arm32v7-${META_TAG} \
|
|
|
|
${DELETEIMAGE}:arm32v7-${META_TAG} \
|
|
|
|
${DELETEIMAGE}:arm32v7-latest \
|
|
|
|
${DELETEIMAGE}:arm32v7-latest \
|
|
|
|
${DELETEIMAGE}:arm32v7-${EXT_RELEASE_TAG} \
|
|
|
|
${DELETEIMAGE}:arm32v7-${EXT_RELEASE_TAG} \
|
|
|
|
${DELETEIMAGE}:arm32v7-${SEMVER} \
|
|
|
|
|
|
|
|
${DELETEIMAGE}:arm64v8-${META_TAG} \
|
|
|
|
${DELETEIMAGE}:arm64v8-${META_TAG} \
|
|
|
|
${DELETEIMAGE}:arm64v8-latest \
|
|
|
|
${DELETEIMAGE}:arm64v8-latest \
|
|
|
|
${DELETEIMAGE}:arm64v8-${EXT_RELEASE_TAG} \
|
|
|
|
${DELETEIMAGE}:arm64v8-${EXT_RELEASE_TAG} || :
|
|
|
|
|
|
|
|
if [ -n "${SEMVER}" ]; then
|
|
|
|
|
|
|
|
docker rmi \
|
|
|
|
|
|
|
|
${DELETEIMAGE}:amd64-${SEMVER} \
|
|
|
|
|
|
|
|
${DELETEIMAGE}:arm32v7-${SEMVER} \
|
|
|
|
${DELETEIMAGE}:arm64v8-${SEMVER} || :
|
|
|
|
${DELETEIMAGE}:arm64v8-${SEMVER} || :
|
|
|
|
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
done
|
|
|
|
docker rmi \
|
|
|
|
docker rmi \
|
|
|
|
ghcr.io/linuxserver/lsiodev-buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER} \
|
|
|
|
ghcr.io/linuxserver/lsiodev-buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER} \
|
|
|
|