Files
GestionIntegralWeb/.drone.yml

108 lines
3.2 KiB
YAML
Raw Normal View History

2025-06-15 23:06:51 -03:00
kind: pipeline
type: docker
name: Build y Deploy
volumes:
- name: dockersock
host:
path: /var/run/docker.sock
2025-06-15 23:06:51 -03:00
trigger:
branch:
2025-06-16 18:06:14 -03:00
- main
2025-06-15 23:06:51 -03:00
event:
2025-06-16 18:06:14 -03:00
- push
2025-06-15 23:06:51 -03:00
steps:
- name: build-and-publish-backend
2025-06-16 18:06:14 -03:00
image: docker:latest # Usamos la imagen oficial de Docker CLI
volumes:
- name: dockersock
path: /var/run/docker.sock
2025-06-16 18:06:14 -03:00
environment:
# Pasamos las credenciales de forma segura como variables de entorno
GITEA_USER:
2025-06-15 23:06:51 -03:00
from_secret: GITEA_USER
2025-06-16 18:06:14 -03:00
ACTIONS_PAT:
2025-06-15 23:06:51 -03:00
from_secret: ACTIONS_PAT
2025-06-16 18:06:14 -03:00
REGISTRY_URL:
from_secret: REGISTRY_URL
commands:
# 1. Iniciar sesión en el registro de Gitea
- echo "Iniciando sesión en ${REGISTRY_URL}..."
- docker login -u $GITEA_USER -p $ACTIONS_PAT $REGISTRY_URL
# 2. Definir los tags para la imagen
- export TAG_LATEST="${REGISTRY_URL}/${DRONE_REPO_OWNER}/${DRONE_REPO_NAME,,}-backend:latest"
- export TAG_COMMIT="${REGISTRY_URL}/${DRONE_REPO_OWNER}/${DRONE_REPO_NAME,,}-backend:${DRONE_COMMIT_SHA:0:8}"
- echo "Creando imagen con tags: ${TAG_LATEST} y ${TAG_COMMIT}"
# 3. Construir la imagen de Docker
- docker build -t $TAG_LATEST -t $TAG_COMMIT -f Backend/GestionIntegral.Api/Dockerfile .
# 4. Subir ambos tags al registro
- docker push $TAG_LATEST
- docker push $TAG_COMMIT
2025-06-16 12:48:22 -03:00
- name: build-and-publish-frontend
2025-06-16 18:06:14 -03:00
image: docker:latest
2025-06-16 12:48:22 -03:00
volumes:
- name: dockersock
path: /var/run/docker.sock
2025-06-16 18:06:14 -03:00
environment:
GITEA_USER:
2025-06-16 12:48:22 -03:00
from_secret: GITEA_USER
2025-06-16 18:06:14 -03:00
ACTIONS_PAT:
2025-06-16 12:48:22 -03:00
from_secret: ACTIONS_PAT
2025-06-16 18:06:14 -03:00
REGISTRY_URL:
from_secret: REGISTRY_URL
commands:
- docker login -u $GITEA_USER -p $ACTIONS_PAT $REGISTRY_URL
- export TAG_LATEST="${REGISTRY_URL}/${DRONE_REPO_OWNER}/${DRONE_REPO_NAME,,}-frontend:latest"
- export TAG_COMMIT="${REGISTRY_URL}/${DRONE_REPO_OWNER}/${DRONE_REPO_NAME,,}-frontend:${DRONE_COMMIT_SHA:0:8}"
- docker build -t $TAG_LATEST -t $TAG_COMMIT -f Frontend/Dockerfile .
- docker push $TAG_LATEST
- docker push $TAG_COMMIT
2025-06-16 12:48:22 -03:00
depends_on:
- build-and-publish-backend
2025-06-15 23:06:51 -03:00
- name: deploy-to-production
2025-06-16 18:06:14 -03:00
# Este paso ya estaba bien y no necesita cambios
2025-06-15 23:06:51 -03:00
image: alpine:latest
environment:
SSH_KEY:
from_secret: PROD_SERVER_SSH_KEY
PROD_HOST:
from_secret: PROD_SERVER_HOST
PROD_USER:
from_secret: PROD_SERVER_USER
DB_PASSWORD:
from_secret: DB_SA_PASSWORD_SECRET
JWT_KEY:
from_secret: JWT_KEY_SECRET
REGISTRY:
from_secret: REGISTRY_URL
GITEA_USER:
from_secret: GITEA_USER
GITEA_PAT:
from_secret: ACTIONS_PAT
commands:
- apk add --no-cache openssh-client
- mkdir -p ~/.ssh
- echo "$SSH_KEY" > ~/.ssh/id_rsa
- chmod 600 ~/.ssh/id_rsa
- ssh-keyscan -H $PROD_HOST >> ~/.ssh/known_hosts
- |
ssh $PROD_USER@$PROD_HOST << 'EOF'
echo "--- CONECTADO AL SERVIDOR DE PRODUCCIÓN ---"
cd /opt/gestion-integral
export DB_SA_PASSWORD="${DB_PASSWORD}"
export JWT_KEY="${JWT_KEY}"
docker login ${REGISTRY} -u ${GITEA_USER} -p ${GITEA_PAT}
docker compose pull
docker compose up -d
docker image prune -af
echo "--- DESPLIEGUE COMPLETADO ---"
EOF
depends_on:
2025-06-16 18:06:14 -03:00
- build-and-publish-frontend