- Implementadas 5 herramientas optimizadas: repos, commits, issues, secrets, variables - Descripciones compactas y claras para minimizar tokens - Integración con Gitea API usando token de autenticación - Enrutado en gitea.nucleoriofrio.com/mcp/* via Traefik - Sin autenticación Authentik (acceso directo) - Dockerfile y package.json configurados - Workflow actualizado para build y deploy automático - Variables de entorno agregadas al .env.example
80 lines
3.0 KiB
YAML
80 lines
3.0 KiB
YAML
name: build-and-deploy
|
||
|
||
on:
|
||
push:
|
||
branches: [ main, master ]
|
||
|
||
jobs:
|
||
#───────────────── build & push ─────────────────
|
||
build:
|
||
runs-on: docker
|
||
env:
|
||
REG: ${{ vars.REGISTRY_URL }}
|
||
APP_NAME: ${{ vars.APP_NAME }}
|
||
REPO_OWNER: ${{ github.repository_owner }}
|
||
steps:
|
||
- uses: actions/checkout@v3
|
||
- uses: docker/setup-buildx-action@v2
|
||
- uses: docker/login-action@v2
|
||
with:
|
||
registry: ${{ vars.REGISTRY_URL }}
|
||
username: ${{ secrets.REGISTRY_USERNAME }}
|
||
password: ${{ secrets.REGISTRY_PASSWORD }}
|
||
|
||
- name: Build+push ${{ vars.APP_NAME }}
|
||
run: |
|
||
cd nuxt4
|
||
docker build -t $REG/$REPO_OWNER/$APP_NAME:${{ github.sha }} -t $REG/$REPO_OWNER/$APP_NAME:latest .
|
||
docker push $REG/$REPO_OWNER/$APP_NAME:${{ github.sha }}
|
||
docker push $REG/$REPO_OWNER/$APP_NAME:latest
|
||
|
||
- name: Build+push MCP Docker Server
|
||
run: |
|
||
cd mcp-docker-server
|
||
docker build -t $REG/$REPO_OWNER/mcp-docker-server:${{ github.sha }} -t $REG/$REPO_OWNER/mcp-docker-server:latest .
|
||
docker push $REG/$REPO_OWNER/mcp-docker-server:${{ github.sha }}
|
||
docker push $REG/$REPO_OWNER/mcp-docker-server:latest
|
||
|
||
- name: Build+push MCP Gitea Server
|
||
run: |
|
||
cd mcp-gitea-server
|
||
docker build -t $REG/$REPO_OWNER/mcp-gitea-server:${{ github.sha }} -t $REG/$REPO_OWNER/mcp-gitea-server:latest .
|
||
docker push $REG/$REPO_OWNER/mcp-gitea-server:${{ github.sha }}
|
||
docker push $REG/$REPO_OWNER/mcp-gitea-server:latest
|
||
|
||
#───────────────── deploy ─────────────────
|
||
deploy:
|
||
needs: build
|
||
runs-on: docker
|
||
env:
|
||
REG: ${{ vars.REGISTRY_URL }}
|
||
REPO_OWNER: ${{ github.repository_owner }}
|
||
APP_NAME: ${{ vars.APP_NAME }}
|
||
# Variables de entorno para docker-compose
|
||
APP_DOMAIN: ${{ vars.APP_DOMAIN }}
|
||
NUXT_PUBLIC_APP_URL: ${{ vars.NUXT_PUBLIC_APP_URL }}
|
||
# Variables para MCP Gitea Server
|
||
GITEA_URL: ${{ vars.GITEA_URL }}
|
||
GITEA_DOMAIN: ${{ vars.GITEA_DOMAIN }}
|
||
GITEA_TOKEN: ${{ secrets.GITEA_TOKEN }}
|
||
steps:
|
||
- uses: actions/checkout@v3
|
||
- name: Login to registry
|
||
run: docker login ${{ vars.REGISTRY_URL }} -u ${{ secrets.REGISTRY_USERNAME }} -p ${{ secrets.REGISTRY_PASSWORD }}
|
||
|
||
- name: Info about environment
|
||
run: |
|
||
echo "ℹ️ Deploying ${{ vars.APP_NAME }}"
|
||
echo " Domain: ${{ vars.APP_DOMAIN }}"
|
||
echo " Image: ${{ vars.REGISTRY_URL }}/${{ github.repository_owner }}/${{ vars.APP_NAME }}:latest"
|
||
echo " Network: principal"
|
||
|
||
- name: Pull fresh images used in compose
|
||
run: docker compose pull
|
||
|
||
- name: Clean up stack
|
||
run: docker compose --project-name $APP_NAME down
|
||
|
||
- name: Update stack
|
||
run: docker compose --project-name $APP_NAME up -d --remove-orphans --wait
|