OpenZeppelin 可昇級合約插件 7/9 不同網路的設定檔

以太坊 ethereum andy 5年前 (2020-11-09) 1326次浏览 已收录 0个评论 扫描二维码
文章目录[隐藏]

OpenZeppelin 可昇級合約插件 7/9 不同網路的設定檔

不同網路的設定檔 Network Files

OpenZeppelin 可昇級合約會持續追綜已經部署的合約,透過在根目錄底下的 .openzeppelin 資料夾內的設定檔,以及代理合約管理員。在 .openzeppelin 資料夾裡面,每個網路會有一個設定檔。建議把所有的設定檔案都納入源碼的版本控制,除了正在開發的這個設定檔。可以看到這些檔案大約長成 ./openzeppelin/unknown-*.json

注意:./openzeppelin 資料夾不相容於 OpenZeppelin CLI , 下一篇會說明如何使用 OpenZeppelin CLI 專案來部署。

<network_name>.json

OpenZeppelin 可昇級合約插件會建立設定檔,每個使用的網路都會建立一個,像是 mainnet , ropsten 各會有自己的設定檔,結構如下

  1. // .openzeppelin/.json
  2. {
  3. "manifestVersion": "3.0",
  4. "impls": {
  5. "...": {
  6. "address": "...",
  7. "txHash": "...",
  8. "layout": {
  9. "storage": [...],
  10. "types": {...}
  11. }
  12. },
  13. "...": {
  14. "address": "...",
  15. "txHash": "...",
  16. "layout": {
  17. "storage": [...],
  18. "types": {...}
  19. }
  20. }
  21. },
  22. "admin": {
  23. "address": "...",
  24. "txHash": "..."
  25. }
  26. }

每個一邏輯合約都會追蹤,除了部署地址會追蹤之外,以下的欄位也會追蹤
types 所有在合約內使用的類型,包括基本類型如 uint256 到自定義的 struct 類型(前面的文件說不能使用?)
storage 追蹤同一條線上合約的存儲的順序及規則(代理及委派的邏輯合約)。引用 type 欄位定義的類型,用於驗証後續版本之間的任何存儲順序及規則的變化是否相容。

檔案名稱 <network_name>.json ,注意這裡的 network_name 不是 Truffle 或是 Buidler 檔定檔內的網路名稱,而是從 chain id 來的。
這裡有個公鏈上的命名規則,如果鏈沒有被收錄官方列表,像是 Ethereum Classic ,就以 unknown-<chain_id>.json 的方式命名

設定檔和版本管理

公鏈的設定檔像是 mainnet.json 或是 ropsten.json 應該被納入版本控制。這些包括專案在想應網路中的狀態,這些信息是很有用的。像是合約各版本被部署後的地址。

然而本地的私有鏈像是 unknow-.json 只有表示專案開發時的私有鏈像是 ganache-cli 只跟單一貢獻者有關的就不用納入版本管理。
以下是 .gitignore 的參考範例

  1. // .gitignore
  2. # OpenZeppelin
  3. .openzeppelin/unknown-*.json

參考

https://docs.openzeppelin.com/upgrades-plugins/1.x/network-files


神隊友學長Andy , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:OpenZeppelin 可昇級合約插件 7/9 不同網路的設定檔
喜欢 (0)
[320208045@qq.com]
分享 (0)
andy
关于作者:
中年大叔,打拼 like young students.
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址