@@ -241,22 +241,67 @@ pipeline {
241241 TEMPDIR=$(mktemp -d)
242242 docker pull ghcr.io/linuxserver/jenkins-builder:latest
243243 docker run --rm -e CONTAINER_NAME=${CONTAINER_NAME} -e GITHUB_BRANCH=master -v ${TEMPDIR}:/ansible/jenkins ghcr.io/linuxserver/jenkins-builder:latest
244+ # Stage 1 - Jenkinsfile update
245+ if [[ "$(md5sum Jenkinsfile | awk '{ print $1 }')" != "$(md5sum ${TEMPDIR}/docker-${CONTAINER_NAME}/Jenkinsfile | awk '{ print $1 }')" ]]; then
246+ mkdir -p ${TEMPDIR}/repo
247+ git clone https://github.com/${LS_USER}/${LS_REPO}.git ${TEMPDIR}/repo/${LS_REPO}
248+ cd ${TEMPDIR}/repo/${LS_REPO}
249+ git checkout -f master
250+ cp ${TEMPDIR}/docker-${CONTAINER_NAME}/Jenkinsfile ${TEMPDIR}/repo/${LS_REPO}/
251+ git add Jenkinsfile
252+ git commit -m 'Bot Updating Templated Files'
253+ git push https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/${LS_USER}/${LS_REPO}.git --all
254+ echo "true" > /tmp/${COMMIT_SHA}-${BUILD_NUMBER}
255+ echo "Updating Jenkinsfile"
256+ rm -Rf ${TEMPDIR}
257+ exit 0
258+ else
259+ echo "Jenkinsfile is up to date."
260+ fi
261+ # Stage 2 - Delete old templates
262+ OLD_TEMPLATES=".github/ISSUE_TEMPLATE.md"
263+ for i in ${OLD_TEMPLATES}; do
264+ if [[ -f "${i}" ]]; then
265+ TEMPLATES_TO_DELETE="${i} ${TEMPLATES_TO_DELETE}"
266+ fi
267+ done
268+ if [[ -n "${TEMPLATES_TO_DELETE}" ]]; then
269+ mkdir -p ${TEMPDIR}/repo
270+ git clone https://github.com/${LS_USER}/${LS_REPO}.git ${TEMPDIR}/repo/${LS_REPO}
271+ cd ${TEMPDIR}/repo/${LS_REPO}
272+ git checkout -f master
273+ cd ${TEMPDIR}/docker-${CONTAINER_NAME}
274+ for i in ${TEMPLATES_TO_DELETE}; do
275+ git rm "${i}"
276+ done
277+ git commit -m 'Bot Updating Templated Files'
278+ git push https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/${LS_USER}/${LS_REPO}.git --all
279+ echo "true" > /tmp/${COMMIT_SHA}-${BUILD_NUMBER}
280+ echo "Deleting old templates"
281+ rm -Rf ${TEMPDIR}
282+ exit 0
283+ else
284+ echo "No templates to delete"
285+ fi
286+ # Stage 3 - Update templates
244287 CURRENTHASH=$(grep -hs ^ ${TEMPLATED_FILES} | md5sum | cut -c1-8)
245288 cd ${TEMPDIR}/docker-${CONTAINER_NAME}
246289 NEWHASH=$(grep -hs ^ ${TEMPLATED_FILES} | md5sum | cut -c1-8)
247- if [[ "${CURRENTHASH}" != "${NEWHASH}" ]]; then
290+ if [[ "${CURRENTHASH}" != "${NEWHASH}" ]] || ! grep -q '.jenkins-external' "${WORKSPACE}/.gitignore" 2>/dev/null ; then
248291 mkdir -p ${TEMPDIR}/repo
249292 git clone https://github.com/${LS_USER}/${LS_REPO}.git ${TEMPDIR}/repo/${LS_REPO}
250293 cd ${TEMPDIR}/repo/${LS_REPO}
251294 git checkout -f master
252295 cd ${TEMPDIR}/docker-${CONTAINER_NAME}
253296 mkdir -p ${TEMPDIR}/repo/${LS_REPO}/.github/workflows
254297 mkdir -p ${TEMPDIR}/repo/${LS_REPO}/.github/ISSUE_TEMPLATE
255- rm -f ${TEMPDIR}/repo/${LS_REPO}/.github/ISSUE_TEMPLATE.md
256298 cp --parents ${TEMPLATED_FILES} ${TEMPDIR}/repo/${LS_REPO}/ || :
257299 cd ${TEMPDIR}/repo/${LS_REPO}/
300+ if ! grep -q '.jenkins-external' .gitignore 2>/dev/null; then
301+ echo ".jenkins-external" >> .gitignore
302+ git add .gitignore
303+ fi
258304 git add ${TEMPLATED_FILES}
259- git rm .github/ISSUE_TEMPLATE.md || :
260305 git commit -m 'Bot Updating Templated Files'
261306 git push https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/${LS_USER}/${LS_REPO}.git --all
262307 echo "true" > /tmp/${COMMIT_SHA}-${BUILD_NUMBER}
@@ -265,8 +310,8 @@ pipeline {
265310 fi
266311 mkdir -p ${TEMPDIR}/gitbook
267312 git clone https://github.com/linuxserver/docker-documentation.git ${TEMPDIR}/gitbook/docker-documentation
268- if [[ ("${BRANCH_NAME}" == "master") || ("${BRANCH_NAME}" == "main") ]] && [[ (! -f ${TEMPDIR}/gitbook/docker-documentation/images/docker-${CONTAINER_NAME}.md) || ("$(md5sum ${TEMPDIR}/gitbook/docker-documentation/images/docker-${CONTAINER_NAME}.md | awk '{ print $1 }')" != "$(md5sum ${TEMPDIR}/docker-${CONTAINER_NAME}/docker-${CONTAINER_NAME}.md | awk '{ print $1 }')") ]]; then
269- cp ${TEMPDIR}/docker-${CONTAINER_NAME}/docker-${CONTAINER_NAME}.md ${TEMPDIR}/gitbook/docker-documentation/images/
313+ if [[ ("${BRANCH_NAME}" == "master") || ("${BRANCH_NAME}" == "main") ]] && [[ (! -f ${TEMPDIR}/gitbook/docker-documentation/images/docker-${CONTAINER_NAME}.md) || ("$(md5sum ${TEMPDIR}/gitbook/docker-documentation/images/docker-${CONTAINER_NAME}.md | awk '{ print $1 }')" != "$(md5sum ${TEMPDIR}/docker-${CONTAINER_NAME}/.jenkins-external/ docker-${CONTAINER_NAME}.md | awk '{ print $1 }')") ]]; then
314+ cp ${TEMPDIR}/docker-${CONTAINER_NAME}/.jenkins-external/ docker-${CONTAINER_NAME}.md ${TEMPDIR}/gitbook/docker-documentation/images/
270315 cd ${TEMPDIR}/gitbook/docker-documentation/
271316 git add images/docker-${CONTAINER_NAME}.md
272317 git commit -m 'Bot Updating Documentation'
@@ -505,7 +550,7 @@ pipeline {
505550 }
506551 sh ''' #! /bin/bash
507552 set -e
508- docker pull ghcr.io/linuxserver/lsiodev- ci:latest
553+ docker pull ghcr.io/linuxserver/ci:latest
509554 if [ "${MULTIARCH}" == "true" ]; then
510555 docker pull ghcr.io/linuxserver/lsiodev-buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER}
511556 docker pull ghcr.io/linuxserver/lsiodev-buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER}
@@ -530,7 +575,7 @@ pipeline {
530575 -e WEB_PATH=\" ${CI_WEBPATH}\" \
531576 -e DO_REGION="ams3" \
532577 -e DO_BUCKET="lsio-ci" \
533- -t ghcr.io/linuxserver/lsiodev- ci:latest \
578+ -t ghcr.io/linuxserver/ci:latest \
534579 python /ci/ci.py'''
535580 }
536581 }
@@ -675,19 +720,19 @@ pipeline {
675720 environment name : ' EXIT_STATUS' , value : ' '
676721 }
677722 steps {
678- echo " Pushing New tag for current commit ${ EXT_RELEASE_CLEAN } -ls ${ LS_TAG_NUMBER } "
723+ echo " Pushing New tag for current commit ${ META_TAG } "
679724 sh ''' curl -H "Authorization: token ${GITHUB_TOKEN}" -X POST https://api.github.com/repos/${LS_USER}/${LS_REPO}/git/tags \
680- -d '{"tag":"'${EXT_RELEASE_CLEAN}'-ls'${LS_TAG_NUMBER }'",\
725+ -d '{"tag":"'${META_TAG }'",\
681726 "object": "'${COMMIT_SHA}'",\
682727 "message": "Tagging Release '${EXT_RELEASE_CLEAN}'-ls'${LS_TAG_NUMBER}' to master",\
683728 "type": "commit",\
684729 "tagger": {"name": "LinuxServer Jenkins","email": "jenkins@linuxserver.io","date": "'${GITHUB_DATE}'"}}' '''
685730 echo " Pushing New release for Tag"
686731 sh ''' #! /bin/bash
687732 curl -s https://api.github.com/repos/${EXT_USER}/${EXT_REPO}/releases/latest | jq '. |.body' | sed 's:^.\\ (.*\\ ).$:\\ 1:' > releasebody.json
688- echo '{"tag_name":"'${EXT_RELEASE_CLEAN}'-ls'${LS_TAG_NUMBER }'",\
733+ echo '{"tag_name":"'${META_TAG }'",\
689734 "target_commitish": "master",\
690- "name": "'${EXT_RELEASE_CLEAN}'-ls'${LS_TAG_NUMBER }'",\
735+ "name": "'${META_TAG }'",\
691736 "body": "**LinuxServer Changes:**\\ n\\ n'${LS_RELEASE_NOTES}'\\ n**'${EXT_REPO}' Changes:**\\ n\\ n' > start
692737 printf '","draft": false,"prerelease": false}' >> releasebody.json
693738 paste -d'\\ 0' start releasebody.json > releasebody.json.done
@@ -714,15 +759,15 @@ pipeline {
714759 TEMPDIR=$(mktemp -d)
715760 docker pull ghcr.io/linuxserver/jenkins-builder:latest
716761 docker run --rm -e CONTAINER_NAME=${CONTAINER_NAME} -e GITHUB_BRANCH="${BRANCH_NAME}" -v ${TEMPDIR}:/ansible/jenkins ghcr.io/linuxserver/jenkins-builder:latest
717- docker pull ghcr.io/linuxserver/lsiodev- readme-sync
762+ docker pull ghcr.io/linuxserver/readme-sync
718763 docker run --rm=true \
719764 -e DOCKERHUB_USERNAME=$DOCKERUSER \
720765 -e DOCKERHUB_PASSWORD=$DOCKERPASS \
721766 -e GIT_REPOSITORY=${LS_USER}/${LS_REPO} \
722767 -e DOCKER_REPOSITORY=${IMAGE} \
723768 -e GIT_BRANCH=master \
724769 -v ${TEMPDIR}/docker-${CONTAINER_NAME}:/mnt \
725- ghcr.io/linuxserver/lsiodev- readme-sync bash -c 'node sync'
770+ ghcr.io/linuxserver/readme-sync bash -c 'node sync'
726771 rm -Rf ${TEMPDIR} '''
727772 }
728773 }
0 commit comments