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

2024-04-18 12:18

本文主要是介绍使用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 verify plugin 验证Eip1967代理合约的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/914756

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected