Popcornswap合约解析+教你如何避免大部分土矿风险_POP:POPE

最近惊闻BSC上2个土矿又跑路了,金额在千万级别,有一个矿朋友还中招了,实在是看不下去,和大家谈谈,如何避免大部分土矿的坑。

土矿一般来讲,抽走资金一般这几个步骤:

通过高APY吸引你冲动梭哈(注意,很多鸡贼的土矿都是写APR,看起来更高,用APR的土矿求稳可以直接关闭),毕竟高APY都是真金白银支撑的,收益这么高大户早来了,正所谓的收益越高,风险越大

通过一些“所谓的”安全措施(timelock等)让你觉得风险很低

盗取资金之后马上换为非erc代币或者无法冻结的代币,然后等待混币机会逃走

看到了这个步骤,你应该明白了,如果能够做到:

不开源的土矿一律不碰,不管他APY写的多么诱人

开源的土矿,如果要参与,一定是在diff合约,检查变量参数之后,少量资金参与。(然而可能还有风险,比如popcornswap,会详解)

那么相信你能规避大部分风险,下面简单讲一下怎么diff合约,怎么检查参数,以及一些衍生的思考。(小白向)

Naver与LINE NEXT达成合作,为K-pop乐迷推出NFT平台:金色财经消息,韩国互联网巨头Naver与LINENEXT合作推出了NFT平台NOW.Drops。该平台将允许K-pop乐迷创建定制的音乐NFT。

NOW.Drops允许用户从NOW.的独家内容中裁剪出他们最喜欢的音乐表演的NFT,NAVER的直播音频和视频流服务以韩国艺术家为主。

NOW.Drops可以通过LINE的电子钱包DOSI访问,用户可以通过社交媒体账户登录并进行支付。LINE NEXT是东京移动应用巨头LINE公司的NFT子公司,该公司由Naver和软银集团所有。(Forkast)[2022/9/22 7:13:34]

第一步:diff

这里以在线对比工具 https://www.diffchecker.com/ 为例

注意一点,diff的合约需要是你真实要转币进去的合约地址(可以转非常少的量去拿地址)

K-pop 经纪公司 Fantagio 与 Crypto.com 签署谅解备忘录,将共同开发 NFT 项目:8月4日消息,韩国娱乐机构 Fantagio 周三宣布与数字资产平台 Crypto.com 签署谅解备忘录(MOU),将共同开展 NFT项目。

在科斯达克上市的 Fantagio 管理着 ASTRO 和 Weki Meki 等 K-pop 偶像团体,以及包括车银优和邕圣佑在内的韩国演员。[2022/8/4 3:55:23]

首先拿到原版的MasterChef代码(这里以pancakeswap为例):

https://bscscan.com/address/0x73feaa1ee314f8c655e354234017be2193c9e24e#code

接着这里以popcornswap为例:

https://bscscan.com/address/0x584527ded17aceb3dc617c40b04e8fe9afc57096#code

网石子公司与Kakao Entertainment将合作推出虚拟K-Pop女团:10月27日消息,韩国手机游戏开发商网石游戏(Netmarble)旗下Metaverse Entertainment Inc.正在与Kakao Entertainment合作开发一个虚拟女子组合项目。

虚拟K-Pop女子组合MAVE:将由四名AI成员组成,计划于明年推出。Kakao Entertainment首席执行官Lee Jin-soo表示,该公司“预计Netmarble顶级角色制作能力和Kakao Entertainment全球价值链的结合,将对元宇宙新世界带来不同的冲击。”他补充说,元偶像只是其迈向全球娱乐市场使命的开始。(Forkast)[2021/10/27 6:16:04]

分别吧代码复制到两边,开始diff

这里我保存了diff结果,可以直接点这个link:https://www.diffchecker.com/VqaCP3DK

数据:Popsicle Finance黑客攻击事件损失超过2000万美元:据BlockSec安全团队统计,在Popsicle Finance黑客攻击事件中,攻击者共计获利超过2000万美元,其中包括2560 WETH、96.2 WBTC、16万DAI、539万USDC、498万USDT、1.05万UNI,攻击者在获利后将全部资产转成ETH,并拆分成小额用TornadoCash实施分散。

据此前报道,跨链收益率提升平台Popsicle Finance团队成员表示,Popsicle Finance遭到黑客攻击,目前仅有Sorbetto Fragola一款产品受到影响。团队将在几周内修复漏洞并对受损用户进行赔偿。此前Popsicle Finance曾与跨链交易平台Multichain.xyz以及Tether合作推出跨链USDT封装代币fUSDT。[2021/8/4 1:33:49]

像结果中字符串(名称等)的修改,或者// 后的内容(注释)都可以忽略

新加坡区块链创业项目PopulStay(潮箱)在东京的首次亮相:新加坡区块链创业项目PopulStay(潮箱)在东京的首次亮相开启路演,在路演现场Populstay(潮箱)项目获得了日本Softbank投资部, MooreManagement, YJCapital等投资机构的关注,并与瑞士的数字资产和交易所Lykke达成了初步的合作意向。在技术合作方面,与顶级区块链技术研发机构德国XIAM达成技术对接意向。同时也被三菱東京UFJ銀行邀请参加明年1月的区块链加速器。[2018/2/27]

如上图这种,可以忽略

如果是原版添加的代码,土狗删除的,一般也不重要,重点是土狗和原版代码不同的地方:

上图为关键差异,土狗修改了原版的migrator方法,还增加了个一个叫做preUpgrade的函数。

看到这里,如果你对合约一无所知,安全期间,就可以直接关闭页面保平安了。

这里简单分析一下差异,首先migrate方法,这个是sushiswap继承的代码,原版代码就有将池子里钱掏空的可能性(所以土狗如果有migrate方法,求稳就不要去玩)。

popcorn这里,新的preUpgrade方法,是public的,代表所有人都能调用,就是一个非常可疑的点,理论上在migrator设置为恶意地址的时候能够让migrator掏空所有的钱。

第二步:检查变量

点击土狗合约的这个按钮:

检查migrator,owner等变量:(owner是核心)

可以看到migrator是0,owner是一个timelock地址,土狗的一种套路是,声称自己有timelock,给出了合约地址,但owner并不是timelock的地址,那明显就是局了。

当然timelock合约,也可以做小动作,所以也需要做diff操作,这里他的timelock没有问题,就不赘述了

那么完成了上面两步,很多资深矿工可能会觉得,timelock有的,合约变量没问题,虽然有代码存在风险,但是有timelock啊,没事,冲tmd,对低级土狗而言,可能确实就无风险了,但很可惜,popcornswap是一个略高级的土狗。看我下面分解盗币过程:

项目方通过调用:

https://bscscan.com/tx/0x38f75296e3343228c0309f8c99a24ca4f4812372f2b032f38ce25ac5a992b768

preUpgrade方法,让自己的地址有了合约里token的transferFrom权限(简单理解为uniswap交易之前你需要allow合约花你的币,这里是allow自己花合约里的币)

看前面的代码可以发现,preUpgrade确实又这个功能,但他只会给migrator这个权限,而migrator又是0,修改migrator需要经过时间锁,那么他是怎么做到的呢?(这个问题其实也困扰了我一会)

答案是:项目方在部署合约后,加timelock之前,把migrator改成了自己的地址,并通过preUpgrade提前获取了里面所有token的allowance,然后再改回migrator,添加时间锁。

因为这些tx混在项目方添加池子的tx中,普通人根本不可能去检查一个池子之前的每一个tx,所以popcornswap得以在2小时内盗取2mil的代币。

这个作案手法也引起了我的思考,目前并没有有效的工具,能够查出一个合约地址里,token allow给其他地址的情况,因此非常难发现问题。普通的用户,没有能力,也不太可能发现这个端倪,甚至我相信在本次事件中,一些对合约代码有所了解的土矿老司机也一并翻车。

那么popcornswap的解析就讲到哪里,下面是我个人的一些思考,以及私货(不愿意看的朋友就可以关闭文章了)

本次作案手法曝光之后,相信未来的土矿也很有可能利用类似的手法进行盗币,而对普通用户而言防不胜防,事实上最近2天bsc上就有2个矿翻车,金额还都不小。

作为交易所公链,不管是bsc,还是heco,他们的核心竞争力是什么?是去中心化吗?

我个人认为不是的。

bsc,heco等,他们最大的优势应该是1. 低手续费 2. 交易所公信力背书

以bsc为例,作为一个类似DPos的设计公链,跨链桥非去中心化,以及上面的大部分资产都是币安发放的情况下,即使代码开源,谈何去中心化?

个人认为,反而应该反其道行之,引入类似EOS的仲裁机制,最大程度的保证用户在链上的的财产安全才是生存之道。

本次popcornswap事件以及最新翻车的土矿,币安目前都还在踢皮球阶段,要求用户去报案或者说我们在监视黑客地址等等,而不是想办法帮用户挽回损失,长此以往,当土矿跑路越来越多的情况下,请问币安,谁还会去用BSC?

如果类似事件在Heco或者其他交易所公链发生,而他们拥有类似的安全机制,保证了用户的资产安全,这样大部分散户才敢放心的在上面继续使用,毕竟,你作为交易所背书的公链,优势不是,也不可能会是去中心化。

希望所有交易所公链技术团队三思,通过代码升级保证自己公链的安全性来差异化竞争,也许还不太晚。

原标题:Popcornswap合约解析+教你如何避免大部分土矿风险

作者:iNexusPro

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

水星链

[0:46ms0-1:156ms