Plans
Plan Unloop Long
Create a plan to close or reduce a leveraged long position
POST
Plan Unloop Long
Plan Unloop Long
Creates a plan to close or reduce a leveraged long position on a Morpho market. Unlooping withdraws the exposure asset, swaps it for the backing asset, and repays the loan — repeatedly — to deleverage. Returns a plan ID and an EIP-712 digest that must be signed to authorize execution.Request
Path parameters
| Parameter | Type | Description |
|---|---|---|
account_id | string | The sub-account ID |
Body parameters
| Parameter | Type | Required | Description |
|---|---|---|---|
exposure_asset | string | Yes | Long exposure asset (e.g., "WETH") |
backing_asset | string | Yes | Loan currency asset (e.g., "USDC") |
market_id | string | Yes | Morpho market ID (0x-prefixed 32-byte hex) |
exposure_amount | string | Yes | Amount of exposure to close in the asset’s smallest unit |
backing_amount_to_exit | string | Yes | Target backing asset amount to withdraw after deleveraging |
min_swap_backing_amount | string | Yes | Minimum acceptable backing asset from swaps (slippage protection) |
pool_fee | integer | Yes | Uniswap pool fee tier (e.g., 500, 3000, 10000) |
network | string | Yes | Network name (e.g., "base", "mainnet") |
Examples
Response (201 Created)
Response fields
| Field | Type | Description |
|---|---|---|
plan_id | string | Unique identifier for this plan (pln_ prefix) |
details | object | Transaction details including EIP-712 signing data |
details.eip712_data.digest | string | The hash to sign with the account’s signer key |
expires_at | string | ISO 8601 timestamp — plan must be executed before this time |
Errors
| Status | Code | Description |
|---|---|---|
| 400 | invalid_params | Missing required parameters or invalid market ID |
| 400 | plan_failed | Could not generate a valid plan |
| 400 | no_wallet | Account has no wallets |
| 408 | timeout | Folio computation timed out |
Notes
- Plans expire after 2 minutes. Sign and execute via Execute Plan before expiry.
- The
market_idmust match the one used when opening the position with Plan Loop Long. - Set
min_swap_backing_amountto protect against slippage — the transaction will revert if swaps yield less than this amount.
Plan Unloop Long