获取 Solana 兑换交易指令#
获取在 Solana 兑换或者询价自定义组装使用的交易指令数据。
请求地址#
GET https://web3.okx.com/api/v6/dex/aggregator/swap-instruction
请求参数#
| 参数 | 类型 | 必传 | 描述 |
|---|---|---|---|
| chainIndex | String | 是 | 链的唯一标识。 如 501: Solana,更多可查看这里。 |
| amount | String | 是 | 币种询价数量 (数量需包含精度,如兑换 1.00 USDT 需输入 1000000,兑换 1.00 DAI 需输入 1000000000000000000),币种精度可通过代币基础信息取得。 |
| fromTokenAddress | String | 是 | 询价币种合约地址 (如:0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee) |
| toTokenAddress | String | 是 | 目标币种合约地址 (如:0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48) |
| userWalletAddress | String | 是 | 用户钱包地址 (如:0x3f6a3f57569358a512ccc0e513f171516b0fd42a) |
| slippagePercent | String | 是 | 滑点限制。 注意: 1. 在 EVM 网络上,滑点最小值为 0,最大值为 100。2. 在 Solana 网络上,滑点最小值为 0,最大值需小于 100。(如: 0.5代表这笔交易的最大滑点为0.5%) |
| autoSlippage | Boolean | 否 | 默认为 false。当设置为 true 时,原 slippagePercent 参数(如果有传入)将会被 autoSlippage 覆盖,将基于当前市场数据计算并设定自動滑点。 |
| maxAutoSlippagePercent | String | 否 | 当 autoSlippage 设置为 true 时,此值为 API 所返回的 autoSlippage 的最大上限(例如,0.5 代表 0.5%)。建议采用此值以控制风险。 |
| swapReceiverAddress | String | 否 | 购买的资产的收件人地址 如果未设置,则用户钱包地址收到购买的资产 (如:0x3f6a3f57569358a512ccc0e513f171516b0fd42a) |
| feePercent | String | 否 | 发送到分佣地址的询价或者目标币种数量百分比。最小百分比 > 0, Solana 链 最大百分比:10。 其他链最大百分比:3最多支持小数点后 9 位,系统将自动忽略超出的部分。 |
| fromTokenReferrerWalletAddress | String | 否 | 收取 fromToken 分佣费用的钱包地址。 使用 API 时,需要结合 feePercent 设置佣金比例,且单笔交易只能选择 fromToken 分佣或 toToken 分佣。 注意: 对于 Solana:分佣地址需提前存入一些 SOL 进行激活。 |
| toTokenReferrerWalletAddress | String | 否 | 收取 toToken 分佣费用的钱包地址。 使用 API 时,需要结合 feePercent 设置佣金比例,且单笔交易只能选择 fromToken 分佣或 toToken 分佣。 注意: 对于 Solana:分佣地址需提前存入一些 SOL 进行激活。 |
| positiveSlippagePercent | String | 否 | 此功能仅对 白名单或者企业用户开放 ,如您想使用,请联系 dexapi@okx.com 设置后将能对报价改善部分收取一定费用,该费用不超过报价总额的 10%,该上限是可配置的,可通过自定义百分比参数进行修改。 百分比参数默认设置为 0。 最小百分比:0,最大百分比:10 最多支持小数点后 1 位。目前该参数仅支持 Solana 链 |
| positiveSlippageFeeAddress | String | 否 | 收取正滑点分佣费用的钱包地址。 使用时需要结合 positiveSlippagePercent 设置比例。若填入,所有正滑点收益将转至該地址,若未填入则使用收取分佣费用的钱包地址。 |
| dexIds | String | 否 | 限定询价的流动性池 dexId , 多个组合按 , 分隔 (如 1,50,180 ,更多可查看流动性列表) |
| excludeDexIds | String | 否 | 限定不会使用於询价的流动性池 dexId,多个组合按,分隔 (如 1,50,180 ,更多可查看流动性列表) |
| disableRFQ | String | 否 | 禁用所有被归类为 RFQ 且依赖时效性报价的流动性来源。默认设置为 false。 |
| directRoute | Boolean | 否 | 默认设置为 false。启用后,将限制路由仅使用单一流动性池。当前,该功能仅适用于 Solana 兑换。 |
| priceImpactProtectionPercent | String | 否 | (可选,默认值为 90%) 允许的价格影响百分比 (介于 0 和 100 之间)。 当用户设置了 priceImpactProtectionPercent 后,如果估算的价格影响超过了指定的百分比,将会返回一个错误。例如,如果 priceImpactProtectionPercent = 25,任何价格影响高于 25% 的报价都将返回错误。 这是一个可选开启的功能,默认值为 90。当百分比被设置为 100 时,此功能将被禁用,也就是说,每一笔交易都会被允许通过。 注意:当我们无法计算价格影响时,我们会返回 null,并且价格影响保护也会被禁用。 |
| useTokenLedger | Boolean | 否 | Token Ledger 会在 swap 执行之前记录你的代币余额。 当你无法在一开始就确定确切的输入金额时,这个机制非常有用。 例如,当输入金额来自同一笔交易中的前一条指令时。 |
| computeUnitPrice | String | 否 | 用于 Solana 网络上的交易,类似于 Ethereum 上的 gasPrice,这个价格决定了交易的优先级,价格越高意味着交易越有可能更快地被网络处理。 |
| computeUnitLimit | String | 否 | 用于 Solana 网络上的交易,可类比为 Ethereum 上的的 gasLimit,这个限制可以确保交易不会占用过多的计算资源。 |
响应参数#
| 参数 | 类型 | 描述 |
|---|---|---|
| addressLookupTableAccount | Array | 地址查找表账户。是 Solana 区块链中的一种数据结构,用于优化交易中地址的管理和引用。它允许开发者将一组相关的地址存储在一个表中,并通过索引值(而非完整的 32 字节地址)在交易中引用这些地址,从而显著提升交易的效率和可扩展性。 |
| instructionLists | Array | 交易指令详细信息 |
| data | String | 指令数据 |
| accounts | Array | 指令账户信息 |
| isSigner | Boolean | 账户是否是签名者 |
| isWritable | Boolean | 账户是否可写 |
| pubkey | Boolean | 账户公钥地址 |
| programId | String | 指令执行程序id |
| routerResult | Object | 询价路径数据对象 |
| chainIndex | String | 否 |
| swapMode | String | 交易模式 |
| fromTokenAmount | String | 询价币种的兑换数量 (如:500000000000000000000000) |
| toTokenAmount | String | 目标币种的兑换数量 (如:168611907733361) |
| tradeFee | String | 询价路径预估消耗的网络费用 (USD 计价) |
| estimateGasFee | String | 预估消耗的 gas,各个链的最小单位返回,例如 wei |
| dexRouterList | Array | 询价路径数据集合 |
| router | String | 币种兑换的主路径 |
| dexProtocol | Object | 兑换路径中执行的 DEX 协议 |
| dexName | String | DEX 协议名称 (如:Verse) |
| percent | String | 一条路径中单一 DEX 协议的兑换资产占所有 DEX 协议百分比 (如:100) |
| fromTokenIndex | String | ***表示在路由过程中 fromToken 的索引 |
| fromToken | Object | 询价币种信息 |
| tokenContractAddress | String | 币种合约地址 (如:0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48) |
| tokenSymbol | String | 币种简称 (如:USDC) |
| tokenUnitPrice | String | 该接口返回的币种单价是基于链上的实时美元价格。注:此价格仅为推荐价格,在一些特殊情况中,币种单价可能为 null |
| decimal | String | 币种精度定义了单个的该币种可以被分成多少份的最小单位。例如,如果一个币种的精度是 8,则表示单个的这种代币可以被分成 100,000,000 份的最小单位。注意:该参数仅供参考,币种精度会随着合约拥有者的设置改变等原因发生变化。 |
| isHoneyPot | Boolean | 代币是否为貔貅币。 是:true 否:false |
| taxRate | String | 代币卖出税率,适用于可设定税费机制的代币(如SafeMoon、SPL2022代币)。普通代币无税费时返回 0。取值为 最小:0 最大:1,0.01表示1%。 |
| toTokenIndex | String | 表示在路由过程中 toToken 的索引 |
| toToken | Object | 目标币种信息 |
| tokenContractAddress | String | 币种合约地址 (如:0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48) |
| tokenSymbol | String | 币种简称 (如:USDC) |
| tokenUnitPrice | String | 该接口返回的币种单价是一个结合了链上、交易所以及其他第三方来源数据的综合美元价格。注:此价格仅为推荐价格,在一些特殊情况中,币种单价可能为 null |
| decimal | String | 币种精度定义了单个的该币种可以被分成多少份的最小单位。例如,如果一个币种的精度是 8,则表示单个的这种代币可以被分成 100,000,000 份的最小单位。注意:该参数仅供参考,币种精度会随着合约拥有者的设置改变等原因发生变化。 |
| isHoneyPot | Boolean | 代币是否为貔貅币。 是:true 否:false |
| taxRate | String | 代币买入税率,适用于可设定税费机制的代币(如SafeMoon、SPL2022代币)。普通代币无税费时返回 0。取值为 最小:0 最大:1,0.01表示1%。 |
| priceImpactPercent | String | Percentage = (接收价值 – 支付价值) / 支付价值。因为当前兑换数量影响了流动性池深度,导致产生了价值差额。若接收价值大于支付价值,Percentage 有可能是正数。 |
| tx | Object | 发交易信息 |
| from | String | 用户钱包地址 (如:0x3f6a3f57569358a512ccc0e513f171516b0fd42a) |
| to | String | 欧易 DEX router 合约地址 (如:0x3b3ae790Df4F312e745D270119c6052904FB6790) |
| minReceiveAmount | String | 目标币种的最小兑换数量 (兑换价格达到滑点限制的极限值时,目标币种的兑换数量,如:900645839798) |
| slippagePercent | String | 当前交易的滑点值 |
请求示例#
shell
curl --location --request GET 'https://web3.okx.com/api/v6/dex/aggregator/swap-instruction??chainIndex=501&userWalletAddress=J5CBzXpcYn6WR2JBah8zU4Yxct985CAFGwXRcFaX2pbS&autoSlippage=true&toTokenReferrerWalletAddress=A9bBCSy9y4vggKgcT7jkUiN77Q95soLbLYhCcbWUpy3g&amount=100000&fromTokenAddress=EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v&toTokenAddress=11111111111111111111111111111111&feePercent=0.875&slippagePercent=0.05&useTokenLedger=true \
--header 'OK-ACCESS-KEY: 37c541a1-****-****-****-10fe7a038418' \
--header 'OK-ACCESS-SIGN: leaV********3uw=' \
--header 'OK-ACCESS-PASSPHRASE: 1****6' \
--header 'OK-ACCESS-TIMESTAMP: 2023-10-18T12:21:41.274Z'
响应示例#
200
{
"code": "0",
"data": {
"addressLookupTableAccount": [
"Ga7MuV4c198RzhFvvpEHFVLUHaEDAM1VqW2rr2sJqfxe",
"2WejwkssZt7cd2At71Cc4yiev5cAKc5iZt3cZdyL5tkQ"
],
"createTokenAccountList": [
"FZcMUbUG4qaptFXmpX8xB2ivFKkxHywoEWpqskM6Md6D",
"H1KZidz2CNt5VjNaoV2bpSDsspaPtrKCLoLKXZEZrEB9",
"8XrtGP8RG33AnrN2yJ6H3gnXPNQ3dYXKqM72bpzhcsd6",
"DT2krA8vSP96D68nH86eAztZHVM18YB5i4gDXjLBDXm7",
"A9bBCSy9y4vggKgcT7jkUiN77Q95soLbLYhCcbWUpy3g",
"D9GYt4W7VvteKCSvTgyjzuiBJyTy94Kmr6YiC9fbxGjW"
],
"instructionLists": [
{
"data": "AgY6BAA=",
"accounts": [],
"programId": "ComputeBudget111111111111111111111111111111"
},
{
"data": "Axm5AgAAAAAA",
"accounts": [],
"programId": "ComputeBudget111111111111111111111111111111"
},
{
"data": "AgAAAPAdHwAAAAAA",
"accounts": [
{
"isSigner": true,
"isWritable": true,
"pubkey": "J5CBzXpcYn6WR2JBah8zU4Yxct985CAFGwXRcFaX2pbS"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "H1KZidz2CNt5VjNaoV2bpSDsspaPtrKCLoLKXZEZrEB9"
}
],
"programId": "11111111111111111111111111111111"
},
{
"data": "k/F7ZPSErnb9",
"accounts": [
{
"isSigner": true,
"isWritable": true,
"pubkey": "J5CBzXpcYn6WR2JBah8zU4Yxct985CAFGwXRcFaX2pbS"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "J5CBzXpcYn6WR2JBah8zU4Yxct985CAFGwXRcFaX2pbS"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "H1KZidz2CNt5VjNaoV2bpSDsspaPtrKCLoLKXZEZrEB9"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "So11111111111111111111111111111111111111112"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "11111111111111111111111111111111"
}
],
"programId": "proVF4pMXVaYqmy4NjniPh4pqKNfMmsihgd4wdkCX3u"
},
{
"data": "5FW5cE5PTQI=",
"accounts": [
{
"isSigner": false,
"isWritable": true,
"pubkey": "H9sbECFAyQXYJpvy5a3REamkZbGx8MnvUQ9wUZEJgANb"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "FZcMUbUG4qaptFXmpX8xB2ivFKkxHywoEWpqskM6Md6D"
}
],
"programId": "proVF4pMXVaYqmy4NjniPh4pqKNfMmsihgd4wdkCX3u"
},
{
"data": "JFyT2xqwn1o3PQMAAAAAAJdQCQAAAAAAMgABAAAARRAnAbCDhUAAAGQ=",
"accounts": [
{
"isSigner": true,
"isWritable": true,
"pubkey": "J5CBzXpcYn6WR2JBah8zU4Yxct985CAFGwXRcFaX2pbS"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "FZcMUbUG4qaptFXmpX8xB2ivFKkxHywoEWpqskM6Md6D"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "H1KZidz2CNt5VjNaoV2bpSDsspaPtrKCLoLKXZEZrEB9"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "So11111111111111111111111111111111111111112"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "A9bBCSy9y4vggKgcT7jkUiN77Q95soLbLYhCcbWUpy3g"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "proVF4pMXVaYqmy4NjniPh4pqKNfMmsihgd4wdkCX3u"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "ARu4n5mFdZogZAravu7CcizaojWnS6oqka37gdLT5SZn"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "8XrtGP8RG33AnrN2yJ6H3gnXPNQ3dYXKqM72bpzhcsd6"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "DT2krA8vSP96D68nH86eAztZHVM18YB5i4gDXjLBDXm7"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "ATokenGPvbdGVxr1b2hvZbsiqW5xWH25efTNsLJA8knL"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "11111111111111111111111111111111"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "H9sbECFAyQXYJpvy5a3REamkZbGx8MnvUQ9wUZEJgANb"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "Ag3hiK9svNixH9Vu5sD2CmK5fyDWrx9a1iVSbZW22bUS"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "proVF4pMXVaYqmy4NjniPh4pqKNfMmsihgd4wdkCX3u"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "goonERTdGsjnkZqWuVjs73BZ3Pb9qoCUdBUL17BnS5j"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "ARu4n5mFdZogZAravu7CcizaojWnS6oqka37gdLT5SZn"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "8XrtGP8RG33AnrN2yJ6H3gnXPNQ3dYXKqM72bpzhcsd6"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "DT2krA8vSP96D68nH86eAztZHVM18YB5i4gDXjLBDXm7"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "JAQxrJ2WuDF4APfSifurJJ4HzV5Z3FyBuBeSMj7mo9aw"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "4ynTYgJK5ruYx3AZMRjCHrJk1qkm61fePF7dkbvRQD46"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "AABxS823DPBxDkxEcdFSduUH1p3XmKjL5AuVgbH5qB3U"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "CyCg79QpzH8MbnPDMEJEvbw3ugJXWisWYPHEE363eUuJ"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "2pA6DAAPdrHZd1knT75Dy3Q3ZwyVWQ9gL4zZJSYqSuSR"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "Sysvar1nstructions1111111111111111111111111"
},
{
"isSigner": false,
"isWritable": false,
"pubkey": "TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA"
},
{
"isSigner": false,
"isWritable": true,
"pubkey": "D9GYt4W7VvteKCSvTgyjzuiBJyTy94Kmr6YiC9fbxGjW"
}
],
"programId": "proVF4pMXVaYqmy4NjniPh4pqKNfMmsihgd4wdkCX3u"
}
],
"routerResult": {
"chainIndex": "501",
"contextSlot": 395101989,
"dexRouterList": [
{
"dexProtocol": {
"dexName": "GoonFi",
"percent": "100"
},
"fromToken": {
"decimal": "6",
"isHoneyPot": false,
"taxRate": "0",
"tokenContractAddress": "EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",
"tokenSymbol": "USDC",
"tokenUnitPrice": "0.99975"
},
"fromTokenIndex": "0",
"toToken": {
"decimal": "9",
"isHoneyPot": false,
"taxRate": "0",
"tokenContractAddress": "So11111111111111111111111111111111111111112",
"tokenSymbol": "wSOL",
"tokenUnitPrice": "129.9"
},
"toTokenIndex": "1"
}
],
"estimateGasFee": "276998",
"fromToken": {
"decimal": "6",
"isHoneyPot": false,
"taxRate": "0",
"tokenContractAddress": "EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",
"tokenSymbol": "USDC",
"tokenUnitPrice": "0.99975"
},
"fromTokenAmount": "100000",
"priceImpactPercent": "0.02",
"router": "EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v--11111111111111111111111111111111",
"swapMode": "exactIn",
"toToken": {
"decimal": "9",
"isHoneyPot": false,
"taxRate": "0",
"tokenContractAddress": "11111111111111111111111111111111",
"tokenSymbol": "SOL",
"tokenUnitPrice": "129.9"
},
"toTokenAmount": "610455",
"tradeFee": "0.0006497"
},
"tx": {
"from": "J5CBzXpcYn6WR2JBah8zU4Yxct985CAFGwXRcFaX2pbS",
"minReceiveAmount": "607402",
"slippagePercent": "0.5",
"to": "proVF4pMXVaYqmy4NjniPh4pqKNfMmsihgd4wdkCX3u"
},
"wsolRentFee": 2039280
},
"msg": ""
}
