Build edit-order payload
Execution
Build Edit-Order Payload
Build a signed canonical payload to change the TP/SL of an existing perpetual position or pending order.
POST
Build edit-order payload
Edits the take-profit and/or stop-loss attached to a position or pending order. Pass
0 on Gains to remove a leg.
Request Body
gains or lighter.Chain of the position/order.
Mobula market identifier.
Gains trade index (regex
^\d+$). Required for Gains.New take-profit price (≥ 0). On Gains, pass
0 to clear the TP.New stop-loss price (≥ 0). On Gains, pass
0 to clear the SL.Authentication
Every/2/perp/payloads/<action> endpoint verifies the caller by requiring two extra fields in the request body alongside the action parameters:
Unix timestamp in milliseconds. Must be within 30 seconds of server time. Older timestamps are rejected to prevent replay.
Hex signature (EIP-191
personal_sign) of the message `${endpoint}-${timestamp}`, where endpoint is the path of this endpoint without the leading slash (e.g., for this page: api/2/perp/payloads/<this-action>). The recovered signer address becomes the user for the request. Single-use — replay returns 403 signature already used.Authentication errors
| Status | message |
|---|---|
| 403 | timestamp expired — timestamp older than 30s |
| 403 | signature already used — replay attempt |
| 400 | zod validation failed — timestamp/signature shape invalid |
Response envelope
Every/2/perp/payloads/<action> endpoint returns the same envelope shape. You pass these fields verbatim into POST /2/perp/execute-v2 to execute the action.
Top-level shape. Successful (2xx) responses return
{ data: { ... } }. A success: true flag is only present inside the body of execute-v2’s response, not on the payload-build endpoints. Parse defensively: read body.data, then check for the action-specific fields you need (e.g. data.payloadStr).Endpoint-specific errors
| Status | message |
|---|---|
| 400 | edit-order payload action failed — invalid TP/SL direction, missing position, or DEX refusal |
Full flow — edit TP/SL end-to-end
Single example covering both DEXes (Lighter offchain-api, Gains evm-tx). The flow branches ondata.transport.
Body
application/json