Estos informes siguen el estándar COSIF y deben coincidir con la estructura XML definida por BACEN. Puede adaptar la lógica a su propio modelo de datos, pero el formato XML debe respetarse.
¿Qué es CADOC 4111?
El CADOC 4111 es un documento regulatorio requerido por el Banco Central de Brasil (BACEN) que reporta saldos diarios de cuentas contables agrupados por código COSIF (Plan de Cuentas para Instituciones del Sistema Financiero Nacional).
Lo que BACEN espera recibir
- Saldos consolidados por código COSIF
- Fecha base del informe
- CNPJ de la institución (primeros 8 dígitos)
- Tipo de envío (
I= Inclusión,S= Sustitución)
Requisitos de envío
| Documento | Plazo | Código STA |
|---|---|---|
| 4111 | Día siguiente a la fecha de referencia (o siguiente día hábil) | ACOS011 |
El código STA identifica el tipo de documento en el sistema de transmisión de BACEN. Use
ACOS011 al enviar CADOC 4111.Entendiendo la estructura de datos
Antes de construir la plantilla, es esencial entender cómo se organizan los datos en el libro mayor de Midaz.
Rutas de operación
Las rutas de operación funcionan como clasificadores contables. Cada ruta tiene:- Identificador único (
id): Usado internamente para relacionar operaciones - Código COSIF (
code): El código contable de 10 dígitos que será reportado a BACEN
Operaciones
Las operaciones representan movimientos financieros en el libro mayor. Cada operación contiene:- Cuenta asociada (
account_id): Qué cuenta fue afectada - Ruta (
route): ID de la ruta/clasificación contable aplicada - Saldo después de la operación (
available_balance_after): El saldo de la cuenta inmediatamente después de esta operación - Fecha y hora (
created_at): Cuándo ocurrió la operación
Relación entre rutas y operaciones

Estructura de CADOC
Formato base
El informe CADOC debe ser un archivo XML y debe seguir la estructura definida por BACEN:Campos obligatorios
Estos campos son requeridos y deben incluirse:<?xml version="1.0" encoding="UTF-8"?>
Siempre inicia el archivo. Define la versión de XML y la codificación para que el sistema sepa cómo leer el contenido.
Etiqueta <documento>
Envuelve toda la estructura CADOC e incluye:
| Campo | Descripción | Formato |
|---|---|---|
codigoDocumento | Identificador fijo | "4111" |
cnpj | Primeros 8 dígitos del CNPJ | Numérico, 8 posiciones |
dataBase | Fecha de referencia | AAAA-MM |
tipoRemessa | Tipo de envío | "I" o "S" |
Si su primer envío fue rechazado debido a errores, aún necesita usar
"I" en su próximo intento. Solo use "S" para reemplazar datos previamente aprobados.<contas>
Agrupa todas las entradas de cuentas para el período del informe.
Etiqueta <conta>
codigoConta: Código COSIF de la ruta de operación (10 dígitos numéricos)saldoDia: Saldo consolidado en formato decimal (dos decimales)
Lógica de construcción de la plantilla
Estructura general
La plantilla sigue una lógica de agregación en dos niveles:- Primer nivel: Iterar a través de todas las rutas de operación disponibles
- Segundo nivel: Para cada ruta, sumar los saldos de las operaciones vinculadas
Encabezado del documento
El encabezado XML debe contener:- Código del documento: Identificador fijo
4111 - CNPJ: Extraído de los datos de la organización, limitado a los primeros 8 dígitos
- Fecha base: Fecha de generación del informe en formato
AAAA-MM - Tipo de envío:
Ipara inclusión
Iterando sobre rutas
La plantilla debe iterar a través de todas las rutas de operación registradas. Para cada ruta:- Verificar código COSIF: Solo las rutas con un código COSIF válido deben generar líneas en el informe
- Filtrar operaciones: Seleccionar solo las operaciones que pertenecen a esa ruta específica
- Calcular saldo: Sumar los saldos de las operaciones filtradas
No todas las rutas tienen un código COSIF completo. Las rutas sin código se usan para controles internos y no deben aparecer en el informe regulatorio.
Filtrando operaciones por ruta
La asociación entre operaciones y rutas se realiza a través del identificador de ruta. La plantilla usa este identificador para:- Acceder a una ruta específica
- Encontrar todas las operaciones que referencian esta ruta
- Procesar solo estas operaciones en la agregación
Sumando saldos
Para cada conjunto de operaciones de una ruta, la plantilla suma los saldos disponibles. El campo utilizado es el saldo disponible después de cada operación. La función de agregación itera a través de todas las operaciones que cumplen los criterios de filtro (misma ruta) y acumula los valores del campo de saldo.Usando Reporter
Aquí está la plantilla completa para generar CADOC 4111 en Reporter:
Desglose del código
Línea 1 - Declaración XML
Línea 2 - Elemento raíz <documento>
codigoDocumento="4111": Identificador fijo del tipo de documentocnpj: Accede al documento legal de la organización y extrae los primeros 8 caracteres usando el filtroslicedataBase: Genera la fecha actual en el formato requerido por BACEN usando la etiquetadate_timetipoRemessa="I": Indica inclusión de datos
Línea 4 - Inicio del bucle for
op_route: Variable que recibe cada ruta durante la iteración (nombre elegido para evitar conflicto con el camporouteen operaciones)midaz_transaction.operation_route: Colección de todas las rutas de operación
Línea 5 - Condición if
Línea 6 - Elemento <conta>
codigoConta: Muestra el código COSIF de la ruta actualsaldoDia: Usa la etiquetasum_bypara sumar saldos, filtrando solo las operaciones cuya ruta coincide con el identificador de la ruta actual (op_route.id)
Líneas 7-8 - Cierre de bloques
Referencia de etiquetas y filtros
| Elemento | Tipo | Función |
|---|---|---|
{{ variable }} | Expresión | Muestra el valor de una variable |
{% tag %} | Etiqueta | Ejecuta lógica (bucle, condición, agregación) |
|slice:":8" | Filtro | Extrae los primeros 8 caracteres |
for ... in | Etiqueta | Itera a través de una colección |
if | Etiqueta | Condición de ejecución |
sum_by ... by ... if | Etiqueta | Suma valores con filtro condicional |
date_time | Etiqueta | Genera fecha formateada |
Consideraciones del filtro de fecha
Ejemplo de solicitud con filtro de fecha
Para generar CADOC 4111 para un día específico, envíe una solicitudPOST /v1/reports con el encabezado X-Organization-Id y el siguiente cuerpo:
Explicación de campos
| Campo | Descripción |
|---|---|
templateId | Identificador de la plantilla CADOC 4111 registrada en Reporter |
filters.midaz_transaction.operation | Indica que el filtro se aplicará a la colección de operaciones |
created_at.between | Filtra operaciones creadas dentro del intervalo especificado |
between[0] | Fecha y hora de inicio (medianoche del día deseado) |
between[1] | Fecha y hora de fin (último segundo del día deseado) |
Las fechas deben estar en formato ISO 8601 con zona horaria UTC (
Z).Evolución de la plantilla y extracción de saldos
Estamos trabajando en la evolución de nuestra plantilla principal para soportar la agregación de saldos en cumplimiento con BACEN CADOC 4111, que requiere el saldo final del último día hábil. Mientras esta funcionalidad está siendo desarrollada, proporcionamos una versión alternativa para extraer estos saldos usando la siguiente plantilla.
Plantilla de extracción
Esta plantilla auxiliar está diseñada para calcular correctamente los saldos, asegurando el cumplimiento de sus informes a través de los siguientes pasos:- Agrupar operaciones por cuenta
- Ordenar entradas por fecha y hora
- Seleccionar el último registro de cada cuenta para obtener el saldo final
- Sumar saldos finales por código COSIF
Ejemplo de plantilla de extracción
Salida de extracción
La plantilla exporta todas las operaciones en formato CSV, conteniendo:- Identificador de cuenta
- Alias de cuenta
- Código COSIF
- Fecha y hora de la operación
- Saldo disponible
Mejores prácticas para construcción de plantillas
Nomenclatura de variables
Use nombres descriptivos y únicos para las variables de iteración, evitando conflictos con los nombres de campos de entidades.Validación de campos
Siempre verifique si los campos opcionales tienen valores antes de usarlos. Los campos vacíos pueden generar líneas no deseadas en el informe.Formato de fecha
BACEN requiere fechas en formatoAAAA-MM. Asegúrese de configurar el formato correctamente en la plantilla.
Manejo de CNPJ
El CNPJ debe presentarse con solo los primeros 8 dígitos, sin formato (puntos, barras o guiones).Resumen de componentes
| Componente | Fuente de Datos | Uso en Plantilla |
|---|---|---|
| CNPJ | Organización (Onboarding) | Encabezado del documento |
| Código COSIF | Ruta de Operación (Transacción) | Identificador de cuenta |
| Saldo | Operación (Transacción) | Valor a agregar |
| Fecha Base | Función de fecha actual | Encabezado del documento |

