| .. | ||
| especificaciones | ||
| implementacion | ||
| _MAP.md | ||
| README.md | ||
MAI-005: Control de Obra
ID: MAI-005 Fase: 1 - Alcance Inicial Presupuesto: $35,000 MXN Story Points: 52 SP Sprint: Sprint 15-18 (Semanas 29-36) Prioridad: P0 Estado: En documentación
Resumen Ejecutivo
Este módulo gestiona el control integral de avances físicos y financieros en obra, desde la programación con ruta crítica hasta la captura de evidencias fotográficas geolocalizadas. Incluye herramientas avanzadas de seguimiento con Curva S, Earned Value Management (EVM), bitácora digital, checklists de calidad con firma digital y reportes oficiales para INFONAVIT.
Problema que Resuelve
Las constructoras enfrentan desafíos críticos en el control de obra:
- Falta de visibilidad en tiempo real del avance físico vs programado
- Desviaciones no detectadas a tiempo en costo y tiempo
- Registro manual de avances propenso a errores y fraudes
- Evidencias fotográficas sin validación de ubicación o fecha
- Reportes tardíos o incompletos para clientes y INFONAVIT
- Falta de trazabilidad en inspecciones de calidad
Sin este módulo: Control en Excel desactualizado, avances reportados sin evidencia, desviaciones detectadas muy tarde, problemas en auditorías INFONAVIT.
Con este módulo: Seguimiento en tiempo real con métricas EVM, captura móvil geolocalizada, evidencias inmutables con hash SHA256, trazabilidad completa, reportes oficiales automatizados.
Objetivos
- Programación con CPM: Crear cronogramas con cálculo automático de ruta crítica
- Seguimiento EVM: Medir desempeño con SPI/CPI y proyecciones de costo
- Captura móvil eficiente: Registro de avances desde obra con geolocalización
- Documentación robusta: Evidencias fotográficas verificables con marca de agua
- Control de calidad: Checklists digitales con firma y gestión de No Conformidades
- Visibilidad ejecutiva: Dashboard en tiempo real con KPIs y alertas automáticas
- Reportes oficiales: Generación automática para INFONAVIT y clientes
Alcance Funcional
1. Programación de Obra con Ruta Crítica
- Creación de cronogramas con actividades y dependencias
- Algoritmo Critical Path Method (CPM) para identificar actividades críticas
- Cálculo de holguras totales y libres
- Diagramas de Gantt interactivos
- Milestones con triggers de pago
- Reprogramaciones con control de versiones
- Baseline inmutable para comparación
2. Curva S y Earned Value Management
- Generación automática de snapshots diarios (CRON 23:00)
- Gráficas de líneas: Programado vs Real
- Cálculo de métricas EVM:
- PV (Planned Value): Valor planificado
- EV (Earned Value): Valor ganado
- AC (Actual Cost): Costo real
- SPI (Schedule Performance Index): Desempeño de tiempo
- CPI (Cost Performance Index): Desempeño de costo
- EAC (Estimate at Completion): Proyección de costo final
- VAC (Variance at Completion): Varianza al completar
- Alertas si varianza >5% del presupuesto
3. Captura de Avances Físicos
- Tres modos de registro:
- Por porcentaje: 45% → 70% (+25%)
- Por cantidad: 225 m³ → 350 m³ (+125 m³)
- Por unidad: Seleccionar lotes/viviendas individuales
- App móvil React Native:
- Captura desde obra con interfaz intuitiva
- Geolocalización automática con PostGIS
- Validación de distancia del sitio (umbral 500m)
- Fotos asociadas al avance
- Modo offline robusto:
- Almacenamiento local en SQLite
- Sincronización automática al recuperar conexión
- Cola de sincronización con reintentos
- Resolución de conflictos
- Workflow de aprobación:
- Estados: Pendiente → Revisado → Aprobado/Rechazado
- Validaciones automáticas de coherencia
- Notificaciones a supervisores
4. Evidencias Fotográficas
- Procesamiento automático:
- Marca de agua inmutable: "Proyecto | Lote | Fecha Hora"
- Thumbnail 300x225 px para performance
- Compresión JPEG calidad 85%
- Hash SHA256 para verificación de integridad
- Metadatos EXIF extraídos:
- Dispositivo, fecha original, coordenadas GPS
- Altitud, orientación, flash, ISO, exposición
- Georreferenciación PostGIS:
- Almacenamiento de coordenadas GPS
- Mapa visual con pins por ubicación
- Validación de ubicación en el sitio
- Álbumes organizados:
- Por proyecto, etapa, fecha o tema
- Exportación a PDF con galería
- Exportación ZIP de fotos seleccionadas
5. Bitácora Digital de Obra
- Registro diario de eventos en obra
- Categorías: Avance, Incidencia, Clima, Visita
- Multimedia: Fotos, videos, grabaciones de voz
- Geolocalización automática
- Timeline visual por proyecto
- Exportación a PDF para reportes oficiales
6. Checklists de Calidad
- Templates configurables:
- Items de tipo: Boolean, Numérico, Texto, Foto obligatoria
- Tolerancias para mediciones (10 ± 1 cm)
- Valores de referencia normativos
- Registro de No Conformidades (NC):
- Severidad: Menor, Mayor, Crítica
- Acción correctiva propuesta
- Responsable y fecha límite
- Seguimiento de cierre con fotos de verificación
- Firma digital:
- Canvas para dibujar firma con dedo/mouse
- Timestamp y hash del documento
- PDF generado con firma visible
- Cálculo de compliance:
- % = (Items conformes / Total items) × 100
- Semáforos: Verde ≥95%, Amarillo 80-94%, Rojo <80%
7. Dashboard en Tiempo Real
- KPIs principales:
- Avance físico, financiero, tiempo transcurrido
- SPI, CPI con colores según umbral
- Varianzas de costo y tiempo
- Curva S interactiva: Chart.js con zoom y tooltips
- Mapa de calor de unidades:
- Bloques por unidad con gradiente de color
- Verde (100%), Amarillo (50-99%), Rojo (0-49%)
- Panel de alertas:
- Críticas, Advertencias, Informativas
- Acciones sugeridas
- Widgets configurables: Drag & drop con react-grid-layout
- Actualización WebSocket: Push en tiempo real
8. Reportes Oficiales
Tipos de reportes:
- INFONAVIT: Formato oficial con secciones obligatorias
- Ejecutivo: Resumen para dirección (5-10 páginas)
- Calidad: Checklists, NCs, inspecciones
- Financiero: Avance financiero vs presupuesto
- Productividad: Análisis de cuadrillas y rendimientos
- Fotográfico: Álbum de evidencias
Características:
- Firma digital con canvas
- Hash del documento para verificación
- Generación a PDF con PDFKit
- Exportación a Excel con ExcelJS
- Envío automático programado (diario, semanal, mensual)
- Historial con tracking de descargas
Reutilización del Core ERP
Nivel de Reutilización: 0% - Módulo vertical 100% específico de construcción
Este módulo es completamente específico de la industria de la construcción y no reutiliza componentes del core ERP genérico. Sin embargo, se integra con los módulos base del vertical:
Dependencias internas:
- Utiliza autenticación y autorización de MAI-001
- Consume estructura de proyectos de MAI-002
- Lee presupuestos y partidas de MAI-003
- Provee datos para MAI-004 (Compras) en consumo de materiales
Justificación: Los requerimientos de control de obra con CPM, EVM, geolocalización GPS, evidencias fotográficas con hash SHA256, checklists de calidad con firma digital y reportes INFONAVIT son únicos del sector construcción y no aplican a otros verticales.
Requerimientos Funcionales
RF-OBRA-001: Programación de Obra y Curva S
Descripción: Sistema de programación con Critical Path Method (CPM) y seguimiento con Curva S y Earned Value Management (EVM).
Funcionalidades:
- CRUD de cronogramas con actividades y dependencias
- Algoritmo CPM para cálculo de ruta crítica
- Generación automática de snapshots de Curva S
- Métricas EVM (PV, EV, AC, SPI, CPI, EAC, VAC)
- Diagramas de Gantt interactivos
- Reprogramaciones con control de versiones
Documento: RF-OBRA-001
RF-OBRA-002: Captura de Avances Físicos
Descripción: Captura de avances desde app móvil con geolocalización, modo offline y workflow de aprobación.
Funcionalidades:
- Captura por porcentaje, cantidad o unidad
- App React Native con SQLite offline
- Geolocalización PostGIS con validación de radio
- Sincronización automática con cola de reintentos
- Workflow de aprobación multinivel
- Actualización automática de métricas
Documento: RF-OBRA-002
RF-OBRA-003: Evidencias Fotográficas y Checklists
Descripción: Gestión de evidencias fotográficas geolocalizadas con marca de agua inmutable y checklists de calidad con firma digital.
Funcionalidades:
- Procesamiento automático con marca de agua
- Hash SHA256 para integridad
- Metadatos EXIF y georreferenciación PostGIS
- Templates de checklists configurables
- Gestión de No Conformidades (NC)
- Firma digital con canvas
- Exportación a PDF y ZIP
Documento: RF-OBRA-003
RF-OBRA-004: Dashboard y Reportes de Avances
Descripción: Dashboard ejecutivo en tiempo real con WebSocket y generación de reportes oficiales con firma digital.
Funcionalidades:
- KPIs en tiempo real (físico, financiero, SPI, CPI)
- Curva S interactiva con Chart.js
- Mapa de calor de unidades
- Panel de alertas categorizadas
- Widgets configurables drag & drop
- Generación de reportes PDF/Excel
- Firma digital y hash de documentos
- Envío automático programado
Documento: RF-OBRA-004
Integración con App Móvil
MOB-003: App Supervisor de Obra
Este módulo se integra completamente con la aplicación móvil MOB-003: App Supervisor de Obra, diseñada para residentes y supervisores de obra.
Funcionalidades móviles:
-
F-MOB003-01: Captura de avances (8 SP)
- Registro de % avance por concepto
- Tres modos: Porcentaje, Cantidad, Por unidad
- Asociación automática a actividades del cronograma
-
F-MOB003-02: Fotos geoetiquetadas (5 SP)
- Evidencia con GPS embebido (PostGIS)
- Marca de agua automática
- Hash SHA256 para integridad
-
F-MOB003-03: Checklist de inspección (4 SP)
- Listas de verificación configurables
- Firma digital en dispositivo móvil
- Registro de No Conformidades
-
F-MOB003-04: Bitácora digital (4 SP)
- Registro de notas diarias
- Multimedia: Fotos, videos, voz
- Categorización de eventos
-
F-MOB003-05: Modo offline (4 SP)
- Trabajo sin conexión con SQLite
- Sincronización automática
- Resolución de conflictos
Stack tecnológico móvil:
- React Native 0.73+ con Expo 50
- TypeScript 5.3+
- WatermelonDB para almacenamiento offline
- expo-camera para fotos con EXIF
- expo-location para GPS
- Zustand para state management
Documento de referencia: EPIC-MAI-019: Apps Móviles
Dependencias con Otros Módulos
MAI-001: Fundamentos (Autenticación y Autorización)
Relación: Consume servicios de autenticación Datos compartidos:
- Usuarios con roles (Residente, Jefe de Proyecto, Director)
- Sesiones JWT para API y WebSocket
- Permisos por acción (crear, aprobar, firmar)
MAI-002: Proyectos y Estructura
Relación: Consume estructura de proyectos Datos compartidos:
- Proyectos activos con ubicación GPS
- Unidades/lotes con identificadores únicos
- Etapas de construcción
- Cuadrillas y personal asignado
MAI-003: Presupuestos y Costos
Relación: Lee presupuestos y actualiza costos reales Datos compartidos:
- Catálogo de partidas presupuestales
- Cantidades y precios unitarios
- Presupuesto total por proyecto (BAC para EVM)
- Costos reales ejecutados (AC para EVM)
MAI-004: Compras e Inventarios (Opcional)
Relación: Compara materiales consumidos vs presupuesto Datos compartidos:
- Consumo de materiales por actividad
- Validación de órdenes vs avances
- Alertas de desviaciones de costo
MAE-014: Finanzas (Indirecto)
Relación: Provee métricas financieras Datos compartidos:
- Flujo de caja por proyecto
- Proyecciones de costos (EAC)
- Varianzas financieras (VAC)
Arquitectura del Módulo
Diagrama de Arquitectura
┌─────────────────────────────────────────────────────────────────┐
│ FRONTEND WEB │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │
│ │ Dashboard │ │ Programación│ │ Reportes │ │
│ │ React + │ │ CPM/Gantt │ │ PDF/Excel │ │
│ │ Chart.js │ │ react-gantt │ │ jsPDF │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ │
│ ▲ ▲ ▲ │
│ │ │ │ │
│ └──────────────────┴──────────────────┘ │
│ │ │
│ WebSocket (Socket.io) │
│ │ │
└────────────────────────────┼─────────────────────────────────────┘
│
┌────────────────────────────┼─────────────────────────────────────┐
│ BACKEND NESTJS │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │
│ │ Schedule │ │ Progress │ │ Evidence │ │
│ │ Service │ │ Service │ │ Service │ │
│ │ (CPM/EVM) │ │ (Approval) │ │ (Photos/QC) │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ │
│ │ │ │ │
│ ├──────────────────┼──────────────────┤ │
│ │ │ │ │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │
│ │ CPM Algorithm│ │ Sync Queue │ │ Image Proc │ │
│ │ Calculator │ │ (BullMQ) │ │ (Sharp) │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ │
│ │ │ │ │
│ ▼ ▼ ▼ │
└─────────────────────────────────────────────────────────────────┘
│
┌────────────────────────────┼─────────────────────────────────────┐
│ POSTGRESQL 15+ │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │
│ │ schedules │ │ progress │ │ evidence │ │
│ │ (CPM, S- │ │ (Records, │ │ (Photos, │ │
│ │ Curve) │ │ Approval) │ │ Checklists) │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ │
│ │ │ │ │
│ │ PostGIS Extension │ │
│ │ (Geolocation) │ │
│ │ │ │
│ ┌──────────────────────────────────────────────────┐ │
│ │ analytics (KPIs, Alerts) │ │
│ └──────────────────────────────────────────────────┘ │
└─────────────────────────────────────────────────────────────────┘
│
┌────────────────────────────┼─────────────────────────────────────┐
│ MOBILE APP (React Native) │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │
│ │ Progress │ │ Camera + │ │ Checklist │ │
│ │ Capture │ │ GPS Geo │ │ + Signature │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ │
│ │ │ │ │
│ ▼ ▼ ▼ │
│ ┌────────────────────────────────────────────────┐ │
│ │ SQLite (Offline Storage) │ │
│ │ + Sync Queue (WatermelonDB) │ │
│ └────────────────────────────────────────────────┘ │
└─────────────────────────────────────────────────────────────────┘
│
┌────────────────────────────┼─────────────────────────────────────┐
│ STORAGE (AWS S3 / GCS) │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │
│ │ Original │ │ Thumbnails │ │ PDFs │ │
│ │ Photos │ │ (300x225) │ │ (Reports) │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ │
└─────────────────────────────────────────────────────────────────┘
Schema de Base de Datos
Schemas principales:
schedules- Programación, actividades, Curva S, milestonesprogress- Registros de avance, aprobaciones, batch updates, offline syncevidence- Fotos, checklists, templates, álbumes, NCsanalytics- KPIs, alertas, productividad, widgets, reportes
Tablas clave:
schedules
→ schedule_activities (CPM: ES, EF, LS, LF, total_float, is_critical_path)
→ milestones (payment_trigger, planned_date, actual_date)
→ s_curve_snapshots (planned_pct, actual_pct, spi, cpi, eac, vac)
progress_records
→ unit_progress (percent_complete, start_date, completion_date)
→ offline_sync_queue (device_id, local_id, payload JSONB, sync_status)
→ approval_workflows (levels JSONB, applies_to_activities[])
photos (sha256_hash, geolocation POINT, exif_data JSONB, has_watermark)
quality_checklists (items JSONB, compliance_percent, signature_data, pdf_path)
kpi_metrics (physical_progress, spi, cpi, eac, etc, vac, critical_alerts)
alerts (severity, related_entity_type, actions_taken JSONB)
Features de PostgreSQL:
- PostGIS POINT para coordenadas GPS
- JSONB para items flexibles (actividades, checklists)
- Triggers para actualización automática de estados
- Stored procedures para cálculo de CPM, EVM, compliance
- Materialized views para performance (dashboard summary)
- Full-text search en descripciones y notas
Stack Tecnológico
Backend
framework: NestJS 10+
language: TypeScript 5+
database: PostgreSQL 15+ (schemas: schedules, progress, evidence, analytics)
extensions: PostGIS para geolocalización
orm: TypeORM con migraciones
async_processing: Bull/BullMQ para batch updates y sync offline
scheduler: node-cron para snapshots diarios (23:00)
image_processing: Sharp para compresión y watermark
metadata: ExifReader para metadatos EXIF
hashing: crypto (SHA256) para integridad
pdf_generation: PDFKit
excel_export: ExcelJS
email: SendGrid / AWS SES
real_time: WebSocket (Socket.io)
storage: AWS S3 / Google Cloud Storage
Frontend Web
framework: React 18
language: TypeScript
state: Zustand
data_fetching: React Query (cache y sincronización)
charts: Chart.js / Recharts para Curva S y KPIs
gantt: react-gantt-chart para diagramas
maps: Leaflet para geolocalización
file_upload: react-dropzone
signature: react-signature-canvas
grid: react-grid-layout para widgets drag&drop
websocket: Socket.io-client
dates: date-fns
pdf_client: jsPDF
Mobile App
framework: React Native 0.73+
platform: Expo 50
language: TypeScript
offline_db: SQLite con WatermelonDB
sync: Background fetch + Queue
network_detection: NetInfo
camera: expo-camera con EXIF
geolocation: expo-location
file_system: expo-file-system / react-native-fs
local_storage: AsyncStorage
state: Zustand
Infraestructura
containers: Docker + Docker Compose
orchestration: Kubernetes (producción)
storage: AWS S3 / Google Cloud Storage
cdn: CloudFront / Cloud CDN
monitoring: Prometheus + Grafana
logging: Winston + ELK Stack
ci_cd: GitHub Actions / GitLab CI
Flujos de Trabajo
Flujo 1: Creación de Programa de Obra
1. [Director] Crea cronograma nuevo
2. [Director] Agrega actividades con duración, dependencias y lag
3. [Sistema] Ejecuta algoritmo CPM:
- Forward Pass: Calcula ES (Earliest Start), EF (Earliest Finish)
- Backward Pass: Calcula LS (Latest Start), LF (Latest Finish)
- Float Calculation: TF = LF - EF, FF = min(ES[successors]) - EF
- Identifica Critical Path: actividades donde TF == 0
4. [Director] Envía para aprobación
5. [Jefe] Aprueba → Estado: Active, isBaseline: true (v1)
6. [Sistema] Genera snapshot inicial de Curva S
Flujo 2: Captura y Aprobación de Avances
1. [Residente] (App Móvil):
- Selecciona proyecto y actividad
- Captura % avance o cantidad
- Toma fotos con GPS automático
- Envía (online) o guarda en SQLite (offline)
2. [Sistema] (Sincronización si offline):
- Al recuperar conexión, detecta registros pendientes
- Cola BullMQ procesa registros
- Sube fotos a S3/GCS
- Marca como synced
3. [Jefe de Proyecto] (Web):
- Recibe notificación de avance pendiente
- Abre detalle con validaciones automáticas:
* Incremento de % coherente
* Fotos geolocalizadas en el sitio
* Sin duplicados
- Aprueba o Rechaza con motivo
4. [Sistema] (Al aprobar):
- Actualiza schedule_activity.percent_complete
- Actualiza unit_progress.percent_complete
- Recalcula KPIs (físico, SPI, CPI, EAC)
- Genera snapshot de Curva S (si aplica)
- Emite evento WebSocket → Dashboard se actualiza en vivo
Flujo 3: Inspección con Checklist de Calidad
1. [Residente] Selecciona template de checklist (ej: "Acabados Vivienda")
2. [Residente] Completa items uno por uno:
- Boolean: ¿Pintura uniforme? ✅
- Numérico: Espesor de piso = 10.2 cm (tolerancia: 10 ± 1) ✅
- Foto: Toma foto de evidencia
3. [Residente] Registra No Conformidades (NC) si encuentra:
- Severidad: Mayor
- Descripción: "Grietas en muro norte"
- Acción correctiva: "Resanar y repintar"
- Responsable: Juan Pérez
- Fecha límite: 2025-12-10
4. [Residente] Dibuja firma digital en canvas
5. [Sistema]:
- Calcula compliance_percent = (conformes / total) × 100
- Genera timestamp y hash del documento
- Genera PDF con firma visible
- Almacena en S3/GCS
6. [Jefe] Recibe notificación de NC y da seguimiento
Flujo 4: Generación de Reporte Oficial INFONAVIT
1. [Director] Selecciona "Generar Reporte INFONAVIT"
2. [Director] Configura:
- Período: 2025-12-01 a 2025-12-31
- Formato: PDF
- Secciones: Carátula, Resumen, Avance por Etapa, Curva S, Fotos
- Requiere firma: Sí
3. [Sistema] (Background job):
- Ejecuta queries SQL para recopilar datos
- Calcula KPIs y métricas EVM
- Genera gráficas (Chart.js server-side con node-canvas)
- Procesa fotografías seleccionadas
- Compila PDF con PDFKit
4. [Director] Recibe notificación "Reporte listo para firma"
5. [Director] Dibuja firma digital en canvas
6. [Sistema]:
- Captura firma Base64 + timestamp
- Calcula hash SHA256 del documento completo
- Inserta firma en PDF
- Sube a S3/GCS
7. [Sistema] Envía por email a contactos de INFONAVIT (si configurado)
8. [Sistema] Guarda registro en reports_generated con tracking
Roles y Permisos
| Rol | Permisos |
|---|---|
| Residente de Obra | Capturar avances móvil, tomar fotos, crear checklists, bitácora |
| Jefe de Proyecto | Crear cronogramas, aprobar avances, ver dashboard, generar reportes ejecutivos |
| Director de Proyecto | Aprobar programas, autorizar reprogramaciones, firmar reportes oficiales |
| Inspector de Calidad | Crear templates de checklists, registrar NCs, dar seguimiento |
| Finanzas | Ver métricas EVM (AC, EAC, VAC), exportar datos financieros |
| Cliente/INFONAVIT | Consultar reportes oficiales, ver galería de fotos (solo lectura) |
Indicadores Clave (KPIs)
KPIs del Sistema
-
Eficiencia en Programación
- Tiempo promedio para aprobar programa: <48h
- % Programas con ruta crítica identificada: 100%
- Precisión de proyecciones de término: ±5 días
-
Adopción de Captura Móvil
- % Avances registrados desde app: >90%
- % Registros con geolocalización: >95%
- % Sincronizaciones exitosas (offline): >98%
-
Calidad de Evidencias
- % Fotos con metadatos EXIF completos: >95%
- % Fotos georreferenciadas: >90%
- % Checklists completados con firma: 100%
-
Exactitud de Seguimiento
- Diferencia Curva S proyectada vs real: <5%
- % Avances aprobados en <24h: >80%
- % Alertas críticas atendidas en <48h: >90%
-
Generación de Reportes
- Tiempo de generación de reporte: <60s
- % Reportes entregados a tiempo: >95%
- % Reportes con firma digital: 100% (oficiales)
Métricas EVM
- SPI (Schedule Performance Index): >0.95 (verde), 0.85-0.95 (amarillo), <0.85 (rojo)
- CPI (Cost Performance Index): >0.95 (verde), 0.85-0.95 (amarillo), <0.85 (rojo)
- VAC (Variance at Completion): Alerta si >5% del presupuesto
Puntos Críticos
-
Complejidad del algoritmo CPM
- Riesgo: Cálculos incorrectos de ruta crítica
- Mitigación: Algoritmo probado con tests extensivos, casos edge documentados
-
Sincronización offline
- Riesgo: Pérdida de datos o duplicados
- Mitigación: Cola robusta con reintentos, resolución de conflictos, SQLite transaccional
-
Performance con miles de fotos
- Riesgo: Lentitud en carga de galería
- Mitigación: Thumbnails, lazy loading, paginación, CDN
-
Validación de geolocalización
- Riesgo: Registros falsos desde fuera del sitio
- Mitigación: Validación PostGIS de radio, alertas de ubicaciones sospechosas
-
Integridad de evidencias
- Riesgo: Manipulación de fotos o documentos
- Mitigación: Hash SHA256, marca de agua inmutable, firma digital con timestamp
Documentos Relacionados
Requerimientos Funcionales
- RF-OBRA-001: Programación de Obra y Curva S
- RF-OBRA-002: Captura de Avances Físicos
- RF-OBRA-003: Evidencias Fotográficas y Checklists
- RF-OBRA-004: Dashboard y Reportes de Avances
Especificaciones Técnicas
- ET-OBRA-001: Implementación de Programación y Curva S
- ET-OBRA-002: Implementación de Captura de Avances
- ET-OBRA-003: Implementación de Evidencias y Checklists
- ET-OBRA-004: Implementación de Dashboard y Reportes
Historias de Usuario
- US-OBRA-001: Crear Programa de Obra con Ruta Crítica - 8 SP
- US-OBRA-002: Seguimiento con Curva S y Earned Value - 5 SP
- US-OBRA-003: Capturar Avances desde Obra - 8 SP
- US-OBRA-004: Aprobar Avances con Flujo de Validación - 5 SP
- US-OBRA-005: Gestión de Evidencias Fotográficas - 8 SP
- US-OBRA-006: Checklists de Calidad - 5 SP
- US-OBRA-007: Dashboard Ejecutivo en Tiempo Real - 8 SP
- US-OBRA-008: Generación de Reportes Oficiales - 5 SP
Referencias Técnicas
Estimación y Planificación
Distribución por Sprint
Sprint 15 (13 SP): Programación CPM + Curva S + EVM
- US-OBRA-001: Crear Programa de Obra (8 SP)
- US-OBRA-002: Seguimiento con Curva S (5 SP)
Sprint 16 (13 SP): Captura móvil + Aprobaciones
- US-OBRA-003: Capturar Avances desde Obra (8 SP)
- US-OBRA-004: Aprobar Avances (5 SP)
Sprint 17 (13 SP): Evidencias fotográficas + Checklists QC
- US-OBRA-005: Evidencias Fotográficas (8 SP)
- US-OBRA-006: Checklists de Calidad (5 SP)
Sprint 18 (13 SP): Dashboard + Reportes oficiales
- US-OBRA-007: Dashboard Ejecutivo (8 SP)
- US-OBRA-008: Reportes Oficiales (5 SP)
Total: 52 Story Points en 4 sprints (8 semanas)
Equipo Sugerido
- 2 Backend developers (NestJS + PostgreSQL + PostGIS)
- 1 Mobile developer (React Native + SQLite)
- 2 Frontend developers (React + Chart.js + WebSocket)
- 1 QA engineer
- 1 Product Owner (medio tiempo)
Riesgos y Mitigaciones
| Riesgo | Probabilidad | Impacto | Mitigación |
|---|---|---|---|
| Complejidad del algoritmo CPM | Media | Alto | Algoritmo probado, tests extensivos con casos edge |
| Sincronización offline | Media | Medio | Cola con reintentos, SQLite robusto, WatermelonDB |
| Performance con miles de fotos | Media | Medio | Thumbnails, lazy loading, paginación, CDN |
| Cálculo de EVM incorrecto | Baja | Alto | Validación con experto PMI, tests unitarios |
| WebSocket desconexiones | Media | Bajo | Reconexión automática, fallback a polling |
| Manipulación de evidencias | Baja | Alto | Hash SHA256, marca de agua, firma digital |
Próximos Pasos
Implementación
- ✅ Documentación completa
- Sprint Planning con equipo
- Setup de infraestructura (BD con PostGIS, storage S3/GCS)
- Sprint 15: Programación CPM y Curva S
- Sprint 16: Captura móvil y aprobaciones
- Sprint 17: Evidencias fotográficas y checklists
- Sprint 18: Dashboard y reportes
- Testing integral y UAT
- Capacitación a usuarios (residentes, jefes, directores)
- Go-live escalonado (1 proyecto piloto)
Integraciones Futuras
- BI avanzado con Power BI / Tableau
- Integración con drones para fotogrametría aérea
- Machine learning para predicción de retrasos
- App móvil nativa (Swift/Kotlin) para mejor performance
- Integración con BIM (Building Information Modeling)
- Exportación a MS Project / Primavera P6
Generado: 2025-12-06 Estado: Documentado Mantenedores: @tech-lead @backend-team @frontend-team @mobile-team