- Transaction Routes define the complete structure of a transaction — the required sequence of operations and how they fit together to form a valid financial event.
- Operation Routes define the rules for each individual operation (or “leg”) of that transaction, including the expected account type or specific account, the accounting annotation, and whether it’s a debit or credit.
You define the validation patterns through Operation Routes and Transaction Routes. Midaz ensures your transactions comply with these rules before processing.
What is Transaction Routing for?
Transaction Routing provides structured control over your financial operations by separating transaction logic from business code. Instead of hardcoding validation rules in your application, you configure reusable patterns that ensure every financial movement follows your organization’s requirements. These entities are dedicated to linking Transactions and Operations from the Midaz ledger to higher-level abstractions that facilitate integration with specialized plugins and external systems, especially for accounting and treasury abstractions. The structured annotations and classifications create a standardized vocabulary that other components can understand and leverage. This approach delivers:
- Consistency: All transactions follow predefined structures regardless of where they originate.
- Flexibility: Adapt your ledger design to match your business needs without code changes.
- Integrity: Automatic validation prevents malformed transactions from affecting your ledger.
- Maintainability: Centralized configuration makes it easier to update financial rules as your business evolves.
- Interoperability: Business-semantic fields enable seamless integration with accounting plugins and external financial systems.
Working with Transaction Routing
To use Transaction Routing, you must complete the initial configuration followed by ongoing transaction execution. Here’s your step-by-step process:
Initial Setup
1. Configure Ledger for transaction route validation
To activate transaction route validation for a specific Ledger, enable the validation settings through the Ledger Settings API. This controls whether transactions in that Ledger must comply with your configured routes.validateRoutes: When enabled, every transaction must reference a valid transaction route.validateAccountType: When enabled, account types are validated against operation route rules.
2. Create Operation Routes
Create Operation Routes that define validation rules and behavior for individual transaction components. Key fields:- title: Brief label that identifies the operation route.
- description: Optional detailed explanation.
- metadata: Key-value pairs for business context and custom categorization.
-
operationType: The accounting direction for this route —
source,destination, orbidirectional.source— Identifies accounts where funds originate (debit side).destination— Identifies accounts where funds are sent (credit side).bidirectional— Applies to both sides of the transaction, acting as both source and destination.
-
account: Optional validation rules specifying required account type or specific account.
- ruleType: Type of account validation rule (
account_type,alias). - validIf: The expected value that must match for validation to pass.
- ruleType: Type of account validation rule (
- accountingEntries: Optional accounting entries for each action type. See Accounting Entries below.
- Target Specific Account
- Target Account Type
accountingEntries field maps each stage to the correct double-entry accounting codes automatically.
Configure accounting entries for each action type:
direct, hold, commit, cancel, revert) maps to a double-entry accounting pair — allowing your ledger to automatically annotate operations with the correct accounting codes based on the transaction lifecycle stage.
The
operationType field now also supports bidirectional, which allows the route to operate in both directions — useful for routes that handle both sending and receiving, or for operations that may need to be reversed.Accounting entries validation matrix
Not every combination ofoperationType and action is valid. Midaz enforces a strict validation matrix when you create or update an Operation Route — if the rules aren’t met, the request is rejected before persisting.
Understanding this matrix is critical for integrators: sending an invalid combination returns error 0166 (field required) or 0162/0165 (scenario not allowed for direction).
source
| Action | Debit | Credit | Notes |
|---|---|---|---|
direct | Required | Optional | Standard one-step transaction at origin |
hold | Required | Required | Reserves funds — moves available → on_hold |
commit | Required | Optional | Finalizes a two-phase transaction |
cancel | Required | Required | Releases reserved funds — moves on_hold → available |
revert | — | — | Not allowed (error 0165). Use bidirectional instead |
| Action | Debit | Credit | Notes |
|---|---|---|---|
direct | Optional | Required | Standard one-step transaction at destination |
hold | — | — | Not allowed (error 0162) |
commit | Optional | Required | Finalizes a two-phase transaction |
cancel | — | — | Not allowed (error 0162) |
revert | — | — | Not allowed (error 0165). Use bidirectional instead |
| Action | Debit | Credit | Notes |
|---|---|---|---|
direct | Required | Required | Both sides of the double entry |
hold | Required | Required | Both sides of the double entry |
commit | Required | Required | Both sides of the double entry |
cancel | Required | Required | Both sides of the double entry |
revert | Required | Required | Only direction that supports revert |
An entry with neither
debit nor credit is always rejected, regardless of operation type or action.- Reserve group atomicity: If you define
hold, you must also definecommitandcancel(and vice versa). These three actions form an atomic group — you can’t configure one without the others. - Direct is mandatory: If any other action (
hold,commit,cancel,revert) is defined,directmust also be present. It serves as the baseline entry for the operation route.
3. Build Transaction Routes
Complete your setup by combining Operation Routes into Transaction Routes. These define your complete transaction patterns, mapping how different operations work together to form balanced financial events that match your business processes.4. Configure Accounting Entries (Actions)
Each Operation Route can include Accounting Entries — structured rubrics that define how debit and credit entries are recorded for each type of transactional event. When a Ledger is configured to validate routes, only events with registered entries are allowed. This ensures consistency in your accounting reports.Action types
Each action represents a transactional event. You configure accounting entries per action on each Operation Route:| Action | Identifier | Description |
|---|---|---|
| Direct Transaction | direct | Standard one-step transaction between two accounts, with no intermediate stages. |
| Hold (Value Reserve) | hold | First step of a Two-Phase Transaction: moves value from the available balance to on_hold on the source account. |
| Commit (Confirmation) | commit | Confirms a pending Two-Phase Transaction, transferring the on_hold value from the source account to the available balance on the destination account. |
| Cancel | cancel | Cancels a pending Two-Phase Transaction, returning the on_hold value to the available balance on the source account. |
| Revert | revert | Creates a reverse transaction that undoes the original operation. |
Accounting entry structure
Each action entry contains a debit and/or credit rubric, depending on the operation type:- Source routes require the debit rubric.
- Destination routes require the credit rubric.
- Bidirectional routes require both debit and credit rubrics.
- code — The chart of accounts code (e.g.,
1.1.1.001). - description — A human-readable description of the entry (e.g.,
Customer checking — outbound).
Validation behavior
When route validation is enabled for a Ledger and accounting entries are configured:- Only events with registered entries are allowed. If a client registers only the
directaction on a route, any attempt to execute a Two-Phase Transaction (which requireshold) will be automatically rejected. - Successful operations will have the rubric details recorded in the
routeCodeandrouteDescriptionfields on each operation.
Practical example: missing action rejection
Practical example: missing action rejection
Scenario: A client creates an Operation Route with only the
direct action configured.If that client attempts a Two-Phase Transaction (by sending pending: true), the transaction is automatically rejected because there is no hold entry registered.This ensures that your accounting reports remain consistent — all stages of an operation must be mapped before they can be executed.Ongoing Operations
5. Execute Validated Transactions
With your routing configuration in place, you can now submit transactions with confidence by including the ID of the previously created Transaction Route in your transaction request. Midaz will automatically validate the transaction against your defined routing patterns, ensuring consistency and integrity across all financial operations. For the previously configured Transaction Route and Operation Routes examples, the system composes the following validation structure:@user/wallet_123 account matches the user_wallet account type rule, and @external/BRL matches the exact alias requirement, ensuring the transaction follows your configured routing patterns.
Route fields on operations
When route validation is enabled and accounting entries are configured, every successfully processed operation will include two additional fields populated from the matched rubric:- routeCode — The chart of accounts code from the matching accounting entry rubric.
- routeDescription — The description from the matching accounting entry rubric.
Managing Operation and Transaction Routes
To configure your Operation Routes, use the following endpoints:
- Create an Operation Route — Define a new accounting rule for your operations.
- List Operation Routes — View all configured Operation Routes.
- Retrieve an Operation Route — Get detailed information on a specific Operation Route.
- Update an Operation Route — Modify existing accounting rules.
- Delete an Operation Route — Remove an outdated or unused Operation Route.
- Create a Transaction Route — Define new routing logic to connect transactions to accounting operations.
- List Transaction Routes — View all configured Transaction Routes.
- Retrieve a Transaction Route — Get details of a specific Transaction Route.
- Update a Transaction Route — Modify existing routing criteria.
- Delete a Transaction Route — Remove routes that are no longer applicable.

