You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

98 lines
6.7 KiB
Markdown

# Estado del Proyecto — Task Manager para WhatsApp
Estado general: listo para piloto con la junta directiva; 170 tests pasando. Riesgos operativos principales: CI/CD básico, red interna entre Evolution API y el bot, y backups/persistencia.
Siguiente paso de desarrollo: ejecutar el plan mínimo de CI/CD, healthcheck y backups descrito en docs/CI-CD-PLAN.md (pendiente de cerrar las decisiones marcadas).
## Hecho (por áreas)
- Servidor webhook
- Endpoint /health, validación de entorno, extracción robusta de texto (conversation/extended/captions).
- Detección DM vs grupo y política “solo DM”.
- Registro/verificación de webhooks y sincronización de grupos activos con caché; sincronización periódica de miembros y handlers incrementales (alta/baja/rol) idempotentes.
- Control de acceso por grupos (allowed_groups): modos discover/enforce, aprobación/bloqueo vía /admin y notificación opcional a ADMIN_USERS en descubrimiento.
- Rate limiting por usuario (15/min por defecto; desactivado en tests; aviso con cooldown).
- Base de datos y migraciones
- Inicialización con PRAGMA FK y timestamps de alta precisión.
- Esquema: users, tasks, task_assignments, user_preferences, response_queue (con metadata).
- Modo journal WAL activado (busy_timeout y autocheckpoint configurados) para mejorar concurrencia y rendimiento.
- Migrador up-only con tabla schema_migrations; FK siempre ON al abrir; backup automático con VACUUM INTO; sin baseline por defecto; validación de checksum; log persistente en data/migrations.log; resumen de estado al arrancar.
- Cola de respuestas
- Persistente con workers en background, reintentos con backoff exponencial + jitter, recuperación de items processing tras reinicios, y limpieza/retención.
- 2xx=sent, 4xx=failed definitivo, 5xx/red=reintento; evita enviar al propio bot.
- Comandos
- Crear, listar (grupo/mis/sin/todos), completar, tomar, soltar; ayuda por DM.
- Fechas “hoy/mañana” con TZ configurable; formato dd/MM; vencidas con ⚠️.
- Menciones reales y tokens @…; reglas por defecto: grupo→sin responsable, DM→creador.
- Recordatorios por DM
- Preferencias por usuario (daily|weekly|off; hora con soporte en modelo/servicio), evita duplicados por día, weekly en lunes, respeta TZ, no envía si no hay tareas.
- Contactos y nombres
- Caché en memoria, actualización por webhooks, fallback a Evolution API (saltado en tests); nombres amigables en textos.
- Testing
- ~170 tests unitarios con SQLite en memoria; ResponseQueue (reintentos/cleanup), comandos (alias/fechas/listados/x/tomar/soltar), recordatorios, utilidades.
- Observabilidad y mantenimiento
- Endpoint /metrics (Prometheus por defecto; JSON opcional) con contadores/gauges básicos: sync_runs_total, sync_errors_total, webhook_events_total_*, webhook_errors_total, active_groups, active_members, last_sync_*.
- /health detallado (full=1) con active_groups, active_members, last_sync_at y snapshot_age_ms.
- Job diario de limpieza de miembros inactivos configurable (GROUP_MEMBERS_INACTIVE_RETENTION_DAYS; por defecto 180 días).
## Pendiente (priorizado)
- MVP operativo (bloqueantes/casi bloqueantes)
1) CI/CD: pipeline mínimo (build + bun test + build/push imagen + despliegue CapRover). Ver docs/CI-CD-PLAN.md.
2) Persistencia/backup: volumen /app/data y backup diario del fichero SQLite.
3) Seguridad/red: ejecutar en red interna con Evolution API; si no, proteger el webhook (IP allowlist/reverse proxy).
4) Ensayo E2E en staging: registro de webhook, recepción de MESSAGES_UPSERT reales y envío de DMs.
- Post-MVP (mejoras)
- Observabilidad: ampliar métricas (latencias/histogramas, etiquetas), dashboards y alertas.
- Orden por destinatario en ResponseQueue; idempotency_key opcional.
- Permisos/roles y pertenencia a grupos (si se requiere).
- Edición/eliminación de tareas.
- Política de caché de contactos (TTL configurable, invalidación más fina).
## Roadmap y próximas iteraciones
- Iteración A — Operativa lista para piloto
- Entregables: pipeline CI (GitHub Actions), build de imagen, despliegue CapRover con volumen /app/data, backup diario configurado, checklist de red interna verificada.
- Iteración B — Observabilidad mínima
- Entregables: logs con contexto en puntos clave, ruta /metrics (Prometheus/JSON) y /health detallada, guía de troubleshooting.
- Iteración C — Calidad de datos/UX
- Entregables: mejoras de caché de contactos, afinado de recordatorios (hora por usuario), pruebas adicionales de ResponseQueue y comandos.
## Checklist de readiness para piloto
- Infra
- [ ] App en CapRover con volumen /app/data.
- [ ] Variables de entorno configuradas; TZ correcta.
- [ ] Evol. API y bot en la misma red; /health OK.
- Operación
- [ ] Backups diarios de data/tasks.db y procedimiento de restauración.
- [ ] Logs accesibles; worker de cola activo.
- Funcional
- [ ] Bot añadido a los grupos; grupos activos sincronizados.
- [ ] Comandos base verificados en un grupo real (crear/ver/x/tomar/soltar/configurar).
- Comunicación/privacidad
- [ ] Aviso a la junta: cómo usar, qué se guarda, cómo desactivar recordatorios.
## Riesgos y mitigaciones
- Webhook expuesto públicamente
- Mitigación: red interna; si no es posible, IP allowlist/reverse proxy y rotación de claves.
- Pérdida de datos en SQLite
- Mitigación: volumen persistente + backups diarios + prueba de restore.
- TZ incorrecta y mensajes con fecha errónea
- Mitigación: fijar TZ en entorno, tests de humo con “hoy/mañana”.
- Fallos o latencia de Evolution API
- Mitigación: reintentos con backoff; logs de error; visibilidad en ResponseQueue.
## Testing y cobertura
- Cubre: comandos, ResponseQueue (reintentos/cleanup), recordatorios (daily/weekly/TZ), utilidades, normalización de IDs, validaciones básicas en servidor.
- Falta: pruebas E2E reales contra Evolution API (recomendado antes del piloto).
## Notas de despliegue/operación
- SQLite en modo WAL; backups consistentes con VACUUM INTO previo; tener en cuenta archivos -wal y -shm.
- Log persistente de migraciones en data/migrations.log (una línea por evento, formato JSONL); revisar en despliegues.
- Persistencia en data/; mapear a volumen y monitorizar tamaño; ejecutar VACUUM periódicamente si procede.
- Rotación de logs vía orquestador; considerar niveles/etiquetas para búsquedas.
## Changelog breve
- Reintentos/backoff y recuperación de ResponseQueue: completado.
- Recordatorios por DM (daily/weekly) con preferencias: completado.
- Rate limiting por usuario: completado.
- Ayuda por DM y formato de mensajes unificado: completado.
- Sincronización de miembros (full sync + webhooks incrementales): completado.
- Limpieza/retención de historiales de cola: completado.