Files
onlyoffice/Jenkinsfile
Lucas 308c745f09
All checks were successful
jenkins-ci Build successful
chore: add jenkins support
2026-01-26 10:56:27 +00:00

59 lines
2.1 KiB
Groovy

pipeline {
agent any
environment {
GITEA_REPO_PATH = "lucas/onlyoffice"
GITEA_API_URL = "https://gitea.lucasroyer.fr/api/v1"
}
stages {
stage('Check git...') {
steps {
checkout scm
}
}
stage('Deploy') {
steps {
withCredentials([
file(credentialsId: 'onlyoffice-app-env', variable: 'APP_ENV_PATH'),
]) {
echo "Deploy new onlyoffice server..."
sh """
cp "\$APP_ENV_PATH" app.env
docker compose up -d --remove-orphans
rm -f app.env
"""
}
}
}
}
post {
always {
script {
echo "Send Gitea check..."
// Get and store SHA
def commitSha = sh(script: 'git rev-parse HEAD', returnStdout: true).trim()
// Convert from Jenkins to Gitea API
def buildState = (currentBuild.currentResult == 'SUCCESS') ? 'success' : 'failure'
def buildDesc = (currentBuild.currentResult == 'SUCCESS') ? 'Build successful' : 'Build failed'
// Send it to Gitea API with secret 'gitea-token'
withCredentials([string(credentialsId: 'gitea-token', variable: 'GITEA_TOKEN')]) {
// Use \$TOKEN to avoid jenkins to print token in logs
sh """
curl -f -X POST "${GITEA_API_URL}/repos/${GITEA_REPO_PATH}/statuses/${commitSha}" \
-H "Authorization: token \$GITEA_TOKEN" \
-H "Content-Type: application/json" \
-d '{"state": "${buildState}", "target_url": "${env.BUILD_URL}", "description": "${buildDesc}", "context": "jenkins-ci"}'
"""
}
}
echo "Clean unused image..."
sh "docker image prune -f"
}
success { echo "Success !" }
failure { echo "Failed." }
}
}