> ## Documentation Index
> Fetch the complete documentation index at: https://anypay-docs-update-resources-2026-06-29.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# GetIntent

## Overview

The `GetIntent` endpoint retrieves the complete intent object for a specific intent ID. This provides all the details about the intent including quote information, fee breakdown, transaction calls, and metadata.

## Use Cases

* Retrieve full intent details after creation
* Review quote and fee information
* Inspect transaction calls and preconditions
* Verify intent parameters
* Debug issues with intent execution
* Display intent details in UI

## Request Parameters

### Required Fields

* **intentId** (string): The unique identifier of the intent

## Response

The response includes:

* **intent** (Intent): Complete intent object with all details

### Intent Object Structure

The intent object contains comprehensive information:

#### Core Fields

* **id** (number): Internal database ID
* **intentId** (string): Unique intent identifier
* **status** (IntentStatus): Current status
* **ownerAddress** (string): Wallet address of the intent owner
* **originIntentAddress** (string): Intent contract address on origin chain
* **destinationIntentAddress** (string): Intent contract address on destination chain
* **destinationSalt** (number): Salt for deterministic intent address generation
* **trailsVersion** (string): Version of Trails protocol used
* **expiresAt** (string): Intent expiration timestamp
* **createdAt** (string): Creation timestamp
* **updatedAt** (string): Last update timestamp

#### Quote Request

* **quoteRequest** (QuoteIntentRequest): Original quote parameters
  * Origin and destination chain/token details
  * Amounts and trade type
  * Options (provider, slippage, etc.)

#### Transaction Details

* **depositTransaction** (DepositTransaction): Deposit details
  * Token address and amount
  * Recipient address
  * Token decimals

* **calls** (IntentCalls\[]): Cross-chain calls to execute
  * Chain ID for each call set
  * Transaction calls with calldata
  * Nonce and space information

* **preconditions** (TransactionPrecondition\[]): Pre-execution checks
  * Token balance requirements
  * Minimum amount validations

* **metaTxns** (MetaTxn\[]): Meta-transaction information
  * Meta-transaction IDs
  * Wallet addresses
  * Contract targets

#### Quote Information

* **quote** (IntentProviderQuote): Quote provider details
  * Provider name and request ID
  * Input/output amounts and minimums
  * Slippage and price impact
  * Provider fees in USD

#### Fee Breakdown

* **fees** (IntentFees): Comprehensive fee information
  * **originGas**: Origin chain gas fees
  * **destinationGas**: Destination chain gas fees
  * **provider**: Provider fees (quote provider + Trails)
  * **feeTokenAddress**: Token used for fees
  * **feeTokenTotal**: Total fee in fee token
  * **totalFeeAmount**: Total fee amount
  * **totalFeeUsd**: Total fee in USD

## Example

```typescript theme={null}
const intentResponse = await fetch('https://trails-api.sequence.app/rpc/Trails/GetIntent', {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json',
    'X-Access-Key': 'YOUR_ACCESS_KEY'
  },
  body: JSON.stringify({
    intentId: 'intent_123abc'
  })
});

const { intent } = await intentResponse.json();

console.log('Intent ID:', intent.intentId);
console.log('Status:', intent.status);
console.log('Owner:', intent.ownerAddress);
console.log('Expires:', intent.expiresAt);

// Quote information
console.log('From Amount:', intent.quote.fromAmount);
console.log('To Amount:', intent.quote.toAmount);
console.log('Price Impact:', intent.quote.priceImpact);

// Fee breakdown
console.log('Total Fee (USD):', intent.fees.totalFeeUsd);
console.log('Origin Gas Fee:', intent.fees.originGas.totalFeeUsd);
console.log('Destination Gas Fee:', intent.fees.destinationGas?.totalFeeUsd);
console.log('Provider Fee:', intent.fees.provider.totalFeeUsd);
```

## Detailed Fee Inspection

```typescript theme={null}
function analyzeFees(intent: Intent) {
  const fees = intent.fees;
  
  console.log('=== Fee Breakdown ===');
  
  // Gas fees
  console.log('\nOrigin Chain Gas:');
  console.log('  Chain ID:', fees.originGas.chainId);
  console.log('  Gas Limit:', fees.originGas.totalGasLimit);
  console.log('  Gas Price:', fees.originGas.gasPrice);
  console.log('  Native Token:', fees.originGas.nativeTokenSymbol);
  console.log('  Cost (USD):', fees.originGas.totalFeeUsd);
  console.log('  Network Status:', fees.originGas.chainGasUsageStatus);
  
  console.log('\nDestination Chain Gas:');
  console.log('  Chain ID:', fees.destinationGas?.chainId);
  console.log('  Gas Limit:', fees.destinationGas?.totalGasLimit);
  console.log('  Gas Price:', fees.destinationGas?.gasPrice);
  console.log('  Native Token:', fees.destinationGas?.nativeTokenSymbol);
  console.log('  Cost (USD):', fees.destinationGas?.totalFeeUsd);
  console.log('  Network Status:', fees.destinationGas?.chainGasUsageStatus);
  
  // Provider fees
  console.log('\nProvider Fees:');
  console.log('  Quote Provider:', fees.provider.quoteProvider);
  console.log('  Provider Fee:', fees.provider.quoteProviderFeeUsd, 'USD');
  console.log('  Trails Fee:', fees.provider.trailsFeeUsd, 'USD');
  console.log('  Total Provider:', fees.provider.totalFeeUsd, 'USD');
  
  // Grand total
  console.log('\n=== TOTAL ===');
  console.log('Fee Token:', fees.feeTokenAddress);
  console.log('Total Amount:', fees.totalFeeAmount);
  console.log('Total USD:', fees.totalFeeUsd);
}

const { intent } = await getIntent('intent_123abc');
analyzeFees(intent);
```

## Inspecting Transaction Calls

```typescript theme={null}
function inspectCalls(intent: Intent) {
    console.log('=== Transaction Origin Calls ===\n');

    console.log('Origin Chain ID:', intent.originCalls.chainId);
    console.log('Origin Space:', intent.originCalls.space);
    console.log('Origin Nonce:', intent.originCalls.nonce);
    console.log('Origin Calls:', intent.originCalls.calls.length);

    intent.originCalls.calls.forEach((call, callIndex) => {
        console.log(`\n  Call ${callIndex + 1}:`);
        console.log('    To:', call.to);
        console.log('    Value:', call.value);
        console.log('    Data:', call.data);
        console.log('    Gas Limit:', call.gasLimit);
        console.log('    Delegate:', call.delegateCall);
    });

    console.log('=== Transaction Destination Calls ===\n');

    console.log('Destination Chain ID:', intent.destinationCalls?.chainId);
    console.log('Destination Space:', intent.destinationCalls?.space);
    console.log('Destination Nonce:', intent.destinationCalls?.nonce);
    console.log('Destination Calls:', intent.destinationCalls?.calls.length);

    intent.destinationCalls?.calls.forEach((call, callIndex) => {
        console.log(`\n  Call ${callIndex + 1}:`);
        console.log('    To:', call.to);
        console.log('    Value:', call.value);
        console.log('    Data:', call.data);
        console.log('    Gas Limit:', call.gasLimit);
        console.log('    Delegate:', call.delegateCall);
    });
}

const { intent } = await getIntent('intent_123abc');
inspectCalls(intent);
```

## Use Cases

### 1. Display Intent Summary in UI

```tsx theme={null}
import { TrailsApi, type Intent } from "@0xtrails/api";
import { useEffect, useState } from "react";

const trailsApi = new TrailsApi('YOUR_API_KEY')

export const IntentSummary = ({ intentId }: { intentId: string }) => {
    const [intent, setIntent] = useState<Intent | null>(null);

    useEffect(() => {
        trailsApi.getIntent({ intentId }).then(({ intent }) => setIntent(intent));
    }, [intentId]);

    if (!intent) return <div>Loading...</div>;

    return (
        <div>
            <h2>Intent {intent.intentId}</h2>
            <div>Status: {intent.status}</div>
            <div>From: Chain {intent.quoteRequest.originChainId}</div>
            <div>To: Chain {intent.quoteRequest.destinationChainId}</div>
            <div>Amount: {intent.quote.fromAmount} → {intent.quote.toAmount}</div>
            <div>Total Fee: ${intent.fees.totalFeeUsd}</div>
            <div>Expires: {new Date(intent.expiresAt).toLocaleString()}</div>
        </div>
    );
}
```

### 2. Verify Intent Before Signing

```typescript theme={null}
import { TrailsApi } from "@0xtrails/api";

const trailsApi = new TrailsApi('YOUR_API_KEY')

export async function verifyBeforeSigning(intentId: string) {
    const { intent } = await trailsApi.getIntent({ intentId });

    // Check expiration
    const expiresAt = new Date(intent.expiresAt);
    const now = new Date();

    if (expiresAt < now) {
        throw new Error('Intent has expired');
    }

    // Check fees are reasonable
    if (intent.fees.totalFeeUsd > 10) {
        console.warn('High fees detected:', intent.fees.totalFeeUsd);
    }

    const slippage = (intent.quote.fromAmount - intent.quote.fromAmountMin) / intent.quote.fromAmount;
    // Check if slippage is greater than 5%
    if (slippage > 0.05) {
        console.warn('High slippage:', slippage * BigInt(100), '%');
    }

    return intent;
}
```

<Info>
  Use this endpoint to retrieve intent details at any time. The intent object remains accessible even after execution completes.
</Info>

## Next Steps

* Use `GetIntentReceipt` to check execution status and get transaction hashes
* Use `SearchIntents` to find all intents for a specific address
* Modify and recommit expired intents with fresh quotes


## OpenAPI

````yaml trails-api.gen.json post /rpc/Trails/GetIntent
openapi: 3.0.0
info:
  title: Trails API
  version: 0.0.1
servers:
  - url: https://trails-api.sequence.app
    description: Trails API
security: []
paths:
  /rpc/Trails/GetIntent:
    post:
      tags:
        - Trails
      operationId: Trails-GetIntent
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/GetIntentRequest'
      responses:
        '200':
          description: OK
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/GetIntentResponse'
        4XX:
          description: Client error
          content:
            application/json:
              schema:
                oneOf:
                  - $ref: '#/components/schemas/ErrorWebrpcEndpoint'
                  - $ref: '#/components/schemas/ErrorWebrpcRequestFailed'
                  - $ref: '#/components/schemas/ErrorWebrpcBadRoute'
                  - $ref: '#/components/schemas/ErrorWebrpcBadMethod'
                  - $ref: '#/components/schemas/ErrorWebrpcBadRequest'
                  - $ref: '#/components/schemas/ErrorWebrpcClientAborted'
                  - $ref: '#/components/schemas/ErrorWebrpcStreamLost'
                  - $ref: '#/components/schemas/ErrorUnauthorized'
                  - $ref: '#/components/schemas/ErrorPermissionDenied'
                  - $ref: '#/components/schemas/ErrorSessionExpired'
                  - $ref: '#/components/schemas/ErrorMethodNotFound'
                  - $ref: '#/components/schemas/ErrorRequestConflict'
                  - $ref: '#/components/schemas/ErrorAborted'
                  - $ref: '#/components/schemas/ErrorGeoblocked'
                  - $ref: '#/components/schemas/ErrorRateLimited'
                  - $ref: '#/components/schemas/ErrorProjectNotFound'
                  - $ref: '#/components/schemas/ErrorAccessKeyNotFound'
                  - $ref: '#/components/schemas/ErrorAccessKeyMismatch'
                  - $ref: '#/components/schemas/ErrorInvalidOrigin'
                  - $ref: '#/components/schemas/ErrorInvalidService'
                  - $ref: '#/components/schemas/ErrorUnauthorizedUser'
                  - $ref: '#/components/schemas/ErrorQuotaExceeded'
                  - $ref: '#/components/schemas/ErrorQuotaRateLimit'
                  - $ref: '#/components/schemas/ErrorNoDefaultKey'
                  - $ref: '#/components/schemas/ErrorMaxAccessKeys'
                  - $ref: '#/components/schemas/ErrorAtLeastOneKey'
                  - $ref: '#/components/schemas/ErrorTimeout'
                  - $ref: '#/components/schemas/ErrorInvalidArgument'
                  - $ref: '#/components/schemas/ErrorUnavailable'
                  - $ref: '#/components/schemas/ErrorQueryFailed'
                  - $ref: '#/components/schemas/ErrorIntentStatus'
                  - $ref: '#/components/schemas/ErrorNotFound'
                  - $ref: '#/components/schemas/ErrorUnsupportedNetwork'
                  - $ref: '#/components/schemas/ErrorClientOutdated'
                  - $ref: '#/components/schemas/ErrorIntentsSkipped'
                  - $ref: '#/components/schemas/ErrorQuoteExpired'
                  - $ref: '#/components/schemas/ErrorHighPriceImpact'
                  - $ref: '#/components/schemas/ErrorIntentsDisabled'
        5XX:
          description: Server error
          content:
            application/json:
              schema:
                oneOf:
                  - $ref: '#/components/schemas/ErrorWebrpcBadResponse'
                  - $ref: '#/components/schemas/ErrorWebrpcServerPanic'
                  - $ref: '#/components/schemas/ErrorWebrpcInternalError'
                  - $ref: '#/components/schemas/ErrorUnexpected'
                  - $ref: '#/components/schemas/ErrorChainNodeHealth'
components:
  schemas:
    GetIntentRequest:
      type: object
      required:
        - intentId
      properties:
        intentId:
          type: string
    GetIntentResponse:
      type: object
      required:
        - intent
      properties:
        intent:
          $ref: '#/components/schemas/Intent'
    ErrorWebrpcEndpoint:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: WebrpcEndpoint
        code:
          type: number
          example: 0
        msg:
          type: string
          example: endpoint error
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorWebrpcRequestFailed:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: WebrpcRequestFailed
        code:
          type: number
          example: -1
        msg:
          type: string
          example: request failed
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorWebrpcBadRoute:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: WebrpcBadRoute
        code:
          type: number
          example: -2
        msg:
          type: string
          example: bad route
        cause:
          type: string
        status:
          type: number
          example: 404
    ErrorWebrpcBadMethod:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: WebrpcBadMethod
        code:
          type: number
          example: -3
        msg:
          type: string
          example: bad method
        cause:
          type: string
        status:
          type: number
          example: 405
    ErrorWebrpcBadRequest:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: WebrpcBadRequest
        code:
          type: number
          example: -4
        msg:
          type: string
          example: bad request
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorWebrpcClientAborted:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: WebrpcClientAborted
        code:
          type: number
          example: -8
        msg:
          type: string
          example: request aborted by client
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorWebrpcStreamLost:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: WebrpcStreamLost
        code:
          type: number
          example: -9
        msg:
          type: string
          example: stream lost
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorUnauthorized:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: Unauthorized
        code:
          type: number
          example: 1000
        msg:
          type: string
          example: Unauthorized access
        cause:
          type: string
        status:
          type: number
          example: 401
    ErrorPermissionDenied:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: PermissionDenied
        code:
          type: number
          example: 1001
        msg:
          type: string
          example: Permission denied
        cause:
          type: string
        status:
          type: number
          example: 403
    ErrorSessionExpired:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: SessionExpired
        code:
          type: number
          example: 1002
        msg:
          type: string
          example: Session expired
        cause:
          type: string
        status:
          type: number
          example: 403
    ErrorMethodNotFound:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: MethodNotFound
        code:
          type: number
          example: 1003
        msg:
          type: string
          example: Method not found
        cause:
          type: string
        status:
          type: number
          example: 404
    ErrorRequestConflict:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: RequestConflict
        code:
          type: number
          example: 1004
        msg:
          type: string
          example: Conflict with target resource
        cause:
          type: string
        status:
          type: number
          example: 409
    ErrorAborted:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: Aborted
        code:
          type: number
          example: 1005
        msg:
          type: string
          example: Request aborted
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorGeoblocked:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: Geoblocked
        code:
          type: number
          example: 1006
        msg:
          type: string
          example: Geoblocked region
        cause:
          type: string
        status:
          type: number
          example: 451
    ErrorRateLimited:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: RateLimited
        code:
          type: number
          example: 1007
        msg:
          type: string
          example: Rate-limited. Please slow down.
        cause:
          type: string
        status:
          type: number
          example: 429
    ErrorProjectNotFound:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: ProjectNotFound
        code:
          type: number
          example: 1008
        msg:
          type: string
          example: Project not found
        cause:
          type: string
        status:
          type: number
          example: 401
    ErrorAccessKeyNotFound:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: AccessKeyNotFound
        code:
          type: number
          example: 1101
        msg:
          type: string
          example: Access key not found
        cause:
          type: string
        status:
          type: number
          example: 401
    ErrorAccessKeyMismatch:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: AccessKeyMismatch
        code:
          type: number
          example: 1102
        msg:
          type: string
          example: Access key mismatch
        cause:
          type: string
        status:
          type: number
          example: 409
    ErrorInvalidOrigin:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: InvalidOrigin
        code:
          type: number
          example: 1103
        msg:
          type: string
          example: Invalid origin for Access Key
        cause:
          type: string
        status:
          type: number
          example: 403
    ErrorInvalidService:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: InvalidService
        code:
          type: number
          example: 1104
        msg:
          type: string
          example: Service not enabled for Access key
        cause:
          type: string
        status:
          type: number
          example: 403
    ErrorUnauthorizedUser:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: UnauthorizedUser
        code:
          type: number
          example: 1105
        msg:
          type: string
          example: Unauthorized user
        cause:
          type: string
        status:
          type: number
          example: 403
    ErrorQuotaExceeded:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: QuotaExceeded
        code:
          type: number
          example: 1200
        msg:
          type: string
          example: Quota request exceeded
        cause:
          type: string
        status:
          type: number
          example: 429
    ErrorQuotaRateLimit:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: QuotaRateLimit
        code:
          type: number
          example: 1201
        msg:
          type: string
          example: Quota rate limit exceeded
        cause:
          type: string
        status:
          type: number
          example: 429
    ErrorNoDefaultKey:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: NoDefaultKey
        code:
          type: number
          example: 1300
        msg:
          type: string
          example: No default access key found
        cause:
          type: string
        status:
          type: number
          example: 403
    ErrorMaxAccessKeys:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: MaxAccessKeys
        code:
          type: number
          example: 1301
        msg:
          type: string
          example: Access keys limit reached
        cause:
          type: string
        status:
          type: number
          example: 403
    ErrorAtLeastOneKey:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: AtLeastOneKey
        code:
          type: number
          example: 1302
        msg:
          type: string
          example: You need at least one Access Key
        cause:
          type: string
        status:
          type: number
          example: 403
    ErrorTimeout:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: Timeout
        code:
          type: number
          example: 1900
        msg:
          type: string
          example: Request timed out
        cause:
          type: string
        status:
          type: number
          example: 408
    ErrorInvalidArgument:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: InvalidArgument
        code:
          type: number
          example: 2000
        msg:
          type: string
          example: Invalid argument
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorUnavailable:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: Unavailable
        code:
          type: number
          example: 2002
        msg:
          type: string
          example: Unavailable resource
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorQueryFailed:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: QueryFailed
        code:
          type: number
          example: 2003
        msg:
          type: string
          example: Query failed
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorIntentStatus:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: IntentStatus
        code:
          type: number
          example: 2004
        msg:
          type: string
          example: Invalid intent status
        cause:
          type: string
        status:
          type: number
          example: 422
    ErrorNotFound:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: NotFound
        code:
          type: number
          example: 8000
        msg:
          type: string
          example: Resource not found
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorUnsupportedNetwork:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: UnsupportedNetwork
        code:
          type: number
          example: 8008
        msg:
          type: string
          example: Unsupported network
        cause:
          type: string
        status:
          type: number
          example: 422
    ErrorClientOutdated:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: ClientOutdated
        code:
          type: number
          example: 8009
        msg:
          type: string
          example: Client is outdated
        cause:
          type: string
        status:
          type: number
          example: 422
    ErrorIntentsSkipped:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: IntentsSkipped
        code:
          type: number
          example: 7000
        msg:
          type: string
          example: >-
            Intents skipped as client is attempting a transaction that does not
            require intents
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorQuoteExpired:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: QuoteExpired
        code:
          type: number
          example: 7001
        msg:
          type: string
          example: Intent quote has expired. Please try again.
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorHighPriceImpact:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: HighPriceImpact
        code:
          type: number
          example: 7002
        msg:
          type: string
          example: Quote unavailable due to high price impact
        cause:
          type: string
        status:
          type: number
          example: 422
    ErrorIntentsDisabled:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: IntentsDisabled
        code:
          type: number
          example: 9000
        msg:
          type: string
          example: Intents service is currently unavailable
        cause:
          type: string
        status:
          type: number
          example: 400
    ErrorWebrpcBadResponse:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: WebrpcBadResponse
        code:
          type: number
          example: -5
        msg:
          type: string
          example: bad response
        cause:
          type: string
        status:
          type: number
          example: 500
    ErrorWebrpcServerPanic:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: WebrpcServerPanic
        code:
          type: number
          example: -6
        msg:
          type: string
          example: server panic
        cause:
          type: string
        status:
          type: number
          example: 500
    ErrorWebrpcInternalError:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: WebrpcInternalError
        code:
          type: number
          example: -7
        msg:
          type: string
          example: internal error
        cause:
          type: string
        status:
          type: number
          example: 500
    ErrorUnexpected:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: Unexpected
        code:
          type: number
          example: 2001
        msg:
          type: string
          example: Unexpected server error
        cause:
          type: string
        status:
          type: number
          example: 500
    ErrorChainNodeHealth:
      type: object
      required:
        - error
        - code
        - msg
        - status
      properties:
        error:
          type: string
          example: ChainNodeHealth
        code:
          type: number
          example: 9001
        msg:
          type: string
          example: Intent quote is unavailable due to interrupted chain node access
        cause:
          type: string
        status:
          type: number
          example: 503
    Intent:
      type: object
      required:
        - id
        - projectId
        - intentId
        - status
        - quoteRequest
        - ownerAddress
        - originChainId
        - destinationChainId
        - originIntentAddress
        - salt
        - depositTransaction
        - originCalls
        - originPrecondition
        - originMetaTxn
        - quote
        - fees
        - trailsVersion
        - trailsContracts
        - expiresAt
      properties:
        id:
          type: number
        projectId:
          type: number
        intentId:
          type: string
        status:
          $ref: '#/components/schemas/IntentStatus'
        quoteRequest:
          $ref: '#/components/schemas/QuoteIntentRequest'
        ownerAddress:
          type: string
        originChainId:
          type: number
        destinationChainId:
          type: number
        originIntentAddress:
          type: string
        destinationIntentAddress:
          type: string
        salt:
          type: number
        depositTransaction:
          $ref: '#/components/schemas/DepositTransaction'
        passthrough:
          type: boolean
        originCalls:
          $ref: '#/components/schemas/IntentCalls'
        destinationCalls:
          $ref: '#/components/schemas/IntentCalls'
        originPrecondition:
          $ref: '#/components/schemas/TransactionPrecondition'
        destinationPrecondition:
          $ref: '#/components/schemas/TransactionPrecondition'
        originMetaTxn:
          $ref: '#/components/schemas/MetaTxn'
        destinationMetaTxn:
          $ref: '#/components/schemas/MetaTxn'
        quote:
          $ref: '#/components/schemas/IntentProviderQuote'
        fees:
          $ref: '#/components/schemas/IntentFees'
        trailsVersion:
          type: string
        intentProtocol:
          $ref: '#/components/schemas/IntentProtocolVersion'
        trailsContracts:
          $ref: '#/components/schemas/TrailsContracts'
        expiresAt:
          type: string
        updatedAt:
          type: string
        createdAt:
          type: string
    IntentStatus:
      type: string
      description: Represented as uint8 on the server side
      enum:
        - QUOTED
        - COMMITTED
        - EXECUTING
        - FAILED
        - SUCCEEDED
        - ABORTED
        - REFUNDED
        - INVALID
    QuoteIntentRequest:
      type: object
      required:
        - ownerAddress
        - originChainId
        - originTokenAddress
        - destinationChainId
        - destinationTokenAddress
      properties:
        ownerAddress:
          type: string
        originChainId:
          type: number
        originTokenAddress:
          type: string
        destinationChainId:
          type: number
        destinationTokenAddress:
          type: string
        destinationToAddress:
          type: string
        destinationApproveAddress:
          type: string
        destinationCallData:
          type: string
        destinationCallValue:
          type: number
        originTokenAmount:
          type: number
        destinationTokenAmount:
          type: number
        tradeType:
          $ref: '#/components/schemas/TradeType'
        fundMethod:
          $ref: '#/components/schemas/FundMethod'
        onlyNativeGasFee:
          type: boolean
        options:
          $ref: '#/components/schemas/QuoteIntentRequestOptions'
    DepositTransaction:
      type: object
      required:
        - toAddress
        - tokenAddress
        - amount
        - chainId
        - to
        - data
        - value
      properties:
        toAddress:
          type: string
        tokenAddress:
          type: string
        decimals:
          type: number
        amount:
          type: number
        chainId:
          type: number
        to:
          type: string
        data:
          type: string
        value:
          type: number
    IntentCalls:
      type: object
      required:
        - chainId
        - calls
      properties:
        chainId:
          type: number
        space:
          type: number
        nonce:
          type: number
        calls:
          type: array
          description: '[]TransactionCall'
          items:
            $ref: '#/components/schemas/TransactionCall'
    TransactionPrecondition:
      type: object
      required:
        - type
        - chainId
        - ownerAddress
        - tokenAddress
        - minAmount
      properties:
        type:
          type: string
        chainId:
          type: number
        ownerAddress:
          type: string
        tokenAddress:
          type: string
        minAmount:
          type: number
    MetaTxn:
      type: object
      required:
        - id
        - chainId
        - walletAddress
        - contract
        - input
      properties:
        id:
          type: string
        chainId:
          type: number
        walletAddress:
          type: string
        contract:
          type: string
        input:
          type: string
        bridgeGas:
          type: number
    IntentProviderQuote:
      type: object
      required:
        - routeProviders
        - routeProvidersRequestIds
        - routeProvidersFeeUsd
        - fromAmount
        - fromAmountMin
        - fromAmountUsd
        - fromAmountMinUsd
        - toAmount
        - toAmountMin
        - toAmountUsd
        - toAmountMinUsd
        - maxSlippage
        - priceImpact
        - priceImpactUsd
        - priceImpactDetails
      properties:
        routeProviders:
          type: array
          description: '[]RouteProvider'
          items:
            $ref: '#/components/schemas/RouteProvider'
        routeProvidersRequestIds:
          type: array
          description: '[]string'
          items:
            type: string
        routeProvidersFeeUsd:
          type: array
          description: '[]float64'
          items:
            type: number
        estimatedDuration:
          type: number
        fromAmount:
          type: number
        fromAmountMin:
          type: number
        fromAmountUsd:
          type: number
        fromAmountMinUsd:
          type: number
        toAmount:
          type: number
        toAmountMin:
          type: number
        toAmountUsd:
          type: number
        toAmountMinUsd:
          type: number
        maxSlippage:
          type: number
        priceImpact:
          type: number
        priceImpactUsd:
          type: number
        priceImpactDetails:
          $ref: '#/components/schemas/PriceImpactDetails'
    IntentFees:
      type: object
      required:
        - originGas
        - provider
        - feeTokenAddress
        - feeTokenAmount
        - feeTokenUsd
        - feeTokenTotal
        - gasFeeTotal
        - gasFeeUsd
        - trailsFeeTotal
        - trailsFeeUsd
        - collectorFeeTotal
        - collectorFeeUsd
        - providerFeeTotal
        - providerFeeUsd
        - totalFeeAmount
        - totalFeeUsd
      properties:
        originGas:
          $ref: '#/components/schemas/IntentTransactionGasFee'
        destinationGas:
          $ref: '#/components/schemas/IntentTransactionGasFee'
        provider:
          $ref: '#/components/schemas/IntentProviderFees'
        feeTokenAddress:
          type: string
        feeTokenAmount:
          type: number
        feeTokenUsd:
          type: number
        feeTokenTotal:
          type: number
        gasFeeTotal:
          type: number
        gasFeeUsd:
          type: number
        trailsFeeTotal:
          type: number
        trailsFeeUsd:
          type: number
        collectorFeeTotal:
          type: number
        collectorFeeUsd:
          type: number
        providerFeeTotal:
          type: number
        providerFeeUsd:
          type: number
        totalFeeAmount:
          type: number
        totalFeeUsd:
          type: number
    IntentProtocolVersion:
      type: string
      description: Represented as string on the server side
      enum:
        - v1
        - v1_5
    TrailsContracts:
      type: object
      required:
        - trailsIntentEntrypointAddress
        - trailsRouterAddress
        - trailsRouterShimAddress
      properties:
        trailsIntentEntrypointAddress:
          type: string
        trailsRouterAddress:
          type: string
        trailsRouterShimAddress:
          type: string
    TradeType:
      type: string
      description: Represented as string on the server side
      enum:
        - EXACT_INPUT
        - EXACT_OUTPUT
    FundMethod:
      type: string
      description: Represented as string on the server side
      enum:
        - WALLET
        - DIRECT_TRANSFER
        - ONRAMP_MESH
        - ONRAMP_MELD
    QuoteIntentRequestOptions:
      type: object
      properties:
        intentProtocol:
          $ref: '#/components/schemas/IntentProtocolVersion'
        swapProvider:
          $ref: '#/components/schemas/RouteProvider'
        bridgeProvider:
          $ref: '#/components/schemas/RouteProvider'
        swapProviderFallback:
          type: boolean
        bridgeProviderFallback:
          type: boolean
        preference:
          $ref: '#/components/schemas/RoutePreference'
        slippageTolerance:
          type: number
        trailsAddressOverrides:
          $ref: '#/components/schemas/TrailsAddressOverrides'
    TransactionCall:
      type: object
      required:
        - to
      properties:
        to:
          type: string
        value:
          type: number
        data:
          type: string
        gasLimit:
          type: number
        delegateCall:
          type: boolean
        onlyFallback:
          type: boolean
        behaviorOnError:
          type: number
    RouteProvider:
      type: string
      description: Represented as string on the server side
      enum:
        - AUTO
        - CCTP
        - GASZIP
        - LIFI
        - LZ_OFT
        - RELAY
        - SUSHI
        - WETH
        - ZEROX
    PriceImpactDetails:
      type: object
      required:
        - executionPriceImpact
        - marketPriceImpact
        - providerFeesPriceImpact
        - trailsFeesPriceImpact
        - netPriceImpact
      properties:
        executionPriceImpact:
          $ref: '#/components/schemas/PriceImpact'
        marketPriceImpact:
          $ref: '#/components/schemas/PriceImpact'
        providerFeesPriceImpact:
          $ref: '#/components/schemas/PriceImpact'
        trailsFeesPriceImpact:
          $ref: '#/components/schemas/PriceImpact'
        netPriceImpact:
          $ref: '#/components/schemas/PriceImpact'
    IntentTransactionGasFee:
      type: object
      required:
        - chainId
        - totalGasLimit
        - gasPrice
        - nativeTokenSymbol
        - chainGasUsageStatus
        - totalFeeAmount
        - totalFeeUsd
        - metaTxnFeeDetails
        - metaTxnGasQuote
      properties:
        chainId:
          type: number
        totalGasLimit:
          type: number
        gasPrice:
          type: number
        nativeTokenSymbol:
          type: string
        nativeTokenPriceUsd:
          type: number
        chainGasUsageStatus:
          $ref: '#/components/schemas/ChainGasUsageStatus'
        totalFeeAmount:
          type: number
        totalFeeUsd:
          type: string
        metaTxnFeeDetails:
          $ref: '#/components/schemas/MetaTxnFeeDetails'
        metaTxnGasQuote:
          type: string
    IntentProviderFees:
      type: object
      required:
        - quoteProvider
        - quoteProviderFee
        - quoteProviderFeeUsd
        - trailsFee
        - trailsFeeUsd
        - quoteProviderWithTrailsFee
        - providerWithTrailsFeeUsd
        - totalFeeAmount
        - totalFeeUsd
      properties:
        quoteProvider:
          type: string
        quoteProviderFee:
          type: number
        quoteProviderFeeUsd:
          type: number
        trailsFee:
          type: number
        trailsFeeUsd:
          type: number
        quoteProviderWithTrailsFee:
          type: number
        providerWithTrailsFeeUsd:
          type: number
        totalFeeAmount:
          type: number
        totalFeeUsd:
          type: number
    RoutePreference:
      type: string
      description: Represented as string on the server side
      enum:
        - RECOMMENDED
        - FASTEST
        - CHEAPEST
        - TRUSTLESS
    TrailsAddressOverrides:
      type: object
      properties:
        sequenceWalletFactoryAddress:
          type: string
        sequenceWalletMainModuleAddress:
          type: string
        sequenceWalletMainModuleUpgradableAddress:
          type: string
        sequenceWalletGuestModuleAddress:
          type: string
        sequenceWalletUtilsAddress:
          type: string
    PriceImpact:
      type: object
      required:
        - priceImpact
        - priceImpactUsd
      properties:
        priceImpact:
          type: number
        priceImpactUsd:
          type: number
    ChainGasUsageStatus:
      type: string
      description: Represented as string on the server side
      enum:
        - NORMAL
        - BUSY
        - VERY_BUSY
    MetaTxnFeeDetails:
      type: object
      required:
        - metaTxnId
        - estimatedGasLimit
        - feeNative
      properties:
        metaTxnId:
          type: string
        estimatedGasLimit:
          type: number
        feeNative:
          type: number

````