7.8 KiB
HLL Vietnam
HLL Vietnam es la base inicial del repositorio para una futura web de comunidad enfocada en la comunidad hispana de Discord del juego HLL Vietnam.
En esta primera fase, el proyecto se centra en una landing sencilla, limpia y profesional que sirva como punto de entrada para la comunidad. La implementacion actual utiliza HTML, CSS y JavaScript sin frameworks pesados para mantener una base facil de mantener y ampliar.
Estado actual
- Landing inicial de comunidad.
- Estructura de repositorio preparada para crecer.
- Carpeta de backend reservada para una futura implementacion en Python.
- Carpeta
ai/ya integrada como capa operativa para orquestacion por tasks y trabajo con Codex.
Estructura del repositorio
/
|-- README.md
|-- .gitignore
|-- AGENTS.md
|-- docs/
| |-- project-overview.md
| |-- roadmap.md
| `-- decisions.md
|-- frontend/
| |-- index.html
| |-- historico.html
| |-- Dockerfile
| |-- .dockerignore
| `-- assets/
| |-- css/
| |-- js/
| `-- img/
|-- backend/
| |-- README.md
| |-- requirements.txt
| |-- Dockerfile
| |-- .dockerignore
| |-- .env.example
| `-- app/
| `-- __init__.py
|-- ai/
| |-- README.md
| |-- architecture-index.md
| |-- repo-context.md
| |-- system-metrics.md
| |-- task-template.md
| |-- prompts/
| | `-- plan-feature.md
| |-- orchestrator/
| | `-- README.md
| `-- tasks/
| |-- pending/
| |-- in-progress/
| `-- done/
|-- docker-compose.yml
`-- scripts/
Backend futuro
El backend principal esta previsto en Python, pero en esta fase no se introduce infraestructura final de produccion. La base actual prioriza un bootstrap pequeno, una persistencia local clara y una evolucion controlada.
Como abrir el frontend localmente
- Ve a la carpeta
frontend/. - Abre
index.htmldirectamente en el navegador.
No hace falta servidor para esta primera version.
Ejecucion con Docker
El repositorio ya incluye:
backend/Dockerfilefrontend/Dockerfiledocker-compose.ymlbackend/.env.example
Seleccion de proveedor por entorno hoy:
- desarrollo:
HLL_BACKEND_LIVE_DATA_SOURCE=rconHLL_BACKEND_HISTORICAL_DATA_SOURCE=rcon
- produccion realista en esta fase:
HLL_BACKEND_LIVE_DATA_SOURCE=rconHLL_BACKEND_HISTORICAL_DATA_SOURCE=rcon
Esto refleja la politica operativa actual: RCON es la fuente primaria para live e historico. El scoreboard publico queda como fallback historico cuando RCON falla, no cubre una operacion concreta o aun no tiene cobertura suficiente.
Modo normal recomendado:
- levantar solo
backend+frontend - mantener
historical-runneryrcon-historical-workercomo servicios avanzados bajo demanda - mantener Comunidad Hispana #03 fuera de los targets RCON por defecto
- dejar Elo/MMR y la materializacion historica compleja en pausa operativa hasta una reintroduccion explicita
Primer arranque:
docker compose up --build
Con la configuracion actual, ese comando levanta solo backend y frontend.
Los workers historicos estan en el perfil Compose advanced y no forman parte
del arranque normal.
Accesos locales esperados:
- frontend:
http://localhost:8080 - backend:
http://localhost:8000 - health del backend:
http://localhost:8000/health
Persistencia:
- el SQLite historico se conserva en
backend/data/hll_vietnam_dev.sqlite3 - los snapshots JSON se conservan en
backend/data/snapshots/ docker-compose.ymlmonta./backend/datadentro del contenedor en/app/data
Reinicio normal:
docker compose up -d
Parada:
docker compose down
Recreacion de imagenes tras cambios:
docker compose up --build
Runbook de proveedores
Verificacion minima del proveedor activo:
Invoke-WebRequest http://localhost:8000/health | Select-Object -Expand Content
La respuesta incluye live_data_source y historical_data_source.
Modo desarrollo recomendado:
docker compose up --build
Modo live con RCON en Docker Compose:
$env:HLL_BACKEND_LIVE_DATA_SOURCE='rcon'
$env:HLL_BACKEND_HISTORICAL_DATA_SOURCE='rcon'
$env:HLL_BACKEND_RCON_TARGETS='[
{
"name": "Comunidad Hispana #01",
"host": "203.0.113.10",
"port": 28015,
"password": "replace-me",
"external_server_id": "comunidad-hispana-01",
"region": "ES",
"game_port": 7777,
"query_port": 7778
}
]'
docker compose up -d backend frontend
Buenas practicas:
- no versionar credenciales reales en
backend/.env.example - preferir exportarlas como variables de entorno del host o del secreto del despliegue
- mantener
HLL_BACKEND_HISTORICAL_DATA_SOURCE=rconcomo valor normal y usarpublic-scoreboardsolo como fallback historico controlado - no reintroducir Comunidad Hispana #03 en
HLL_BACKEND_RCON_TARGETSsalvo que una task nueva valide su disponibilidad
Operaciones historicas avanzadas con Docker
Estas operaciones quedan disponibles para uso explicito, pero no son parte del
arranque recomendado. La ruta normal de despliegue es backend + frontend.
El codigo, las migraciones, los snapshots historicos y Elo/MMR se conservan en
la repo, pero Elo/MMR y la materializacion historica compleja quedan pausados
operativamente en esta fase.
Refresh historico puntual dentro del contenedor backend:
docker compose exec backend python -m app.historical_ingestion refresh
Bootstrap o backfill historico:
docker compose exec backend python -m app.historical_ingestion bootstrap
Regeneracion puntual de snapshots mediante refresh controlado:
docker compose exec backend python -m app.historical_runner --max-runs 1
Automatizacion horaria avanzada:
docker compose --profile advanced up -d backend historical-runner frontend
historical-runner es un servicio Compose separado que ejecuta
python -m app.historical_runner --hourly. Sigue disponible para tareas
historicas explicitas, pero no se recomienda como requisito normal de
despliegue. Los targets RCON por defecto solo incluyen comunidad-hispana-01
y comunidad-hispana-02; comunidad-hispana-03 queda deshabilitado en la
configuracion por defecto porque ya no es una fuente operativa vigente.
Verificacion minima:
docker compose ps historical-runnerdocker compose logs -f historical-runner- revisar
generated_atenbackend/data/snapshots/
Arquitectura historica RCON-first
La linea historica actual usa RCON como fuente primaria. El flujo previsto es:
- captura de sesiones RCON para cobertura, frescura y ventanas competitivas
- ingesta de AdminLog mediante
app.rcon_admin_log_ingestion - parsing de eventos AdminLog hacia eventos normalizados
- almacenamiento en tablas
rcon_admin_log_*yrcon_historical_* - materializacion de partidas cerradas y estadisticas de jugador desde eventos RCON
- enriquecimiento opcional con snapshots de perfil de jugador, sin tratarlos como hechos autoritativos de una partida
El scoreboard publico queda limitado a enriquecimiento, links confiables o fallback historico cuando RCON falla, no tiene cobertura suficiente o no cubre una operacion concreta. Elo/MMR sigue pausado y Comunidad Hispana #03 permanece fuera de los targets RCON por defecto.
Comandos manuales RCON dentro del contenedor backend:
docker compose exec backend python -m app.rcon_admin_log_ingestion --minutes 1440
docker compose exec backend python -m app.rcon_historical_worker capture
Si se prefiere operar fuera de Docker, el backend sigue pudiendo arrancar localmente con python -m app.main desde backend/.
Evolucion prevista
La capa inspirada en ai-dev-platform-template ya esta integrada y adaptada al contexto real de HLL Vietnam. Las siguientes iteraciones deben centrarse en usarla para planificar y ejecutar tasks reales del producto sin ampliar alcance fuera de ese flujo.