aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar LinuxServer-CI <ci@linuxserver.io> 2024-08-21 22:01:59 +0000
committerGravatar LinuxServer-CI <ci@linuxserver.io> 2024-08-21 22:01:59 +0000
commita4106036e3e1b9fe4015c5a78695a24bf0adda41 (patch)
treea3de9eb72c2f3fd8c07ffdce3191889cc3d4c9f2
parent94cc347b9160984dcf72da2d5b20afd666064a13 (diff)
downloaddocker-nzbhydra2-a4106036e3e1b9fe4015c5a78695a24bf0adda41.tar.gz
docker-nzbhydra2-a4106036e3e1b9fe4015c5a78695a24bf0adda41.tar.zst
docker-nzbhydra2-a4106036e3e1b9fe4015c5a78695a24bf0adda41.zip
Bot Updating Templated Files
-rw-r--r--Jenkinsfile62
1 files changed, 52 insertions, 10 deletions
diff --git a/Jenkinsfile b/Jenkinsfile
index b36be22..456d3ac 100644
--- a/Jenkinsfile
+++ b/Jenkinsfile
@@ -17,6 +17,8 @@ pipeline {
GITLAB_TOKEN=credentials('b6f0f1dd-6952-4cf6-95d1-9c06380283f0')
GITLAB_NAMESPACE=credentials('gitlab-namespace-id')
DOCKERHUB_TOKEN=credentials('docker-hub-ci-pat')
+ QUAYIO_API_TOKEN=credentials('quayio-repo-api-token')
+ GIT_SIGNING_KEY=credentials('484fbca6-9a4f-455e-b9e3-97ac98785f5f')
EXT_GIT_BRANCH = 'master'
EXT_USER = 'theotherp'
EXT_REPO = 'nzbhydra2'
@@ -39,9 +41,23 @@ pipeline {
CI_WEBPATH='/system/about'
}
stages {
+ stage("Set git config"){
+ steps{
+ sh '''#!/bin/bash
+ cat ${GIT_SIGNING_KEY} > /config/.ssh/id_sign
+ chmod 600 /config/.ssh/id_sign
+ ssh-keygen -y -f /config/.ssh/id_sign > /config/.ssh/id_sign.pub
+ echo "Using $(ssh-keygen -lf /config/.ssh/id_sign) to sign commits"
+ git config --global gpg.format ssh
+ git config --global user.signingkey /config/.ssh/id_sign
+ git config --global commit.gpgsign true
+ '''
+ }
+ }
// Setup all the basic environment variables needed for the build
stage("Set ENV Variables base"){
steps{
+ echo "Running on node: ${NODE_NAME}"
sh '''#! /bin/bash
containers=$(docker ps -aq)
if [[ -n "${containers}" ]]; then
@@ -391,9 +407,9 @@ pipeline {
echo "Updating Unraid template"
cd ${TEMPDIR}/unraid/templates/
GH_TEMPLATES_DEFAULT_BRANCH=$(git remote show origin | grep "HEAD branch:" | sed 's|.*HEAD branch: ||')
- if grep -wq "${CONTAINER_NAME}" ${TEMPDIR}/unraid/templates/unraid/ignore.list && [[ -f ${TEMPDIR}/unraid/templates/unraid/deprecated/${CONTAINER_NAME}.xml ]]; then
+ if grep -wq "^${CONTAINER_NAME}$" ${TEMPDIR}/unraid/templates/unraid/ignore.list && [[ -f ${TEMPDIR}/unraid/templates/unraid/deprecated/${CONTAINER_NAME}.xml ]]; then
echo "Image is on the ignore list, and already in the deprecation folder."
- elif grep -wq "${CONTAINER_NAME}" ${TEMPDIR}/unraid/templates/unraid/ignore.list; then
+ elif grep -wq "^${CONTAINER_NAME}$" ${TEMPDIR}/unraid/templates/unraid/ignore.list; then
echo "Image is on the ignore list, marking Unraid template as deprecated"
cp ${TEMPDIR}/docker-${CONTAINER_NAME}/.jenkins-external/${CONTAINER_NAME}.xml ${TEMPDIR}/unraid/templates/unraid/
git add -u unraid/${CONTAINER_NAME}.xml
@@ -486,10 +502,10 @@ pipeline {
}
}
/* #######################
- GitLab Mirroring
+ GitLab Mirroring and Quay.io Repo Visibility
####################### */
- // Ping into Gitlab to mirror this repo and have a registry endpoint
- stage("GitLab Mirror"){
+ // Ping into Gitlab to mirror this repo and have a registry endpoint & mark this repo on Quay.io as public
+ stage("GitLab Mirror and Quay.io Visibility"){
when {
environment name: 'EXIT_STATUS', value: ''
}
@@ -505,6 +521,8 @@ pipeline {
"visibility":"public"}' '''
sh '''curl -H "Private-Token: ${GITLAB_TOKEN}" -X PUT "https://gitlab.com/api/v4/projects/Linuxserver.io%2F${LS_REPO}" \
-d "mirror=true&import_url=https://github.com/linuxserver/${LS_REPO}.git" '''
+ sh '''curl -H "Content-Type: application/json" -H "Authorization: Bearer ${QUAYIO_API_TOKEN}" -X POST "https://quay.io/api/v1/repository${QUAYIMAGE/quay.io/}/changevisibility" \
+ -d '{"visibility":"public"}' ||: '''
}
}
/* ###############
@@ -599,7 +617,7 @@ pipeline {
--provenance=false --sbom=false \
--build-arg ${BUILD_VERSION_ARG}=${EXT_RELEASE} --build-arg VERSION=\"${VERSION_TAG}\" --build-arg BUILD_DATE=${GITHUB_DATE} ."
sh "docker tag ${IMAGE}:arm64v8-${META_TAG} ghcr.io/linuxserver/lsiodev-buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER}"
- retry(5) {
+ retry_backoff(5,5) {
sh "docker push ghcr.io/linuxserver/lsiodev-buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER}"
}
sh '''#! /bin/bash
@@ -755,7 +773,7 @@ pipeline {
passwordVariable: 'QUAYPASS'
]
]) {
- retry(5) {
+ retry_backoff(5,5) {
sh '''#! /bin/bash
set -e
echo $DOCKERHUB_TOKEN | docker login -u linuxserverci --password-stdin
@@ -773,7 +791,7 @@ pipeline {
docker push ${PUSHIMAGE}:${META_TAG}
docker push ${PUSHIMAGE}:${EXT_RELEASE_TAG}
if [ -n "${SEMVER}" ]; then
- docker push ${PUSHIMAGE}:${SEMVER}
+ docker push ${PUSHIMAGE}:${SEMVER}
fi
done
'''
@@ -796,7 +814,7 @@ pipeline {
passwordVariable: 'QUAYPASS'
]
]) {
- retry(5) {
+ retry_backoff(5,5) {
sh '''#! /bin/bash
set -e
echo $DOCKERHUB_TOKEN | docker login -u linuxserverci --password-stdin
@@ -859,7 +877,7 @@ pipeline {
"object": "'${COMMIT_SHA}'",\
"message": "Tagging Release '${EXT_RELEASE_CLEAN}'-ls'${LS_TAG_NUMBER}' to master",\
"type": "commit",\
- "tagger": {"name": "LinuxServer Jenkins","email": "jenkins@linuxserver.io","date": "'${GITHUB_DATE}'"}}' '''
+ "tagger": {"name": "LinuxServer-CI","email": "ci@linuxserver.io","date": "'${GITHUB_DATE}'"}}' '''
echo "Pushing New release for Tag"
sh '''#! /bin/bash
curl -H "Authorization: token ${GITHUB_TOKEN}" -s https://api.github.com/repos/${EXT_USER}/${EXT_REPO}/releases/latest | jq '. |.body' | sed 's:^.\\(.*\\).$:\\1:' > releasebody.json
@@ -991,6 +1009,13 @@ EOF
###################### */
post {
always {
+ sh '''#!/bin/bash
+ rm -rf /config/.ssh/id_sign
+ rm -rf /config/.ssh/id_sign.pub
+ git config --global --unset gpg.format
+ git config --global --unset user.signingkey
+ git config --global --unset commit.gpgsign
+ '''
script{
if (env.EXIT_STATUS == "ABORTED"){
sh 'echo "build aborted"'
@@ -1020,3 +1045,20 @@ EOF
}
}
}
+
+def retry_backoff(int max_attempts, int power_base, Closure c) {
+ int n = 0
+ while (n < max_attempts) {
+ try {
+ c()
+ return
+ } catch (err) {
+ if ((n + 1) >= max_attempts) {
+ throw err
+ }
+ sleep(power_base ** n)
+ n++
+ }
+ }
+ return
+}