Saltar al contenido principal

Valores numéricos (string)

Todos los valores financieros en Fees Engine deben expresarse como string, usando el tipo numeric. Esto garantiza el manejo de decimales de alta precisión para activos como BRL o BTC, y previene errores de redondeo durante cálculos, divisiones o exenciones.
Importante
  • Requerido: Midaz v3.x.x (usa numeric).
  • Incompatible: Midaz v2.x.x (formato obsoleto amount + scale).
Los clientes que usen Midaz v2.x.x deben actualizar a v3.x.x para garantizar la integración y funcionalidad adecuadas con el Motor de Tarifas.
Ejemplo:
"value": "12.50"

Reglas de cálculo de tarifas

Cada tarifa usa una applicationRule para definir cómo se calcula. Puedes elegir entre tres tipos de reglas: Puedes combinar diferentes reglas en un solo paquete para ajustarse a tu caso de uso. Otros campos clave:
  • isDeductibleFrom: define si la tarifa se deduce del remitente o del receptor.
  • referenceAmount: ya sea originalAmount o afterFeesAmount.
  • priority: define el orden de aplicación. La prioridad 1 siempre debe usar originalAmount.

maxBetweenTypes

Aplica el mayor valor entre: una tarifa fija o una basada en porcentaje. Ejemplo
  • Valor de tarifa fija: R$5.
  • Tarifa porcentual: 2%.
  • Monto de referencia: R$1,000.
tasa = 1000 * 0.02 = R$ 20.00
Dado que R20.00>R20.00 > R5, se aplica la tarifa basada en porcentaje.

flatFee

Aplica un monto de tarifa fijo. El comportamiento depende de isDeductibleFrom. Ejemplo
  • Tarifa fija: R$15.
  • Monto de referencia: R$115.
isDeductibleFromFórmulaTarifa Total
falsereferenceAmount + feeR$ 130.00
truereferenceAmount - feeR$ 100.00

percentual

Aplica una tarifa como porcentaje del monto de referencia. Ejemplo
  • Valor: 30%.
  • Monto de referencia: R$ 389.50.
isDeductibleFromFórmulaTarifa Total
falsereferenceAmount * valueR$ 116.85
truereferenceAmount - (referenceAmount * value)R$ 272.65

División de tarifas

Cuando una transacción tiene múltiples cuentas de origen, el Motor de Tarifas divide las tarifas proporcionalmente.

Ejemplo

  • Monto total: R$4,000.00
  • Tarifa fija: R$15.00
  • Impuesto: 4%
  • isDeductibleFrom: false

Porcentaje de participación

Fórmula: (Monto de Cuenta ÷ Monto Total) × 100
CuentaParticipaciónMonto
@account125%R$ 1,000
@account225%R$ 1,000
@account340%R$ 1,600
@account410%R$ 400

Distribución de tarifa fija

Fórmula: Tarifa fija × participación %
CuentaPorción de TarifaTotal
@account1R$ 3.75R$ 1,003.75
@account2R$ 3.75R$ 1,003.75
@account3R$ 6.00R$ 1,606.00
@account4R$ 1.50R$ 401.50

Impuesto proporcional

Fórmula: monto de cuenta × impuesto %
CuentaImpuestoTotal c/ Impuesto
@account1R$ 40.00R$ 1,040.00
@account2R$ 40.00R$ 1,040.00
@account3R$ 64.00R$ 1,664.00
@account4R$ 16.00R$ 416.00

Monto final por cuenta

Fórmula: principal + tarifa + impuesto
CuentaTarifaImpuestoTotal Final
@account1R$ 3.75R$ 40.00R$ 1,043.75
@account2R$ 3.75R$ 40.00R$ 1,043.75
@account3R$ 6.00R$ 64.00R$ 1,670.00
@account4R$ 1.50R$ 16.00R$ 417.50

Validaciones

  • Total de participaciones = 100%
  • División de tarifa coincide con tarifa fija
  • División de impuesto = 4%
  • Total enviado = R$ 4,175.00

Exenciones de tarifas: reglas y jerarquía

Por monto de transacción

Usa minimumAmount y maximumAmount para definir cuándo deben aplicarse las tarifas.
Por ejemplo: Si el rango es R0300,unatransaccioˊndeR 0–300, una transacción de R 301 no activará tarifas.

Por cuenta

El sistema verifica waivedAccounts. Si la fuente está listada, está exenta de tarifas.
Jerarquía: Verificación de rango de valor > luego exención de cuenta

Ejemplo mixto: exenciones de tarifas y división proporcional de tarifas

Veamos un ejemplo de un paquete que incluye cuentas con exenciones de tarifas y requiere dividir las tarifas proporcionalmente.

Escenario

Estamos procesando una transacción de R$ 4,000, que incluye:
  • Una tarifa fija de R$ 16.
  • Solo algunas cuentas están sujetas a la tarifa fija
  • Un impuesto IOF del 6% a deducir.

División en el lado de origen

Cuenta de Origen%Valor Proporcional
@account115%R$ 600
@account235%R$ 1,400
@account340%R$ 1,600
@account410%R$ 400
Tarifa fija aplicada solo a @account3 y @account4.

Resultado después de Tarifa Administrativa (proporcional)

CuentaTarifa AdminTotal
@account1ExentoR$ 600
@account2ExentoR$ 1,400
@account3R$ 12.80R$ 1,612.80
@account4R$ 3.20R$ 403.20
El valor total de envío aumenta a R$4,016.

Deducción de IOF (destinatario)

Destinatario%BrutoIOF (6%)Neto
@donation125%R$ 1,000R$ 60R$ 940
@donation225%R$ 1,000R$ 60R$ 940
@donation325%R$ 1,000R$ 60R$ 940
@donation425%R$ 1,000R$ 60R$ 940
Las tarifas se acreditan a las cuentas definidas en el creditAccount de cada tarifa.

Decimales repetidos

Cuando una división de tarifa resulta en decimales repetidos (por ejemplo, 0.3333…), el Motor de Tarifas ajusta automáticamente el primer o mayor valor por un centavo para garantizar que el total permanezca exacto. Esto evita deriva por redondeo y mantiene tu libro mayor consistente.
I