2026-01-06 13:59:38 -03:00
|
|
|
pipeline {
|
|
|
|
|
agent any
|
|
|
|
|
|
|
|
|
|
options { skipDefaultCheckout(true) }
|
|
|
|
|
|
|
|
|
|
environment {
|
|
|
|
|
IMAGE_NAME = 'rd.jenkins'
|
|
|
|
|
|
2026-01-06 14:05:19 -03:00
|
|
|
AWS_URL = "test" //credentials('aws-ecr-url')
|
|
|
|
|
AWS_USER = "test" //credentials('aws-ecr-username')
|
|
|
|
|
AWS_REGION = "test" //credentials('aws-ecr-region')
|
2026-01-06 13:59:38 -03:00
|
|
|
AWS_CREDS_ID = 'aws-jenkins'
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
stages {
|
|
|
|
|
stage('Checkout') {
|
|
|
|
|
steps {
|
|
|
|
|
cleanWs()
|
|
|
|
|
|
|
|
|
|
script {
|
|
|
|
|
checkout scm
|
|
|
|
|
|
|
|
|
|
sh 'git submodule update --init --recursive'
|
|
|
|
|
|
|
|
|
|
def tagName = sh(
|
|
|
|
|
script: "git describe --tags --exact-match 2>/dev/null || echo 'no-tag'",
|
|
|
|
|
returnStdout: true
|
|
|
|
|
).trim()
|
|
|
|
|
|
|
|
|
|
echo "Detected tag: ${tagName}"
|
|
|
|
|
|
|
|
|
|
if (tagName == 'no-tag') {
|
|
|
|
|
echo "Not a tag build, skipping deployment."
|
|
|
|
|
currentBuild.result = 'SUCCESS'
|
|
|
|
|
error("Stopping pipeline: not a tag push.")
|
|
|
|
|
}
|
|
|
|
|
|
2026-01-06 14:05:19 -03:00
|
|
|
if (!(tagName ==~ /^v[0-9]+(\.[0-9]+){0,2}$/)) {
|
|
|
|
|
echo "[!] Invalid tag format. Expected format: vX.Y.Z"
|
2026-01-06 13:59:38 -03:00
|
|
|
currentBuild.result = 'SUCCESS'
|
|
|
|
|
error("Stopping pipeline: invalid tag format.")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
env.IMAGE_TAG = tagName
|
|
|
|
|
env.AWS_IMAGE = "${AWS_URL}/${AWS_USER}/${IMAGE_NAME}:${IMAGE_TAG}"
|
|
|
|
|
|
|
|
|
|
echo "Tag validado: ${env.IMAGE_TAG}"
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
stage('Build Image') {
|
|
|
|
|
steps {
|
|
|
|
|
sh "echo ${AWS_IMAGE}"
|
|
|
|
|
script {
|
|
|
|
|
docker.build("${AWS_IMAGE}", '--no-cache --pull -f src/Service/Infrastructure/App/Dockerfile .')
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// stage('AWS ECR Login') {
|
|
|
|
|
// steps {
|
|
|
|
|
// withAWS(credentials: AWS_CREDS_ID, region: AWS_REGION) {
|
|
|
|
|
// script {
|
|
|
|
|
// sh """
|
|
|
|
|
// set -euo pipefail
|
|
|
|
|
// echo "Logging in to AWS ECR: \${AWS_URL}"
|
|
|
|
|
// aws ecr get-login-password --region "\${AWS_REGION}" \\
|
|
|
|
|
// | docker login --username AWS --password-stdin "\${AWS_URL}"
|
|
|
|
|
// """
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
// stage('Push Image') {
|
|
|
|
|
// steps {
|
|
|
|
|
// sh "docker push ${AWS_IMAGE}"
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
}
|
|
|
|
|
}
|