以小博大,简析 Sushi Swap 攻击事件始末_SLP:ShibZilla2.0

By:慢雾安全团队

2020年11月30日,据慢雾区情报,以太坊AMM代币兑换协议SushiSwap遭遇攻击,损失约1.5万美元。慢雾安全团队第一时间介入分析,并以简讯的形式分享,供大家参考。

背景提要

SushiSwap项目中SushiMaker合约的作用是用于存放SushiSwap中每个交易对产生的手续费。其中手续费会以SLP(流动性证明)的形式存放在合约中。SushiMaker合约中有一个convert函数,用于将从每一个交易对中收集的手续费通过调用各自交易对的burn函数获得对应的代币,然后将这些代币转换成sushi代币,添加到SushiBar合约中,为SushiBar中抵押sushi代币的用户增加收益,而此次的问题就出在SushiMaker合约。

Circle CEO:将于今年秋天制定实现无缝的稳定币支付与跨链路线图:8月12日消息, Circle CEO Jeremy Allaire发推称,今年秋天,Circle将制定路线图,旨在实现无缝的稳定币支付与跨链,并推出一个智能合约开发平台,让Web2开发者能够轻松使用。[2023/8/12 16:21:30]

攻击流程

1、攻击者选中SushiSwap中的一个交易对,如USDT/WETH,然后添加流动性获得对应的SLP(USDT/WETH流动性证明,以下简称SLP),使用获得的SLP和另外的少量WETH创建一个新的SushiSwap交易对,然后得到新代币池的SLP1(WETH/SLP(USDT/WETH)流动性证明,以下简称SLP1)转入SushiMaker合约中。

汇丰:到2030年将有5-10%的资产被代币化:金色财经报道,在最近的一份报告中,汇丰银行和北方信托预测,到2030年,所有资产的5%-10%将被代币化。根据麦肯锡的数据,2021年管理的总资产达126万亿美元,而BCG的数字是112万亿美元。使用麦肯锡的数字和5%的复合增长率,到2030年,AUM约为195万亿美元,代币化占该数字的5%至10%。[2023/2/25 12:28:27]

2、调用SushiSwap的convert函数,传入的token0为第一步获得的SLP,token1为WETH。调用convert函数后,SushiMaker合约会调用token0和token1构成的代币池的burn函数燃烧SLP1,燃烧掉攻击者在第一步中打入SushiMaker合约中的SLP1,得到WETH和SLP。

上海检察官方发布一起虚拟货币案:非法获利6000个USDT:金色财经报道,9月14日,上海检察官方发布了一起侵犯公民个人信息刑事附带民事公益诉讼案开庭审理的相关情况,该案被告人张某非法获利为6000个USDT(泰达币),浦东新区检察院公益诉讼检察官最终以获利的虚拟币价值计算出公益损害赔偿数额,\t实现了公共利益最大限度保护。

公益诉讼检察官认为,虚拟币在我国不具有法定货币地位,但是其作为工具,易被违法犯罪的人利用,“如果在交易中使用该币种,对违法所得金额,我们仍然可以按照该币种交易市场价值进行计算违法所得金额。[2022/9/16 7:02:11]

3、SushiMaker合约的convert函数紧接着会调用内部的_toWETH函数将burn获得的代币转换成WETH,由于在第二步SushiMaker合约通过burn获得了SLP和WETH。其中WETH无需转换,只需转换SLP。此时,转换将会通过调用SLP/WETH交易对进行转换,也就是攻击者在第一步创建的交易对。由于SushiMaker合约在转换时会将所有的balanceOf(token0)转换成WETH,这里传入的token0为SLP,于是合约将合约中所有的SLP通过SLP/WETH交易对进行兑换(兑换的SLP包含USDT/WETH交易对每次swap产生的收益和在第二步合约通过burn函数获得的SLP)。而SLP/WETH代币池是攻击者创建的,攻击者只需在初始化的时候添加少量的WETH,就可以在SushiMaker交易对进行兑换的过程中,用少量的WETH换取SushiMaker合约中对应交易对的所有的SLP。

Algorand生态去中心化预言机网络Algoracle完成150万美元种子轮融资:5月18日消息,去中心化预言机网络Algoracle宣布完成150万美元种子轮融资,Borderless Capital领投,Algorand基金会、Valhalla Capital、Big Brain Holdings、Xpand Capital、Parea Capital、OrcaDAO、GMI Capital和EXA Finance等参投。据悉,该资金将用于帮助和加速Algorand原生去中心化预言机网络的开发和启动。(news.bitcoin)[2022/5/18 3:24:49]

4、攻击者使用burn函数在SLP/WETH交易对中燃烧掉自己的SLP1,拿到大量的SLP和小量的WETH,并继续对其他流动性池重复该过程,持续获利。

总结

攻击者使用SLP和WETH创建一个新的代币池,使用新代币池的SLP1在SushiMaker中进行convert,使用少量的SLP将SushiMaker合约中的所有SLP转到自己创建的代币池中,即将对应交易对一段时间内的所有手续费收入囊中。并对其他交易对重复这个过程,持续获利。

往期回顾

假钱换真钱,揭秘PickleFinance被黑过程

闪电贷重入攻击,OUSD损失700万美金技术简析

如何使用闪电贷从0撬动百万美元?ValueDeFi协议闪电贷攻击简要分析

无中生有?DeFi协议Akropolis重入攻击简析

Acala创世已通过慢雾科技安全审计

慢雾导航

慢雾科技官网

https://www.slowmist.com/

慢雾区官网

https://slowmist.io/

慢雾GitHub

https://github.com/slowmist

Telegram

https://t.me/slowmistteam

Twitter

https://twitter.com/@slowmist_team

Medium

https://medium.com/@slowmist

币乎

https://bihu.com/people/586104

知识星球

https://t.zsxq.com/Q3zNvvF

火星号

http://t.cn/AiRkv4Gz

链闻号

https://www.chainnews.com/u/958260692213.htm

本文来源于非小号媒体平台:

慢雾科技

现已在非小号资讯平台发布68篇作品,

非小号开放平台欢迎币圈作者入驻

入驻指南:

/apply_guide/

本文网址:

/news/9558993.html

免责声明:

1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险

2.本文版权归属原作所有,仅代表作者本人观点,不代表非小号的观点或立场

上一篇:

币安为何推出第三条链?这对BNB意味着什么?

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

水星链

[0:15ms0-0:473ms