北京时间2022年4月24日下午4时33分,CertiK审计团队监测到WienerDOGE项目被恶意利用,造成了3万美元的损失。攻击者利用WDODGE的收费机制和交换池之间的不一致,发起了攻击。
事件发生的根本原因是:通过紧缩的代币合约造成发送方的LP对没有被排除在转账费用之外。因此,攻击者能够将LP对中的通货紧缩代币耗尽,进而导致货币对价格失衡。
而随后于同一天内接连发生了另外三起恶意利用:
Nova Wallet已测试Moonbeam Network波卡平行链众贷:官方消息,Polkadot&Kusama生态应用Nova Wallet表示,已测试Moonbeam Network波卡平行链众贷,安卓用户现在可以通过Nova Wallet以去中心化方式向Moonbeam Network贡献他们的DOT, iOS版本即将发布。[2021/11/6 6:34:47]
下午6时20分,LastKilometer项目被闪电贷攻击利用,造成了26495美元的损失;
晚上9时45分,Medamon项目被闪存贷攻击利用,造成3159美元的损失;
波卡二层扩容协议Plasm Network正在波卡上创建ETH2.0:1月13日,波卡中国社区PolkaWorld官方推特发文称,波卡二层扩容协议Plasm Network正在波卡Polkadot上创建一个ETH2.0。PolkaWorld表示,由于Plasm极好的可扩展性,它是DApp开发者在Plasm上部署智能合约的绝佳选择。[2021/1/13 16:05:40]
紧接着,PI-DAO项目被闪存贷攻击利用,造成了6445美元的损失。
这一系列攻击的攻击者与攻击方法,与同一天早些时候发生的WienerDOGE相同。
本体将构建波卡平行链将DeID解决方案集成至波卡网络:11月11日,本体Ontology宣布与Polkadot合作,将其分布式ID解决方案DeID集成到Polkadot上,以加强两个生态系统之间的协作。至此,本体将构建一个Polkadot平行链,并提供与DeID和跨链协作相关的一组信用基础架构服务。[2020/11/11 12:18:51]
攻击步骤
①攻击者通过闪电贷获得了2900枚BNB。
②攻击者将2900枚BNB换成了6,638,066,501,83枚WDOGE。
动态 | 波卡实验网络Kusama已修复网络故障,恢复正常运行:波卡实验网络Kusama和波卡创始Gavin Wood发推宣布Kusama网络已完全从前几日的故障中恢复,目前网络已正常运行。一周前,Polkascan区块浏览器显示,波卡实验网络Kusama更新出现故障并停止出块。[2020/1/13]
●LP的状态:
○WdogE:199,177,850,468
○WBNB:2978
③将5,974,259,851,654枚WDOGE发送到LP,由于WDOGE比BNB多,所以LP现在处于不平衡状态。
●LP的状态:
○WDOGE:5,178,624,112,169
○WBNB:2978
④调用skim()函数,从LP中取回4,979,446,261,701枚WDOGE。由于攻击者在调用skim()之前发送了大量的WDOGE,所以LP将支付大量的费用。这一操作清空了LP内的WDOGE的数量。
攻击者还调用可sync()函数来更新LP内的储备值。若干枚WDOGE和2978枚BNB的存在,造成了WDOGE的价格与WBNB相比异常昂贵。
⑤最后,攻击者用剩下的WDOGE换回了2978枚BNB,偿还了闪电贷,赚取了78枚BNB。
而其他几个项目被攻击的流程步骤也相似:
闪电贷取得WBNB,并用WBNB换取LP中的通缩代币;
直接将通缩的代币转移到LP对上;
调用skim()函数,迫使LP对输回通缩代币;
由于转让费的存在,攻击者会重复步骤2~3,将LP对中的通缩代币耗尽;
通过LP对中的价格不平衡来获取利润。
漏洞分析
当用户转移一定数量的WDOGE时,除了费用,还有4%的代币将被销毁。
因此,如果LP发送100枚WDOGE,其余额将减少104枚WDOGE。
所以,LP应该被排除在费用和代币销毁之外。
资产去向
写在最后
如果同时对代币和LP合约进行审计,这一风险因素就可以被发现。
然而,如果只有代币合约被审计,那么交换机制将被视为一个外部依赖。
而这种情况在审计过程中将会指出第三方依赖风险。具体为:如果是代币合约,CertiK审计专家将会与项目方讨论,确认是否需要除去LP对的手续费;如果是LP对方的合约,CertiK审计专家会提出通缩币的讨论,并且提醒项目方可能存在的风险。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。