Beanstalk Farms攻击事件分析:恶意提案如何防范?_BEA:ALK

2022年4月17日,成都链安链必应-区块链安全态势感知平台舆情监测显示,算法稳定币项目BeanstalkFarms遭黑客攻击,黑客获利近8000万美元,成都链安技术团队第一时间对事件进行了分析,结果如下。

#1事件相关信息

攻击交易

0xcd314668aaa9bbfebaf1a0bd2b6553d01dd58899c508d4729fa7311dc5d33ad7

攻击者地址

0x1c5dcdd006ea78a7e4783f9e6021c32935a10fb4

比特币代金券公司Azteco完成600万美元种子轮融资,Jack Dorsey领投:5月18日消息,比特币代金券公司Azteco宣布完成600万美元种子轮融资,Jack Dorsey领投,Lightning Ventures、Hivemind Ventures、Ride Wave Ventures、Aleka Capital、Visary Capital、Gaingels、David Van Der Weele、Sunil Rajaraman等参投。

Azteco代金券可以在线支付,也可以在195多个国家的数十万个零售店支付,让人们可以消费、储蓄,也可以向朋友、家人和商家发送小额比特币。该公司计划将此轮融资资金用于产品开发和在拉丁美洲和欧洲的市场扩张。[2023/5/18 15:12:03]

攻击合约

ZT创新板5月31日上线HTMOON:据官网公告,ZT创新板即将上线HTMOON,并于5月31日16:00开启HTMOON/USDT交易对。

HTMoon是HTMoon协议发行的第一个社区令牌。HTMoon协议是由HTMoon团队开发的分散式自治项目,并由社区100%推广。

ZT数字资产交易平台是一家全球性的数字资产交易服务商,致力于为用户打造创新型热门数字资产首发地。[2021/5/30 22:57:04]

0x79224bC0bf70EC34F0ef56ed8251619499a59dEf

被攻击合约

ZT挖矿宝上线ZTB/BONBON - SUPT挖矿?:据官网公告,ZT挖矿宝将于3月16日上线“ZTB/BONBON - SUPT”挖矿活动。本活动采用“锁仓挖矿”的模式,锁仓周期为15天,参与挖矿的币种为:ZTB、BONBON,用户可根据自己情况灵活分配资产进行参与。

本期挖矿收益代币为SUPT,可挖奖励总量共888,888枚SUPT。其中,ZTB挖矿于3月16日11:00?(UTC+8)开始;BONBON挖矿于3月16日15:00?(UTC+8)开始。

ZT数字资产交易平台是一家全球性的数字资产交易服务商,致力于为全球用户打造创新型数字资产首发地。[2021/3/15 18:46:23]

0xc1e088fc1323b20bcbee9bd1b9fc9546db5624c5

#2攻击流程

1.攻击者从攻击的前一天发起了提案交易,提案通过会提取Beanstalk:BeanstalkProtocol合约中的资金。

2.黑客通过闪电贷换取了350,000,000个DAI,500,000,000个USDC,150,000,000个USDT,32,100,950个BEAN和11,643,065个LUSD作为资金储备。

3.黑客将2步骤的DAI,USDC,USDT资金在Curve.fiDAI/USDC/USDT交易池中添加为979,691,328个3Crv流动性代币,用15,000,000个3Crv换来15,251,318个LUSD。

4.将964,691,328个3Crv代币兑换为795,425,740个BEAN3CRV-f用于投票,将32,100,950个BEAN和26,894,383LUSD添加流动性得到58,924,887个BEANLUSD-f流动性代币。

5.使用4步骤中的BEAN3CRV-f和BEANLUSD-f来对提案进行投票,导致提案通过。从而Beanstalk:BeanstalkProtocol合约向攻击合约转入了36,084,584个BEAN,0.54个UNI-V2,874,663,982个BEAN3CRV-f以及60,562,844个BEANLUSD-f。

6.最后攻击者将流动性移除并归还闪电贷,把多余的代币兑换为24830个ETH转入攻击者账户中。

#3漏洞分析

本次攻击主要利用了投票合约中的票数是根据账户中的代币持有量得到的。

攻击者至少在一天前发起提取Beanstalk:BeanstalkProtocol资金的提案,然后调用emergencyCommit进行紧急提交来执行提案,这个就是攻击者1天之前发起攻击准备的原因所在。

#4资金追踪

截止发文时,攻击者获利22029601个USDC,14742429个DAI,6,603,829个USDT与0.5407个UNI-V2,640224美元的BAEN代币资金近8000万,在攻击时将其中的25万USDC捐赠了乌克兰,之后攻击者将资金转换为ETH并将资金持续向Tornado.Cash转移。

针对本次事件,成都链安技术团队建议:

1.投票所用资金应在合约中锁定一定时间,避免使用账户的当前资金余额来统计投票数量,以避免可能出现的反复投票以及使用闪电贷进行投票;

2.项目方和社区应关注所有提案,如果提案是恶意提案,建议在提案投票期间应及时做出处理措施,将提案废弃,禁止其接受投票以及执行;

3.可考虑禁止合约地址参与投票;此外项目上线前最好进行全面的安全审计,规避安全风险。

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

金宝趣谈

[0:15ms0-4:460ms