风险提示:央行等十部委发布《关于进一步防范和处置虚拟货币交易炒作风险的通知》, 请读者提高风险意识。

Jacky GU:关于FERC20智能合约验证的说明

临时方案来证明目前部署在主网上的智能合约,与github上公布的合约相同。

jackygu
jackygu
热度 ...

原文作者:jackygu

原文来源:mirror

FERC20 社区,大家好,

我是Jacky,这两天一直忙于FERC20的合约验证,但因为合约在编译过程中使用了新的viaIR技术,至今未能在以太坊区块链浏览器上成功验证合约,我找了国内外技术圈的朋友,尚未解决。

这意味着大家暂时无法在区块链浏览器的Contract标签页中看到合约源码。

但合约的验证是非常重要的,这决定了社区对智能合约是否信任。所以我想了一个临时方案来证明目前部署在主网上的智能合约,与github上公布的合约相同。并希望社区里熟悉智能合约技术的同学来验证这件事。

下面我将验证步骤详细介绍如下:(以下方法用于V1,V2版本方法也可一样验证)

1. 合约简介

FERC20一共有两个合约:InscriptionFactory.sol和Inscription.sol。

  • 前者用于管理所有的FERC20代币合约,包括生成代币、检索代币等功能;
  • 后者即FERC20合约,它继承了标准的ERC20并做了一些功能上的扩展。

因为Inscription.sol合约被包含在InscriptionFactory.sol中,所以只需要一份InscriptionFactory.sol源文件即可。

合约源文件:https://github.com/jackygu2006/ferc20_contracts

为方便社区技术同学验证,我已将InscriptionFactory.sol合约做扁平化处理,扁平化后的源文件:https://gist.github.com/jackygu2006/5d1cb712cbd7ac46e9950f5832494a74

2. 验证方式

第一步

将InscriptionFactory.sol合约部署到与以太坊主网一模一样的Goerli测试网上。

打开Remix工具,新建一个空合约文件,命名为InscriptionFactory.sol,然后将从上面github复制下来的源文件粘贴至合约文件里。如下图:

github

github

然后点击上图下方的红色框位置,选择Use configuration file, 并点击compiler_config.json,会在主窗口看到配置文件,如下图。

github

重点:在compiler_config.json配置文件中加上"viaIR" : true,如上图中红色部分。

github

按上图指示,先选择编译环境为Injected Provider - MetaMask,这时候Remix会链接Metamask钱包,请确保连接到Goerli测试网,并确保操作账户中有一些测试币(0.1E就够了)。Metamask钱包链接成功后,会看到显示Goerli(5) network

然后在合约中选择InscriptionFactory,并点击Deploy按钮。

如果一切顺利,会弹出Metamask钱包,你可以选择较低的Gas价格,并签名发送交易,约15秒后,合约部署完毕,将在测试网上新部署的InscriptionFactory合约地址复制保留。

第二步 生成standard-json-input.json文件。

因为编译合约时使用了viaIR方式,所以无法通过常规的在区块链浏览器中上传合约源码的方式进行验证,只能通过standard-json-input方式验证。因此,我们需要一个包括合约源码和配置的json文件。

关于如何生成该文件,在reddit上有个帖子可以参考,链接。

如果你使用hardhat开发合约,则可以在build下得到standard-json-input.json文件。

github

第三步 查看测试网上的合约字节码

通过上述方式部署完成后,即得到一个合约地址。大家可以按我下面的方法进行操作(但请将我的合约地址换成你们部署后得到的地址)

我部署后得到的在Goerli上的InscriptionFactory合约地址为:0xfb1be5133e61012de5790589c9b8f9e5d79978df

打开Goerli浏览器:https://goerli.etherscan.io/

关于【Jacky GU:关于FERC20智能合约验证的说明】的延伸阅读

github

github

github

请务必按上图中的选项选择,即:

  • 编译类型为Solidity(Standard-Json-Input)
  • 编译器版本为v0.8.18+commit.87f61d96
  • 开源协议选择MIT

然后点击Continue按钮,进到下一页,见下图:

github

选择第二步生成的standard-json-input.json文件,然后点击Step2上传该文件。

接着点击下方的蓝色Verify and publish按钮,半分钟左右,出现下图页面:

github

注意:上面这个页面表示源码验证失败,不过这无关紧要。

在上面页面上找到下图红色位置,复制Goerli测试链上已经部署的智能合约字节码,并保存为文件。因为较长,就不粘贴在这里了。

github

第四步 查看以太坊主网上的合约字节码

与第三步的步骤相同,只是打开的是以太坊主网浏览器,合约地址是主网上的。

主网已经在运行的InscriptionFactory合约地址为:0x47B9949041EbF2472332883e64025D5d024941C6

(这里省略,请参考第三步)

最后,拿到在主网上部署的InscriptionFactory合约字节码,复制并保存。

第五步 对比Goerli测试链和主链的字节码

github

注意,必须要每个字节都相同,才能证明两段程序的相同

我已按照上述方案验证通过,每个人都可以按上述方式验证

3.验证原理

智能合约是将源代码编译后得到的字节码部署到区块链上的一段程序。原则是:源码相同,字节码必然相同,源码不同,字节码必然不同。

以太坊Goerli测试网与主网完全一致,所以,我们就可以通过对比测试网和主网上的字节码来验证github上开源的合约是否就是部署在区块链上的智能合约。

尾声

以上只是用于验证开源合约与链上合约一致性的临时解决方案,我称之为通过以太坊官方主网和官方测试网的间接验证。

社区里有同学能解决直接在以太坊主网上验证该合约的,请下载合约源码后自行处理,解决后,请截图后通过推特跟我联系,或者发推特并 @jackygu2020,第一个解决该问题的同学将从捐赠池中获得1000 ferc。

我相信通过社区,很快能解决这个问题。

谢谢大家的支持!!!

免责声明:本文仅代表作者个人观点,不代表链观CHAINLOOK立场,不承担法律责任。文章及观点也不构成投资意见。请用户理性看待市场风险,以及遵守所在国家和地区的相关法律法规。
图文来源:jackygu,如有侵权请联系删除。转载或引用请注明文章出处!

标签:

分享至
https://www.chainlook.cn/toutiao/1691122483.html

下一篇:

长推:盘点 Polychain Capital 投资项目,谁会脱颖而出?

本文介绍了 Polychain Capital 今年的 11 个投资项目。

免责声明:
链观CHAINLOOK作为区块链技术应用与Web3行业研究的智库媒体,旨在为中国区块链专家、学者们提供最新的行业资讯信息与数据样本,用于区块链技术研究与创新。本站所发布的文章仅代表作者的个人观点,不代表链观CHAINLOOK官方立场,本站所发布的区块链行业研究报告与数据分析成果是通过人工智能算法对数据内容进行分析与归纳生成,不代表任何投资暗示与建议,链观CHAINLOOK不承担法律责任。

风险提示:
虚拟货币不具有法定货币等同的法律地位,参与虚拟货币投资交易存在法律风险,链观CHAINLOOK坚决反对各类代币炒作,请读者提高风险意识,理性看待区块链技术应用及市场风险。

© 链观CHAINLOOK All Rights Reserved. 京ICP备18054193号-5