81 Commits

Author SHA1 Message Date
Guillermo
3ea406044b change docker image tag build process
Some checks failed
Tag Release / new images (release) Failing after 11s
2026-02-17 10:47:11 +00:00
Guillermo
4cd49d8c9a change docker image tag build process 2026-02-17 10:42:21 +00:00
Guillermo
7a931d32ba Update actions
Some checks failed
Tag Release / new images (release) Failing after 12s
2026-02-17 10:39:24 +00:00
01853b41ba two steps
All checks were successful
Tag Release / new images (release) Successful in 4s
2026-02-16 16:59:16 +00:00
8c2ffaae55 typo? 2026-02-16 16:57:23 +00:00
Guillermo
1976432a95 Changing workflows triggers
Some checks failed
Tag Release / create new images with tag (release) Failing after 0s
2026-02-16 16:50:00 +00:00
Guillermo
c25c6c2916 action for tag creation
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 1m7s
2026-02-16 16:17:26 +00:00
Guillermo
1a682c121e reduced at 468
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 1m8s
2026-02-16 14:44:43 +00:00
c633124454 Reduccion 1
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 1m36s
2026-02-15 15:08:56 +00:00
1030fa994c Reducción 1
Some checks failed
Workflow de prueba / Build and push images (push) Has been cancelled
2026-02-15 15:08:25 +00:00
5707b1fbc4 back to original
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 1m32s
2026-02-15 15:01:52 +00:00
Guillermo
d6db3d3e70 trying to reduce image size 2 fix typo
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 1m39s
2026-02-15 11:28:20 +00:00
Guillermo
768e384ed6 trying to reduce image size 2
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 32s
2026-02-15 11:24:09 +00:00
Guillermo
b6dc8485c0 trying to reduce image size
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 35s
2026-02-15 11:11:36 +00:00
Guillermo
47070f71db trying to reduce image size
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 34s
2026-02-15 11:06:09 +00:00
Guillermo
5e688aa1fa vuelta a node par aservir frontend
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 1m29s
2026-02-15 10:38:22 +00:00
232a687942 ignore more files
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 1m26s
2026-02-14 23:21:46 +00:00
b50e3c756c reduce image
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 1m25s
2026-02-14 23:04:32 +00:00
8cfce22f1d slimer image
Some checks failed
Workflow de prueba / Build and push images (push) Has been cancelled
2026-02-14 23:03:29 +00:00
2433b48c35 image frontend reduction
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 1m27s
2026-02-14 22:50:49 +00:00
c5064383fe fix typo in image name
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 1m28s
2026-02-14 19:04:01 +00:00
77b61d3f33 Change backend build context
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 1m34s
2026-02-14 18:41:30 +00:00
Guillermo
070af13d86 push differents images
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 33s
2026-02-14 11:57:57 +00:00
Guillermo
2a070ab921 new tag of image
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 1m22s
2026-02-14 11:39:18 +00:00
Guillermo
7923b8c13e new test
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 1m20s
2026-02-14 11:23:44 +00:00
Guillermo
d924636def new registry
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 1m24s
2026-02-14 10:45:41 +00:00
Guillermo
8bb952eba5 branch
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 1m19s
2026-02-13 14:04:11 +00:00
Guillermo
80df1368b1 branch
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 1m22s
2026-02-13 14:01:07 +00:00
Guillermo
a5fe8414de branch
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 10s
2026-02-13 13:56:26 +00:00
Guillermo
5edfd256c1 branch
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 10s
2026-02-13 13:55:42 +00:00
Guillermo
9f04467a6d bad user to push
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 11s
2026-02-13 13:53:31 +00:00
Guillermo
f8323ea419 bad user to push
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 10s
2026-02-13 13:51:41 +00:00
Guillermo
1cc463f659 bad user to push
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 1m28s
2026-02-13 13:46:11 +00:00
Guillermo
caa7cfb564 remove amr64
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 1m19s
2026-02-13 13:42:27 +00:00
Guillermo
559f49db8a remove amr64
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 1m22s
2026-02-13 13:29:50 +00:00
Guillermo
57d2bcdd07 remove amr64 2026-02-13 13:28:37 +00:00
Guillermo
807bcc8034 registry problems
Some checks failed
Workflow de prueba / Build and push images (push) Has been cancelled
2026-02-13 13:23:01 +00:00
Guillermo
46b85f5ee7 without QEMU & pushing to registry
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 9m31s
2026-02-13 13:06:16 +00:00
Guillermo
d252607c79 without QEMU 2026-02-13 12:53:43 +00:00
Guillermo
083e398f5d bad param name?
Some checks failed
Workflow de prueba / Build and push images (push) Has been cancelled
2026-02-13 12:49:53 +00:00
Guillermo
3721bdd35f typo fixed
Some checks failed
Workflow de prueba / Build and push images (push) Has been cancelled
2026-02-13 12:40:35 +00:00
Guillermo
1f2928a71d bug fixed?
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 9m30s
2026-02-13 11:57:40 +00:00
Guillermo
a92fb51b5d bug fixed?
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 22s
2026-02-13 11:51:47 +00:00
Guillermo
26534774ef bug fixed? 2026-02-13 11:50:40 +00:00
Guillermo
0f67f16047 With registry URL & credentials 2026-02-13 11:49:12 +00:00
Guillermo
eea9bcd885 Added a new step
Some checks failed
Workflow de prueba / Build and push images (push) Failing after 11m53s
2026-02-13 08:41:24 +00:00
Guillermo
2747bef898 fix typo in action
All checks were successful
Workflow de prueba / Build and push images (push) Successful in 9m29s
2026-02-13 07:43:13 +00:00
Guillermo
932ab0f0d4 test gitea action
Some checks failed
Workflow de prueba / Build and push images (push) Has been cancelled
2026-02-12 22:08:48 +00:00
Guillermo
4039dc54cb traefik version updated 2026-02-12 14:19:56 +00:00
Guillermo
fe0c2de0d4 fixing bugs 2026-02-12 14:17:28 +00:00
Guillermo
02d25ea19f script to deploy traefik in server 2026-02-12 13:20:00 +00:00
Guillermo
af4a5a35c7 looks clean 2026-02-12 13:00:40 +00:00
Guillermo
022f04b9ed cleaning install script 2026-02-12 12:53:13 +00:00
Guillermo
122a10be49 sed command +g 2026-02-12 12:51:33 +00:00
Guillermo
2ef0a742e1 double quotes 2026-02-12 11:58:28 +00:00
Guillermo
9e01d9d2fb test 2026-02-12 11:43:27 +00:00
Guillermo
3532f4f621 adaptations 2026-02-12 11:32:38 +00:00
Guillermo
9effa23d3b Bug fixes 2026-02-12 11:19:18 +00:00
Guillermo
6a8ffe5da8 Actualizado Domain y subdomain 2026-02-12 09:19:56 +00:00
Guillermo
df12fe5339 Change domain_base in traefik labels 2026-02-12 09:12:29 +00:00
Guillermo
4fc681b2c4 cambiado el path de instalacion, eliminado el nginx y con labels de traefik 2026-02-10 18:39:21 +00:00
sujucu70
9c779eccb4 Merge pull request #23 from sujucu70/claude/check-agent-readiness-status-Exnpc
fix: remove duplicate 'table' object causing clickToExpand translatio…
2026-02-08 16:27:34 +01:00
sujucu70
7be286e2c9 Merge pull request #22 from sujucu70/claude/check-agent-readiness-status-Exnpc
fix: remove duplicate 'summary' object in agenticReadiness causing tr…
2026-02-08 16:10:42 +01:00
sujucu70
39806559d7 Merge pull request #21 from sujucu70/claude/check-agent-readiness-status-Exnpc
fix: change default language from Spanish to English
2026-02-08 15:54:15 +01:00
sujucu70
b3c4724100 Merge pull request #20 from sujucu70/claude/check-agent-readiness-status-Exnpc
Claude/check agent readiness status exnpc
2026-02-08 15:43:12 +01:00
sujucu70
a250559509 Merge pull request #19 from sujucu70/claude/check-agent-readiness-status-Exnpc
Claude/check agent readiness status exnpc
2026-02-08 15:28:27 +01:00
sujucu70
0e29d998c9 Merge pull request #18 from sujucu70/claude/check-agent-readiness-status-Exnpc
feat: translate OpportunityPrioritizer component to English
2026-02-08 14:06:05 +01:00
sujucu70
57239e86a2 Merge pull request #17 from sujucu70/claude/check-agent-readiness-status-Exnpc
fix: pass translation function t as prop to AgenticReadinessHeader
2026-02-08 12:57:42 +01:00
sujucu70
5dcd605168 Merge pull request #16 from sujucu70/claude/check-agent-readiness-status-Exnpc
fix: translate all remaining Spanish text in RoadmapTab
2026-02-08 12:18:44 +01:00
sujucu70
556a3f3d11 Merge pull request #15 from sujucu70/claude/check-agent-readiness-status-Exnpc
fix: translate remaining Spanish text in RoadmapTab priority queues s…
2026-02-08 11:54:45 +01:00
sujucu70
3f77897a4c Merge pull request #14 from sujucu70/claude/check-agent-readiness-status-Exnpc
Claude/check agent readiness status exnpc
2026-02-08 11:39:07 +01:00
sujucu70
d7fd852bec Merge pull request #13 from sujucu70/claude/check-agent-readiness-status-Exnpc
Claude/check agent readiness status exnpc
2026-02-08 00:36:05 +01:00
sujucu70
c7580f60ef Merge pull request #12 from sujucu70/claude/check-agent-readiness-status-Exnpc
Claude/check agent readiness status exnpc
2026-02-07 22:04:41 +01:00
sujucu70
69fce1dc28 Merge pull request #11 from sujucu70/claude/check-agent-readiness-status-Exnpc
Claude/check agent readiness status exnpc
2026-02-07 19:43:53 +01:00
sujucu70
20bcf94137 Merge pull request #10 from sujucu70/claude/check-agent-readiness-status-Exnpc
Claude/check agent readiness status exnpc
2026-02-07 19:18:18 +01:00
sujucu70
dc93b6d9e0 Merge pull request #9 from sujucu70/claude/check-agent-readiness-status-Exnpc
Claude/check agent readiness status exnpc
2026-02-07 19:07:46 +01:00
sujucu70
75ddb23000 Merge pull request #8 from sujucu70/claude/check-agent-readiness-status-Exnpc
feat: complete RoadmapTab Spanish-to-English translation
2026-02-07 18:58:20 +01:00
sujucu70
badbc82478 Merge pull request #7 from sujucu70/claude/check-agent-readiness-status-Exnpc
Claude/check agent readiness status exnpc
2026-02-07 18:47:20 +01:00
sujucu70
bbaf34f507 Merge pull request #6 from sujucu70/claude/check-agent-readiness-status-Exnpc
fix: translate remaining Spanish UI strings and comments to English
2026-02-07 18:07:00 +01:00
sujucu70
0a98843d6c Merge pull request #5 from sujucu70/claude/check-agent-readiness-status-Exnpc
Translate Phase 3 low-priority backend files (complete Spanish-to-Eng…
2026-02-07 12:18:17 +01:00
sujucu70
83a32a48b2 Merge pull request #4 from sujucu70/claude/check-agent-readiness-status-Exnpc
Claude/check agent readiness status exnpc
2026-02-07 12:05:50 +01:00
8 changed files with 359 additions and 215 deletions

View File

@@ -0,0 +1,52 @@
name: Workflow de prueba
on:
pull_request_review:
types: [submitted]
env:
DOCKER_ORG: beyondcx
BRANCH_NAME: ${{ github.head_ref || github.ref_name }}
jobs:
Build and push images:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup Buildx
uses: docker/setup-buildx-action@v3
with:
driver-opts: network=host
- name: Echo the Tag
run: echo "Tag ${{ env.DOCKER_ORG }}/beyondcx:${{ env.BRANCH_NAME }}"
- name: Login to Registry
uses: docker/login-action@v3
with:
registry: ${{ secrets.REGISTRY_URL }}
username: ${{ secrets.REGISTRY_USER }}
password: ${{ secrets.REGISTRY_PWD }}
- name: Build frontend and push it to registry
uses: docker/build-push-action@v5
with:
context: frontend
push: false
tags: ${{ secrets.REGISTRY_URL }}/${{ env.DOCKER_ORG }}/frontend-analytics-demo:${{ env.BRANCH_NAME }}
platforms: linux/amd64
file: frontend/Dockerfile
- name: Build backend and push it to registry
uses: docker/build-push-action@v5
with:
context: backend
push: false
tags: ${{ secrets.REGISTRY_URL }}/${{ env.DOCKER_ORG }}/backend-analytics-demo:${{ env.BRANCH_NAME }}
platforms: linux/amd64
file: backend/Dockerfile

49
.gitea/workflows/tag.yaml Normal file
View File

@@ -0,0 +1,49 @@
name: Tag Release
on:
release:
types: [created,edited,published]
jobs:
new images:
runs-on: ubuntu-latest
steps:
- name: Extract Tag Name
uses: olegtarasov/get-tag@v2.1.4
id: tagName
- name: Show tag
run: echo "$GIT_TAG_NAME";
- name: Checkout
uses: actions/checkout@v4
- name: Setup Buildx
uses: docker/setup-buildx-action@v3
with:
driver-opts: network=host
- name: Login to Registry
uses: docker/login-action@v3
with:
registry: ${{ secrets.REGISTRY_URL }}
username: ${{ secrets.REGISTRY_USER }}
password: ${{ secrets.REGISTRY_PWD }}
- name: Build frontend and push it to registry
uses: docker/build-push-action@v5
with:
context: frontend
push: true
tags: ${{ secrets.REGISTRY_URL }}/${{ env.DOCKER_ORG }}/frontend-analytics-demo:${{ step.tagName.outputs.tag }}
platforms: linux/amd64
file: frontend/Dockerfile
- name: Build backend and push it to registry
uses: docker/build-push-action@v5
with:
context: backend
push: true
tags: ${{ secrets.REGISTRY_URL }}/${{ env.DOCKER_ORG }}/backend-analytics-demo:${{ step.tagName.outputs.tag }}
platforms: linux/amd64
file: backend/Dockerfile

View File

@@ -11,3 +11,8 @@ build
data/output data/output
*.zip *.zip
.DS_Store .DS_Store
*.log
Dockerfile
docker-compose.yml
.env
tests

View File

@@ -1,31 +1,50 @@
# backend/Dockerfile # ---------------------------
FROM python:3.11-slim # Builder stage
# ---------------------------
FROM python:3.13-bookworm AS builder
# Evitar .pyc y buffering # Solo herramientas necesarias para compilar dependencias
ENV PYTHONDONTWRITEBYTECODE=1 RUN apt-get update && apt-get install -y --no-install-recommends \
ENV PYTHONUNBUFFERED=1 build-essential && apt-get clean && rm -rf /var/lib/apt/lists/*
ADD https://astral.sh/uv/install.sh /install.sh
RUN chmod -R 655 /install.sh && /install.sh && rm /install.sh
ENV PATH="/root/.local/bin:$PATH"
WORKDIR /app WORKDIR /app
# Dependencias del sistema mínimas # Copiamos solo archivos de dependencias (mejor cache)
RUN apt-get update && apt-get install -y --no-install-recommends \
build-essential \
&& rm -rf /var/lib/apt/lists/*
# Copiamos pyproject y lock si lo hubiera
COPY pyproject.toml ./ COPY pyproject.toml ./
# Instalamos dependencias # Cambiamos pip por uv más moderno y rápido
RUN pip install --upgrade pip && \ RUN uv sync
pip install .
# ---------------------------
# Runtime stage
# ---------------------------
FROM python:3.13-slim-bookworm AS production
# Copiamos el resto del código (respetando .dockerignore)
COPY . .
# Variables de autenticación básica
ENV BASIC_AUTH_USERNAME=admin ENV BASIC_AUTH_USERNAME=admin
ENV BASIC_AUTH_PASSWORD=admin ENV BASIC_AUTH_PASSWORD=admin
WORKDIR /app
# Crear usuario no-root
RUN useradd --create-home appuser
# Copiamos código y producto uv
COPY . .
COPY --from=builder /app/.venv .venv
# Cambiar permisos
#RUN chown -R appuser:appuser /app
#USER appuser
ENV PATH="/app/.venv/bin:$PATH"
EXPOSE 8000 EXPOSE 8000
CMD ["python", "-m", "uvicorn", "beyond_api.main:app", "--host", "0.0.0.0", "--port", "8000"] CMD ["uvicorn", "beyond_api.main:app", "--host", "0.0.0.0", "--port", "8000"]

View File

@@ -4,7 +4,7 @@ services:
backend: backend:
build: build:
context: ./backend context: ./backend
container_name: beyond-backend container_name: XXX-backend
environment: environment:
# credenciales del API (las mismas que usas ahora) # credenciales del API (las mismas que usas ahora)
BASIC_AUTH_USERNAME: "beyond" BASIC_AUTH_USERNAME: "beyond"
@@ -15,39 +15,37 @@ services:
expose: expose:
- "8000" - "8000"
networks: networks:
- beyond-net - XXX-beyond-net
frontend: XXXfrontend:
build: build:
context: ./frontend context: ./frontend
args: args:
# el front compilará con este BASE_URL -> /api # el front compilar con este BASE_URL -> /api
VITE_API_BASE_URL: /api VITE_API_BASE_URL: /api
container_name: beyond-frontend container_name: XXX-frontend
expose: expose:
- "4173" - "4173"
networks: networks:
- beyond-net - XXX-beyond-net
- frontend
nginx: labels:
image: nginx:1.27-alpine - "traefik.enable=true"
container_name: beyond-nginx - "traefik.http.routers.XXX-server.rule=Host(`DDD`)"
- "traefik.http.routers.XXX-server.entrypoints=websecure"
- "traefik.http.routers.XXX-server.tls=true"
- "traefik.http.routers.XXX-server.tls.certresolver=doresolv"
- "traefik.http.routers.XXX-server.service=XXXfrontend"
- "traefik.http.services.XXXfrontend.loadBalancer.server.port=4173"
depends_on: depends_on:
- backend - backend
- frontend
ports:
- "80:80"
- "443:443"
volumes:
- /etc/letsencrypt:/etc/letsencrypt:ro
- ./nginx/conf.d:/etc/nginx/conf.d:ro
networks:
- beyond-net
volumes: volumes:
cache-data: cache-data:
driver: local driver: local
networks: networks:
beyond-net: XXX-beyond-net:
driver: bridge driver: bridge
frontend:
external: true

View File

@@ -20,17 +20,22 @@ ENV VITE_API_BASE_URL=${VITE_API_BASE_URL}
# Construimos el bundle # Construimos el bundle
RUN npm run build RUN npm run build
# 2) Fase de servidor estático # 2) Fase de servidor estático. Tenemos que revisar
FROM node:20-alpine FROM node:20-alpine
#FROM nginx:alpine
WORKDIR /app WORKDIR /app
#RUN rm -rf /usr/share/nginx/html/*
# Copiamos el build # Copiamos el build
#COPY --from=build /app/dist /usr/share/nginx/html
COPY --from=build /app/dist ./dist COPY --from=build /app/dist ./dist
# Server estático muy simple # Server estático muy simple
RUN npm install -g serve RUN npm install -g serve
#EXPOSE 80
EXPOSE 4173 EXPOSE 4173
#CMD ["nginx", "-g", "daemon off;"]
CMD ["serve", "-s", "dist", "-l", "4173"] CMD ["serve", "-s", "dist", "-l", "4173"]

View File

@@ -5,8 +5,8 @@ set -euo pipefail
# CONFIGURACIÓN BÁSICA EDITA ESTO # CONFIGURACIÓN BÁSICA EDITA ESTO
############################################### ###############################################
# TODO: pon aquí la URL real de tu repo (sin credenciales) # TODO: pon aquí la URL real de tu repo (sin credenciales)
REPO_URL_DEFAULT="https://github.com/igferne/Beyond-Diagnosis.git" REPO_URL_DEFAULT="ssh://git@git.beyondcx.org:2424/susana/BeyondCXAnalytics-Demo.git"
INSTALL_DIR="/opt/beyonddiagnosis" INSTALL_BASE="/opt/beyondcx"
############################################### ###############################################
# UTILIDADES # UTILIDADES
@@ -38,11 +38,13 @@ if [ -z "$DOMAIN" ]; then
exit 1 exit 1
fi fi
read -rp "Email para Let's Encrypt (avisos de renovación): " EMAIL SUBDOMAIN=${DOMAIN%%.*}
if [ -z "$EMAIL" ]; then if [[ $DOMAIN == $SUBDOMAIN ]]; then
echo "El email no puede estar vacío." DOMAIN=$DOMAIN".analytics.beyondcx.org"
exit 1
fi fi
echo "el dominio es $DOMAIN y el subdominio $SUBDOMAIN"
INSTALL_DIR=$INSTALL_BASE"/"$SUBDOMAIN
read -rp "Usuario de acceso (Basic Auth / login): " API_USER read -rp "Usuario de acceso (Basic Auth / login): " API_USER
if [ -z "$API_USER" ]; then if [ -z "$API_USER" ]; then
@@ -61,41 +63,14 @@ echo
read -rp "URL del repositorio Git (HTTPS, sin credenciales) [$REPO_URL_DEFAULT]: " REPO_URL read -rp "URL del repositorio Git (HTTPS, sin credenciales) [$REPO_URL_DEFAULT]: " REPO_URL
REPO_URL=${REPO_URL:-$REPO_URL_DEFAULT} REPO_URL=${REPO_URL:-$REPO_URL_DEFAULT}
echo
read -rp "¿El repositorio es PRIVADO en GitHub y necesitas token? [s/N]: " IS_PRIVATE
IS_PRIVATE=${IS_PRIVATE:-N}
GIT_CLONE_URL="$REPO_URL" GIT_CLONE_URL="$REPO_URL"
if [[ "$IS_PRIVATE" =~ ^[sS]$ ]]; then
echo "Introduce un Personal Access Token (PAT) de GitHub con permiso de lectura del repo."
read -rsp "GitHub PAT: " GITHUB_TOKEN
echo
if [ -z "$GITHUB_TOKEN" ]; then
echo "El token no puede estar vacío si el repo es privado."
exit 1
fi
# Construimos una URL del tipo: https://TOKEN@github.com/usuario/repo.git
if [[ "$REPO_URL" =~ ^https:// ]]; then
GIT_CLONE_URL="https://${GITHUB_TOKEN}@${REPO_URL#https://}"
else
echo "La URL del repositorio debe empezar por https:// para usar el token."
exit 1
fi
fi
echo echo
echo "Resumen de configuración:" echo "Resumen de configuración:"
echo " Dominio: $DOMAIN" echo " Dominio: $DOMAIN"
echo " Email Let'sEnc: $EMAIL"
echo " Usuario API: $API_USER" echo " Usuario API: $API_USER"
echo " Repo (visible): $REPO_URL" echo " Repo (visible): $REPO_URL"
if [[ "$IS_PRIVATE" =~ ^[sS]$ ]]; then echo " Path del despliegue: $INSTALL_DIR"
echo " Repo privado: Sí (se usará un PAT sólo para el clon inicial)"
else
echo " Repo privado: No"
fi
echo
read -rp "¿Continuar con la instalación? [s/N]: " CONFIRM read -rp "¿Continuar con la instalación? [s/N]: " CONFIRM
CONFIRM=${CONFIRM:-N} CONFIRM=${CONFIRM:-N}
@@ -104,70 +79,20 @@ if [[ ! "$CONFIRM" =~ ^[sS]$ ]]; then
exit 0 exit 0
fi fi
############################################### # COMENZAMOS ...
# 2. INSTALAR DOCKER + DOCKER COMPOSE + CERTBOT
###############################################
step "Instalando Docker, docker compose plugin y certbot"
apt-get update -y
# Dependencias para repositorio Docker
apt-get install -y \
ca-certificates \
curl \
gnupg \
lsb-release
# Clave GPG de Docker
if [ ! -f /etc/apt/keyrings/docker.gpg ]; then
install -m 0755 -d /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | \
gpg --dearmor -o /etc/apt/keyrings/docker.gpg
fi
# Repo Docker estable
if [ ! -f /etc/apt/sources.list.d/docker.list ]; then
echo \
"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \
$(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \
tee /etc/apt/sources.list.d/docker.list > /dev/null
fi
apt-get update -y
apt-get install -y \
docker-ce \
docker-ce-cli \
containerd.io \
docker-buildx-plugin \
docker-compose-plugin \
git \
certbot
systemctl enable docker
systemctl start docker
# Abrimos puertos en ufw si está activo
if command -v ufw >/dev/null 2>&1; then
if ufw status | grep -q "Status: active"; then
step "Configurando firewall (ufw) para permitir 80 y 443"
ufw allow 80/tcp || true
ufw allow 443/tcp || true
fi
fi
###############################################
# 3. CLONAR / ACTUALIZAR REPO
###############################################
step "Descargando/actualizando el repositorio en $INSTALL_DIR" step "Descargando/actualizando el repositorio en $INSTALL_DIR"
eval $(ssh-agent -s)
ssh-add /home/garbelo/.ssh/id_ed25519
if [ -d "$INSTALL_DIR/.git" ]; then if [ -d "$INSTALL_DIR/.git" ]; then
echo "Directorio git ya existe, haciendo 'git pull'..." echo "Directorio git ya existe, haciendo 'git pull'..."
git -C "$INSTALL_DIR" pull --ff-only git -C "$INSTALL_DIR" pull --ff-only
else else
rm -rf "$INSTALL_DIR" rm -rf "$INSTALL_DIR"
echo "Clonando repositorio..." echo "Clonando repositorio..."
git clone "$GIT_CLONE_URL" "$INSTALL_DIR" # git clone "$GIT_CLONE_URL" "$INSTALL_DIR"
git clone -b proxy "$GIT_CLONE_URL" "$INSTALL_DIR"
fi fi
cd "$INSTALL_DIR" cd "$INSTALL_DIR"
@@ -189,97 +114,22 @@ else
sed -i "s/BASIC_AUTH_PASSWORD:.*/BASIC_AUTH_PASSWORD: \"$API_PASS\"/" docker-compose.yml sed -i "s/BASIC_AUTH_PASSWORD:.*/BASIC_AUTH_PASSWORD: \"$API_PASS\"/" docker-compose.yml
fi fi
# Aseguramos que nginx exponga también 443 if ! grep -q "XXX" docker-compose.yml; then
if grep -q 'ports:' docker-compose.yml && grep -q 'nginx:' docker-compose.yml; then echo "⚠ No encuentro XXX en docker-compose.yml. Revisa el archivo a mano."
if ! grep -q '443:443' docker-compose.yml; then
sed -i '/- "80:80"/a\ - "443:443"' docker-compose.yml || true
fi
fi
# Aseguramos que montamos /etc/letsencrypt dentro del contenedor de nginx
if ! grep -q '/etc/letsencrypt:/etc/letsencrypt:ro' docker-compose.yml; then
sed -i '/nginx:/,/networks:/{
/volumes:/a\ - /etc/letsencrypt:/etc/letsencrypt:ro
}' docker-compose.yml || true
fi
###############################################
# 5. OBTENER CERTIFICADO LET'S ENCRYPT
###############################################
step "Obteniendo certificado SSL de Lets Encrypt para $DOMAIN"
if [ -f "/etc/letsencrypt/live/$DOMAIN/fullchain.pem" ]; then
echo "Certificado ya existe, saltando paso de emisión."
else else
# Asegurarnos de que no hay nada escuchando en 80/443 sed -i "s/XXX/$SUBDOMAIN/g" docker-compose.yml
systemctl stop nginx || true fi
if [[ $DOMAIN == $SUBDOMAIN ]]; then
certbot certonly \ set DOMAIN=$DOMAIN".analytics.beyondcx.org"
--standalone \ fi
--non-interactive \ if ! grep -q "DDD" docker-compose.yml; then
--agree-tos \ echo "⚠ No encuentro DDD en docker-compose.yml. Revisa el archivo a mano."
-m "$EMAIL" \ else
-d "$DOMAIN" sed -i "s/DDD/$DOMAIN/" docker-compose.yml
echo "Certificado emitido en /etc/letsencrypt/live/$DOMAIN/"
fi fi
###############################################
# 6. CONFIGURAR NGINX DENTRO DEL REPO
###############################################
step "Generando configuración nginx con SSL"
mkdir -p nginx/conf.d
cat > nginx/conf.d/beyond.conf <<EOF
server {
listen 80;
server_name $DOMAIN;
return 301 https://\$host\$request_uri;
client_max_body_size 1024M;
}
server {
listen 443 ssl;
server_name $DOMAIN;
client_max_body_size 1024M;
ssl_certificate /etc/letsencrypt/live/$DOMAIN/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/$DOMAIN/privkey.pem;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_ciphers HIGH:!aNULL:!MD5;
# FRONTEND (React)
location / {
proxy_pass http://frontend:4173/;
proxy_http_version 1.1;
proxy_set_header Host \$host;
proxy_set_header X-Real-IP \$remote_addr;
proxy_set_header Upgrade \$http_upgrade;
proxy_set_header Connection "upgrade";
}
# BACKEND (FastAPI)
location /api/ {
proxy_pass http://backend:8000/;
proxy_http_version 1.1;
proxy_set_header Host \$host;
proxy_set_header X-Real-IP \$remote_addr;
proxy_set_header Upgrade \$http_upgrade;
proxy_set_header Connection "upgrade";
proxy_connect_timeout 60s;
proxy_send_timeout 600s;
proxy_read_timeout 600s;
send_timeout 600s;
}
}
EOF
###############################################
# 7. BUILD Y ARRANQUE DE CONTENEDORES
###############################################
step "Construyendo imágenes Docker y arrancando contenedores" step "Construyendo imágenes Docker y arrancando contenedores"
docker compose build docker compose build

166
prepare_server.sh Normal file
View File

@@ -0,0 +1,166 @@
#!/usr/bin/env bash
set -euo pipefail
step() {
echo
echo "=================================================="
echo " 👉 $1"
echo "=================================================="
}
require_root() {
if [ "$(id -u)" -ne 0 ]; then
echo "Este script debe ejecutarse como root (o con sudo)."
exit 1
fi
}
require_root
step "Instalando Docker, docker compose plugin y certbot"
apt-get update -y
# Dependencias para repositorio Docker
apt-get install -y \
ca-certificates \
curl \
gnupg \
lsb-release
# Clave GPG de Docker
if [ ! -f /etc/apt/keyrings/docker.gpg ]; then
install -m 0755 -d /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | \
gpg --dearmor -o /etc/apt/keyrings/docker.gpg
fi
# Repo Docker estable
if [ ! -f /etc/apt/sources.list.d/docker.list ]; then
echo \
"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \
$(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \
tee /etc/apt/sources.list.d/docker.list > /dev/null
fi
apt-get update -y
apt-get install -y \
docker-ce \
docker-ce-cli \
containerd.io \
docker-buildx-plugin \
docker-compose-plugin \
git
systemctl enable docker
systemctl start docker
# Abrimos puertos en ufw si está activo
if command -v ufw >/dev/null 2>&1; then
if ufw status | grep -q "Status: active"; then
step "Configurando firewall (ufw) para permitir 80 y 443"
ufw allow 80/tcp || true
ufw allow 443/tcp || true
fi
fi
# Creamos carpeta del proxy con docker compose.
mkdir -p /opt/beyondcx/traefik
cat > /opt/beyondcx/traefik/docker-compose.yaml <<EOF
services:
traefik:
image: traefik:v3.6.1
container_name: traefik-prod-1
ports:
- "80:80"
- "443:443"
- "8080:8080"
environment:
- DO_AUTH_TOKEN=\${DO_AUTH_TOKEN}
volumes:
- /var/run/docker.sock:/var/run/docker.sock
- ./config/traefik.yml:/etc/traefik/traefik.yaml:ro
- ./data/certs:/var/traefik/certs/:rw
- ./config/conf:/etc/traefik/conf/:rw
- ./logs:/var/traefik/logs:rw
logging:
driver: "json-file"
options:
max-size: "100m"
networks:
- frontend
restart: unless-stopped
networks:
frontend:
external: true
EOF
mkdir -p /opt/beyondcx/traefik/config
mkdir -p /opt/beyondcx/traefik/logs
mkdir -p /opt/beyondcx/traefik/config/conf
echo "DO_AUTH_TOKEN=" > /opt/beyondcx/traefik/.env
cat > /opt/beyondcx/traefik/config/traefik.yml <<EOF
global:
checkNewVersion: false
sendAnonymousUsage: false
log:
level: DEBUG
api:
dashboard: true
insecure: true
entryPoints:
web:
address: :80
websecure:
address: :443
certificatesResolvers:
doresolv:
acme:
email: "garbelo@gmail.com"
storage: /var/traefik/certs/doresolv-acme.json
caServer: 'https://acme-v02.api.letsencrypt.org/directory'
keyType: EC256
dnsChallenge:
provider: digitalocean
resolvers:
- "8.8.8.8:53"
- "1.1.1.1:53"
providers:
docker:
endpoint: "unix:///var/run/docker.sock"
exposedByDefault: false
network: frontend
file:
directory: /etc/traefik/conf/
watch: true
EOF
cd /opt/beyondcx/traefik
PROXY_NETWORK="frontend"
if docker network inspect $PROXY_NETWORK > /dev/null 2>&1; then
echo "red de traefik existe"
else
docker network create $PROXY_NETWORK
fi
docker compose up -d
step "Levantado traefik "
docker compose ps
docker compose logs
step "Recuerda, tienes que crear el DO_AUTH_TOKEN en el .env"