移花接木:Revest Finance 被黑分析

By:九九@慢雾安全团队

2022 年 03 月 27 日,据慢雾区消息,Revest Finance 的 Revest 合约遭到黑客攻击,黑客盗取了近 770 万枚 ECO、579 枚 LYXe、近 7.15 亿枚 BLOCKS 以及超 35 万枚 RENA。慢雾安全团队第一时间介入分析,并将结果分享如下:

相关信息

Revest Finance 提出了一种新协议,用于将可替代的 ERC-20 代币作为不可替代的代币化金融工具进行打包、转移和存储,利用 ERC-1155 非可替代代币(NFT)标准来简化访问和商业通用性。使用该产品,资产的所有权可以以不影响资产价值的方式进行交易,从而形成一个新的商业模式。通过有针对性的用例发现该协议的机制、治理和货币化。

以下是本次攻击涉及的相关地址:

攻击者地址:

https://etherscan.io/address/0xef967ece5322c0d7d26dab41778acb55ce5bd58b

攻击合约:

https://etherscan.io/address/0xb480ac726528d1c195cd3bb32f19c92e8d928519

Aave V2以太坊池上的TUSD储备已被冻结:7月4日消息,关于冻结AaveV2以太坊池上的TUSD储备的AIP提案已于近期通过并执行,继最近发生的TUSD资产事件之后,ACI提议冻结AaveV2以太坊池上的TUSD储备。将阻止用户在AaveV2以太坊池中存入或借出TUSD。

这不会影响目前的头寸,用户仍然可以从AaveV2以太坊池中偿还和提取TUSD。本AIP旨在对TUSD情况采取保守方法。它将允许社区在做出任何进一步决定之前先评估情况。[2023/7/4 22:17:02]

被攻击合约:

https://etherscan.io/address/0x2320a28f52334d62622cc2eafa15de55f9987ed9#code

攻击交易:

https://etherscan.io/tx/0xe0b0c2672b760bef4e2851e91c69c8c0ad135c6987bbf1f43f5846d89e691428

https://etherscan.io/tx/0x613b2de3bb9043884a219296eeb1ada8c47b5a0262b9c68ca06ffd2de3a5d9f5

Mirror:应用中断问题已经解决:金色财经报道,Web3内容发布平台Mirror表示,应用中断问题已经解决。

此前报道,Mirror应用由于负载而遭到中断,团队正在调查根本原因。[2023/5/17 15:07:07]

https://etherscan.io/tx/0x0251c2b8012a61567ec5855010d29618ada066642e4a2866755d58337c2866d9

https://etherscan.io/tx/0x19b10c6d38f0b911fdc0e722d681a70a56699d70559eefef3d4d6fe88276c813

攻击核心点

在被攻击的 Revest 合约中,用户调用 mintAddressLock 函数来将一定数量的 ERC-20 代币存入 Revest Smart Vault 时,就会创建 FNFT。该 NFT 代表了用户拥有的代币资产数额,后续可以调用 withdrawFNFT 函数将代币赎回。

攻击核心点就在于攻击者利用 ERC1155 标准铸造 NFT 时会调用接受者地址的 onERC1155Received 函数,因此攻击者利用该点回调重入了 Revest 合约中的 depositAdditionalToFNFT 函数,该函数会铸造一个新的 NFT,接着会调用 tokenVault 合约的 handleMultipleDeposits 函数记录新的 NFT 的信息,而 handleMultipleDeposits 函数中缺少了对该新铸造的 NFT 是否存在的判断,故此攻击者利用重入修改了已经铸造过的 NFT 的信息,而用户铸造 NFT 打入 ERC20 资产代币的流程是在重入操作之前的,故此用户无需打入 ERC20 代币就成功铸造了代表自己具有 360001 枚 ERC20 代币资产的 NFT。

NFT市场LooksRare交易量突破30万笔,交易总额超260亿美元:金色财经报道,据Dune Analytics数据显示,NFT市场LooksRare交易量已突破30万笔,本文撰写时为30,9,854笔,此外当前LooksRare平台交易总额达到26,486,919,027美元,用户量为115,535个。[2022/9/23 7:15:21]

具体细节分析

此处拿获取 RENA 代币的攻击进行分析,其他几个攻击手法一致,不做过多赘述。

1. 攻击者首先从 uniswap 池子中闪电贷借出 2 枚 RENA 代币

2. 接着调用 Revest 合约中的 mintAddressLock 函数,传入 quantities 为 2,该函数进行加锁操作后会调用 doMint 函数来铸造 NFT

在 doMint 函数中,会调用 tokenVault 合约的 createFNFT 函数记录所铸造的 NFT 函数信息,接着用户给 tokenVault 合约转账相应的 ERC20 代币,最后调用 FNFTHandler 合约中的 mint 函数来发放 NFT

EPNS为推送交付节点引入SNS模块,允许开发者直接接收Web3通信至其平台:金色财经报道,以太坊消息推送服务EPNS宣布为推送交付节点引入SNS模块,让开发人员可以直接接收Web3通信到他们正在构建的平台,包括钱包、浏览器扩展、Telegram、Twitter、Discord等任何应用。

SNS通过将所有用户Web3钱包通信作为topic写Amazon SNS来工作,开发人员只需订阅该主题即可开始接收这些通知。托管SNS模块是一种中级解决方案,消除了运行节点或同步信息的繁重负载,提供了要实施的webhook,以开始在软件中接收通知、聊天或任何其他Web3通信。[2022/8/19 12:34:57]

所铸造的 NFT 的 fnftId 为 1027, 所记录的该 NFT 相关信息如下:

因为 depositAmount 为 0,故此 NFT 代表用户拥有的 ERC20 代币资产为 0,故无需转相关资产代币给合约

Yuga Labs联合创始人:已销毁拥有无限铸造无聊猿权限的私钥:6月8日消息,Yuga Labs 的联合创始人兼开发人员 EmperorTomatoKetchup 在其社交网站上表示,拥有无聊猿 NFT 无限铸造权限的私钥已经被销毁。

此前报道,6 月 6 日,加密开发者 foobar 在其社交网站表示,无聊猿 BAYC 合约存在一个拥有无限增发权限的私钥,如果该私钥被黑客攻击获取,市场上或将出现无聊猿倾销。[2022/6/8 4:10:57]

3. 再次调用 Revest 合约中的 mintAddressLock 函数,传入 quantities 为 360000,与上面相同的步骤调用 doMint 进行铸造 NFT,所铸造的 NFT 的 fnftId 为 1028,记录的 NFT 信息如下:

因为 depositAmount 为 0,故仍然无需转账代币资产给 tokenVault,但是与之前不同的是,这一次铸造 NFT 的操作中,因为在调用 FNFTHandler 合约的 mint 函数时会调用 _doSafeTransferAcceptanceCheck 函数

该函数会调用攻击合约的 onERC1155Received 函数,故此攻击者利用攻击合约中的重写的 onERC1155Received 函数回调重入了 Revest 合约的 depositAdditionalToFNFT 函数

在 depositAdditionalToFNFT 函数需要传入指定的 fnftId(此处是 1027)、NFT 数量 quantity(此处是 1)与单个 NFT 中需要存款的资产数额 amount(此处是 1),该函数会 burn 掉传入的 fnftId 的指定数量的 NFT,接着用户转入指定数量的 ERC20 代币资产并 mint 新的 NFT,需要转账的数量是 quantity *? amount 为 1,最后调用 tokenVault 合约中的 handleMultipleDeposits?记录新的 NFT 的存款数量为上面传入指定 fnftId 的 NFT 的 depositAmount 值 + 传入的 amount 的值

而在 handleMultipleDeposits 函数 mint 新的 NFT 时没有判断该 NFT 的信息是否在 tokenVault 合约中存在,故此攻击者利用该问题直接修改了 1028 号 NFT 的信息,使得该 NFT 虽然在 doMint 操作时第一次记录的 depositAmount 为 0,但是在重入后却修改成了 1

4. 最后调用 withdrawFNFT 函数进行提取 NFT 中所代表的 ERC20 代币资产

该函数燃烧掉指定的 NFT 后,会调用 tokenVault 合约中的 withdrawToken 函数进行提款

因为 depositAmount 在回调后被修改了为了 1,故此最后提款的 RENA 数量计算出来约为 360000 枚

5. 攻击者归还闪电贷后获利离场

总结

本次攻击事件是由于在 tokenVault 合约中的 handleMultipleDeposits 函数中没有判断该新铸造的 NFT 是否存在,故此攻击者利用该点直接修改了已经铸造过的 NFT 的信息,并且在 Revest 合约中关键的函数没有做重入锁的限制,导致了被回调利用。慢雾安全团队建议在进行铸造 NFT 等敏感操作时需增加对 NFT 是否已经存在的判断,且在合约关键函数中必须添加重入锁的限制,避免再次出现此类问题。

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

银河链

莱特币金色趋势丨ETH绝佳机会可能来了

前期大调整回撤至上升通道中位线迎来连续2周的反弹,自前期向上突破该线一直在未有效跌破,并且前期这波大跌也未破下方0.618支撑线以及312牛市起涨趋势线,大方向还是震荡向上的姿态,自前期触顶4380美金到目前已经84天时间.

TRXFATF将发布监管新规 将影响整个加密行业

据彭博社报道,金融行动特别工作组(FATF)将于6月21日发布一份说明,阐明参与国应如何对加密资产行业实施监督。据报道,新规则将适用于处理加密资产和代币的广泛领域,包括加密资产交易所、托管机构和对冲基金.

中币下载欧盟提出建议考虑欧洲数字货币的草案

欧盟发布的一份文件草案建议欧盟考虑发行自己的数字货币。欧盟议会将很快投票通过MiCA法案:金色财经报道,在最近的一份声明中,欧盟议会表示其成员将很快投票通过加密资产市场监管法案(MiCA),投票定于立法机构全体会议期间进行.

[0:0ms0-1:810ms