1.前言
北京时间3月15日晚,知道创宇区块链安全实验室监测到Gnosis链上的借贷类协议HundredFinance与Agave均遭遇了闪电贷袭击,包括AAVE的分支Agave和Compound的分支HundredFinance。协议损失超1100万美元。目前项目方已暂停其数百个市场。
知道创宇区块链安全实验室第一时间跟踪本次事件并分析。
2.分析
安全公司:BSC上项目HUNTER发生Rug Pull,损失达120万美元:5月8日消息,据CertiK监测,HUNTER项目(代币为Hound)发生Rug Pull,损失达120万美元。目前其Discord、电报频道已经关闭,官方网站也不可用。其BSC链上合约地址为:0x1e4402Fa427a7A835fC64ea6d051404ce767A569。[2022/5/8 2:58:45]
2.1攻击者相关信息
百金融被攻击tx:
0x534b84f657883ddc1b66a314e8b392feb35024afdec61dfe8e7c510cfac1a098
攻击合约:0xdbf225e3d626ec31f502d435b0f72d82b08e1bdd
谢霆锋旗下锋味同萌将与Hungry Sausages Lab合作推NFT:3月28日消息,香港电影演员兼歌手谢霆锋进军NFT市场。谢霆锋创立及主理的美食与生活品牌锋味旗下年轻化子品牌锋味同萌与总部位于香港的创意工作室 Hungry Sausages Lab 合作,将推出 100 枚 NFT。这些 NFT 将于 4 月 1 日进行白名单预售或意向登记,并在 4 月 4 日公开铸造,起拍价为 0.15 ETH。
这 100 枚 NFT 将以谢霆锋厨师动漫角色为特点,也是 Hungry Sausages 系列 5000 枚 NFT 的一部分。锋味联合创始人Derek Yeung表示,元宇宙热潮遍布全球。我们在实体市场拓展业务的同时,也在积极探索通过虚拟世界创造新体验的新颖方式。[2022/3/28 14:22:33]
攻击地址:0xd041ad9aae5cf96b21c3ffcb303a0cb80779e358
动态 | Brave获选Product Hunt 2019年最佳隐私类产品:知名产品评鉴网站Product Hunt已发布了其2019年“金猫奖“(Golden Kitty)的获奖名单,对23个不同类别的产品进行了评价。在隐私类产品中,区块链浏览器Brave入选并获得第一名。(Coinpost)[2020/1/31]
攻击后跨链匿名化:https://etherscan.io/txs?a=0xd041ad9aae5cf96b21c3ffcb303a0cb80779e358
龙舌兰被攻击tx:
0xa262141abcf7c127b88b4042aee8bf601f4f3372c9471dbd75cb54e76524f18e
攻击合约:0xF98169301B06e906AF7f9b719204AA10D1F160d6
动态 | 公链项目 ThunderCore 主网低调上线:由康奈尔大学计算机科学副教授 Elaine Shi 参与创立的公链项目 ThunderCore 主网已经低调上线,有投资人表示已经收到该项目代币 Thunder Token。尽管 ThunderCore 团队没有在任何渠道发布主网上线的消息,但是从项目开发者社区发现,ThunderCore 主网区块浏览器已经可以查看主网区块状态,ThunderCore 主网从 26 日开始已经开始生成区块。项目官方网站上也已经提供了一份针对投资人的换币说明,指引投资人如何进行操作,以收到 ThunderCore 主网上的原生代币 Thunder Token。有多位投资人表示,ThunderCore 团队目前正在向投资人发放原生代币,计划首先向第二轮投资人发放,然后再向第一轮投资人发放。ThunderCore 目前已经融资 5000 万美元,投资人包括 Pantera Capital、Huobi Capital、MetaStable、FBG Capital、SV Angel、真格、Hashed、Sora Ventures、zk Capital、Kinetic 等多家机构。(链闻)[2019/3/1]
攻击地址:0x0a16a85be44627c10cee75db06b169c7bc76de2c
Bithunb提供三种虚拟货币出资服务:韩国最大虚拟货币交易所Bithumb在观望中称6月15日下午5点30分开始提供Ethos,Steemit,Strat的出资服务。(出资服务指可以兑换成法币)[2018/6/15]
攻击后跨链匿名化:https://etherscan.io/txs?a=0x0a16a85be44627c10cee75db06b169c7bc76de2c
2.2攻击流程
由于百金融与龙舌兰攻击流程与手法类似,因此我们使用百金融进行分析。
百金融攻击调用流程
1、攻击者利用合约在三个池子中利用闪电贷借出WXDAI和USDC
2、在WETH池子质押借出的部分USDC
3、利用重入利用一笔质押,超额借出池子中资金
4、重复质押-重入借出步骤,将其他两个池子资产超额借出
5、归还闪电贷
6、获利转移
2.3漏洞细节
导致本次问题的根本原因是由于在Gnosis链上的官方桥接代币xDAI合约中实现了一个对于to地址的回调
合约实现地址:
https://blockscout.com/xdai/mainnet/address/0xf8D1677c8a0c961938bf2f9aDc3F3CFDA759A9d9/contracts
该回调将直接导致重入漏洞的产生,同时由于在HundredFinance团队fork的Compound版本中没有严格遵循检查-生效-交互,进而导致了总借贷量更新晚于重入实现。最终攻击者得以超额借贷。
类似的,对于Agave项目方,攻击者利用liquidateCall函数内部调用会调用xDAI的callAfterTransfer方法进行回调,最终导致攻击者能再次进行借贷。
在百金融攻击中攻击者重入的调用路径如下:
在Agave攻击中攻击者回调路径如下:
3.总结
此次遭受攻击的两个借贷项目由于错误的引入了存在重入的token,同时项目方的fork的代码没有采用检查-生效-交互模式导致了问题的发生。
我们强调:对于一个优秀的项目的引用必须建立在足够的理解和严谨的开发上,尤其是存在差异化的部分,切忌顾此失彼最终因为一个小的差错导致项目全部的损失。
近期,各类合约漏洞安全事件频发,合约审计、风控措施、应急计划等都有必要切实落实。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。