@@ -93,7 +93,7 @@ pipeline {
9393 env. CODE_URL = ' https://github.com/' + env. LS_USER + ' /' + env. LS_REPO + ' /commit/' + env. GIT_COMMIT
9494 env. DOCKERHUB_LINK = ' https://hub.docker.com/r/' + env. DOCKERHUB_IMAGE + ' /tags/'
9595 env. PULL_REQUEST = env. CHANGE_ID
96- env. TEMPLATED_FILES = ' Jenkinsfile README.md LICENSE .editorconfig ./.github/CONTRIBUTING.md ./.github/FUNDING.yml ./.github/ISSUE_TEMPLATE/config.yml ./.github/ISSUE_TEMPLATE/issue.bug.yml ./.github/ISSUE_TEMPLATE/issue.feature.yml ./.github/PULL_REQUEST_TEMPLATE.md ./.github/workflows/external_trigger_scheduler.yml ./.github/workflows/greetings.yml ./.github/workflows/package_trigger_scheduler.yml ./.github/workflows/call_issue_pr_tracker.yml ./.github/workflows/call_issues_cron.yml ./.github/workflows/permissions.yml ./.github/workflows/external_trigger.yml '
96+ env. TEMPLATED_FILES = ' Jenkinsfile README.md LICENSE .editorconfig ./.github/CONTRIBUTING.md ./.github/FUNDING.yml ./.github/ISSUE_TEMPLATE/config.yml ./.github/ISSUE_TEMPLATE/issue.bug.yml ./.github/ISSUE_TEMPLATE/issue.feature.yml ./.github/PULL_REQUEST_TEMPLATE.md ./root/etc/s6-overlay/s6-rc.d/init-deprecate/run ./root/etc/s6-overlay/s6-rc.d/init-deprecate/up ./root/etc/s6-overlay/s6-rc.d/init-deprecate/type ./root/etc/s6-overlay/s6-rc.d/init-deprecate/dependencies.d/init-config-end ./root/etc/s6-overlay/s6-rc.d/init-services/dependencies.d/init-deprecate ./root/etc/s6-overlay/s6-rc.d/user/contents.d/init-deprecate '
9797 if ( env. SYFT_IMAGE_TAG == null ) {
9898 env. SYFT_IMAGE_TAG = ' latest'
9999 }
@@ -332,6 +332,7 @@ pipeline {
332332 fi
333333 echo "Starting Stage 2 - Delete old templates"
334334 OLD_TEMPLATES=".github/ISSUE_TEMPLATE.md .github/ISSUE_TEMPLATE/issue.bug.md .github/ISSUE_TEMPLATE/issue.feature.md .github/workflows/call_invalid_helper.yml .github/workflows/stale.yml .github/workflows/package_trigger.yml"
335+ OLD_TEMPLATES="${OLD_TEMPLATES} $(echo .github/workflows/{external_trigger,external_trigger_scheduler,package_trigger_scheduler,call_issue_pr_tracker,call_issues_cron}.yml)"
335336 for i in ${OLD_TEMPLATES}; do
336337 if [[ -f "${i}" ]]; then
337338 TEMPLATES_TO_DELETE="${i} ${TEMPLATES_TO_DELETE}"
@@ -367,6 +368,10 @@ pipeline {
367368 cd ${TEMPDIR}/docker-${CONTAINER_NAME}
368369 mkdir -p ${TEMPDIR}/repo/${LS_REPO}/.github/workflows
369370 mkdir -p ${TEMPDIR}/repo/${LS_REPO}/.github/ISSUE_TEMPLATE
371+ mkdir -p \
372+ ${TEMPDIR}/repo/${LS_REPO}/root/etc/s6-overlay/s6-rc.d/init-deprecate/dependencies.d \
373+ ${TEMPDIR}/repo/${LS_REPO}/root/etc/s6-overlay/s6-rc.d/init-services/dependencies.d \
374+ ${TEMPDIR}/repo/${LS_REPO}/root/etc/s6-overlay/s6-rc.d/user/contents.d
370375 cp --parents ${TEMPLATED_FILES} ${TEMPDIR}/repo/${LS_REPO}/ || :
371376 cp --parents readme-vars.yml ${TEMPDIR}/repo/${LS_REPO}/ || :
372377 cd ${TEMPDIR}/repo/${LS_REPO}/
@@ -396,6 +401,19 @@ pipeline {
396401 git add docs/images/docker-${CONTAINER_NAME}.md
397402 echo "Updating docs repo"
398403 git commit -m 'Bot Updating Documentation'
404+ git mv docs/images/docker-${CONTAINER_NAME}.md docs/deprecated_images/docker-${CONTAINER_NAME}.md || :
405+ if ! command -v yq || ! yq --help | grep -q 'mikefarah'; then
406+ YQ_DL_VERSION=$(curl -fsX GET "https://api.github.com/repos/mikefarah/yq/releases/latest" | jq -r '. | .tag_name')
407+ echo "No yq found, retrieving from upstream release version ${YQ_DL_VERSION}"
408+ curl -fo /usr/local/bin/yq -L "https://github.com/mikefarah/yq/releases/download/${YQ_DL_VERSION}/yq_linux_amd64"
409+ chmod +x /usr/local/bin/yq
410+ fi
411+ if ! yq -e '.plugins.[].redirects.redirect_maps.[] | select(. == "deprecated_images/docker-" + env(CONTAINER_NAME) + ".md")' mkdocs.yml >/dev/null 2>&1; then
412+ echo "Updating mkdocs.yml with deprecation info"
413+ yq -i '(.plugins.[] | select(.redirects)).redirects.redirect_maps |= . + {"images/docker-" + env(CONTAINER_NAME) + ".md" : "deprecated_images/docker-" + env(CONTAINER_NAME) + ".md"}' mkdocs.yml
414+ git add mkdocs.yml
415+ fi
416+ git commit -m 'Bot Moving Deprecated Documentation' || :
399417 git pull https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/linuxserver/docker-documentation.git ${GH_DOCS_DEFAULT_BRANCH} --rebase
400418 git push https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/linuxserver/docker-documentation.git ${GH_DOCS_DEFAULT_BRANCH} || \
401419 (MAXWAIT="10" && echo "Push to docs failed, trying again in ${MAXWAIT} seconds" && \
@@ -870,6 +888,7 @@ pipeline {
870888 docker buildx imagetools create --prefer-index=false -t ${PUSHIMAGE}:${SEMVER} ${CACHEIMAGE}:amd64-${COMMIT_SHA}-${BUILD_NUMBER} || \
871889 { if [[ "${PUSHIMAGE}" != "${QUAYIMAGE}" ]]; then exit 1; fi; }
872890 fi
891+ docker buildx imagetools create -t ${PUSHIMAGE}:bullseye ghcr.io/linuxserver/jenkins-builder:empty || true
873892 done
874893 '''
875894 }
@@ -905,8 +924,7 @@ pipeline {
905924 fi
906925 done
907926 for MANIFESTIMAGE in "${IMAGE}" "${GITLABIMAGE}" "${GITHUBIMAGE}" "${QUAYIMAGE}"; do
908- docker buildx imagetools create -t ${MANIFESTIMAGE}:bullseye ${MANIFESTIMAGE}:amd64-bullseye ${MANIFESTIMAGE}:arm64v8-bullseye || \
909- { if [[ "${MANIFESTIMAGE}" != "${QUAYIMAGE}" ]]; then exit 1; fi; }
927+ docker buildx imagetools create -t ${MANIFESTIMAGE}:bullseye -t ${MANIFESTIMAGE}:amd64-bullseye -t ${MANIFESTIMAGE}:arm64v8-bullseye ghcr.io/linuxserver/jenkins-builder:empty || true
910928 docker buildx imagetools create -t ${MANIFESTIMAGE}:${META_TAG} ${MANIFESTIMAGE}:amd64-${META_TAG} ${MANIFESTIMAGE}:arm64v8-${META_TAG} || \
911929 { if [[ "${MANIFESTIMAGE}" != "${QUAYIMAGE}" ]]; then exit 1; fi; }
912930 docker buildx imagetools create -t ${MANIFESTIMAGE}:${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:amd64-${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG} || \
@@ -1081,6 +1099,26 @@ EOF
10811099
10821100 }
10831101 }
1102+ stage(' Deprecate/Disable Future Builds' ) {
1103+ when {
1104+ branch " bullseye"
1105+ environment name : ' CHANGE_ID' , value : ' '
1106+ environment name : ' EXIT_STATUS' , value : ' '
1107+ }
1108+ steps {
1109+ sh ''' #! /bin/bash
1110+ TEMPDIR=$(mktemp -d)
1111+ mkdir -p ${TEMPDIR}/repo
1112+ git clone https://github.com/${LS_USER}/${LS_REPO}.git ${TEMPDIR}/repo/${LS_REPO}
1113+ cd ${TEMPDIR}/repo/${LS_REPO}
1114+ git checkout -f bullseye
1115+ git rm Jenkinsfile
1116+ git commit -m 'Disabling future builds'
1117+ git pull https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/${LS_USER}/${LS_REPO}.git bullseye
1118+ git push https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/${LS_USER}/${LS_REPO}.git bullseye
1119+ rm -Rf ${TEMPDIR}'''
1120+ }
1121+ }
10841122 }
10851123 /* ######################
10861124 Send status to Discord
0 commit comments