freeBuf
主站

分类

漏洞 工具 极客 Web安全 系统安全 网络安全 无线安全 设备/客户端安全 数据安全 安全管理 企业安全 工控安全

特色

头条 人物志 活动 视频 观点 招聘 报告 资讯 区块链安全 标准与合规 容器安全 公开课

官方公众号企业安全新浪微博

FreeBuf.COM网络安全行业门户,每日发布专业的安全资讯、技术剖析。

FreeBuf+小程序

FreeBuf+小程序

零时科技 || DualPools 攻击分析
2024-02-22 15:52:17

1708587949_65d6fbadcf78a9518e532.jpg!small?1708587949424


背景

监测到针对DualPools的链上攻击事件:

https://bscscan.com/tx/0x90f374ca33fbd5aaa0d01f5fcf5dee4c7af49a98dc56b47459d8b7ad52ef1e93

DualPools (https://dualpools.com)是基于VenusProtocol (https://venus.io/)修改,是一个DeFi项目,提供了Swap, Lend, Borrow等服务。

其运行模式如下图:

1708587983_65d6fbcf4d93b64cfdecd.png!small?1708587983314


DualPools是一个去中心化借贷平台,用户通过deposti存入underlyingAssets(标的资产),获得对应的dToken;反之,通过Redeem取出underlyingAssets时,销毁对应的dToken。

其中,underlyingAssets标的资产和dToken的兑换比例是通过exchangeRate(流动性指数)来控制的,简单来讲exchangeRate就是dToken的价值。

exchangeRate = (totalCash + totalBorrows - totalReserves) / totalSupply

攻击分析

简单来讲,攻击分为两部分:

1. 黑客通过DualPools新交易池流动性不足(流动性为0),大幅抬高dLINK的价格,通过borrow掏空其他交易池的标的资产(WBNB, BTCB,ETH, ADA, BUSD)。

2. 利用精度截断的问题,取回前期投入的所有LINK。

  • 步骤1详细分析

攻击者通过DODO Private Pool和PancakeSwapV3进行借贷,获取BNB和BUSD作为初始攻击资金,如下图:

1708588072_65d6fc28789483aa015cb.png!small?1708588071701

随后,通过VenusProtocol抵押BNB和BUSD,并借出11500 LINK来进行针对DualPools的攻击。

1708588092_65d6fc3cb3e32ed0fe634.png!small?1708588091688

首先,攻击者通过再交易池dLINK-LINK mint获得2个最小单位的dLINK,随后,向交易池中转账11499999999999999999998个单位的LINK。

1708588107_65d6fc4bb21210eba449d.png!small?1708588106843

由于该交易池并未初始化,所以没有任何流动性。且exchangeRate的计算方式如下:

exchangeRate = (totalCash + totalBorrows - totalReserves) / totalSupply

此时totalCash为交易池中LINK的余额,为11499999999999999999998+2=11500000000000000000000,totalBorrows和totalReserves均为0,totalSupply为2(因为,黑客通过mint获得了2个最小单位的dLINK)。所以,此时的exchangeRate为5750000000000000000000(将dLINK的价值拉高了575倍)。
由于攻击者拥有的2个dLINK,且价值足够高,所以,黑客从其他池子中通过borrow借走了50 BNB, 0.17 BTCB, 3.99 ETH, 6378 ADA, 911 BUSD。

1708588122_65d6fc5ad42f986fccaba.png!small?1708588121974


  • 步骤2详细分析

攻击者通过redeemUnderlying将之前mint的2个最小单位dLINK兑换为11499999999999999999898个单位的LINK。因为,exchangeRate被攻击者操纵为5750000000000000000000。所以,兑换11499999999999999999898个最小单位的LINK需要的dLINK为 11499999999999999999898 / 5750000000000000000000 = 1.999999999999999 
即1.999999个最小单位的dLINK,但是由于数据精度截断,导致只需要1个最小单位的dLINK。

1708588173_65d6fc8df031abc2cde89.png!small?1708588172975

至此,攻击者取出了之前投入的 11499999999999999999898 个单位的LINK。随后,将从VenusProtocol, PancakeSwapV3, DODO Private Pool的借款归还,完成攻击。

1708588180_65d6fc945bb5766087607.png!small?1708588179779


总结

攻击者利用DualPools新交易池流动性差的原因,操纵标的资产的exchangeRate,导致标的资产对应的dToken价格失真,从而可以以极小的dToken作为抵押借出大量的其他标的资产。随后,利用智能合约除法的截断问题,取回之前攻击时投入的资产。至此,完成对DeFi项目DualPools的攻击。


# 资讯 # 黑客 # 攻击事件
本文为 独立观点,未经允许不得转载,授权请联系FreeBuf客服小蜜蜂,微信:freebee2022
被以下专辑收录,发现更多精彩内容
+ 收入我的专辑
+ 加入我的收藏
相关推荐
  • 0 文章数
  • 0 关注者
文章目录