Overview
The closure flow has eight steps, grouped into three phases:
| Phase | Steps | Goal |
|---|---|---|
| 1. Freeze | 1–2 | Stop new inflows at both the Holder and Balance level. |
| 2. Settle and zero | 3–4 | Clear pending activity and return remaining funds to the customer. |
| 3. Close and archive | 5–8 | Deactivate Ledger Accounts and archive CRM records under retention policy. |
Throughout this guide,
{organization_id} and {ledger_id} identify the Midaz Organization and Ledger that own the accounts. They are abbreviated as /v1/.../accounts/{accountId} for readability.Prerequisites
Before starting, make sure you have:
- The
holderIdof the customer being offboarded. - The list of
accountIdvalues linked to that Holder across the Ledger (retrieve them from the Holder’s Alias Accounts). - Confirmation from your compliance team that the customer relationship can be terminated (no legal holds, open disputes, or pending regulatory requirements).
- Appropriate API credentials with permission to modify holders, balances, and accounts.
Via API
Run the full closure flow programmatically. Each step lists the endpoint, an example payload, and the compliance rationale.
Step 1 — Freeze the Holder
Deactivate the Holder so that no new alias accounts or downstream CRM workflows can be initiated for the customer. This is the first signal across the platform that the relationship is being closed.Freezing the Holder is a logical state change, not a deletion. The record remains fully readable for audit and regulatory purposes.
Step 2 — Block credits on the accounts
For each account linked to the Holder, prevent new funds from entering. First, list the Balances of the account, then update each balance to disable receiving. Retrieve the account balances:balanceId returned, block incoming funds:
Step 3 — Settle pending activity
Before you can zero a balance, the account must have no in-flight movements.- Check for transactions in processing. Confirm there are no pending or uncommitted transactions on the account. Commit or cancel them as appropriate using Commit a pending transaction or Cancel a pending transaction.
- Cancel active schedules. Cancel any recurring or scheduled transactions tied to the account so that no new entries are generated after closure begins.
Step 4 — Zero the balance
Return any remaining funds to the customer (the account holder) and confirm every balance reaches zero.- Record a return transaction that moves the remaining
availableamount from each customer account to the holder’s designated destination (for example, an external settlement account). Use Create a transaction. - Confirm
available = 0on every balance of every account in the Ledger before proceeding. You can verify this with Retrieve balances by account.
Step 5 — Close the Ledger Accounts in Midaz
With balances zeroed and pending activity cleared, delete each Ledger Account.204 No Content. Repeat for every account linked to the Holder. See Delete an account for the full contract.
Deleting a Ledger Account is a logical removal. The account and its historical operations remain available for audit and reporting, subject to your retention policy.
Step 6 — Register the closing date on the alias
Record the official closure date on the Holder’s Alias Account so that the CRM and any regulatory exports reflect when the relationship ended.closingDate lives in the bankingDetails object of the Alias Account and uses YYYY-MM-DD format. See Alias Accounts for the full field reference. Setting an accurate closing date is required for BACEN account-lifecycle reporting.Step 7 — Archive the alias accounts in CRM
Archive each Alias Account in CRM. Use a soft delete so the record is removed from active use but preserved for the regulatory retention period.Step 8 — Archive the Holder in CRM
Finally, archive the Holder itself with a soft delete once all of its alias accounts have been archived.Via Console
Run the same eight-step closure flow from the Midaz Console. The Console covers most of the flow point-and-click, but two steps — blocking credits (Step 2) and cancelling scheduled transactions (Step 3) — still require the API. Each step below notes the equivalent API step on this page.
Step 1 — Freeze the Holder
Set the Holder toINACTIVE so no new alias accounts or downstream CRM workflows can start for the customer.
Freezing the Holder is a logical state change, not a deletion. The record stays fully readable for audit and regulatory purposes. See Editing a Holder.
Step 2 — Block credits on the accounts
For each account linked to the Holder, setallowReceiving to false on every balanceId via the API so new inflows are blocked while outflows remain available for the return transaction in Step 4.
Step 3 — Settle pending activity
Confirm there are no in-flight movements before zeroing any balance.From the Transactions page, filter by the accounts linked to the Holder and confirm there are no pending or uncommitted transactions. Commit or cancel any that are in flight.
Step 4 — Zero the balance
Return any remaining funds to the customer and confirm every balance reaches zero.From the Transactions page, click New Transaction and create a return transaction that moves the remaining
available amount from each customer account to the holder’s designated destination (for example, an external settlement account). See Creating a Transaction.Step 5 — Close the Ledger Accounts in Midaz
With balances zeroed and pending activity cleared, delete each Ledger Account.From the Accounts page, find the Account linked to the Holder, click the three dots () in the Actions column, and select Delete.
Deleting a Ledger Account is a logical removal. The account and its historical operations remain available for audit and reporting, subject to your retention policy. See Deleting an Account.
Step 6 — Register the closing date on the alias
Record the official closure date on the Holder’s Alias Account so the CRM and regulatory exports reflect when the relationship ended.From the Alias Accounts page, find the alias account to update, click the three dots () in the Actions column, and select Edit.
In the Alias Account form, set the Closing Date (in
bankingDetails) to the official closure date using YYYY-MM-DD format.An accurate closing date is required for BACEN account-lifecycle reporting. See Editing an Alias Account.
Step 7 — Archive the alias accounts in CRM
Archive each Alias Account with a soft delete so the record is removed from active use but preserved for the regulatory retention period.From the Alias Accounts page, find the alias account to archive, click the three dots () in the Actions column, and select Delete.
Step 8 — Archive the Holder in CRM
Once all of its alias accounts are archived, archive the Holder itself with a soft delete.From the Holders page, find the Holder to archive, click the three dots () in the Actions column, and select Delete.
BACEN compliance notes
- Order is mandatory. Freezing inflows (Steps 1–2) before settling and zeroing (Steps 3–4) prevents funds from entering an account that is mid-closure.
- Return funds before closing. Any residual balance must be returned to the customer and confirmed at zero before an account is deleted. Closing an account with funds is both blocked by Midaz and non-compliant.
- Archive, don’t erase. Holders and alias accounts are soft-deleted (no
hard_delete) so the records remain available for the regulatory retention period. Permanent deletion would remove evidence required for BACEN audits. - Record the closing date. The
closingDateon the alias gives regulators an authoritative timestamp for when the relationship ended. - Preserve the audit trail. Ledger Accounts and operations are logically removed and remain queryable for reconciliation and reporting.

