使用truffle verify plugin 验证Eip1967代理合约

Posted 伍肆伍柒

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用truffle verify plugin 验证Eip1967代理合约相关的知识,希望对你有一定的参考价值。

准备阶段

依赖版本如下
Truffle v5.4.21

  //file /package.json
 "dependencies": 
    "@truffle/hdwallet-provider": "^1.7.0",
    "ganache-cli": "^6.12.2",
    "truffle-contract-size": "^2.0.1"
  ,
  "devDependencies": 
    "@openzeppelin/contracts": "^4.3.3",
    "@openzeppelin/truffle-upgrades": "^1.11.0",
    "truffle-plugin-verify": "^0.5.17"
  ,

使用 npm install --save-dev truffle-plugin-verify 文档参考地址。安装成功之后,发布好对应的合约,Eip1957 可升级代理发布方式可以参考openzeppelin 文档 upgrading-smart-contracts,在喜好中选择自己使用的框架就可以看到对应的文档了

我使用的是truffle。
按照流程发布好所有合约之后,关联的合约一共涉及到3个分别是

  1. proxyAdmin 代理升级的权限合约
  2. TransparentUpgradeableProxy 透明代理合约
  3. CustomContract 逻辑合约
    要进行验证得时候直接
    truffle run verify CustomContract --network xxx --debug xxx为发布的网络,在truffle-config.js文件中配置。通常可能会遇到timeout的问题,国内的网络环境原因导致的失败。这个使用需要指定 科学上网,通过设置环境变量 https_proxy 的方式让truffle走代理。linux上命令如下 export https_proxy=http://127.0.0.1:8808 等待一段时间,就可以验证TransparentUpgradeableProxy.sol 合约了。

    具体的逻辑合约需要使用指定地址的方式进行验证
    truffle run verify CustomContract@0x0000dsa0d0a0sd0sa0das00d0sa00sd0as --network xxx --debug 0x00000…这个就是逻辑合约的实际部署地址,运行之后会输出上面相似的内容,表示验证成功。由于我的 合约已经验证过一次了,所以这里会显示已经验证过。如果需要开源chainlink的VRF合约,需要下载chainlink的verify插件。具体方式,需要参考广告文档。不过,一般来讲,这些三方库标准合约,已经大量部署了,只要有人验证过标准合约,scan上面就会显示与某某合约一致,然后也会显示对应的源代码,所以前人种树后人乘凉啊。
    对于不适用truffle-verify的方式进行合约验证的可以参看如下这篇文章。
    how-to-verify-a-contract-on-etherscan-bscscan-polygonscan
    以及openzeppelin的快速问答。上面有对常见问题所有解答,对于透明代理有疑惑的,强烈建议先看下上面的内容。

2021年12月2日 更新
国内部署合约到 bsc会经常timeout,header no found,等各种问题。除非由自己的bsc全节点,而使用truffle-verify-plugin truffle-upgrade 都需要依赖发布成功之后生成的记录,truffle-upgrade依赖.openzeppelin/下的json文件用于校验是否能安全升级,其中的检查包括,变量布局,变量名称,构造函数,自定义结构,详细的检测项请看这里truffle-upgrades#common-options。如果在升级的过程中丢失了其中某一个版本的合约,那就麻烦大了,目前的解决方法是,知道原有的丢失那个合约的源文件,然后找个主网部署一下,之后把对应的地址改成实际的丢失合约地址。之后再尝试运行升级合约。如果还是不行,那就近 proxyAdmin的地址使用部署钱包,调用升级方法。

如果丢失某个版本合约,升级时会提示 0x000 未注册 相应内容请参考这里。

在设计合约中没法使用constant immutable修饰的变量,不是不能用,而是用了之后就没法改了。具体的原理参考,上文提及的快速问答部分。所以这种方式也可以用来锁定某些没法修改的内容。用来增强公示。

truffle使用详解

truffle使用详解

1.truffle是什么

tuffle是基于以太坊的solidity语言的一套开发框架,本身基于javascript。

2.Truffle测试环境

truffle有很多优秀的客户端,推荐使用Ganache CLI .当开发基于truffle的应用时,它会在你设备的内存中创建一个完整的区块链,它在执行交易的时候是实时返回的。详情可以参考Ganache CLI

3.安装truffle

npm install -g truffle

4.truffle项目结构解析

首先,我们以MetaCoin这个官方项目来解析一下目录结构

mkdir MetaCoin
cd MetaCoin
truffle unbox metacoin

结构目录大概是这样的(README.md是我自己加的)

技术分享图片

contract/:solidity智能合约所在的目录
migrations/:移植文件所在的目录
test/:测试文件所在的目录
truffle.js:truffle项目的配置文件

5.文件编译

truffle compile

当你第一次编译的时候,所有的文件都会被编译。之后,truffle只会编译最近一次编译之后改动过的文件。如果你想编译所有文件可以使用--all选项

当你编译之后你的文件目录会多一个build文件夹,里面是编译之后的json文件。
技术分享图片

6.truffle的配置文件

module.exports = {
  // See <http://truffleframework.com/docs/advanced/configuration>
  // to customize your Truffle configuration!
};

刚开始你的配置文件是这样的,你可以参考上面的地址配置你自己的文件,下面是一个简单的示例:

  module.exports = {
  // See <http://truffleframework.com/docs/advanced/configuration>
  // to customize your Truffle configuration!
  networks:{
  development:{
    host:"127.0.0.1",
    port:8545,
    network_id:"*"
  }
  }
  };

指的是使用127.0.0.1:8545来将你的合约部署到区块链中,这里我使用的是上面提到的ganache-gli,在内存中建立开发用的完整区块链。
你用ganache-gli命令在内存建立区块链后,就可以执行下面的移植(部署)命令了。

7.移植

移植就是将你的程序部署到区块链当中:

truffle migrate

运行上面的移植命令,就是运行migrations文件夹下的文件,你可以将文件夹内的内容看做是一系列部署脚本文件,与编译命令相类似,该命令也只会从上次移植命令之后运行,如果你想重新部署,可以使用--reset选项

注意,migration的文件名以数字为前缀,以描述为后缀。为了记录迁移是否成功运行,需要编号前缀。后缀是纯粹为了人类的可读性和理解力

我们可以来看看migration文件夹中的.js文件

var ConvertLib = artifacts.require("./ConvertLib.sol");
var MetaCoin = artifacts.require("./MetaCoin.sol");

module.exports = function(deployer) {
deployer.deploy(ConvertLib);
deployer.link(ConvertLib, MetaCoin);
deployer.deploy(MetaCoin);

};

开始是一个artifacts.require(),这相当于在js中的require,我们需要通过这行代码告诉truffle我们要部署哪些文件,它返回的是合约的抽象,我们可以在下面的代码中使用它。这里需要特别注意的是: 这里的名字必须与合约的名字相同

接下来是module.exports ,所有的migrations文件必须通过module.exports抛出一个方法,这个方法的第一个参数是deployer对象。该对象通过提供用于部署智能契约的清晰语法,以及执行一些部署的普通职责(例如保存已部署的工件以备以后使用),来辅助部署。

上面使用的deployer.deploy(contract)指的是部署合约,deployer.link(library, destinations)是指:将已部署的库链接到契约或多个契约。这里的库是solidity中的概念,详情可以参考solidity的官方文档。deployer还有一些API,这里不详述,可以参考这里

还有一个初始的migration的文件,我们注意到,在contract文件夹中有Migrations.sol文件,在migration/文件夹中有1_initial_migration.js文件。truffle要求我们有一个移植合约--Migrations.sol来使用移植的功能,如果你使用的是truffle init来初始化你的项目。那么就在contract文件夹和migration/文件夹中只会包含这两个文件,没有示例程序,如下图:
技术分享图片

这个Migrations.sol必须在移植中先被移植,对应的就是1_initial_migration.js文件,一帮来说你并不需要改动这两的文件(当然你也可以改动),这里提出来是为了提醒不要误删

8.与合约进行交互

当你将合约通过上面的过程部署到区块链中,你就可以和合约进行交互了。使用下面的命令打开控制台:
truffle console

比如下面:
技术分享图片

关于与合约交互的一些API可以参考其他一些资料(如web3相关的命令)









以上是关于使用truffle verify plugin 验证Eip1967代理合约的主要内容,如果未能解决你的问题,请参考以下文章

表单验证控件Verify.js

Caused by SSLError(SSLError(1, u'[SSL: CERTIFICATE_VERIFY_FAILED] certificat

验证合约的三种方式

truffle使用详解

ChainIDE 3. 使用truffle部署合约

truffle框架的简单使用