精析DeFi协议Warp Finance“预言机”攻击事件_WARP:FIN

北京时间12月18日6时许,DeFi借贷协议Warp Finance遭到黑客攻击,造成了近800万美元的资产损失。

同时,Warp Finance官方也发布推文表示,已在调查违规贷款情况,并建议用户暂停稳定币的存入,直到事件真相明朗。

成都链安团队在接到区块链安全态势感知平台(Beosin-Eagle Eye)报警后,第一时间对本次攻击事件进行了调查,结果发现:

1、Warp Finance使用的是Uniswap交易对的相对价格作为其预言机的喂价源。

2、攻击者在了解到这个情况后,使用从闪电贷中获取的巨额资金操纵了Uniswap交易对的价格。

Ankr 将为 Mantle 上的构建程序提供 RPC 服务:5月2日消息,以太坊二层网络 Mantle 宣布在第二季度推出主网之前与 Web3 基础设施平台 Ankr 建立合作关系。Ankr 将成为部署在 Mantle 上的第一个远程过程调用(RPC)连接和网关,从而提高网络开发人员的性能和效率。随着 Ankr 加入 Mantle 生态系统,开发人员将能够轻松创建可扩展和安全的 dApp,并简化对 Mantle 区块链的访问。[2023/5/2 14:38:53]

3、通过控制预言机喂价源信息,攻击者破坏了Warp Finance的借款价值判断标准。

4、在Warp Finance错误的数据环境下,攻击者窃取了远远超过抵押品价值的资产。

5、攻击者归还了从闪电贷中借出的款项。

珠宝品牌Chupi完成375万欧元融资,将投资区块链技术追踪钻石:金色财经报道,珠宝品牌Chupi宣布完成375万欧元融资,Business Venture Partners (BVP)、Abbey Finance 和 Permanent TSB (PTSB) 等参投,这也是该公司自2013年成立以来进行的第一笔融资。Chupi公司表示将加大投资区块链技术,并利用该技术对钻石进行追踪和鉴定。(independent)[2023/2/14 12:06:35]

攻击交易地址

0x8bb8dc5c7c830bac85fa48acad2505e9300a91c3ff239c9517d0cae33b595090

攻击过程精析

攻击者首先利用Uniswap进行闪电贷借款,并采用镶嵌式(还款前连续操作)的手法,在WBTC2、USDC3以及USDT2池中分别进行了WETH借贷,如下图所示:

6个月或更短时间Holder的比特币持有量占比跌至15%,创历史新低:金色财经报道,区块链分析公司 Glassnode 数据分析显示,持有 6 个月或更短时间的比特币持有者群体目前拥有约 300 万枚 BTC,相当于总流通供应量的 15%,创下有史以来的最低百分比。据悉,该指标上一次触及低点发生在2015年熊市,当时数据约为17%,但从那时起的两年多的时间里,比特币价格从 200 美元涨到了 20,000 美元。分析表明,持有 6 个月或更短时间的比特币持有者群体通常在两个关键事件期间大量涌现,一是长期投资者在市场走强阶段进行投资和撤资的牛市期间,二是投降抛售期间,广泛的市场恐慌会使“持币时间较短”的用户重新进入流通。(cryptoslate)[2023/1/3 22:22:42]

数据:超7100万枚XRP转移到FTX交易所:11月7日消息,据WhaleAlert的数据,最近几个小时有超过 7100 万 XRP 流入 FTX 交易所。此举是通过两笔交易完成的:第一笔是价值16,631,186美元的 35,774,039 XRP,第二笔是价值 16,557,439 美元的 35,615,409 XRP,两者都从未知钱包转移到 FTX 交易所。[2022/11/7 12:28:24]

其后,为扩大用于攻击的资金量,攻击者又在dYdX进行了闪电贷借款。如下图所示:

此时,借出的资金规模已高达近2亿美元.接下来,攻击者向Uniswap的DAI?2交易池中注入流动性,获取了流动性代币LP,如下图所示:

天桥资本创始人给出熊市生存建议:别碰杠杆,坚持长期投资纪律:金色财经报道,管理35亿美元资产的Skybridge Capital的创始人安东尼-斯卡拉穆奇(Anthony Scaramucci)为加密货币投资者提供了一些关于如何在熊市中生存的建议。\"我们正处于一场血战之中,\"他说。\"这是我的第八个熊市,我期望在这一次也能活下来。\" Scaramucci在接受CNBC采访时表示,他首先建议人们 \"保持非杠杆化,但要坚持你的长期投资纪律\"。

Scaramucci描述道。\"每个人都有长期的观点,直到他们有短期的损失......然后他们开始把自己的头发烧起来,在圈子里跑来跑去。\" 他说,“我只是告诫人们要购买高质量的产品,不受杠杆影响,并保持纪律。”

他补充说,投资者应该 \"认识到熊市的发生\",并补充说,\"如果你看一下过去120年的情况,它们可能每五年就发生一次\"。他指出。\"如果你在这些时期保持纪律性,你就会让自己变得非常富有,我认为这是给投资者的信息。\"(news.bitcoin)[2022/6/14 4:25:06]

然后,将所获的LP代币抵押在Warp Finance合约中,交易及代码如下图:

完成抵押后,攻击者利用借来的资金,将Uniswap DAI?2池中的DAI兑换殆尽,如下图所示:

上述“准备工作”完成后,价格已处于被操纵状态。另一方面,Warp Finance的预言机喂价源是来自Uniswap?LP代币的价格数据,代码如下图:

LP代币价格算法

(A代币的价格×A代币池中的持有量+B代币的价格×B代币池中的持有量)/LP代币的总量

其中,A代币与B代币的价格是由Uniswap的“对应代币与稳定币”交易对计算得出。

因此,在上述情况下,A、B代币的价格处于正常水平、而交易对中的A、B代币相对价格则已经发生异常。这是因为Uniswap采用恒定乘积做市商机制,即A×B=K。当出现大量的兑换某一种代币时,就会产生巨大的滑点,从而产生价差。

假设:A=A代币数量;B=B?代币数量;AP=A代币价格;BP=B代币价格

已知:A×B=k(在未添加流动性时K恒定);Warp价格=(AP×A+BP×B)/totalLP

因AP和BP在本事件中皆为恒定,故可设AP=X1×BP,化简可得Warp价格=((X1×K)/B+B)×BP/totalLP

可得结论为,X1×K?、BP和totalLP在攻击中都是常数,随着B的数量增大,LP价格就会提高。

攻击者正是利用了这一点,使用从闪电贷获取的巨额资金在交易池中海量添加其中一种代币的流动性,迫使另一种代币也随之巨增,从而引发LP的价格失衡。由于LP价格已被操纵,处于一个高位,因此,攻击者可以借出相比正常量更多的资产。

此后,攻击者即通过调用以下函数进行贷款。

在成功控制抵押价格后,攻击者便能利用错误的价格数据贷出远远超过抵押品价值的资产,从中获取暴利。最后,攻击者归还了闪电贷的款项,如下图所示:

事件小结

很明显,这又是一起典型的由闪电贷巨款发起的预言机攻击事件。成都链安曾撰文指出,在当前黑客众多的攻击手法中,“预言机”喂价控制才是隐形的“元凶”。

同时,成都链安也郑重提醒DeFi开发者,应加强预言机的针对性测试,特别是在项目上线前,尽可能模拟价格操控攻击的各类场景,及时发现问题并找出解决方案,切实提高项目抗预言机攻击的能力。

短短一个月后,巨额的财产损失再一次告诫我们,在区块链领域中,安全防护工作尤为重要,许多系统安全漏洞属于防不胜防。因此,我们必须采取积极措施形成连续、有效的保护方案,才能在最大程度上提前规避问题。

此外,如在DeFi项目运行中存在安防方面的任何技术问题,采取第三方安全技术解决方案不失为一种行之有效的办法。最后,成都链安再次呼吁,要加强对项目预言机等多方面的定期安全检测,以防范此类事件的再度发生。

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

水星链

[0:15ms0-1:489ms