# RF-MGN-008-001: Gestión de Cuentas Analíticas **Módulo:** MGN-008 - Contabilidad Analítica **Prioridad:** P0 **Story Points:** 8 **Estado:** Definido **Fecha:** 2025-11-23 ## Descripción Sistema debe gestionar cuentas analíticas (proyectos, departamentos, centros de costo) con jerarquía. ## Actores - **Actor Principal:** Gerente de Proyecto, Contador - **Actores Secundarios:** Sistema ## Precondiciones 1. Usuario debe estar autenticado 2. Tenant y empresa deben estar activos 3. Permisos necesarios deben estar asignados ## Flujo Principal 1. Usuario accede a módulo correspondiente 2. Usuario ejecuta acción principal del requerimiento 3. Sistema valida datos de entrada 4. Sistema procesa lógica de negocio 5. Sistema persiste cambios en base de datos 6. Sistema registra auditoría (MGN-014) 7. Sistema notifica a usuarios relevantes (si aplica) 8. Sistema retorna resultado exitoso ## Flujos Alternativos ### FA-1: Validación Fallida 1. Si datos de entrada son inválidos 2. Sistema retorna error 400 con detalles 3. Usuario corrige datos y reintenta ### FA-2: Sin Permisos 1. Si usuario no tiene permisos necesarios 2. Sistema retorna error 403 3. Sistema registra intento en audit log ### FA-3: Registro No Encontrado 1. Si registro solicitado no existe 2. Sistema retorna error 404 ## Reglas de Negocio - **RN-1:** Validaciones de integridad según modelo de datos - **RN-2:** RLS filtra registros por tenant y empresa - **RN-3:** Cambios quedan registrados en audit log - **RN-4:** Notificaciones según configuración de usuario ## Criterios de Aceptación - [ ] Usuario puede ejecutar funcionalidad principal - [ ] Sistema valida datos correctamente - [ ] Cambios persisten en base de datos - [ ] RLS aplica filtros correctamente - [ ] Permisos RBAC se validan - [ ] Auditoría queda registrada - [ ] Notificaciones se envían (si aplica) ## Entidades Involucradas - **Principales:** analytics.accounts, analytics.account_hierarchy - **Relacionadas:** auth.users, core.companies ## Referencias - [ALCANCE-POR-MODULO.md - MGN-008](../../01-definicion-modulos/ALCANCE-POR-MODULO.md#mgn-008) - [Database Schema DDL](../database-design/schemas/) - [Gap Analysis MGN-008](../../01-definicion-modulos/gaps/GAP-ANALYSIS-MGN-008.md) ## Notas Técnicas - **Patrón Odoo:** Análisis de módulos equivalentes en Odoo - **Backend:** NestJS Service + Repository Pattern - **Frontend:** React Component + Hooks - **Validación:** Class Validator + Custom Validators - **Testing:** Unit tests + E2E tests ## Dependencias - **RF Dependientes:** - RF-MGN-001-001 (Autenticación) - RF-MGN-001-002 (Roles y Permisos) - **Bloqueante para:** Módulos que consumen esta funcionalidad