This commit is contained in:
2025-06-15 22:57:24 -03:00
parent 66686fc548
commit f62fc4b507

View File

@@ -1,80 +1,84 @@
kind: pipeline kind: pipeline
type: docker type: docker
name: Build y Deploy name: Build y Deploy
trigger: trigger:
branch: branch:
- main - main
event: event:
- push - push
steps: steps:
- name: build-and-publish-backend # --- Los pasos de build-and-publish no cambian, ya están bien ---
image: plugins/docker - name: build-and-publish-backend
settings: image: plugins/docker
# El registro es la IP pública para que Docker pueda subir la imagen settings:
registry: registry:
from_secret: REGISTRY_URL from_secret: REGISTRY_URL
# El repo se construye con el dueño y nombre del repo en Gitea repo: ${{DRONE_REPO_OWNER}}/${{DRONE_REPO_NAME}}-backend
repo: ${{DRONE_REPO_OWNER}}/${{DRONE_REPO_NAME}}-backend username:
# El usuario y la contraseña (PAT) para el login from_secret: GITEA_USER
username: password:
from_secret: GITEA_USER from_secret: ACTIONS_PAT
password: dockerfile: Backend/GestionIntegral.Api/Dockerfile
from_secret: ACTIONS_PAT tags:
# El Dockerfile a usar - latest
dockerfile: Backend/GestionIntegral.Api/Dockerfile - ${{DRONE_COMMIT_SHA:0:8}}
# Las etiquetas
tags:
- latest
- ${{DRONE_COMMIT_SHA:0:8}}
- name: build-and-publish-frontend - name: build-and-publish-frontend
image: plugins/docker image: plugins/docker
settings: settings:
registry: registry:
from_secret: REGISTRY_URL from_secret: REGISTRY_URL
repo: ${{DRONE_REPO_OWNER}}/${{DRONE_REPO_NAME}}-frontend repo: ${{DRONE_REPO_OWNER}}/${{DRONE_REPO_NAME}}-frontend
username: username:
from_secret: GITEA_USER from_secret: GITEA_USER
password: password:
from_secret: ACTIONS_PAT from_secret: ACTIONS_PAT
dockerfile: Frontend/Dockerfile dockerfile: Frontend/Dockerfile
tags: tags:
- latest - latest
- ${{DRONE_COMMIT_SHA:0:8}} - ${{DRONE_COMMIT_SHA:0:8}}
depends_on: depends_on:
- build-and-publish-backend - build-and-publish-backend
# --- ¡LA SECCIÓN FINAL Y CORRECTA! --- # --- ¡LA VERSIÓN FINAL Y CORRECTA! ---
- name: deploy-to-production - name: deploy-to-production
image: appleboy/drone-ssh image: appleboy/drone-ssh
settings: # Ya no usamos 'settings', el plugin lee los secretos directamente del entorno del paso.
host: environment:
from_secret: PROD_SERVER_HOST HOST:
username: from_secret: PROD_SERVER_HOST
from_secret: PROD_SERVER_USER USERNAME:
key: from_secret: PROD_SERVER_USER
from_secret: PROD_SERVER_SSH_KEY KEY:
from_secret: PROD_SERVER_SSH_KEY
# --- ¡LA SINTAXIS CORRECTA! ---
# Le pasamos los secretos como variables de entorno al script # Pasamos TODOS los secretos que el script necesita como variables
env_vars: # de entorno al contenedor del plugin.
- DB_SA_PASSWORD=${DB_SA_PASSWORD_SECRET} DB_SA_PASSWORD:
- JWT_KEY=${JWT_KEY_SECRET} from_secret: DB_SA_PASSWORD_SECRET
- REGISTRY_URL=${REGISTRY_URL} JWT_KEY:
- GITEA_USER=${GITEA_USER} from_secret: JWT_KEY_SECRET
- ACTIONS_PAT=${ACTIONS_PAT} REGISTRY_URL:
from_secret: REGISTRY_URL
# El plugin usa 'script', no 'commands'. GITEA_USER:
script: from_secret: GITEA_USER
- cd /opt/gestion-integral ACTIONS_PAT:
- export DB_SA_PASSWORD # Las variables ya están en el entorno, solo las exportamos from_secret: ACTIONS_PAT
- export JWT_KEY
- docker login $REGISTRY_URL -u $GITEA_USER -p $ACTIONS_PAT
- docker compose pull
- docker compose up -d
- docker image prune -af
depends_on: # El plugin usa 'script' y ahora las variables las tenemos que
- build-and-publish-frontend # pasar como argumentos al script o usarlas directamente.
script:
# El comando 'export' es crucial para que 'docker compose' los vea
- export DB_SA_PASSWORD
- export JWT_KEY
- echo "Conectando a $HOST como $USERNAME..."
- cd /opt/gestion-integral
- docker login $REGISTRY_URL -u $GITEA_USER -p $ACTIONS_PAT
- docker compose pull
- docker compose up -d
- docker image prune -af
depends_on:
- build-and-publish-frontend