当前位置:网站首页>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
边栏推荐
- 从ros1到ros2配置的一些东西
- TIPC 寻址2
- Gaode draws lines according to the track
- ImportError: cannot import name ‘Digraph‘ from ‘graphviz‘
- ros缺少xacro的包
- 制造业数字化转型和精益生产什么关系
- Openmldb meetup No.4 meeting minutes
- STM32单片机编程学习
- Some suggestions for young people who are about to enter the workplace in the graduation season
- 一.STM32的开发环境,keil5/MDK5.14安装教程(附下载链接)
猜你喜欢
随机推荐
Approximate sum count (approximate
启牛商学院给的股票账户安全吗?能开户吗?
The difference between SQL left join main table restrictions written after on and where
Tick Data and Resampling
Liftover for genome coordinate conversion
Jenkins安装
sql left join 主表限制条件写在on后面和写在where后面的区别
Mongodb learning and sorting (condition operator, $type operator, limit() method, skip() method and sort() method)
一.STM32的开发环境,keil5/MDK5.14安装教程(附下载链接)
TIPC Service and Topology Tracking4
webauthn——官方开发文档
Rest (XOR) position and thinking
II Stm32f407 chip GPIO programming, register operation, library function operation and bit segment operation
TIPC 寻址2
Order by injection
TIPC Cluster5
从ros1到ros2配置的一些东西
Regular and common formulas
高德根据轨迹画线
Skills of PLC recorder in quickly monitoring multiple PLC bits








