木星链 木星链
Ctrl+D收藏木星链
首页 > FIL币 > 正文

USD:OneRing Finance闪电贷攻击事件分析

作者:

时间:1900/1/1 0:00:00

前言

北京时间2022年3月22日,知道创宇区块链安全实验室?监测到Fantom生态稳定币收益优化器OneRingFinance遭到闪电贷攻击,黑客窃取逾145万美元。

分析

攻击事件如下图所示,该次攻击事件的问题点在于OneRingFinance直接使用交易对中的reserves来实时进行OShare的价格计算,攻击者通过Swap操作提高reserves的量,最终拉升OShare的价格,获取更多的资金。

基础信息

攻击合约:0x6A6d593ED7458B8213fa71F1adc4A9E5fD0B5A58

攻击者地址:0x12EfeD3512EA7b76F79BcdE4a387216C7bcE905e

攻击tx:0xca8dd33850e29cf138c8382e17a19e77d7331b57c7a8451648788bbb26a70145

Avalanche上的AMM Trader Joe预计在明年1月初部署到Arbitrum One:12月2日消息,Avalanche上的AMM Trader Joe发布推文称将会把Liquidity Book AMM 和Joe V1部署在Arbitrum One网络上,以带来零滑点交易和去中心化的流动性供应。

目前,Trader Joe正与Offchain Labs团队密切合作,以在未来几天内启动Arbitrum测试网。预计主网将在1月初部署到Arbitrum One网络上。[2022/12/2 21:16:45]

漏洞合约:0xc06826f52f29b34c5d8b2c61abf844cebcf78abf

流程

攻击者的核心攻击流程如下:

攻击者从USDC/MIM交易对中闪电贷借出8000W的USDC到攻击合约中。

2.攻击者使用swap把1USDC兑换成1.001miMATIC。

动态 | Electroneum与柬埔寨主流网络运营商Cellcard达成合作:2月21日,Electroneum宣布其基于区块链的智能手机M1取得了巨大进展。柬埔寨主流网络运营商Cellcard已与该项目达成合作。根据Cellcard评估的月销售量,其将要求Electroneum提供250部M1手机,(The Cambodia Daily)[2020/2/23]

3.使用depositSafe存入79999997的USDC。

4.合约mint给攻击者41965509OShare,此时攻击者还有2USDC和1.001miMATIC。

5.攻击者将2USDC和0.326miMATIC添加流动性,获得7.82x10-7spLP。

6.将41965509的OSharewithdraw兑换成81534750的USDC。

7.移除流动性获取0.790USDC和0.862miMATIC。

声音 | 原Block.one产品副总裁:中国社区需要了解李嘉图合约、抵押代币等知识:原Block.one产品副总裁Thomas Cox表示,中国社区做的好的一方面是把用户和开发者联系在一起,但需要进一步了解相关知识。例如有的人不知道仲裁,不知道李嘉图合约,不知道什么是抵押代币。也正因为缺乏相关方面知识,导致大多数人在狼人杀游戏中损失惨重,而这只是因为参与者没有仔细看其合约。[2018/8/12]

8.把1.501miMATIC兑换成1.433USDC。

9.归还8000WUSDC和80080USDC的手续费,最净获得?1534750-80080=1454670?USDC

细节

攻击者在攻击之前通过CelerNetwork的cBridge跨链获得了发起攻击所需的gas。

通过流程第二步我们可以看出当时USDC和miMATIC的兑换率为约1:1.001,而通过流程第三步和第四步的?swap?后可以在第五步中看到USDC和miMATIC的兑换率变成了约1:0.163,所以我们需要重点分析?deposit?函数和?withdraw?中计算价格的问题。

区块链品牌营销机构ChainPlus.One获得极豆资本1200万元资金:Odaily获悉,区块链品牌营销机构ChainPlus.One今日宣布获得来自极豆资本的 1200万元首轮融资。资金将主要用于团队建设、海外市场拓展、国内媒体及社群建设。[2018/5/16]

分析交易的Debugger,可以看到调用的是?depositSafe?函数。

查看?depositSafe?函数,其内部会调用?_deposit?函数,继续跟进,发现在?_deposit?函数中又调用了?_doHardWorkAll?函数,最后?mint?OShare给攻击者。

而在?_doHardWorkAll?函数中使用了for循环将部分存入的USDC全部兑换成其他的代币。

执行此次?depositSafe?函数时?getSharePrice?计算的OShare价格为?1062758591235248117。

Monex集团CEO:普通投资者合理投资加密货币还需要时间: 据Cointelegraph消息,日前,Monex集团CEO松本大在纽约演讲时表示,日本的虚拟货币税制虽然在一定程度上会阻碍普通投资者进入市场,但是交易所方面并不太担心。他认为日本的普通投资者认清该如何去合理地投资加密货币还需要时间。[2018/5/4]

接下来我们看下?getSharePrice?函数的代码,在?getSharePrice?函数中调用了?balanceWithInvested?函数,而在?balanceWithInvested?函数中又调用了?investedBalanceInUSD?函数。

继续跟进,investedBalanceInUSD?函数是在合约?MasterChefBaseStrategy?中,其合约地址为:https://ftmscan.com/address/0xdbc07e219ba0cb5fddcd0fa0c5cc1eddfb77e082#code

investedBalanceInUSD?函数返回的是?getUSDBalanceFromUnderlyingBalance?函数,在?getUSDBalanceFromUnderlyingBalance?函数中可以发现合约使用两个代币的数量进行计算,而前面攻击者由于闪电贷存入了大量的USDC,从而使得最终的?_amount?的值也变大了。再次回到?getSharePrice?函数中就可以发现,_sharePrice?也会相应变大。

流程第六步使用了?withdraw?函数。

在?withdraw?函数中我们发现同样调用了?getSharePrice?计算OShare价格,在该阶段为?1136563707735425848,OShare的价格的确变大了,而最终的取款数量是通过内部调用?_withdraw?函数计算得到的。

_withdraw?函数中最终取款的值为?_realWithdraw,而?_realWithdraw=_toWithdraw.mul(uint256(10)**uint256(ERC20(_underlying).decimals())).div(uint256(10)**uint256(decimals()));,所以我们再看到?_toWithdraw,发现其值同样是由?balanceWithInvested?计算得到的,所以这就会导致最终将OShare兑换成USDC变多。

总结一下:

USDC↑->_amount↑->getUSDBalanceFromUnderlyingBalance(_underlyingBal)↑->investedBalanceInUSD()↑->balanceWithInvested()↑->_sharePrice↑

USDC↑->_amount↑->getUSDBalanceFromUnderlyingBalance(_underlyingBal)↑->investedBalanceInUSD()↑->balanceWithInvested()↑->_toWithdraw()↑->_realWithdraw()↑

后续处理

针对此次攻击,OneRingFinance团队采取了四种补救措施,包括暂停保险库,分析、调试、修复漏洞,通过财政库还款,以及提供漏洞赏金。

保险库状态:保险库已暂停,OneRingFinance团队正在努力重新设置。

分析、调试、修复:OneRingFinance团队已工作了很多小时,来修复允许黑客执行这次攻击的问题,团队已与许多合格开发者、协议合作,以查漏协议中所有的代码,协议有漏洞是完全出乎意料的,甚至对一些高级开发人员来说也是如此,因为他们以前审查过OneRingFinance的代码。

通过协议财政部还款:该团队正在制定一项计划,为受影响的人提供具体的中长期还款计划。

赏金:团队将提供被盗资金的15%以及100万RING代币,作为黑客返还资金的赏金。

总结

该次攻击事件是由于项目使用实时储备量来计算价格导致攻击者通过闪电贷借出大量USDC并存入使得储备量增大拉升OShare价格造成差值从而获利。

标签:USDANCNCEUSDCWrapped USDVent FinanceMoonKat Finance1usdc币是多少人民币

FIL币热门资讯
TON:《绝地求生》游戏开发商Krafton将基于Solana区块链开发NFT游戏

本文来自Decrypt,原文作者:AndrewHaywardOdaily星球日报译者|余顺遂摘要:PUBG游戏开发商Krafton将在Solana区块链上开发游戏.

1900/1/1 0:00:00
DFI:DFIAT“持仓分享187,500 DFIAT奖励”活动奖励已发放

尊敬的中币用户:???DFIAT“持仓分享187,500DFIAT奖励”活动已圆满结束,活动奖励已全部发放至获奖用户的账户中,您可登录账户后在查询DFIAT奖励到账情况.

1900/1/1 0:00:00
Gate.io Daily Shark Fin Hit The Price Range: The Final Annualized Yield is Up To 15.5%!

Gate.iolaunched"DailySharkFin_USDT_20220317"and"DailySharkFin_BTC_20220317"at8:00AMonMarch17thUTC.

1900/1/1 0:00:00
PLA:DAO决策下的Plato Farm,IEO收益用于生态发展

据官方报道,PlatoFarm将与多个平台合作,于2022年4月8日推出其IEO,有关IEO的详细信息届时官方会在推特上第一时间同步,感兴趣的朋友们可以关注下.

1900/1/1 0:00:00
Gate.io 9th-Anniversary Action: Try Your Luck to Win $499

Gate.ioisgoingtocelebrateits9thanniversary.Weareplanningactionbeforethecopytradingcompetition.

1900/1/1 0:00:00
UST:Rust智能合约养成日记(6)

相关文章:Rust智能合约养成日记合约状态数据定义与方法实现Rust智能合约养成日记编写Rust智能合约单元测试Rust智能合约养成日记Rust智能合约部署.

1900/1/1 0:00:00