Skip to main content
Version: Endpoint V2

Track transfer status

Returns the current status of a cross-chain transfer. Poll this endpoint after executing user steps to monitor progress until completion.

GET/status/{quoteId}

Check the current status of a transfer. Returns the status and an optional LayerZero Scan explorer URL.
Path ParametersValue
quoteId
string
required
The quote ID from the /quotes response
Header ParametersValue
x-api-key
string
required
Your API key
Query ParametersValue
txHash
string
Optional transaction hash for faster status lookup
Response
{
"status": "SUCCEEDED",
"explorerUrl": "https://layerzeroscan.com/tx/...",
"executionHistory": [
{
"event": "SENT",
"transaction": {
"chainKey": "base",
"hash": "0x..."
}
},
{
"event": "DELIVERED",
"transaction": {
"chainKey": "optimism",
"hash": "0x..."
}
}
]
}

Reference

Authentication

Required. Include your API key in the x-api-key header.

Parameters

ParameterTypeLocationRequiredDescription
quoteIdstringPathYesQuote ID from the /quotes response
txHashstringQueryNoTransaction hash from execution (recommended for faster updates)

Response

Returns transfer status information with optional execution history.

Attributes

AttributeTypeDescription
statusenumCurrent transfer state: PENDING, PROCESSING, SUCCEEDED, FAILED, UNKNOWN
explorerUrlstringOptional LayerZero Scan URL for tracking
executionHistoryarrayOptional array of execution events

Status values

StatusDescriptionTerminal
UNKNOWNTransfer not found or not startedYes
PENDINGTransfer initiated but not yet processingNo
PROCESSINGCross-chain message in transitNo
SUCCEEDEDTransfer completed successfullyYes
FAILEDTransfer failed (reverted or timeout)Yes

Execution history events

EventDescriptionChain
SENTTransaction submittedSource chain
BUS_RODEBatch executed (Stargate V2 only)Source chain
DELIVEREDMessage deliveredDestination chain

Each event includes:

AttributeTypeDescription
eventenumEvent type
transactionobjectTransaction details
transaction.chainKeystringChain where event occurred
transaction.hashstringTransaction hash
transaction.timestampnumberUnix timestamp in milliseconds

Code examples

curl -X GET "https://transfer.layerzero-api.com/v1/status/quote_abc123?txHash=0x..." \
-H "x-api-key: YOUR_API_KEY"

Response

{
"status": "SUCCEEDED",
"explorerUrl": "https://layerzeroscan.com/tx/0x...",
"executionHistory": [
{
"event": "SENT",
"transaction": {
"chainKey": "base",
"hash": "0x123...",
"timestamp": 1704067200000
}
},
{
"event": "DELIVERED",
"transaction": {
"chainKey": "arbitrum",
"hash": "0x456...",
"timestamp": 1704067260000
}
}
]
}

Error handling

HTTP StatusDescriptionAction
404Quote not foundReturn UNKNOWN status
429Rate limit exceededWait 5 seconds, retry
500Server errorRetry with exponential backoff
async function checkStatusSafe(quoteId: string, txHash: string): Promise<string> {
try {
const params = new URLSearchParams({txHash});
const response = await fetch(
`https://transfer.layerzero-api.com/v1/status/${quoteId}?${params}`,
{headers: {'x-api-key': process.env.VT_API_KEY}},
);

if (response.status === 404) return 'UNKNOWN';
if (response.status === 429) {
await new Promise((r) => setTimeout(r, 5000));
return checkStatusSafe(quoteId, txHash);
}

const {status} = await response.json();
return status;
} catch (error) {
console.error('Status check failed:', error);
return 'UNKNOWN';
}
}

Examples