当前位置:网站首页>Precautions for scalable contract solution based on openzeppelin
Precautions for scalable contract solution based on openzeppelin
2022-07-02 11:35:00 【Ni xiansen_】
be based on Openzeppelin Considerations for scalable contract solutions
matters needing attention
Constructors
Please Do not use Constructors contructor(), We know that the runtime logic of scalable contracts is separated from data , Contract data is stored in Agency contract in , The contract we wrote is Logical contract , When the contract is deployed , Logical contract call contructor() The initialization data is Logical contract Of , Agency contract The data in is not initialized , So it's invalid .
Include Global variables Assign initial value when declaring , Because this is equivalent to the constructor contructor() Set these values in .
Parent contract initialization
If MyContract Inherited from contract BaseContract, that BaseContract Contract initialization function initialize() Of modifier( Decorators ) You have to use onlyInitializing, such as :
contract BaseContract is Initializable {
uint256 public y;
function initialize() public onlyInitializing {
y = 42;
}
}
// BaseContract Inherited from Initializable, There is no need to repeat explicit inheritance Initializable
contract MyContract is BaseContract {
int storageValue;
// modifier( Decorators ) initializer To ensure that initialize Will only be called once
function initialize(int initValue) public initializer {
BaseContract.initialize();
storageValue = initValue;
}
......
}
Declare state variables
- When declaring state variables , It cannot be assigned Initial value
It's wrong to do like this
contract MyContract is Initializable {
int storageValue = 666; // Invalid initial value
function initialize() public initializer {
}
......
}
Because this is equivalent to the constructor contructor() Set these values in , Therefore, it does not apply to scalable conventions .
- Defining constant state variables can still
It's OK like this
contract MyContract is Initializable {
// constant Constant keyword
int public constant storageValue = 666; // It works
function initialize() public initializer {
}
......
}
Create a new contract instance in the contract code
- Do not create new contract instances in the contract , The contract created is not scalable
like this , Even if MyContract It's upgradeable , but ERC20 Instances cannot be upgraded
import "@openzeppelin/contracts/token/ERC20/ERC20.sol";
contract MyContract is Initializable {
ERC20 public token;
function initialize() public initializer {
token = new ERC20("Test", "TST"); // This contract cannot be upgraded
}
......
}
- If you want to MyContract Quote other upgradeable contracts , Then inject the deployed scalable contract instance into MyContract in , It's a good solution
like this
import "@openzeppelin/contracts-upgradeable/token/ERC20/IERC20Upgradeable.sol";
contract MyContract is Initializable {
IERC20Upgradeable public token;
function initialize(IERC20Upgradeable _token) public initializer {
token = _token;
}
......
}
Declare the state variable when upgrading the contract
When writing a new version of the contract , Whether due to new features or bug Repair , There is an additional limitation to be observed : The declaration order of contract state variables cannot be changed , Nor can you change its type .
For example, the current version (V1) Contract state variable layout
contract MyContractV1 {
uint256 private x;
string private y;
}
When writing the new version of the contract , Please avoid the wrong operation :
- Change the type of variable
This is wrong
contract MyContractV2 {
string private x;
string private y;
}
- Change the order in which they are declared
This is wrong
contract MyContractV2 {
string private y;
uint256 private x;
}
- Introduce a new variable before the existing variable
This is wrong
contract MyContractV2 {
bytes private a;
uint256 private x;
string private y;
}
That's right
contract MyContractV2 {
uint256 private x;
string private y;
bytes private a;
}
- Delete existing variables
This is wrong
contract MyContractV2 {
string private y;
}
Reference documents :
Openzeppelin Write upgradeable contracts :https://docs.openzeppelin.com/upgrades-plugins/1.x/writing-upgradeable
边栏推荐
- TIPC介绍1
- Some things configured from ros1 to ros2
- STM32 single chip microcomputer programming learning
- Basic usage of MySQL in centos8
- TIPC Service and Topology Tracking4
- Attribute acquisition method and operation notes of C # multidimensional array
- Order by注入
- C#基于当前时间,获取唯一识别号(ID)的方法
- tidb-dm报警DM_sync_process_exists_with_error排查
- The first white paper on agile practice in Chinese enterprises was released | complete download is attached
猜你喜欢

CentOS8之mysql基本用法

从攻击面视角,看信创零信任方案实践

PHP tea sales and shopping online store

QT learning diary 8 - resource file addition

由粒子加速器产生的反中子形成的白洞

2022 love analysis · panoramic report of digital manufacturers of state-owned enterprises

III Chip startup and clock system

QT learning diary 7 - qmainwindow

制造业数字化转型和精益生产什么关系

webauthn——官方开发文档
随机推荐
Astparser parsing class files with enum enumeration methods
MTK full dump grab
JS -- take a number randomly from the array every call, and it cannot be the same as the last time
Some things configured from ros1 to ros2
STM32 single chip microcomputer programming learning
From the perspective of attack surface, see the practice of zero trust scheme of Xinchuang
MySQL linked list data storage query sorting problem
八大排序汇总
ROS lacks catkin_ pkg
Tick Data and Resampling
MySQL basic statement
Regular and common formulas
TIPC协议
原生方法合并word
The difference between SQL left join main table restrictions written after on and where
Thanos Receiver
C file and folder operation
念念不忘,必有回响 | 悬镜诚邀您参与OpenSCA用户有奖调研
sql left join 主表限制条件写在on后面和写在where后面的区别
LVM操作