Compare commits

..

No commits in common. "main" and "teste" have entirely different histories.
main ... teste

96
Jenkinsfile vendored
View file

@ -15,12 +15,7 @@ pipeline {
timestamps()
}
parameters {
booleanParam(name: 'ROLLBACK', defaultValue: false, description: 'Executar rollback da produção?')
}
stages {
stage('Commit') {
steps {
echo 'Pipeline iniciado via push ou merge.'
@ -29,7 +24,7 @@ pipeline {
stage('Checkout Código') {
steps {
git branch: 'main', url: 'https://forgeo-olymp.duckdns.org/rayankonecny/portal-app.git'
git branch: 'main', url: 'https://forgeo-olymp.duckdns.org/rayankonecny/astro-app.git'
script {
env.GIT_COMMIT = sh(script: 'git rev-parse --short HEAD', returnStdout: true).trim()
env.BUILD_TAG = "${env.BUILD_NUMBER}-${env.GIT_COMMIT}"
@ -41,7 +36,7 @@ pipeline {
stage('Build') {
steps {
sh 'npm ci'
sh 'npm run build || echo "Build não crítico"'
sh 'npm run build'
}
}
@ -51,53 +46,42 @@ pipeline {
}
}
stage('SonarQube Analysis') {
environment {
SONAR_SCANNER_HOME = tool 'SonarQube Scanner'
}
steps {
withSonarQubeEnv('SonarQube') {
sh """
${SONAR_SCANNER_HOME}/bin/sonar-scanner \
-Dsonar.projectKey=${SONAR_PROJECT_KEY} \
-Dsonar.sources=. \
-Dsonar.host.url=$SONAR_HOST_URL \
-Dsonar.login=$SONAR_AUTH_TOKEN
"""
}
}
}
stage('Deploy to Stage') {
steps {
sshagent(credentials: ['chave-ssh-id']) {
sh """
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} "
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
set -e
rm -rf ${REMOTE_PATH}
git clone https://forgeo-olymp.duckdns.org/rayankonecny/portal-app.git ${REMOTE_PATH}
mkdir -p ${REMOTE_PATH}
cd ${REMOTE_PATH}
sed -i '/NODE_ENV/d' .env || true
cat <<EOF > Dockerfile
FROM node:18-alpine
WORKDIR /app
COPY package*.json ./
RUN npm install
COPY . .
EXPOSE 5173
CMD [\\"npm\\", \\"run\\", \\"dev\\"]
# STAGE 1: Build (não será usado aqui no servidor)
FROM node:20-alpine AS build
# STAGE 2: Produção estática
FROM node:20-alpine
WORKDIR /var/app/usr/astro
RUN npm install -g serve
COPY dist ./dist
EXPOSE 3000
CMD ["serve", "dist", "-l", "3000"]
EOF
podman build -t ${IMAGE_NAME}:${BUILD_TAG}-stage -t ${IMAGE_NAME}:stage .
exit
'
# Copia arquivos necessários via SCP
scp -r ./dist ${DEPLOY_USER}@${DEPLOY_SERVER}:${REMOTE_PATH}/dist
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
cd ${REMOTE_PATH}
podman build -t ${IMAGE_NAME}:${BUILD_TAG}-stage -t ${IMAGE_NAME}:stage .
podman stop ${CONTAINER_NAME}-stage || true
podman rm ${CONTAINER_NAME}-stage || true
podman run -d --network host --name ${CONTAINER_NAME}-stage ${IMAGE_NAME}:${BUILD_TAG}-stage
"
'
"""
}
}
@ -113,17 +97,14 @@ EOF
steps {
sshagent(credentials: ['chave-ssh-id']) {
sh """
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} "
echo '${BUILD_TAG}' > ${REMOTE_PATH}/last_successful_build.txt
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
echo "${BUILD_TAG}" > ${REMOTE_PATH}/last_successful_build.txt
cd ${REMOTE_PATH}
podman build -t ${IMAGE_NAME}:${BUILD_TAG}-prod -t ${IMAGE_NAME}:prod .
podman stop ${CONTAINER_NAME} || true
podman rm ${CONTAINER_NAME} || true
podman run -d --network host --name ${CONTAINER_NAME} ${IMAGE_NAME}:${BUILD_TAG}-prod
"
'
"""
}
}
@ -133,9 +114,9 @@ ssh ${DEPLOY_USER}@${DEPLOY_SERVER} "
steps {
sshagent(credentials: ['chave-ssh-id']) {
sh """
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} "
podman ps | grep ${CONTAINER_NAME} || echo 'Container não encontrado'
"
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
podman ps | grep ${CONTAINER_NAME} || echo "Container não encontrado"
'
"""
}
}
@ -148,26 +129,23 @@ ssh ${DEPLOY_USER}@${DEPLOY_SERVER} "
steps {
sshagent(credentials: ['chave-ssh-id']) {
sh """
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} "
TAG=\$(cat ${REMOTE_PATH}/last_successful_build.txt || echo 'latest')
echo '[INFO] Restaurando versão: \$TAG'
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} '
TAG=$(cat ${REMOTE_PATH}/last_successful_build.txt || echo "latest")
echo "[INFO] Restaurando versão: \$TAG"
podman stop ${CONTAINER_NAME} || true
podman rm ${CONTAINER_NAME} || true
podman run -d --network host --name ${CONTAINER_NAME} ${IMAGE_NAME}:\$TAG
"
'
"""
}
}
}
stage('Limpeza de Imagens Antigas') {
stage('Limpeza') {
steps {
sshagent(credentials: ['chave-ssh-id']) {
sh """
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} "podman image prune -f"
ssh ${DEPLOY_USER}@${DEPLOY_SERVER} 'podman image prune -f'
"""
}
}
@ -194,4 +172,8 @@ curl -H "Content-Type: application/json" -X POST \
}
}
}
parameters {
booleanParam(name: 'ROLLBACK', defaultValue: false, description: 'Executar rollback da produção?')
}
}