@@ -16,7 +16,6 @@ pipeline {
1616 GITHUB_TOKEN = credentials(' 498b4638-2d02-4ce5-832d-8a57d01d97ab' )
1717 GITLAB_TOKEN = credentials(' b6f0f1dd-6952-4cf6-95d1-9c06380283f0' )
1818 GITLAB_NAMESPACE = credentials(' gitlab-namespace-id' )
19- SCARF_TOKEN = credentials(' scarf_api_key' )
2019 BUILD_VERSION_ARG = ' WPSOFFICE_VERSION'
2120 LS_USER = ' linuxserver'
2221 LS_REPO = ' docker-wps-office'
@@ -327,12 +326,12 @@ pipeline {
327326 else
328327 echo "false" > /tmp/${COMMIT_SHA}-${BUILD_NUMBER}
329328 fi
330- mkdir -p ${TEMPDIR}/gitbook
331- git clone https://github.com/linuxserver/docker-documentation.git ${TEMPDIR}/gitbook /docker-documentation
332- 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
333- cp ${TEMPDIR}/docker-${CONTAINER_NAME}/.jenkins-external/docker-${CONTAINER_NAME}.md ${TEMPDIR}/gitbook /docker-documentation/images/
334- cd ${TEMPDIR}/gitbook /docker-documentation/
335- git add images/docker-${CONTAINER_NAME}.md
329+ mkdir -p ${TEMPDIR}/docs
330+ git clone https://github.com/linuxserver/docker-documentation.git ${TEMPDIR}/docs /docker-documentation
331+ if [[ ("${BRANCH_NAME}" == "master") || ("${BRANCH_NAME}" == "main") ]] && [[ (! -f ${TEMPDIR}/docs /docker-documentation/docs/ images/docker-${CONTAINER_NAME}.md) || ("$(md5sum ${TEMPDIR}/docs /docker-documentation/docs /images/docker-${CONTAINER_NAME}.md | awk '{ print $1 }')" != "$(md5sum ${TEMPDIR}/docker-${CONTAINER_NAME}/.jenkins-external/docker-${CONTAINER_NAME}.md | awk '{ print $1 }')") ]]; then
332+ cp ${TEMPDIR}/docker-${CONTAINER_NAME}/.jenkins-external/docker-${CONTAINER_NAME}.md ${TEMPDIR}/docs /docker-documentation/docs /images/
333+ cd ${TEMPDIR}/docs /docker-documentation
334+ git add docs/ images/docker-${CONTAINER_NAME}.md
336335 git commit -m 'Bot Updating Documentation'
337336 git push https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/linuxserver/docker-documentation.git --all
338337 fi
@@ -423,35 +422,6 @@ pipeline {
423422 "visibility":"public"}' '''
424423 }
425424 }
426- /* #######################
427- Scarf.sh package registry
428- ####################### */
429- // Add package to Scarf.sh and set permissions
430- stage(" Scarf.sh package registry" ){
431- when {
432- branch " master"
433- environment name : ' EXIT_STATUS' , value : ' '
434- }
435- steps{
436- sh ''' #! /bin/bash
437- PACKAGE_UUID=$(curl -X GET -H "Authorization: Bearer ${SCARF_TOKEN}" https://scarf.sh/api/v1/organizations/linuxserver-ci/packages | jq -r '.[] | select(.name=="linuxserver/wps-office") | .uuid' || :)
438- if [ -z "${PACKAGE_UUID}" ]; then
439- echo "Adding package to Scarf.sh"
440- curl -sX POST https://scarf.sh/api/v1/organizations/linuxserver-ci/packages \
441- -H "Authorization: Bearer ${SCARF_TOKEN}" \
442- -H "Content-Type: application/json" \
443- -d '{"name":"linuxserver/wps-office",\
444- "shortDescription":"example description",\
445- "libraryType":"docker",\
446- "website":"https://github.com/linuxserver/docker-wps-office",\
447- "backendUrl":"https://ghcr.io/linuxserver/wps-office",\
448- "publicUrl":"https://lscr.io/linuxserver/wps-office"}' || :
449- else
450- echo "Package already exists on Scarf.sh"
451- fi
452- '''
453- }
454- }
455425 /* ###############
456426 Build Container
457427 ############### */
@@ -847,6 +817,41 @@ pipeline {
847817 curl -H "Authorization: token ${GITHUB_TOKEN}" -X POST https://api.github.com/repos/${LS_USER}/${LS_REPO}/releases -d @releasebody.json.done'''
848818 }
849819 }
820+ // Add protection to the release branch
821+ stage(' Github-Release-Branch-Protection' ) {
822+ when {
823+ branch " master"
824+ environment name : ' CHANGE_ID' , value : ' '
825+ environment name : ' EXIT_STATUS' , value : ' '
826+ }
827+ steps {
828+ echo " Setting up protection for release branch master"
829+ sh ''' #! /bin/bash
830+ curl -H "Authorization: token ${GITHUB_TOKEN}" -X PUT https://api.github.com/repos/${LS_USER}/${LS_REPO}/branches/master/protection \
831+ -d $(jq -c . << EOF
832+ {
833+ "required_status_checks": null,
834+ "enforce_admins": false,
835+ "required_pull_request_reviews": {
836+ "dismiss_stale_reviews": false,
837+ "require_code_owner_reviews": false,
838+ "require_last_push_approval": false,
839+ "required_approving_review_count": 1
840+ },
841+ "restrictions": null,
842+ "required_linear_history": false,
843+ "allow_force_pushes": false,
844+ "allow_deletions": false,
845+ "block_creations": false,
846+ "required_conversation_resolution": true,
847+ "lock_branch": false,
848+ "allow_fork_syncing": false,
849+ "required_signatures": false
850+ }
851+ EOF
852+ ) '''
853+ }
854+ }
850855 // Use helper container to sync the current README on master to the dockerhub endpoint
851856 stage(' Sync-README' ) {
852857 when {
0 commit comments