Un Saldo representa el valor poseído por una cuenta específica en Midaz. Refleja el resultado de todas las operaciones (débitos y créditos) ejecutadas a lo largo del tiempo, y siempre está vinculado a un Activo específico, como BRL, USD o BTC.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.
Múltiples saldos
Una única cuenta puede poseer varios saldos, cada uno identificado por una clave única. Esto permite a las instituciones segmentar fondos sin crear múltiples cuentas para el mismo cliente.
Las cuentas externas no pueden tener múltiples saldos. Cada cuenta externa está limitada a un único saldo.
- Reservas de inversión
- Límites de crédito
- Fondos de garantía (collateral) (bloqueados)
- Fondos operativos del día a día

Balance key
Cada saldo está identificado por un campokey que lo identifica de forma única dentro de la cuenta.
- Longitud máxima: 100 caracteres — no se permiten espacios en blanco.
- Clave por defecto:
"default"— asignada automáticamente cuando una cuenta se utiliza por primera vez en una transacción. - Unicidad: Las claves deben ser únicas por cuenta. Intentar crear un saldo con una clave que ya existe en la misma cuenta devuelve un error.
- En transacciones: Si no se especifica ningún
balanceKeyen una transacción, Midaz utiliza automáticamente el saldo con clave"default".
El campo
key se define en el momento de la creación y no puede modificarse. Elige claves descriptivas como "credit", "collateral" o "savings" para que tu modelo de saldos sea autodocumentado.Permission flags
Cada saldo tiene dospermission flags independientes que controlan si puede participar en transacciones:
| Flag | Tipo | Descripción |
|---|---|---|
allowSending | boolean | Si se pueden enviar fondos desde este saldo |
allowReceiving | boolean | Si se pueden recibir fondos en este saldo |
true cuando no se especifican.
Casos de uso comunes:
- Congelar un saldo: Establece
allowSendingyallowReceivingenfalsepara bloquear cualquier movimiento. - Saldo solo para recepción: Establece
allowSendingenfalsepara bloquear transferencias salientes mientras sigue aceptando entradas. - Saldo solo para envío: Establece
allowReceivingenfalsepara impedir que nuevos fondos entren en este saldo.
Ejemplos de uso
- Billetera de Usuario (BRL): Una billetera digital que muestra un saldo disponible de R$500.
- Caso de uso: Mostrar saldo en una aplicación de banca móvil y validar fondos antes de autorizar un pago.
- Cuenta de Liquidación (USD): Una cuenta de proveedor de liquidez con un saldo en USD de $120,000.
- Caso de uso: Asegurar que las operaciones diarias de tesorería mantengan suficiente margen para las liquidaciones FX.
- Saldo Bloqueado (BRL): Un saldo de cuenta reservado como garantía (collateral).
- Caso de uso: Prevenir el uso de fondos hasta que se cierre un préstamo o se cumplan las condiciones.
Estructura del Saldo
- Saldo > Cuenta: Cada Saldo pertenece a una Cuenta, que posee y mueve valor.
- Saldo > Activo: Cada Saldo está asociado a un Activo específico, como BRL o BTC.
- Saldo > Ledger: Los Saldos existen dentro de un Ledger, permitiendo entornos de múltiples libros.
- Saldo > Clave: Cada Saldo tiene una clave única dentro de la cuenta (p. ej.,
default,credit,collateral).

Características clave
- Seguimiento en tiempo real: Los saldos se actualizan con cada operación confirmada.
- Múltiples saldos por cuenta: Las cuentas pueden poseer varios saldos, cada uno con sus propias reglas.
- Fuente única de verdad: Los saldos reflejan la suma neta de todas las operaciones en la cuenta.
- Consulta por contexto: Los saldos se pueden listar por organización, Ledger, activo, cuenta o clave de saldo.
- Compatible con cuentas externas: Los saldos se pueden recuperar para cuentas internas o externas, incluyendo liquidity pools o socios.
Uso de saldos en transacciones
El campo
balanceKey se ha añadido a los siguientes endpoints de transacción para especificar qué saldo usar:
- Crear una Transacción usando JSON
- Crear una Transacción de Entrada (Inflow)
- Crear una Transacción de Salida (Outflow)
- Crear una Anotación de Transacción
balanceKey, el sistema utiliza por defecto el saldo principal de la cuenta.
Nuevos campos en las respuestas
balanceKey- Se devuelve en Transacciones y Operaciones, indicando qué saldo se utilizó.key- Se devuelve en Saldos, identificando de forma única cada saldo.
Utiliza siempre la
balanceKey de forma coherente en las solicitudes y respuestas para evitar desajustes cuando las cuentas poseen múltiples saldos.Cambios en la clave de caché (Valkey)
Los saldos almacenados en la caché (Valkey) incluyen la
balanceKey.
Formato anterior
Nuevo formato
Overdraft
Los saldos soportan overdraft — la capacidad de ser debitados más allá de los fondos disponibles. Cuando el overdraft está habilitado, el déficit se rastrea como
OverdraftUsed y Midaz maneja automáticamente el split de la operación y el reembolso.
Dos campos soportan esta funcionalidad:
direction— Define si un saldo se comporta como activo (credit, por defecto) o pasivo (debit). Se define en la creación, inmutable.settings— Controla el comportamiento de overdraft:allowOverdraft,overdraftLimitEnabledyoverdraftLimit.
La clave
"overdraft" está reservada para el saldo companion gestionado por el sistema que registra el lado del pasivo. Intentar crear un saldo con esta clave devuelve un error.settings.balanceScope. Los saldos transactional (por defecto) son gestionados por el usuario y participan en transacciones regulares. Los saldos internal son operados exclusivamente por el sistema — como el companion de overdraft — y no pueden ser objetivo de transacciones de usuario, ni modificados o eliminados a través de la API pública.
Para detalles completos sobre modos de configuración, splits de operación, reembolso automático, eventos y casos de uso, vea Overdraft de Saldo.
Historial de saldo
Midaz proporciona consultas point-in-time para saldos, lo que le permite recuperar el estado exacto de un saldo en cualquier momento del pasado. Esto es esencial para auditoría, conciliación e informes históricos.
Cómo funciona
Cuando consulta el historial de saldo, Midaz reconstruye el estado del saldo tal como existía en la fecha y hora especificadas. La respuesta incluye todos los mismos campos que un saldo regular — exceptoallowSending y allowReceiving. Estos campos reflejan permisos operacionales actuales en lugar del estado histórico, por lo que no se incluyen en las instantáneas point-in-time.
Casos de uso
- Auditoría regulatoria: Demuestre el saldo exacto de una cuenta en un punto de control de cumplimiento específico.
- Conciliación: Compare instantáneas de saldos entre sistemas en marcas de tiempo coincidentes.
- Resolución de disputas: Recupere el estado preciso de la cuenta en el momento de una transacción disputada.
- Informes de fin de día: Capture posiciones de saldo al cierre del mercado para operaciones de tesorería.
Consultar historial de saldo
Puede consultar el historial de un saldo individual o de todos los saldos de una cuenta:- Recuperar historial de saldo - Obtener el estado de un saldo específico en un momento determinado.
- Recuperar historial de saldo por cuenta - Obtener el estado de todos los saldos de una cuenta en un momento determinado.
Gestión de Saldos
Puedes recuperar tus Saldos utilizando la API. Los saldos son de solo lectura y son gestionados automáticamente por el motor del Ledger de Midaz.
- Crear un Saldo - Crea un nuevo saldo para una cuenta definiendo una clave única.
- Listar Saldos - Recupera todos los saldos por organización y Ledger.
- Recuperar un Saldo - Obtén el saldo de una cuenta específica por su ID único.
- Recuperar Saldos por Cuenta - Obtén el saldo de una cuenta específica.
- Recuperar un Saldo por Alias de Cuenta - Obtén el saldo utilizando un alias de cuenta legible por humanos (p. ej., @user123).
- Recuperar un Saldo de una Cuenta Externa - Recupera el saldo de una cuenta externa (p. ej.,
@external/BRL). - Actualizar un Saldo - Ajusta manualmente un saldo para fines operativos o de prueba.
- Eliminar un Saldo - Elimina una entrada de saldo del sistema.
Próximos pasos
- Utiliza la API de Operaciones para rastrear transacciones que involucren múltiples saldos.
- Combina múltiples saldos con Enrutamiento de Transacciones para crear flujos financieros flexibles y escalables.

