El Balance Overdraft permite que un saldo sea debitado más allá de sus fondos disponibles sin dejar que el saldo primario quede negativo. El déficit se rastrea como OverdraftUsed, y Midaz maneja automáticamente el split de la operación entre el saldo primario y un saldo companion interno. Cuando llegan créditos, el reembolso se prioriza — el overdraft se paga primero, y cualquier excedente va al Available. Este mecanismo soporta líneas de crédito, BNPL, cuentas de liquidación, anticipo salarial y cualquier escenario donde se requieren posiciones negativas controladas.Documentation Index
Fetch the complete documentation index at: https://docs.lerian.studio/llms.txt
Use this file to discover all available pages before exploring further.
Dirección del saldo
Los saldos llevan un campo
direction que define cómo los débitos y créditos afectan al saldo:
| Dirección | Comportamiento | Uso típico |
|---|---|---|
credit (por defecto) | Débito disminuye, crédito aumenta | Saldos tipo activo — cuentas corrientes, billeteras, reservas |
debit | Débito aumenta, crédito disminuye | Saldos tipo pasivo — préstamos, seguimiento de overdraft, cuentas por pagar |
La dirección se define en el momento de la creación y es inmutable. El saldo companion de overdraft (descrito a continuación) siempre usa
direction=debit.Configuraciones del saldo
El objeto
settings en un saldo controla el comportamiento de overdraft:
| Campo | Tipo | Descripción |
|---|---|---|
allowOverdraft | boolean | Habilita overdraft en este saldo |
overdraftLimitEnabled | boolean | Define si se impone un límite |
overdraftLimit | string (decimal) | Monto máximo de overdraft. Requerido cuando overdraftLimitEnabled es true. Debe ser mayor que 0. |
Un campo
balanceScope también existe dentro de settings, pero es gestionado por el sistema — distingue los saldos internos (como el companion de overdraft) de los saldos transaccionales. No configuras este campo directamente.Modos de configuración
Sin overdraft (por defecto)
El comportamiento estándar. Cualquier débito que exceda el saldo disponible es rechazado.Overdraft ilimitado
El saldo puede quedar negativo sin tope. Útil para cuentas de liquidación o pool donde las posiciones negativas son normales y se concilian externamente.Overdraft limitado
El saldo puede quedar negativo hasta un límite definido. El modo más común para productos de crédito al consumidor.Cómo funciona el overdraft
Split de operación
Cuando una transacción de débito excede los fondos disponibles, Midaz divide automáticamente la operación:- El débito consume todo el Available restante, fijándolo en 0.
- El excedente se acumula como OverdraftUsed en el saldo primario.
- Se crea una operación companion en el saldo interno
"overdraft"(descrito a continuación), registrando el pasivo como un débito de partida doble.
| Paso | Available | OverdraftUsed | Descripción |
|---|---|---|---|
| Antes | 300 | 0 | Estado normal |
| Después | 0 | 200 | 300 consumidos del Available, 200 acumulados como overdraft |
Si un límite está configurado, Midaz valida que el OverdraftUsed resultante no exceda el
overdraftLimit antes de procesar. Si lo excede, la transacción es rechazada con el error 0167 - ErrOverdraftLimitExceeded.Reembolso automático (refund split)
Cuando llega un crédito yOverdraftUsed > 0, Midaz prioriza el reembolso:
- El crédito se aplica al OverdraftUsed primero, reduciendo la deuda.
- Cualquier monto remanente después de que OverdraftUsed llegue a 0 va al Available.
- Una operación companion en el saldo
"overdraft"registra el reembolso.
| Paso | Available | OverdraftUsed | Descripción |
|---|---|---|---|
| Antes | 0 | 200 | Overdraft activo |
| Después | 150 | 0 | 200 reembolsados, 150 van al Available |
Cancelación de transacción pendiente con overdraft
Cuando una transacciónPENDING que consumió overdraft es cancelada, Midaz mantiene el saldo companion sincronizado con el primario:
- La cancelación revierte el hold original y cualquier overdraft consumido durante la ventana pending —
OverdraftUsedregresa al valor previo a la transacción pending. - Una operación
CREDITcompanion en el saldo"overdraft"reduce el pasivo por el monto exacto que fue consumido, reembolsándolo. - Tanto la cancelación primaria como el crédito companion se aplican en el mismo batch atómico, por lo que el saldo primario y el companion nunca se desincronizan — incluso si la cancelación llega en una ráfaga de alta concurrencia.
Position
Toda respuesta de saldo incluye un bloque computado
position que proporciona una vista en tiempo real del estado del saldo:
| Campo | Descripción |
|---|---|
available | Balance.Available menos OverdraftUsed. Puede ser negativo cuando el overdraft está activo. |
onHold | Refleja Balance.OnHold — fondos reservados por operaciones pendientes. |
overdraftLimitAvailable | Margen de overdraft restante. "0" cuando el overdraft está deshabilitado. Omitido cuando es ilimitado. Decimal positivo cuando un límite está configurado. |
Saldo companion
La primera vez en que
allowOverdraft pasa a true en un saldo — sea en la creación o vía update — Midaz auto-aprovisiona un saldo companion bajo la misma cuenta para registrar el lado del pasivo en la partida doble. Se crea una sola vez por cuenta y se reutiliza en cada draw y reembolso de overdraft.
| Propiedad | Valor | Por qué |
|---|---|---|
key | "overdraft" | Clave reservada del sistema |
direction | debit | El companion rastrea un pasivo — los débitos lo aumentan, los créditos lo reducen |
scope | internal | Bloquea operaciones directas de usuarios |
allowSending | true | Necesario para operaciones DEBIT en el companion (consumo de overdraft) |
allowReceiving | true | Necesario para operaciones CREDIT en el companion (reembolsos de overdraft) |
- No puede ser creado, modificado o eliminado a través de la API pública.
- La clave
"overdraft"está reservada — intentar crear un saldo con esta clave devuelve el error0170 - ErrReservedBalanceKey. - Refleja el pasivo como un registro de partida doble, asegurando que el ledger se mantenga equilibrado.
El valor
scope: "internal" controla el acceso directo de usuarios independientemente de las flags de permiso anteriores — cualquier intento de operar directamente sobre este saldo es rechazado con el error 0168 - ErrDirectOperationOnInternalBalance. El companion solo se mueve a través del enrichment de overdraft conducido por el sistema.Estado de overdraft en las operaciones
Toda operación expone el estado de overdraft directamente en los bloques
balance y balanceAfter. El campo overdraftUsed captura cuánto overdraft fue consumido antes y después de la operación — proporcionando un rastro de auditoría completo sin necesidad de una consulta separada al saldo.
Para operaciones que no tocan el overdraft, ambos valores son "0".
Las operaciones companion gestionadas por el sistema en el saldo "overdraft" se exponen con type: "OVERDRAFT" (en mayúsculas). El campo direction lleva la semántica del ciclo de vida: "debit" para un draw, "credit" para un reembolso.
overdraftUsed antes/después — ambas reflejan la transición de overdraft del saldo primario, haciendo el ciclo de vida visible desde cualquiera de los lados. La columna interna snapshot (JSONB) en la tabla operations almacena los mismos valores para indexación y reconstrucción histórica; no forma parte del JSON público y aparece en balance.overdraftUsed y balanceAfter.overdraftUsed. Contexto adicional generado por el sistema puede agregarse al snapshot sin romper el contrato público.
Eventos de overdraft
Midaz publica eventos de ciclo de vida en RabbitMQ cuando el estado de overdraft cambia. La publicación está habilitada por defecto — establezca la flag en
"false" para deshabilitar.
Tipos de evento
| Evento | Descripción |
|---|---|
overdraft.drawn | Se consumió overdraft — OverdraftUsed aumentó |
overdraft.repaid | Se reembolsó parcialmente el overdraft — OverdraftUsed disminuyó pero permanece > 0 |
overdraft.cleared | Se liquidó totalmente el overdraft — OverdraftUsed llegó a 0 |
Ejemplo de payload del evento
Casos de uso
Sobregiro de cuenta corriente
Crédito clásico al consumidor. El saldo de la cuenta corriente puede quedar negativo hasta un límite preaprobado, con intereses acumulados sobre el monto pendiente.Buy Now, Pay Later (BNPL)
Un proveedor de BNPL emite un crédito de compra contra el saldo del cliente, creando una posición de overdraft inmediata que se paga en cuotas.Anticipo salarial (Earned Wage Access)
Los empleados retiran contra ingresos futuros. La posición de overdraft se liquida cuando llegan los créditos de nómina.Anticipo de cuentas por cobrar de marketplace
Los vendedores reciben un anticipo sobre cuentas por cobrar futuras. El overdraft se paga automáticamente conforme llegan las liquidaciones de ventas.Cuentas de liquidación / Pool (modo ilimitado)
Las cuentas de liquidación y pool rutinariamente quedan negativas durante el procesamiento intradía. El overdraft ilimitado evita rechazos artificiales mientras la posición se concilia al final del día.Líneas de crédito revolvente (B2B)
Las empresas retiran y pagan de una facilidad de crédito revolvente. El límite de overdraft representa la línea de crédito total.Prefinanciamiento de seguros
Las aseguradoras prefinancian siniestros antes del cierre de los ciclos de cobro de primas. El overdraft cubre la brecha entre el pago y la cobranza.Programas de fidelización (puntos anticipados)
Los clientes canjean puntos antes de acumularlos. El overdraft rastrea el déficit de puntos, pagado conforme se acumulan nuevos puntos.Reglas de protección
El overdraft introduce varias restricciones de inmutabilidad y acceso para mantener la integridad del ledger:
- La dirección es inmutable. Una vez definida en la creación, la
directionde un saldo no puede cambiarse. - Los saldos internos son de solo lectura. El saldo companion
"overdraft"no puede ser creado, eliminado ni actualizado a través de la API pública. Las solicitudes PATCH sobre saldos internos son rechazadas con el error0175. - Claves reservadas. La clave
"overdraft"está reservada para el saldo companion gestionado por el sistema. - Deshabilitar overdraft preserva la deuda pendiente. Establecer
allowOverdraft: falsemientrasOverdraftUsed > 0está permitido — la flag bloquea nuevos retiros vía overdraft, mientras que los créditos entrantes siguen pagando la deuda existente hasta llegar a cero. - El límite no puede bajar del uso. Si
OverdraftUsed = 200, estableceroverdraftLimit: "100"es rechazado (error0173) — pague el overdraft por debajo del nuevo techo primero, o establezca un límite mayor. - Concurrencia optimista. Las actualizaciones de saldo usan control de concurrencia basado en versión. Las escrituras obsoletas son rechazadas con el error
0174— reintente con la versión más reciente.
Próximos pasos
- Conozca los Saldos — la base sobre la que se construye el overdraft.
- Entienda las Operaciones para rastrear cómo los splits de overdraft aparecen en el ledger.
- Configure el Event Publisher para consumir eventos del ciclo de vida del overdraft.
- Explore las Transacciones para la visión completa de la contabilidad de partida doble en Midaz.

