原文标题:《IOSG Weekly Brief | Curve 能否超越 Uniswap V3? #94》撰文:IOSG Ventures
在过去的 DeFi 之夏中,DeFi 协议都聚焦在各自的利基市场。Uniswap 利用其恒定的产品曲线来占领现货市场,但是 Curve 则是通过集中供应流动性来交易稳定币。
Uniswap v2 vs Curve: 流动性范围 & 深度;来源 : BlackHoleSwap Whitepaper
而 Uniswap v3 的发布改变了这个现状。在一定程度上,v3 是订单簿形式和 AMM 机制的集合。在 v3 里,被动的流动性提供者变成主动的做市商。这就给交易各种形式的资产带来可能,从 altcoin,随着时间衰减的资产(例如:利率衍生品,期权等),到稳定币等等。
Beosin:SEAMAN合约遭受漏洞攻击简析:金色财经报道,根据区块链安全审计公司Beosin旗下Beosin EagleEye 安全风险监控、预警与阻断平台监测显示,2022年11月29日,SEAMAN合约遭受漏洞攻击。Beosin分析发现是由于SEAMAN合约在每次transfer函数时,都会将SEAMAN代币兑换为凭证代币GVC,而SEAMAN代币和GVC代币分别处于两个交易对,导致攻击者可以利用该函数影响其中一个代币的价格。
攻击者首先通过50万BUSD兑换为GVC代币,接下来攻击者调用SEAMAN合约的transfer函数并转入最小单位的SEAMAN代币,此时会触发合约将能使用的SEAMAN代币兑换为GVC,兑换过程是合约在BUSD-SEAMAN交易对中将SEAMAN代币兑换为BUSD,接下来在BUSD-GVC交易对中将BUSD兑换为GVC,攻击者通过多次调用transfer函数触发_splitlpToken()函数,并且会将GVC分发给lpUser,会消耗BUSD-GVC交易对中GVC的数量,从而抬高了该交易对中GVC的价格。最后攻击者通过之前兑换的GVC兑换了50.7万的BUSD,获利7781 BUSD。Beosin Trace追踪发现被盗金额仍在攻击者账户(0x49fac69c51a303b4597d09c18bc5e7bf38ecf89c),将持续关注资金走向。[2022/11/29 21:10:04]
当 Uniswap 宣布进入稳定币市场的不久后,Curve Finance,一个专注于稳定币兑换的协议发布了 v2 版本的白皮书,提出了一种新的 AMM 机制,其结合了集中的流动性和非稳定币资产的被动流动性 。
慢雾:Inverse Finance遭遇闪电贷攻击简析:据慢雾安全团队链上情报,Inverse Finance遭遇闪电贷攻击,损失53.2445WBTC和99,976.29USDT。慢雾安全团队以简讯的形式将攻击原理分享如下:
1.攻击者先从AAVE闪电贷借出27,000WBTC,然后存225WBTC到CurveUSDT-WETH-WBTC的池子获得5,375.5个crv3crypto和4,906.7yvCurve-3Crypto,随后攻击者把获得的2个凭证存入Inverse Finance获得245,337.73个存款凭证anYvCrv3Crypto。
2.接下来攻击者在CurveUSDT-WETH-WBTC的池子进行了一次swap,用26,775个WBTC兑换出了75,403,376.18USDT,由于anYvCrv3Crypto的存款凭证使用的价格计算合约除了采用Chainlink的喂价之外还会根据CurveUSDT-WETH-WBTC的池子的WBTC,WETH,USDT的实时余额变化进行计算所以在攻击者进行swap之后anYvCrv3Crypto的价格被拉高从而导致攻击者可以从合约中借出超额的10,133,949.1个DOLA。
3.借贷完DOLA之后攻击者在把第二步获取的75,403,376.18USDT再次swap成26,626.4个WBTC,攻击者在把10,133,949.1DOLAswap成9,881,355个3crv,之后攻击者通过移除3crv的流动性获得10,099,976.2个USDT。
4.最后攻击者把去除流动性的10,000,000个USDTswap成451.0个WBT,归还闪电贷获利离场。
针对该事件,慢雾给出以下防范建议:本次攻击的原因主要在于使用了不安全的预言机来计算LP价格,慢雾安全团队建议可以参考Alpha Finance关于获取公平LP价格的方法。[2022/6/16 4:32:58]
慢雾:Spartan Protocol被黑简析:据慢雾区情报,币安智能链项目 Spartan Protocol 被黑,损失金额约 3000 万美元,慢雾安全团队第一时间介入分析,并以简讯的形式分享给大家参考:
1. 攻击者通过闪电贷先从 PancakeSwap 中借出 WBNB;
2. 在 WBNB-SPT1 的池子中,先使用借来的一部分 WBNB 不断的通过 swap 兑换成 SPT1,导致兑换池中产生巨大滑点;
3. 攻击者将持有的 WBNB 与 SPT1 向 WBNB-SPT1 池子添加流动性获得 LP 凭证,但是在添加流动性的时候存在一个滑点修正机制,在添加流动性时将对池的滑点进行修正,但没有限制最高可修正的滑点大小,此时添加流动性,由于滑点修正机制,获得的 LP 数量并不是一个正常的值;
4. 随后继续进行 swap 操作将 WBNB 兑换成 SPT1,此时池子中的 WBNB 增多 SPT1 减少;
5. swap 之后攻击者将持有的 WBNB 和 SPT1 都转移给 WBNB-SPT1 池子,然后进行移除流动性操作;
6. 在移除流动性时会通过池子中实时的代币数量来计算用户的 LP 可获得多少对应的代币,由于步骤 5,此时会获得比添加流动性时更多的代币;
7. 在移除流动性之后会更新池子中的 baseAmount 与 tokenAmount,由于移除流动性时没有和添加流动性一样存在滑点修正机制,移除流动性后两种代币的数量和合约记录的代币数量会存在一定的差值;
8. 因此在与实际有差值的情况下还能再次添加流动性获得 LP,此后攻击者只要再次移除流动性就能再次获得对应的两种代币;
9. 之后攻击者只需再将 SPT1 代币兑换成 WBNB,最后即可获得更多的 WBNB。详情见原文链接。[2021/5/2 21:17:59]
来源 :https://curve.fi/files/crypto-pools-paper.pdf;Dashed line – Uniswap v2, blue line – Curve v1, orange line – Curve v2
Force DAO 代币增发漏洞简析:据慢雾区消息,DeFi 量化对冲基金 Force DAO 项目的 FORCE 代币被大量增发。经慢雾安全团队分析发现: 在用户进行 deposit 操纵时,Force DAO 会为用户铸造 xFORCE 代币,并通过 FORCE 代币合约的 transferFrom 函数将 FORCE 代币转入 ForceProfitSharing 合约中。但 FORCE 代币合约的 transferFrom 函数使用了 if-else 逻辑来检查用户的授权额度,当用户的授权额度不足时 transferFrom 函数返回 false,而 ForceProfitSharing 合约并未对其返回值进行检查。导致了 deposit 的逻辑正常执行,xFORCE 代币被顺利铸造给用户,但由于 transferFrom 函数执行失败 FORCE 代币并未被真正充值进 ForceProfitSharing 合约中。最终造成 FORCE 代币被非预期的大量铸造的问题。 此漏洞发生的主要原因在于 FORCE 代币的 transferFrom 函数使用了`假充值`写法,但外部合约在对其进行调用时并未严格的判断其返回值,最终导致这一惨剧的发生。慢雾安全团队建议在对接此类写法的代币时使用 require 对其返回值进行检查,以避免此问题的发生。[2021/4/4 19:45:30]
Curve V1 的联合曲线(bonding curve)结合了恒定产品(XYK)和恒定的价格不变量,所以其价格滑点基本为 0。
事实上,在中间价格区间,蓝线是线性的,表明没有滑点。在远离中间价格的区域,曲线偏离线性形状,流动性急剧下降。也就是说,只有当大量流动性从池中取出时,定价曲线才会变成抛物线。
如果我们将 Curve V1 机制应用到非稳定币交易中,存入的资产会骤减。具体来说,Curve 的联合曲线依靠存入的资产来稳定价格。如果存款价格上升幅度大于资金池价格的滑点,资产很快就会流失。比如,资金池有 token A 和 token B ,50 比 50,各自价格开始都是 1 美元。如果 token A 在外界市场的价格增加 5%,即 1.05 美元,套利者会买入资产池的 token A。而滑点只有 1% 的情况下,直到 token A 在市场和 AMM 中的价格再次相等之前,token A 数量都会持续减少。
Curve v2 则继承了 v1 的一些特性,如上图所示,线性的形状也围绕着中间的价格。然而,为了解决以上的问题,Curve v2 也引入了额外的特性,如加入了内部预言机,持续为 AMM 提供其变化的中间价格,这就为流动性提供者控制了风险。
Curve v2 目前只有一个池 — Tricrypto2,池里包含 USDT, wBTC 和 wETH。到目前为止,Tricrypto 还没有引起太多的注意,仅 99 个地址与其产生过交互。
近来,Curve v2 的交易量一直呈上升趋势。若将过去 30 天的数据年化,交易量大约为 $22B 一年。
来源 :https://dune.xyz/momir/Curve-v2
如上图所示,大部分交易量来自被称为「精英交易者」的地址,其余交易量仅来自聚合器,几乎没有普通用户参与。
用 Uniswap 的总体表现来与 Curve v2 相比是没有意义的,因为 Uniswap v3 是无需许可的并且可以支持无限数量的流动性池。因此,我们将 Uniswap v3 的 wETH/wBTC、wETH/USDT 和 wBTC/USDT 池作为基准来对比 Curve v2 Tricrypto 池(ETH、BTC、USDT 池)。
来源 :https://dune.xyz/momir/Curve-v2
Uniswap v3 池的各项数据都占优势。v3 流动性池通常每天有 200 多个用户,而 Curve Tricrypto 每天只有大约 10 个地址与之交互。同样,Curve Tricrypto 的交易量最多也只有 Uniswap v3 对应的池交易量的 30%。
截至目前,套利者和聚合器正在某种程度上弥补 Curve 用户的不足的问题,然而,Curve 想要真正挑战 Uniswap 的主导地位,可能需要改善用户体验并瞄准更主流的受众。
此外,Curve 必须找到能包含更多样化的资产产品的方式,并最终允许无需许可地推出新代币。
尽管如此,这两个项目都是创新 DeFi 领域的领头羊,两者之间的竞争只会为使用非托管交易所的用户带来好处,即更低的滑点和交易费用。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。