Skip to content

Commit 52bfb40

Browse files
Bot Updating Templated Files
1 parent 5454f57 commit 52bfb40

File tree

1 file changed

+41
-3
lines changed

1 file changed

+41
-3
lines changed

Jenkinsfile

Lines changed: 41 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -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

Comments
 (0)