从代码角度上看懂DEX的聚合交易?_TOK:WhiteBIT Token

1inch发币了,不知道各位老铁有没有领到。有的人暗中窃喜,有人还不了解1inch,这篇文件就介绍了1inch的核心功能。

文章的主要步骤如下:

获得最大的收益兑换方案

授权1inch合约操作你的代币

利用第一步获得的兑换方案进行交易

什么是去中心化交易所聚合器?

去中心化交易所聚合器,即DEX,以下都用DEX表示。DEX聚合器是一个平台,它将搜索一组DEX,以寻找在给定时间和数量下执行交易的最佳价格。

1inchDEX聚合器

1inch的一大特色就是聚合交易,它会在很多个DEX找到收益最大的成交方式。比如100000dai想买x个eth,在uniswap成交77%,在Bancor成交23%,是最合算的,买到的eth最多。

1inch是由AntonBukov和SergejKunz开发的DEX聚合器,通过一次交易将订单在多个DEX之间拆分,给用户提供最好的兑换汇率。1inch的智能合约是开源的。

Uranium Finance攻击者将498,583枚USDC从BNBChain转移到以太坊:金色财经报道,据PeckShield监测,Uranium Finance攻击者已经将498,583枚USDC从BNBChain转移到以太坊。[2023/7/24 15:55:07]

在1inch执行交易,过程其实很简单:

根据输入的token或ETH数量,获得预期可兑换的token数量

授权交易所使用你的token

使用第一步的获取的token数量进行交易

我们首先仔细了解一下1inch的智能合约,让我们感兴趣的是这两个方法:

getExpectedReturn()

swap()

getExpectedReturn-估算最佳兑换方案

getExpectedReturn?可以随意调用,不需要消耗任何gas。

SellToken即将上线首个DEX做空聚合交易平台:据官方消息,SellToken即将上线首个DEX做空聚合交易平台 ,SellToken是一个基于智能合约的去中心化做空交易所,它的运行完全基于不可修改的智能合约代码,根据用户提交的做空请求,由智能合约全自动的执行,完成用户做空操作,SellToken与传统中心化交易所合约有很大的区别,区别在于SellToken开空永不爆仓,避免了巨鲸恶意操控代币价格。

SellToken提供用户极佳的安全性和可信度,所有交易直接在智能合约执行,避免了资金被攻击和失窃的风险,目前,平台支持BNB Chain网络BNB和USDT交易对,以太坊网络稍后开放。此外,平台币SELLC 5%用于空投。[2023/3/25 13:26:05]

这个函数需要传入兑换参数,返回兑换的期望结果,以及交易在各个dex之间的兑换比例。

function?getExpectedReturn(????IERC20?fromToken,????IERC20?toToken,????uint256?amount,????uint256?parts,????uint256?disableFlags)?public?viewreturns(????uint256?returnAmount,????uint256?memory?distribution);

Signature Bank联创、总裁兼CEO计划在2023年转型为高级顾问:金色财经报道,加密友好银行 Signature Bank 宣布,联合创始人、总裁兼 CEO Joseph J. Depaolo 计划在 2023 年转型为高级顾问,首席运营官 Eric R. Howell 将自 3 月 1 日起接替 Depaolo 担任总裁,并继续担任首席运营官和董事会成员。Depaolo 保留 CEO 职位,并继续留在银行董事会中。在 Depaolo 完成高级顾问的转型后,Howell 届时将被任命为新任 CEO。[2023/2/16 12:11:10]

这个方法接收5个参数:

fromToken:当前拥有的token的地址

toToken:要交换的token的地址

amount:想要交换的token数量

parts:卖出数量拆分成多少份进行最优分布的估算。查看distribution?可以了解更多细节,默认是100

知情人士:FTX至少10亿美元客户资金下落不明,其会计系统存在后门:11月12日消息,据两名知情人士透露,至少有10亿美元的客户资金从加密交易所FTX消失。知情人士称,Sam Bankman-Fried已经将100亿美元的客户资金从FTX秘密转移到Alameda Research。一位消息人士估计其中下落不明的金额约为17亿美元。另一位则表示在10亿美元和20亿美元之间。

FTX法律和财务团队调查发现,SBF在FTX的会计系统中实施所谓的“后门”,该系统是利用定制软件构建。(路透社)[2022/11/12 12:55:57]

disableFlags:标记位,用于调整1inch的算法,例如可设置禁用某个特定的DEX

这个方法有2个返回值:

returnAmount:执行交易后将收到的token数量。

distribution:一个uint256类型的数组,代表交易在不同DEX中的分布情况。例如,parts设置为100,成交额度的25%在Kyber的,成交额度的75%在Uniswap,那么?distribution?看起来是这样的:。

安全机构:黑客攻击EthereumPow链获利200 ETHW:9月18日消息,安全机构BlockSec表示,检测到攻击者正在EthereumPow重放PoS链的消息,该漏洞的根本原因是网桥未正确验证跨链消息的实际chainid。攻击者首先通过Gnosis链的omni桥转移了200 WETH,然后在PoW链上重放了相同的消息,获得了额外的200 ETHW。结果,部署在PoW链上的链合约的余额将被耗尽。[2022/9/18 7:04:23]

目前1inch支持的交易所和排序如下:

注意:如果你想交易Eth而不是ERC20token,fromToken需要设置为特殊的值?0x0或?0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE。

getExpectedReturn函数的返回值非常重要,因为接下来需要利用它来执行实际的链上兑换操作。

swap-执行多DEX兑换交易

要执行链上token兑换交易,就需要使用合约提供的另一个函数swap。调用swap时,需要传入我们之前从getExpectedReturn返回的数据,这个操作需要花费gas。如果要卖出的是ERC20token,那么还需要先授权1inch合约可以操作你持有的待卖出token。swap函数的定义如下:

function?swap(????IERC20?fromToken,????IERC20?toToken,????uint256?amount,????uint256?minReturn,????uint256?memory?distribution,????uint256?disableFlags?)?public?payable;

swap函数接收6个参数:

fromToken:待卖出token的地址

toToken:待买入token的地址

amount:待卖出token的数量

minReturn:期望得到的待买入token的最少数量

distribution:兑换交易拆分分布数组

parts:执行估算时的拆分数量,默认值是100

disableFlags:标记位,例如可设置禁用某个特定的DEX

开发环境搭建

我们将使用?ganache-cli分叉(fork)当前的区块链状态,并提前在1个地址上充值了很多DAI。在示例中,地址是?0x78bc49be7bae5e0eec08780c86f0e8278b8b035b。我们还将gaslimit设置的非常高,因此在测试过程中不至于出现outofgas的问题,也不需要在每次交易前估算gas。启动命令是:

ganache-cli?-f?https://mainnet

async?function?waitTransaction(txHash)?{????let?tx?=?null;????while?(tx?==?null)?{????????tx?=?await?web3

我们在之前已经获得了兑换比率,现在把代码变的更可读,定义1个getQuote函数,返回一个包含所有参数的对象。

async?function?getQuote(fromToken,?toToken,?amount,?callback)?{????let?quote?=?null;????try?{????????quote?=?await?onesplitContract

一旦我们得到了兑换token的比率,接下来需要授权1inch可以操作我们持有的token,ERC20token标准不允许在一次交易中向合约发送token并触发下一个操作。我们写了一个简单的函数,调用approval函数,并使用?waitTransaction?等待交易确认。

function?approveToken(tokenInstance,?receiver,?amount,?callback)?{????tokenInstance

);

最后的执行结果看起来是下面这样的:

我们用1000DAI换回来5.85ETH。

在这个过程中,你可能会遇到的这样一个错误提示:“VMExceptionwhileprocessingtransaction:revertOneSplit:actualreturnamountislessthanminReturn”。这表示链上的报价已经更新。如果想避免这种情况发生,你可以在代码中引入一个滑点,根据交易金额,将minReturn参数减小1%或3%。

总结

1inch提供了出色的链上DEX聚合实现,可以在一个交易内利用多个DEX实现最优的兑换策略。1inch的API使用也很简单,只需要用getExpectedReturn估算兑换方案,然后使用swap执行兑换方案,就可以得到最好的兑换结果。你不必总是用eth交易,也可以交换2个ERC20token,甚至可以用weth交易。

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

水星链

[0:15ms0-0:610ms