forked from OpenZeppelin/openzeppelin-foundry-upgrades
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Options.sol
154 lines (150 loc) · 6.55 KB
/
Options.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
/**
* Common options.
*/
struct Options {
/*
* The reference contract to use for storage layout comparisons.
*
* For supported formats, see https://docs.openzeppelin.com/upgrades-plugins/api-foundry-upgrades#contract_name_formats
*
* If not using the `referenceBuildInfoDir` option, this must be in Foundry artifact format.
*
* If using the `referenceBuildInfoDir` option, this must be in annotation format prefixed with the build info directory short name.
* For example, if `referenceBuildInfoDir` is `previous-builds/build-info-v1` and the reference contract name is `ContractV1`,
* then set this to `build-info-v1:ContractV1`
*
* If not set, attempts to use the `@custom:oz-upgrades-from <reference>` annotation from the contract.
*/
string referenceContract;
/*
* Absolute or relative path to a build info directory from a previous version of the project to use for storage layout comparisons.
* Relative paths must be relative to the Foundry project root.
*
* When using this option, refer to this directory using prefix `<dirName>:` before the contract name or fully qualified name
* in the `referenceContract` option or `@custom:oz-upgrades-from` annotation, where `<dirName>` is the directory short name.
* The directory short name must be unique when compared to the main build info directory.
*/
string referenceBuildInfoDir;
/*
* Encoded constructor arguments for the implementation contract.
* Note that these are different from initializer arguments, and will be used in the deployment of the implementation contract itself.
* Can be used to initialize immutable variables.
*/
bytes constructorData;
/*
* Exclude validations for contracts in source file paths that match any of the given glob patterns.
* For example, patterns such as "contracts/helpers/*.sol". Does not apply to reference contracts.
*/
string[] exclude;
/*
* Selectively disable one or more validation errors. Comma-separated list that must be compatible with the
* --unsafeAllow option described in https://docs.openzeppelin.com/upgrades-plugins/1.x/api-core#usage
*/
string unsafeAllow;
/*
* Configure storage layout check to allow variable renaming
*/
bool unsafeAllowRenames;
/*
* Skips checking the `initialOwner` parameter of `Upgrades.deployTransparentProxy`.
* When deploying a transparent proxy, the `initialOwner` must be the address of an EOA or a contract that can call functions on a ProxyAdmin. It must not be a ProxyAdmin contract itself.
* Use this if you encounter an error due to this check and are sure that the `initialOwner` is not a ProxyAdmin contract.
*/
bool unsafeSkipProxyAdminCheck;
/*
* Skips checking for storage layout compatibility errors. This is a dangerous option meant to be used as a last resort.
*/
bool unsafeSkipStorageCheck;
/*
* Skips all upgrade safety checks. This is a dangerous option meant to be used as a last resort.
*/
bool unsafeSkipAllChecks;
/*
* Options for OpenZeppelin Defender deployments.
*/
DefenderOptions defender;
/*
* When set, uses CREATE2 for deployment with the provided salt.
*/
bytes32 customSalt;
}
/**
* Options for OpenZeppelin Defender deployments.
*/
struct DefenderOptions {
/*
* Deploys contracts using OpenZeppelin Defender instead of broadcasting deployments through Forge. Defaults to `false`. See DEFENDER.md.
*
* NOTE: If using an EOA or Safe to deploy, go to https://defender.openzeppelin.com/v2/#/deploy[Defender deploy] to submit the pending deployment(s) while the script is running.
* The script waits for each deployment to complete before it continues.
*/
bool useDefenderDeploy;
/*
* When using OpenZeppelin Defender deployments, whether to skip verifying source code on block explorers. Defaults to `false`.
*/
bool skipVerifySourceCode;
/*
* When using OpenZeppelin Defender deployments, the ID of the relayer to use for the deployment. Defaults to the relayer configured for your deployment environment on Defender.
*/
string relayerId;
/*
* Applies to OpenZeppelin Defender deployments only.
* If this is not set, deployments will be performed using the CREATE opcode.
* If this is set, deployments will be performed using the CREATE2 opcode with the provided salt.
* Note that deployments using a Safe are done using CREATE2 and require a salt.
*
* WARNING: CREATE2 affects `msg.sender` behavior. See https://docs.openzeppelin.com/defender/v2/tutorial/deploy#deploy-caveat for more information.
*/
bytes32 salt;
/*
* The ID of the upgrade approval process to use when proposing an upgrade.
* Defaults to the upgrade approval process configured for your deployment environment on Defender.
*/
string upgradeApprovalProcessId;
/*
* License type to display on block explorers for verified source code.
* See https://etherscan.io/contract-license-types for supported values and use the string found in brackets, e.g. MIT.
* If not set, infers the license type by using the SPDX license identifier from the contract's Solidity file.
* Cannot be set if `skipLicenseType` or `skipVerifySourceCode` is `true`.
*/
string licenseType;
/*
* If set to `true`, does not set the license type on block explorers for verified source code.
* Use this if your contract's license type is not supported by block explorers.
* Defaults to `false`.
*/
bool skipLicenseType;
/*
* Transaction overrides for OpenZeppelin Defender deployments.
*/
TxOverrides txOverrides;
/*
* When using OpenZeppelin Defender deployments, you can use this to identify, tag, or classify deployments.
* See https://docs.openzeppelin.com/defender/module/deploy#metadata.
* Must be a JSON string, for example: '{ "commitHash": "4ae3e0d", "tag": "v1.0.0", "anyOtherField": "anyValue" }'
*/
string metadata;
}
/**
* Transaction overrides for OpenZeppelin Defender deployments.
*/
struct TxOverrides {
/*
* Maximum amount of gas to allow the deployment transaction to use.
*/
uint256 gasLimit;
/*
* Gas price for legacy transactions, in wei.
*/
uint256 gasPrice;
/*
* Maximum total fee per gas, in wei.
*/
uint256 maxFeePerGas;
/*
* Maximum priority fee per gas, in wei.
*/
uint256 maxPriorityFeePerGas;
}