宇宙链 宇宙链
Ctrl+D收藏宇宙链
首页 > 中币下载 > 正文

DeFi:解决 EIP-4626 中的滑点问题

作者:

时间:1900/1/1 0:00:00

简介

EIP-4626提供了一种将代币投资到投资池(通常称为金库)的标准方法。当我们存入自己的资产(ERC-20 代币)时,我们会收到一个份额代币,代表我们在金库里的资产。金库将把汇集的资产投资到一个或多个基础平台,为持有者产生收益。

EIP-4626标准的一个结果是,存款和铸币函数没有提供指定回报的最小份额或资产金额的方法。这通常用于防止高滑点或三明治攻击。mStable 如何通过其 Meta Vaults 解决这个问题——在保持符合标准的同时减轻高滑点攻击?本文描述了这些挑战,并解释了他们的方法是如何工作的。

EIP-4626和mStable金库存款

mStable EIP-4626的首个金库将投资于基于Curve 3Pool的Convex池。从EIP-4626的角度来看,金库的资产是Curve 3Pool的流动性提供者代币(3Crv)。存款函数是EIP-4626规范的一部分,它指定要存入多少资产以及将接收金库份额的帐户。存款函数返回给接收方会铸造多少金库份额。

SushiSwap将在Kava上部署DeFi工具:9月9日消息,SushiSwap发推称,Sushi正在与Kava Network合作,很快将部署一套DeFi工具。[2022/9/9 13:19:20]

例如,存入3Crv Convex mUSD金库将从调用方转移3Crv,并将vcx3CRV-mUSD金库份额转移到接收方。

EIP-4626标准的强大之处在于,在投资池中有一种通用的投资方法,但对资产可以投资到底层平台的内容和时间没有限制。对于mStable的3Crv Convx mUSD 金库来说, 3Crv被添加到Curve mUSD Metapool中,然后产生的流动性提供者代币(musd3Crv)被存入Convex mUSD池中,该池会投资于Curve mUSD gauge并获得更高的回报。

这个过程中的一个技术挑战是如何防止三明治攻击。

什么是三明治攻击?如何预防它们?

当我们向Curve Metapool(或任何其他池)添加流动性时,我们指定自己想存入的资产数量和流动性提供者(LP)代币的最小数量。对于mUSD Metapool,金额是一个包含两项的数组。第一个是mUSD的量,第二个是3Crv的量。3Crv Convex金库只存3Crv,因此金额数组的第一项将为零。

盗取DeFiance Capital创始人资产的黑客将500 ETH转入Tornado Cash:3月24日消息,此前盗取DeFiance Capital创始人Arthur NFT资产的黑客将原地址(0xe47E8cD58c8E95F765e642d7dCB898f622ceFA83)中588枚以太坊转入地址为 0xB09e66b66B7daA35699496fF560E1034990E5e3a的钱包,之后再将其中500枚以太坊分为5次转入Tornado Cash。

此前报道,DeFiance Capital创始人Arthur的E47E8C地址刚疑似遭到入侵,17个Azuki和1个CloneX被盗,总计约310ETH。之后该黑客地址已被Etherscan标记为Arthur0x钱包黑客。[2022/3/24 14:15:11]

开发金库时的一个技术挑战是我们如何设置预期流动性提供者代币的最小数量。

仅仅将min_mint_amount设置为零是不够的,因为它会让存款交易受到三明治攻击。但在我们深入了解三明治攻击是如何工作之前,我们需要更多地了解Curve Metapool定价是如何工作的。由于金库只添加两个池代币(mUSD和3Crv)中的一个,因此它接收到的Metapool流动性提供者(LP)代币的数量将取决于Metapool中mUSD和3Crv的余额。池中的 3Crv 越多,当仅将 3Crv 添加到 Metapool 时,返回的 LP 代币就越少。

数据:DeFi协议总锁仓量达2272.9亿美元:金色财经报道,据Defi Llama数据显示,DeFi协议总锁仓量(TVL)达到2272.9亿美元,24小时涨幅为0.71%。TVL排名前五分别为Curve(229.3亿美元)、Convex Finance(181.8亿美元)、MakerDAO(159.7亿美元)、AAVE(126.2亿美元)、WBTC(111.7亿美元)。[2022/1/11 8:39:59]

例如,如果Curve的mUSD Metapool添加了 200 万个 mUSD,600 万个 3Crv 和 100k 个 3Crv,则将收到 100,068 个 LP 代币 (musd3Crv)。如果 Metapool 有 600 万个 mUSD,添加了 200 万个 3Crv 和 100k 个 3Crv,将收到 100,892 个 LP 代币 (musd3Crv)。

那么三明治攻击是如何实现的呢?

攻击者在将交易包含到区块之前,就会监控Mempool中可能被利用的交易。为了利用交易,他们贿赂区块生产者,将他们的交易包含在可利用的交易之前和之后。也就是说,他们将易受攻击的交易与自己的交易夹在一起。如果有一笔交易将 3Crv 添加到最低 LP 金额为零的 mUSD Metapool,则攻击者的第一笔交易将是减少 Metapool 中的 mUSD 数量。这意味着在易受攻击的添加流动性交易中收到的 Metapool LP 代币数量远低于应有的数量。在第三个交易中,攻击者返还在第一个交易中删除的mUSD,并将收益装入囊中。

数据:前三名DeFi借贷协议有望每年产生超10亿美元利息:2月18日消息,根据Dune Analytics的数据,DeFi领先的三大借贷协议Maker(63.8亿美元)、Compound(87亿美元)和Aave(65亿美元)已积累了约200亿美元。Messari对这些平台进行估值的研究报告表明,它们有望每年产生超过10亿的利息。不过,DappRadar和DeFi Pulse数据网站中,三者总和目前约170亿美元。[2021/2/18 17:26:53]

例子

使用Curve的mUSD Metapool,池中有6,000,000 mUSD和3Crv, 11,917,295个LP代币(musd3Crv)和1.018095美元的虚拟价格。

攻击者通过使用 6,500,000 (54.5%) 池流动性提供者 (musd3Crv) 代币从池中提取 5,973,425 的mUSD,使用他们池中的大部分流动性提供者代币 (musd3Crv) 来平衡池。使用remove_liquidity_one_coin函数进行单边提款,池中剩下 0.43% mUSD 和 99.56% 3Crv。虚拟价格上涨了近1%,至1.019105,因为大量不平衡的提现为池收取了费用。

受害者使用add_liquidity函数将100,000个3Crv添加到不平衡的池中,且没有最小流动性提供者数量。如果池是平衡的,受害者得到81978个LP代币而不是100371个。这意味着受害者得到的LP代币比他们应该得到的少18,393个(18%)。以美元计算,受害者得到的美元价值减少了18,643(18%)。

数字文艺复兴基金会曹寅:DeFi名称具有误导性 优势不是去中心化而是非许可:据官方消息,在由OKEx主办的“后疫情时代:DeFi的机遇与挑战”社群活动上,数字文艺复兴基金会曹寅表示,Defi的名称具有一定误导性,去中心化并不是DeFi的目的,仅仅是手段。DeFi并不特指一种技术或者一类产品,而是一种社会运动和思潮,是一种利用开源软件和去中心化网络将金融产品转变为无需信任中介,无需中心操作即可运行的透明金融协议运动。DeFi的优势并不是去中心化,而是非许可,去中介,自动化,从P2P到P2C,Peer to Contract,去掉了传统金融中交易对手方的风险。[2020/4/30]

对于第三个也是最后一个交易,攻击者使用add_liquidity将他们从第一个交易中提取的5,973,425个mUSD添加回池中,以接收6,503,610个LP代币(musd3Crv)。比第一次交易多取了3610美元。池的虚拟价格将增加1%至1.019216,因为这是另一个不平衡的交易。以美元计算,攻击者的LP价值从6,500,000 * 1.018095 = 6,617,617美元上升到6,503,610 * 1.019216 = 6,628,583美元,增加了10,966美元(1.65%)。

如果受害者损失了18643美元价值,而攻击者只获得了10966美元价值,那么缺失的7677美元价值在哪里?

使池失衡的0.04%费用由流动性提供者和Curve投票托管的CRV (veCRV)持有者平均分摊。攻击者未持有的 5,417,295 LP 代币的价值从 5,515,323 美元增加到 5,520,794 美元。这比池费用的 50% 增加了 5,471 美元。增加的美元价值归于托管 CRV (veCRV) 持有人。

Curve的保护

为了防止三明治攻击,在向Curve Metapool添加流动性时,需要指定一个合理的最小LP代币数量。通常,DeFi 协议会在交易中传入相当数量的金额。Curve池中的add_liquidity函数就是min_mint_amount的一个很好的例子。但是对于标准的EIP-4626存款函数,没有定义参数来指定最小金额,因此我们无法传入相当数量的链下计算的Metapool LP代币。

Curve池有一个calc_token_amount函数,它可以计算池代币存款收到的 LP 代币数量。但这不能用来防止三明治攻击。如果已经运行了一个交易来平衡池,那么calc_token_amount函数将只返回当前不公平的LP代币数量。

因此问题仍然存在,EIP-4626函数没有办法传递最小量。打破标准来添加这一点是不可取的,使用预言机也是次优的。我们需要链上方法。

mStable的方法

mStable的金库获得一个公平的Metapool LP代币价格的方法是使用Curve Metapool和Curve 3Pool的虚拟价格。get_virtual_price函数以美元为单位返回池的流动性提供者代币的价格。它通过计算池的不变式来实现这一点,该不变式是池中代币的美元价值除以代币的总供应量。由于池中代币的余额不影响池的不变值或总美元价值,虚拟价格不会受到三明治攻击。

对于存入mStable金库的存款,我们需要在Curve的3Pool LP代币(3Crv)中对Metapool LP代币进行定价,因为这是我们在金库中使用的资产。为此,我们得到3Pool虚拟价格,并将其除以Metapool LP代币价格。

一旦我们有了一个合理的价格,我们就可以通过目前配置为 1% 的滑点系数来降低它。这个调整后的公平价格用于计算在向池中添加3Crv流动性时可以接收的Curve Metapool LP代币(musd3Crv)的最小数量。

存款的全部流程如下:

结论

虽然标准在标准化和获得采用方面起着巨大的作用,但像这样的问题提醒我们,在DeFi方面没有轻松的胜利。我们需要认识到现有标准的局限性,并为它们寻找最佳的解决方案。

Source:https://medium.com/mstable/solving-the-issue-with-slippage-in-eip-4626-3af9a5d8e597

去中心化金融社区

个人专栏

阅读更多

金色早8点

比推 Bitpush News

Foresight News

PANews

Delphi Digital

区块链骑士

深潮TechFlow

链捕手

区块律动BlockBeats

比推BitpushNews

DeFi之道

标签:CRV3CRVUSDMUSDCVXCRV价格3crv币怎么卖Aave BUSDmusd币是什么时候发行的

中币下载热门资讯
加密货币迈向合规时代 请收好这份美国加密税收入门指南

撰文:Kadeem Clarke编译:0x11,Foresight News无论你是经验丰富的加密货币交易员,亦或只是收到少量加密货币作为礼物,了解它的税收影响都至关重要.

1900/1/1 0:00:00
速览2023年值得关注的10个DeFi协议

原文作者:Thor Hartvigsen,DeFi 研究员原文编译:Leo,BlockBeats2022 的行业洗牌势必会给 2023 的加密带来更新的转变,其中比较受关注的一大「转变」就是 DeFi 再度冲进人们视野中.

1900/1/1 0:00:00
金色观察 | 从2022年加密市场吸取的22个教训

推特用户DeFi Edge总结了在2022年学到的一些加密教训。 1、锁定代币不值得 Ve类型的锁定机制在DeFi中变得流行,你锁定你的代币一段时间,获得额外的收益或效用作为交换。有些人看着他们锁定的代币在熊市中下跌-90%.

1900/1/1 0:00:00
细数2022年比特币的十大重要进展

价格暴跌和加密货币的崩溃占据了 2022 年的头条新闻,但仍旧可以认为 2022 年也是比特币取得重大进展的一年.

1900/1/1 0:00:00
一文了解以太坊 L2 生态最新进展

原文作者:Aylo (alpha please)这篇文章是关于以太坊 L2 的,我已尽力总结这个生态发生的事以及当前的景观,但我不可避免地会错过很多东西.

1900/1/1 0:00:00
无Gas的四种签名类型风险性对比

研究种类:Layer1, Gas, Singnature贡献者:Dewei 审核者:DAOctor 原文:Safe Signing 101如果用户能够自由交互而无需支付高额 gas 费.

1900/1/1 0:00:00