Skip to main content
GET
/
status
/
{quoteId}
Check transfer status
curl --request GET \
  --url https://transfer.layerzero-api.com/v1/status/{quoteId}
{
  "status": "SUCCEEDED",
  "explorerUrl": "https://layerzeroscan.com/tx/...",
  "executionHistory": [
    {
      "event": "SENT",
      "transaction": {
        "chainKey": "base",
        "hash": "0x..."
      }
    },
    {
      "event": "DELIVERED",
      "transaction": {
        "chainKey": "optimism",
        "hash": "0x..."
      }
    }
  ]
}
Returns the current status of a cross-chain transfer. Poll this endpoint after executing user steps to monitor progress until completion.

Reference

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_ID?txHash=0x..."

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}`,
    );

    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

Path Parameters

quoteId
string
required

The quote ID from the /quotes response

Example:

"quote_abc123"

Query Parameters

txHash
string

Optional transaction hash for faster status lookup

Example:

"0x..."

Response

200 - application/json

Successfully retrieved status

status
enum<string>
Available options:
PENDING,
PROCESSING,
SUCCEEDED,
FAILED,
UNKNOWN
explorerUrl
string
executionHistory
object[]