DEX:不再安全的TWAP预言机?VesperFi Fianance被黑事件分析

11月3日,知道创宇区块链安全实验室 监测到 以太坊上的 DeFi 协议 VesperFi Fianance 遭遇预言机操控攻击,损失超 300 万美元。知道创宇区块链安全实验室 第一时间对本次事件深入跟踪并进行分析。

攻击分为两部分:

第一部分:攻击阶段

交易哈希:

0x89d0ae4dc1743598a540c4e33917efdce24338723b0fabf34813b79cb0ecf4c5

1.攻击者向 pool 添加(VUSD 对 USDC 为无穷大)的 0.1USDC 流动性

Lido官网已不再展示Polkadot和Kusama质押信息:4月9日消息,Lido官网已不再提供Polkadot和Kusama质押信息展示,当前仅提供以太坊(ETH)、Polygon和Solana质押信息。数据显示,截至目前Lido以太坊质押总额已突破110亿美元(5,928,918 ETH),创历史新高。

据此前报道,Lido Finance拟于今年八月停止Polkadot和Kusama生态系统流动性抵押。[2023/4/9 13:52:57]

Kava 11升级后用户新申领的奖励将不再有解锁期:10月20日消息,Kava官方表示,在拟于10月26日执行的Kava 11主网升级完成后,用户在Kava App新申领的奖励将不再有解锁期,因此建议Kava用户在主网升级后再进行奖励申领。[2022/10/20 16:32:11]

2.攻击者通过 Swap 用 232k USDC 兑换走 pool 内正常的 222k VUSD 流动性

2Miners:ASIC矿机和Nicehash将不再支持ETC:11月1日,山寨币矿池2Miners发推称,ASIC矿机和算力租赁平台NiceHash将不再支持ETC。[2020/11/2 11:24:20]

第二部分:套利阶段

0x8527fea51233974a431c92c4d3c58dee118b05a3140a04e0f95147df9faf8092

1.通过 Swap 将 222k VUSD 兑换为 2205MM fVUSD

2.将 2205MM 抵押置换成其他 pool 基础代币

1.首要分析为什么黑客要进行两次操作,而不通过同一攻击合约完成操作?

解决这个问题首先我们要知道 Uniswap V3 使用的预言机为 TWAP 类型,该预言机功能为获取一个时间周期上的交易平均价格,也就是说当价格已经发生改变时,该交易可能还并没有处在 TWAP 获取价格的时间周期中。

所以在黑客已经完成攻击后,他并没有急于兑换手中的 VUSD,而是等到价格发生变化时再入手。我们也确实可以看到套利阶段发生在攻击阶段 10 块高后。

攻击交易哈希:

套利交易哈希:

2.至于添加流动性和兑换流动性得到解释

在 Uniswap V3 中,只有一个区块内对价格有影响的第一笔交易会被写入预言机。因此添加过高的流动性可以让 TWAP 发现并获取到攻击者指定的价格。而兑换走流动性则是让 TWAP 发现前一步骤以及套利。

本次安全事件的主角虽然是 VesperFi Fianance,但是更让人关心的是 Uniswap V3 的 TWAP 预言机是否依然安全,可以观察到并非 TWAP 预言机本身错误地获取了价格,而是一个严重超高的价格被设置出来让它获取的,不可否认其存在局限性,但是本次事件最主要的问题还是流动性过于集中在预期价格附近很容易被操纵以及允许 pool 内单个代币不合理的流动性被设置。

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

链链资讯

[0:31ms0-3:970ms