Structure: - control-plane/: Registries, SIMCO directives, CI/CD templates - projects/: Gamilit, ERP-Suite, Trading-Platform, Betting-Analytics - shared/: Libs catalog, knowledge-base Key features: - Centralized port, domain, database, and service registries - 23 SIMCO directives + 6 fundamental principles - NEXUS agent profiles with delegation rules - Validation scripts for workspace integrity - Dockerfiles for all services - Path aliases for quick reference 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
1.9 KiB
1.9 KiB
ADR-004: Sistema de Constantes SSOT
Estado: Aceptada Fecha: 2025-11-24 Responsable: Architecture-Analyst Proyecto: ERP Construccion
Contexto
Necesitamos eliminar duplicacion de constantes (enums, estados, schemas) entre capas para evitar inconsistencias.
Decision
Backend como Single Source of Truth (SSOT) con sincronizacion automatica a Frontend.
// backend/src/shared/constants/database.constants.ts
export const DB_SCHEMAS = {
AUTH: 'auth_management',
PROJECTS: 'project_management', // Especifico construccion
ESTIMATES: 'estimates_management', // Especifico construccion
// ...
};
export const PROJECT_STATUS = {
PLANNING: 'planning',
IN_PROGRESS: 'in_progress',
COMPLETED: 'completed',
SUSPENDED: 'suspended',
};
Script sync-enums.ts genera constantes para Frontend automaticamente.
Justificacion
Referencia a Gamilit
- Elimina 96% de duplicacion
- Refactoring 10x mas rapido
- Validacion pre-commit de consistencia
Especifico para Construccion
- Estados de obra sincronizados (planeacion, ejecucion, terminada)
- Estados INFONAVIT unificados
- Constantes de presupuesto centralizadas
Consecuencias
Positivas
- Eliminacion de duplicacion: 96%
- Reduccion de bugs por inconsistencias: 80%
- Tiempo de refactoring: -60%
Negativas
- Requiere disciplina para usar constantes
- Mitigacion: Validacion pre-commit
Implementacion
Acciones Requeridas
- Implementar script sync-enums.ts
- Centralizar constantes en backend/src/shared/constants/
- Agregar constantes especificas de construccion
- Agregar validacion pre-commit
Criterios de Aceptacion
- Frontend usa constantes generadas desde Backend
- Zero hardcoding de valores criticos
- Validacion pre-commit funcional