Saltar al contenido principal
Reporter le permite generar informes basados en XML que siguen la estructura oficial de CADOC, exactamente como lo requiere el Banco Central de Brasil (BACEN). Esta guía le muestra la estructura y la lógica utilizada para generar los informes CADOC 4010 y CADOC 4016 en XML.
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é son CADOC 4010 y 4016?


El 4010 y el 4016 son informes de Balance Analítico utilizados para enviar informes financieros al BACEN (Banco Central de Brasil).

Lo que BACEN espera recibir

  • Saldos de cierre por código COSIF
  • Fecha base del informe (mes de referencia)
  • CNPJ de la institución (primeros 8 dígitos)
  • Tipo de envío (I = Inclusión, S = Sustitución)

Diferencia entre CADOC 4010 y 4016

DocumentoPeriodicidadFecha BaseCuentas Esperadas
4010MensualAAAA-MMTodas las cuentas
4016Semestral (Jun/Dic)AAAA-MMSin grupos 7 y 8 (Ingresos/Gastos)
El 4016 representa la posición contable de la entidad después del cierre del estado de resultados. En este punto, las cuentas de Ingresos (grupo 7) y las cuentas de Gastos (grupo 8) ya han sido cerradas y sus saldos transferidos al Patrimonio.

Requisitos de envío

DocumentoPlazoCódigo STA
4010Día 18 del mes siguiente (o el siguiente día hábil)ACOS010
4016Último día hábil del mes siguienteACOS016
El código STA identifica el tipo de documento en el sistema de transmisión de BACEN. Use ACOS010 al enviar CADOC 4010 y ACOS016 al enviar CADOC 4016.

Entendiendo la estructura de datos


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
Piense en las rutas como “etiquetas contables” adjuntas a cada operación, indicando bajo qué elemento del plan de cuentas debe clasificarse ese movimiento.

Operaciones

Las operaciones representan movimientos financieros en el libro mayor. Cada operación contiene:
  • Cuenta asociada (account_id): Qué cuenta fue movida
  • 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 entidades

La entidad balance representa el saldo actual de la cuenta, no el historial. Para informes regulatorios que necesitan saldos de un período específico, use la entidad operation con filtros de fecha.

Estructura de CADOC


Formato base

El informe CADOC debe ser un archivo XML y debe seguir la estructura definida por BACEN:
<?xml version="1.0" encoding="UTF-8"?>
<documento codigoDocumento="4010" cnpj="99999999" dataBase="2025-11" tipoRemessa="I">
  <contas>
    <conta codigoConta="1000000009" saldo="99.99" />
    <conta codigoConta="1100000002" saldo="99.99" />
  </contas>
</documento>

Campos obligatorios

<?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:
CampoDescripciónFormato
codigoDocumentoIdentificador fijo"4010" o "4016"
cnpjPrimeros 8 dígitos del CNPJNumérico, 8 posiciones
dataBaseMes de referenciaAAAA-MM
tipoRemessaTipo 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.
Etiqueta <contas> Agrupa todas las entradas de cuentas para el período del informe. Etiqueta <conta>
  • codigoConta: Código de cuenta, siguiendo el formato COSIF (10 dígitos numéricos).
  • saldo: Saldo de la cuenta 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:
  1. Primer nivel: Iterar a través de todas las rutas de operación disponibles
  2. Segundo nivel: Para cada ruta, agregar los saldos de las operaciones vinculadas

Iterando sobre rutas

La plantilla debe iterar a través de todas las rutas de operación registradas. Para cada ruta:
  1. Verificar si tiene código COSIF: Solo las rutas con código completo generan líneas
  2. Filtrar operaciones: Seleccionar operaciones que pertenecen a esa ruta
  3. Calcular el saldo: Agregar los saldos de las operaciones filtradas

Precaución con nomenclatura de variables

Al construir la plantilla, evite usar el mismo nombre para la variable de iteración y el campo de filtro:
EnfoqueEjemploResultado
Incorrectofor route in ... if route == route.idConflicto de nombres
Correctofor op_route in ... if route == op_route.idFunciona correctamente

Plantilla CADOC 4010


Aquí está la plantilla completa para generar CADOC 4010 en Reporter:
<?xml version="1.0" encoding="UTF-8"?>
<documento codigoDocumento="4010" cnpj="{{ midaz_onboarding.organization.0.legal_document|slice:':8' }}" dataBase="{% date_time 'YYYY-MM' %}" tipoRemessa="I">
  <contas>
{%- for op_route in midaz_transaction.operation_route %}
{%- if op_route.code %}
    <conta codigoConta="{{ op_route.code }}" saldo="{% sum_by midaz_transaction.operation by "available_balance_after" if route == op_route.id %}" />
{%- endif %}
{%- endfor %}
  </contas>
</documento>

Explicación línea por línea

Línea 1 - Declaración XML Encabezado XML estándar con codificación UTF-8. Línea 2 - Elemento raíz <documento>
  • codigoDocumento="4010": Identificador fijo para el Balance Analítico
  • cnpj: Extrae los primeros 8 dígitos del documento legal de la organización
  • dataBase: Genera la fecha en formato AAAA-MM (mes de referencia)
  • tipoRemessa="I": Indica inclusión de datos
Línea 4 - Inicio del bucle for
  • op_route: Variable que recibe cada ruta durante la iteración
  • midaz_transaction.operation_route: Colección de todas las rutas de operación
Línea 5 - Condición if Verifica si la ruta tiene un código COSIF completo. Línea 6 - Elemento <conta>
  • codigoConta: Muestra el código COSIF de la ruta actual
  • saldo: Usa la etiqueta sum_by para agregar saldos, filtrando operaciones cuya ruta coincide con el identificador de la ruta actual (op_route.id)
Líneas 7-8 - Cierre de bloques Cierran la condición y el bucle respectivamente.

Etiquetas y filtros utilizados

ElementoTipoFunción
{{ variable }}ExpresiónMuestra el valor de una variable
{% tag %}EtiquetaEjecuta lógica (bucle, condición, agregación)
|slice:':8'FiltroCorta los primeros 8 caracteres
for ... inEtiquetaItera a través de una colección
ifEtiquetaCondición para ejecución
sum_by ... by ... ifEtiquetaSuma valores con filtro condicional
date_timeEtiquetaGenera fecha formateada

Plantilla CADOC 4016


El CADOC 4016 es el Balance Analítico, similar al 4010, pero con periodicidad semestral y una restricción importante: no debe contener cuentas de los grupos 7 (Ingresos) y 8 (Gastos).

¿Por qué excluir los grupos 7 y 8?

El documento 4016 representa la posición contable de la entidad después del cierre del estado de resultados. En este punto, las cuentas de Ingresos (grupo 7) y las cuentas de Gastos (grupo 8) ya han sido cerradas y sus saldos transferidos al Patrimonio.

Ejemplo de plantilla

<?xml version="1.0" encoding="UTF-8"?>
<documento codigoDocumento="4016" cnpj="{{ midaz_onboarding.organization.0.legal_document|slice:':8' }}" dataBase="{% date_time 'YYYY-MM' %}" tipoRemessa="I">
  <contas>
{%- for op_route in midaz_transaction.operation_route %}
{%- if op_route.code and op_route.code|slice:":1" != "7" and op_route.code|slice:":1" != "8" %}
    <conta codigoConta="{{ op_route.code }}" saldo="{% sum_by midaz_transaction.operation by "available_balance_after" if route == op_route.id %}" />
{%- endif %}
{%- endfor %}
  </contas>
</documento>

Diferencia con 4010

La única diferencia en la plantilla es la condición adicional en el if:
PlantillaCondición
4010if op_route.code
4016if op_route.code and op_route.code|slice:":1" != "7" and op_route.code|slice:":1" != "8"

Cómo funciona la exclusión

El filtro slice:":1" extrae el primer carácter del código COSIF:
Código COSIFPrimer DígitoGrupo¿Incluido en 4016?
10000000091Activos
21000000032Pasivos
71000000017IngresosNo
82000000058GastosNo

Generando el informe con filtro de fecha


Ejemplo de solicitud para 4010

Para generar el CADOC 4010 para un mes específico, envíe una solicitud POST /v1/reports con el encabezado X-Organization-Id y el siguiente cuerpo:
{
  "templateId": "CADOC_4010_TEMPLATE_ID",
  "filters": {
    "midaz_transaction": {
      "operation": {
        "created_at": {
          "between": ["2025-11-01T00:00:00Z", "2025-11-30T23:59:59Z"]
        }
      }
    }
  }
}

Explicación de campos

CampoDescripción
templateIdIdentificador de la plantilla CADOC 4010 registrada en Reporter
filters.midaz_transaction.operationIndica que el filtro se aplicará a la colección de operaciones
created_at.betweenFiltra operaciones creadas dentro del intervalo especificado
between[0]Primer día del mes a las 00:00:00 UTC
between[1]Último día del mes a las 23:59:59 UTC
Formato de fecha: ISO 8601 con zona horaria UTC (Z).
Ajuste el último día según el mes (28, 29, 30 o 31 días).

Ejemplo de solicitud para 4016

Para generar el CADOC 4016 para el primer semestre:
{
  "templateId": "CADOC_4016_TEMPLATE_ID",
  "filters": {
    "midaz_transaction": {
      "operation": {
        "created_at": {
          "between": ["2025-01-01T00:00:00Z", "2025-06-30T23:59:59Z"]
        }
      }
    }
  }
}
Para el segundo semestre, ajuste las fechas de julio a diciembre.

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 4010/4016, que requiere el saldo final del último día hábil del mes. 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:
  1. Agrupar operaciones por cuenta
  2. Ordenar entradas por fecha y hora
  3. Seleccionar el último registro de cada cuenta para obtener el saldo final
  4. Sumar saldos finales por código COSIF
Con esta opción, puede extraer la información requerida para CADOC 4010/4016 y transferirla al formato de diseño requerido por BACEN. Esta plantilla puede ayudar si ya tiene un proveedor que construye archivos CADOC.

Ejemplo de plantilla de extracción

account_id;account_alias;codigo_cosif;created_at;saldo_disponivel
{%- for op_route in midaz_transaction.operation_route %}
{%- if op_route.code %}
{%- for op in filter(midaz_transaction.operation, "route", op_route.id) %}
{{ op.account_id }};{{ op.account_alias }};{{ op_route.code }};{{ op.created_at }};{{ op.available_balance_after }}
{%- endfor %}
{%- endif %}
{%- endfor %}

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
Puede importar este CSV en una hoja de cálculo o su sistema de conciliación existente para procesar los saldos finales.

Comparación con CADOC 4111


CADOC 4010 y CADOC 4111 comparten la misma estructura de plantilla, con diferencias solo en los parámetros:
AspectoCADOC 4111CADOC 4010
DocumentoSaldos DiariosBalance Mensual
PeriodicidadDiariaMensual
codigoDocumento"4111""4010"
dataBaseAAAA-MMAAAA-MM
Filtro de fecha1 día1 mes
Saldo esperadoÚltimo del díaÚltimo del mes
Plantilla idéntica: La lógica para iterar sobre rutas y agregar saldos es la misma.

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 formato AAAA-MM para 4010. 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).

Código de cuenta COSIF

El plan de cuentas COSIF está estructurado con 6 niveles jerárquicos y un dígito verificador. El campo codigoConta debe tener 10 dígitos numéricos, sin puntos ni guiones.

Resumen de componentes


ComponenteFuente de DatosUso en Plantilla
CNPJOrganización (Onboarding)Encabezado del documento
Código COSIFRuta de Operación (Transacción)Identificador de cuenta
SaldoOperación (Transacción)Valor a agregar
Fecha BaseFunción de fecha actualEncabezado del documento
Siempre valide el XML renderizado contra el esquema de BACEN antes de enviar. La estructura por sí sola no es suficiente — los datos deben reflejar el libro mayor real de su institución.