Get Best Route
Get the best route for swapping X to Y
Get Best Route API
It goes through all the possible swappers to find the best possible route based on user experience, fee amount, and output of the swap.
You need to pass checkPrerequisites value equals to true when user confirms the route.
When user confirms the route and you want to go to the next step (creating transaction), it's required to pass checkPrerequisites
value equals to true
. Otherwise, Rango won't create the transaction for you.
But it is recommended to set checkPrerequisites
to false
when you want to just give the user the best route preview.
How to filter blockchains and swappers of the route?
These parameters are used to limit blockchains of your interest, swappers, types of transactions, complexity of implementation, etc:
swappers
,swappersExclude
swapperGroups
,swapperGroupsExclude
blockchains
,blockchainsExclude
transactionTypes
Example 1. Imagine that you are developing a dApp which only supports EVM and Solana. You could pass the transactionTypes
equals to ['EVM', 'SOLANA']
.
Example 2. Imagine that you want to only support some specific bridges and dexes in your dApp. you could simply pass the swapperGroups
equals to list of those swappers. e.g. you could pass ['Hyphen', 'Synapse Swapper', '1Inch', 'UniSwap']
.
Example 3. In multi-step routing, the optimal route may not always be a single step, and intermediary blockchains are chosen based on the best price for the route. By using blockchain parameters, you can control which blockchains are involved in the route. e.g. you could pass blockchains
equals to ['ETH', 'BSC', 'ARBITRUM', 'POLYGON']
.
Best Route Request
from
* AssetDescription: The source asset
Example:
{"blockchain": "BSC", "symbol": "BNB", "address": null}
to
* AssetDescription: The destination asset
Example:
{"blockchain": "AVAX_CCHAIN", "symbol": "USDT.E", "address": "0xc7198437980c041c805a1edcba50c1ce5db95118"}
amount
* StringDescription: The human-readable amount of asset from that is going to be swapped.
Example:
0.28
selectedWallets
*Description: The list of wallets chosen by the user for this swap. For a multi-step swap, we need the wallet address for each blockchain involved in the route. (Mapping of blockchain to wallet address)
Example:
{ "AVAX_CCHAIN": "0xeae6d42093eae057e770010ffd6f4445f7956613", "BSC": "0xeae6d42093eae057e770010ffd6f4445f7956613" }
checkPrerequisites
BooleanDescription: It should be set to false when the client only wants to show a route preview to the user, and true when the user has confirmed the swap. If set to true, the server response time will be slower as it will verify certain prerequisites, such as the balance of source token and the necessary fees in the user's wallet.
Default:
false
destination
StringDescription: Custom destination wallet address for the route.
connectedWallets
Description: Optional list of all connected wallets of user in all blockchains.
slippage
numberDescription: Amount of user's preferred slippage in percent. if you don't send it, it will assume 0.5% slippage. (It's used to filter the swappers or routes that are not suitable for the given slippage)
contractCall
BooleanDescription: set this parameter to
true
if you want to send transactions through a contract. It will filter swappers that are not possible to be called by another contract.Caution: if you call Rango contracts using your contract and your contract is not white listed in some underlying protocols like Thorchain, user fund may stuck forever in Thorchain contracts. In this case, you need to exclude these swappers using this flag or ask related protocols to white list your contract.
Example:
true
affiliateRef
StringDescription: The affiliate unique key. In the Rango Exchange App, an affiliate key is generated using a wallet address, and this same wallet address is used to receive the fee charged by the dApp for the request.
Example:
K3ldk3
affiliatePercent
StringDescription: The dApp transaction fee in percent. Rango allows affiliate percent up to maximum of 3.0 percent.
Example:
1.5
which means 1.5 percent of the input amount
affiliateWallets
Description: List of affiliate wallets per blockchain for referral rewards. If this parameter is not provided, the wallet used for generating the
affiliateRef
will be used. By passing this parameter, you can override the wallet address used for the dApp transaction fee for each blockchain.
maxLength
NumberDescription: Maximum number of steps allowed in best route response. You could pass this parameter equals to 1 if you are interested in single step routes which is similar to the Basic API.
Example:
2
disableMultiStepTx
BooleanDescription: Some bridges requires more than one transaction for each swap. For example, some bridges require transaction on both source and destination blockchains by the users. Using this flag, you could enable routing via these protocols. Default is true.
Note: At the moment, only Voyager bridge subjects to this condition.
Default:
true
blockchains
StringDescription: Pass comma separated list of blockchains if you want to filter meta blockchains to some specific ones.
Example:
POLYGON,ETH
blockchainsExclude
BooleanDescription: A boolean value indicating whether the specified blockchains should be excluded or included in the response.
Example:
true
swappers
StringDescription: Pass comma separated list of swappers if you want to filter meta swappers to some specific ones.
Example:
Across,OneInchEth
swappersExclude
BooleanDescription: A boolean value indicating whether the specified swappers should be excluded or included in the response.
Example:
false
swappersGroups
StringDescription: Pass comma separated list of swapper groups if you want to filter meta swapper groups to some specific ones.
Example:
Across,1Inch
swappersGroupsExclude
BooleanDescription: A boolean value indicating whether the specified swapper groups should be excluded or included in the response.
Example:
false
transactionTypes
StringDescription: Pass comma separated list of transaction types if you want to filter blockchains types to some specific ones.
Example:
EVM,COSMOS
transactionTypesExclude
BooleanDescription: A boolean value indicating whether the specified transaction types should be excluded or included in the response.
Example:
false
enableCentralizedSwappers
BooleanDescription: Set this flag to true if you want to enable routing through the centralized solutions and obtain the associated metadata, including related swappers and tokens. The default value for this argument is false.
Caution: To enable these swappers, you must pass the user's IP to the Rango API for compliance checks. Additionally, user funds may be held for KYC if their wallet is flagged as risky by the screening solutions implemented by these protocols.
Default:
false
avoidNativeFee
BooleanDescription: When this condition is true, swappers that charge fees in native tokens will be excluded. For instance, when called from an AA account. Swappers like Stargate charge user fees in native tokens instead of the input amount, causing the transaction value to differ from the user's input amount. Alternatively, the user may need to transfer native tokens in a contract call to cover these protocol fees. Although you can disable these protocols using this flag, we do not recommend it as it reduces the coverage of routes.
Default:
false
interChainMessage
Description: Info about inter-chain message (Source & Destination contracts and IM Message) for cross-chain messaging.
messagingProtocols
Description: List of messaging protocols to be used for passing interchain messages.
Best Route Response
requestId
Description: The unique request Id which is generated for this request by the server. It should be passed down to all other endpoints if this swap continues on. e.g.
d10657ce-b13a-405c-825b-b47f8a5016ad
requestAmount
Description: The human readable input amount from the request.
from
Description: The source asset.
to
Description: The destination asset.
result
Description: The best route data.
validationStatus
Description: Prerequisites (validation) check result. It will be null if the
checkPrerequisites
field was false (or not given) in the request.
diagnosisMessages
Description: A list of string messages that might be the cause of not finding the route. It's just for display purposes.
missingBlockchains
Description: List of all blockchains which are necessary to be present for the best route and the user has not provided any connected wallets for it. A null or empty list indicates that there is no problem.
blockchains
Description: List of all accepted blockchains, an empty list means no filter is required.
processingLimitReached
Description: A warning indicates that it took too much time to find the best route and the server could not find any routes from X to Y.
walletNotSupportingFromBlockchain
Description: A warning indicating that none of your wallets have the same blockchain as X asset.
error
Description: Error occurred during the operation.
errorCode
Description: Error code shows the type of error.
traceId
Description: Trace Id helps Rango support team to trace an issue.
Last updated