@openzeppelin/wizard 0.5.3 → 0.5.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +13 -3
- package/dist/account.d.ts +20 -0
- package/dist/account.d.ts.map +1 -0
- package/dist/account.js +252 -0
- package/dist/account.js.map +1 -0
- package/dist/api.d.ts +12 -7
- package/dist/api.d.ts.map +1 -1
- package/dist/api.js +6 -1
- package/dist/api.js.map +1 -1
- package/dist/build-generic.d.ts +4 -0
- package/dist/build-generic.d.ts.map +1 -1
- package/dist/build-generic.js +3 -0
- package/dist/build-generic.js.map +1 -1
- package/dist/environments/hardhat/package-lock.json +3 -3
- package/dist/environments/hardhat/upgradeable/package-lock.json +7 -7
- package/dist/erc20.d.ts +1 -0
- package/dist/erc20.d.ts.map +1 -1
- package/dist/erc20.js +46 -6
- package/dist/erc20.js.map +1 -1
- package/dist/generate/account.d.ts +3 -0
- package/dist/generate/account.d.ts.map +1 -0
- package/dist/generate/account.js +21 -0
- package/dist/generate/account.js.map +1 -0
- package/dist/generate/erc20.d.ts.map +1 -1
- package/dist/generate/erc20.js +1 -0
- package/dist/generate/erc20.js.map +1 -1
- package/dist/generate/sources.d.ts.map +1 -1
- package/dist/generate/sources.js +6 -0
- package/dist/generate/sources.js.map +1 -1
- package/dist/generate/stablecoin.d.ts.map +1 -1
- package/dist/generate/stablecoin.js +2 -0
- package/dist/generate/stablecoin.js.map +1 -1
- package/dist/governor.d.ts.map +1 -1
- package/dist/governor.js +7 -7
- package/dist/governor.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -1
- package/dist/index.js.map +1 -1
- package/dist/kind.js +2 -1
- package/dist/kind.js.map +1 -1
- package/dist/print.d.ts.map +1 -1
- package/dist/print.js +2 -1
- package/dist/print.js.map +1 -1
- package/dist/signer.d.ts +39 -0
- package/dist/signer.d.ts.map +1 -0
- package/dist/signer.js +115 -0
- package/dist/signer.js.map +1 -0
- package/dist/solidity-version.json +1 -1
- package/dist/stablecoin.js +2 -2
- package/dist/stablecoin.js.map +1 -1
- package/dist/test.js +17 -6
- package/dist/test.js.map +1 -1
- package/dist/utils/convert-strings.d.ts +11 -0
- package/dist/utils/convert-strings.d.ts.map +1 -0
- package/dist/utils/convert-strings.js +30 -0
- package/dist/utils/convert-strings.js.map +1 -0
- package/dist/utils/sanitize.d.ts +2 -0
- package/dist/utils/sanitize.d.ts.map +1 -0
- package/dist/utils/sanitize.js +9 -0
- package/dist/utils/sanitize.js.map +1 -0
- package/dist/zip-foundry.js +4 -4
- package/package.json +5 -6
- package/src/account.ts +292 -0
- package/src/api.ts +16 -7
- package/src/build-generic.ts +6 -0
- package/src/environments/hardhat/package-lock.json +3 -3
- package/src/environments/hardhat/upgradeable/package-lock.json +7 -7
- package/src/erc20.ts +47 -1
- package/src/generate/account.ts +20 -0
- package/src/generate/erc20.ts +1 -0
- package/src/generate/sources.ts +7 -0
- package/src/generate/stablecoin.ts +2 -0
- package/src/governor.ts +9 -8
- package/src/index.ts +1 -1
- package/src/kind.ts +2 -1
- package/src/print.ts +2 -1
- package/src/signer.ts +124 -0
- package/src/solidity-version.json +1 -1
- package/src/stablecoin.ts +2 -2
- package/src/test.ts +17 -5
- package/src/utils/convert-strings.ts +27 -0
- package/src/utils/sanitize.ts +6 -0
- package/src/zip-foundry.ts +4 -4
package/dist/signer.js
ADDED
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.signerFunctions = exports.signers = exports.SignerOptions = void 0;
|
|
4
|
+
exports.addSigner = addSigner;
|
|
5
|
+
const define_functions_1 = require("./utils/define-functions");
|
|
6
|
+
exports.SignerOptions = [false, 'ERC7702', 'ECDSA', 'P256', 'RSA', 'Multisig', 'MultisigWeighted'];
|
|
7
|
+
function addSigner(c, signer) {
|
|
8
|
+
if (!signer)
|
|
9
|
+
return;
|
|
10
|
+
const parent = exports.signers[signer];
|
|
11
|
+
const name = parent.name;
|
|
12
|
+
c.addParent(parent);
|
|
13
|
+
c.addOverride({ name: name === exports.signers.MultisigWeighted.name ? exports.signers.Multisig.name : name }, exports.signerFunctions._rawSignatureValidation);
|
|
14
|
+
// ERC-7702 doesn't require initialization
|
|
15
|
+
if (signer === 'ERC7702')
|
|
16
|
+
return;
|
|
17
|
+
c.addParent({
|
|
18
|
+
name: 'Initializable',
|
|
19
|
+
path: '@openzeppelin/contracts/proxy/utils/Initializable.sol',
|
|
20
|
+
});
|
|
21
|
+
const fn = exports.signerFunctions[`initialize${signer}`];
|
|
22
|
+
c.addModifier('initializer', fn);
|
|
23
|
+
const args = fn.args;
|
|
24
|
+
switch (signer) {
|
|
25
|
+
case 'Multisig':
|
|
26
|
+
c.addFunctionCode(`_addSigners(${args[0].name});`, fn);
|
|
27
|
+
c.addFunctionCode(`_setThreshold(${args[1].name});`, fn);
|
|
28
|
+
break;
|
|
29
|
+
case 'MultisigWeighted':
|
|
30
|
+
c.addFunctionCode(`_addSigners(${args[0].name});`, fn);
|
|
31
|
+
c.addFunctionCode(`_setSignerWeights(${args[0].name}, ${args[1].name});`, fn);
|
|
32
|
+
c.addFunctionCode(`_setThreshold(${args[2].name});`, fn);
|
|
33
|
+
break;
|
|
34
|
+
case 'ECDSA':
|
|
35
|
+
case 'P256':
|
|
36
|
+
case 'RSA':
|
|
37
|
+
c.addFunctionCode(`_setSigner(${fn.args
|
|
38
|
+
.map(({ name }) => name)
|
|
39
|
+
.join(', ')
|
|
40
|
+
.trimEnd()});`, fn);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
exports.signers = {
|
|
44
|
+
ERC7702: {
|
|
45
|
+
name: 'SignerERC7702',
|
|
46
|
+
path: '@openzeppelin/community-contracts/utils/cryptography/SignerERC7702.sol',
|
|
47
|
+
},
|
|
48
|
+
ECDSA: {
|
|
49
|
+
name: 'SignerECDSA',
|
|
50
|
+
path: '@openzeppelin/community-contracts/utils/cryptography/SignerECDSA.sol',
|
|
51
|
+
},
|
|
52
|
+
P256: {
|
|
53
|
+
name: 'SignerP256',
|
|
54
|
+
path: '@openzeppelin/community-contracts/utils/cryptography/SignerP256.sol',
|
|
55
|
+
},
|
|
56
|
+
RSA: {
|
|
57
|
+
name: 'SignerRSA',
|
|
58
|
+
path: '@openzeppelin/community-contracts/utils/cryptography/SignerRSA.sol',
|
|
59
|
+
},
|
|
60
|
+
Multisig: {
|
|
61
|
+
name: 'MultiSignerERC7913',
|
|
62
|
+
path: '@openzeppelin/community-contracts/utils/cryptography/MultiSignerERC7913.sol',
|
|
63
|
+
},
|
|
64
|
+
MultisigWeighted: {
|
|
65
|
+
name: 'MultiSignerERC7913Weighted',
|
|
66
|
+
path: '@openzeppelin/community-contracts/utils/cryptography/MultiSignerERC7913Weighted.sol',
|
|
67
|
+
},
|
|
68
|
+
};
|
|
69
|
+
exports.signerFunctions = {
|
|
70
|
+
...(0, define_functions_1.defineFunctions)({
|
|
71
|
+
initializeECDSA: {
|
|
72
|
+
kind: 'public',
|
|
73
|
+
args: [{ name: 'signer', type: 'address' }],
|
|
74
|
+
},
|
|
75
|
+
initializeP256: {
|
|
76
|
+
kind: 'public',
|
|
77
|
+
args: [
|
|
78
|
+
{ name: 'qx', type: 'bytes32' },
|
|
79
|
+
{ name: 'qy', type: 'bytes32' },
|
|
80
|
+
],
|
|
81
|
+
},
|
|
82
|
+
initializeRSA: {
|
|
83
|
+
kind: 'public',
|
|
84
|
+
args: [
|
|
85
|
+
{ name: 'e', type: 'bytes memory' },
|
|
86
|
+
{ name: 'n', type: 'bytes memory' },
|
|
87
|
+
],
|
|
88
|
+
},
|
|
89
|
+
initializeMultisig: {
|
|
90
|
+
kind: 'public',
|
|
91
|
+
args: [
|
|
92
|
+
{ name: 'signers', type: 'bytes[] memory' },
|
|
93
|
+
{ name: 'threshold', type: 'uint256' },
|
|
94
|
+
],
|
|
95
|
+
},
|
|
96
|
+
initializeMultisigWeighted: {
|
|
97
|
+
kind: 'public',
|
|
98
|
+
args: [
|
|
99
|
+
{ name: 'signers', type: 'bytes[] memory' },
|
|
100
|
+
{ name: 'weights', type: 'uint256[] memory' },
|
|
101
|
+
{ name: 'threshold', type: 'uint256' },
|
|
102
|
+
],
|
|
103
|
+
},
|
|
104
|
+
_rawSignatureValidation: {
|
|
105
|
+
kind: 'internal',
|
|
106
|
+
args: [
|
|
107
|
+
{ name: 'hash', type: 'bytes32' },
|
|
108
|
+
{ name: 'signature', type: 'bytes calldata' },
|
|
109
|
+
],
|
|
110
|
+
returns: ['bool'],
|
|
111
|
+
mutability: 'view',
|
|
112
|
+
},
|
|
113
|
+
}),
|
|
114
|
+
};
|
|
115
|
+
//# sourceMappingURL=signer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signer.js","sourceRoot":"","sources":["../src/signer.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"0.8.
|
|
1
|
+
"0.8.27"
|
package/dist/stablecoin.js
CHANGED
|
@@ -48,7 +48,7 @@ function addLimitations(c, access, mode) {
|
|
|
48
48
|
const type = mode === 'allowlist';
|
|
49
49
|
const ERC20Limitation = {
|
|
50
50
|
name: type ? 'ERC20Allowlist' : 'ERC20Blocklist',
|
|
51
|
-
path: `@openzeppelin/community-contracts/
|
|
51
|
+
path: `@openzeppelin/community-contracts/token/ERC20/extensions/${type ? 'ERC20Allowlist' : 'ERC20Blocklist'}.sol`,
|
|
52
52
|
};
|
|
53
53
|
c.addParent(ERC20Limitation);
|
|
54
54
|
c.addOverride(ERC20Limitation, functions._update);
|
|
@@ -64,7 +64,7 @@ function addLimitations(c, access, mode) {
|
|
|
64
64
|
function addCustodian(c, access) {
|
|
65
65
|
const ERC20Custodian = {
|
|
66
66
|
name: 'ERC20Custodian',
|
|
67
|
-
path: '@openzeppelin/community-contracts/
|
|
67
|
+
path: '@openzeppelin/community-contracts/token/ERC20/extensions/ERC20Custodian.sol',
|
|
68
68
|
};
|
|
69
69
|
c.addParent(ERC20Custodian);
|
|
70
70
|
c.addOverride(ERC20Custodian, functions._update);
|
package/dist/stablecoin.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stablecoin.js","sourceRoot":"","sources":["../src/stablecoin.ts"],"names":[],"mappings":";;;AAoCA,0CAEC;AAED,0DAEC;AAED,0CAiBC;AA3DD,6DAA8E;AAC9E,+DAA2D;AAC3D,mCAAwC;AAExC,mCAKiB;AAOJ,QAAA,QAAQ,GAAgC;IACnD,GAAG,gBAAa;IAChB,IAAI,EAAE,cAAc;IACpB,MAAM,EAAE,KAAK;IACb,WAAW,EAAE,KAAK;IAClB,SAAS,EAAE,KAAK;CACR,CAAC;AAEX,SAAS,YAAY,CAAC,IAAuB;;IAC3C,OAAO;QACL,GAAG,IAAA,oBAAiB,EAAC,IAAI,CAAC;QAC1B,IAAI,EAAE,MAAA,IAAI,CAAC,IAAI,mCAAI,gBAAQ,CAAC,IAAI;QAChC,MAAM,EAAE,MAAA,IAAI,CAAC,MAAM,mCAAI,gBAAQ,CAAC,MAAM;QACtC,WAAW,EAAE,MAAA,IAAI,CAAC,WAAW,mCAAI,gBAAQ,CAAC,WAAW;QACrD,SAAS,EAAE,MAAA,IAAI,CAAC,SAAS,mCAAI,gBAAQ,CAAC,SAAS;KAChD,CAAC;AACJ,CAAC;AAED,SAAgB,eAAe,CAAC,OAA0B,gBAAQ;IAChE,OAAO,IAAA,qBAAa,EAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC;AAC9C,CAAC;AAED,SAAgB,uBAAuB,CAAC,IAAgC;IACtE,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,KAAK,KAAK,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,KAAK,MAAM,CAAC;AACvH,CAAC;AAED,SAAgB,eAAe,CAAC,IAAuB;IACrD,MAAM,OAAO,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;IAEnC,kEAAkE;IAClE,OAAO,CAAC,WAAW,GAAG,KAAK,CAAC;IAE5B,MAAM,CAAC,GAAG,IAAA,kBAAU,EAAC,OAAO,CAAC,CAAC;IAE9B,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;QACtB,YAAY,CAAC,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAED,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;QACxB,cAAc,CAAC,CAAC,EAAE,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;IACzD,CAAC;IAED,OAAO,CAAC,CAAC;AACX,CAAC;AAED,SAAS,cAAc,CAAC,CAAkB,EAAE,MAAc,EAAE,IAAyC;IACnG,MAAM,IAAI,GAAG,IAAI,KAAK,WAAW,CAAC;IAClC,MAAM,eAAe,GAAG;QACtB,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,gBAAgB;QAChD,IAAI,EAAE,
|
|
1
|
+
{"version":3,"file":"stablecoin.js","sourceRoot":"","sources":["../src/stablecoin.ts"],"names":[],"mappings":"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"}
|
package/dist/test.js
CHANGED
|
@@ -22,6 +22,9 @@ test.serial('erc1155 result compiles', async (t) => {
|
|
|
22
22
|
test.serial('stablecoin result compiles', async (t) => {
|
|
23
23
|
await testCompile(t, 'Stablecoin');
|
|
24
24
|
});
|
|
25
|
+
test.serial('account result compiles', async (t) => {
|
|
26
|
+
await testCompile(t, 'Account');
|
|
27
|
+
});
|
|
25
28
|
test.serial('governor result compiles', async (t) => {
|
|
26
29
|
await testCompile(t, 'Governor');
|
|
27
30
|
});
|
|
@@ -53,6 +56,8 @@ function isAccessControlRequired(opts) {
|
|
|
53
56
|
return api_1.stablecoin.isAccessControlRequired(opts);
|
|
54
57
|
case 'RealWorldAsset':
|
|
55
58
|
return api_1.stablecoin.isAccessControlRequired(opts);
|
|
59
|
+
case 'Account':
|
|
60
|
+
throw new Error(`Not applicable for ${opts.kind}`);
|
|
56
61
|
case 'Governor':
|
|
57
62
|
return api_1.governor.isAccessControlRequired(opts);
|
|
58
63
|
case 'Custom':
|
|
@@ -64,12 +69,18 @@ function isAccessControlRequired(opts) {
|
|
|
64
69
|
test('is access control required', async (t) => {
|
|
65
70
|
for (const contract of (0, sources_1.generateSources)('all')) {
|
|
66
71
|
const regexOwnable = /import.*Ownable(Upgradeable)?.sol.*/gm;
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
72
|
+
switch (contract.options.kind) {
|
|
73
|
+
case 'Account':
|
|
74
|
+
break;
|
|
75
|
+
default: {
|
|
76
|
+
if (!contract.options.access) {
|
|
77
|
+
if (isAccessControlRequired(contract.options)) {
|
|
78
|
+
t.regex(contract.source, regexOwnable, JSON.stringify(contract.options));
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
t.notRegex(contract.source, regexOwnable, JSON.stringify(contract.options));
|
|
82
|
+
}
|
|
83
|
+
}
|
|
73
84
|
}
|
|
74
85
|
}
|
|
75
86
|
}
|
package/dist/test.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"test.js","sourceRoot":"","sources":["../src/test.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"test.js","sourceRoot":"","sources":["../src/test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export declare const UINT256_MAX: bigint;
|
|
2
|
+
/**
|
|
3
|
+
* Checks that a string is a valid `uint256` value and converts it to bigint.
|
|
4
|
+
*
|
|
5
|
+
* @param value The value to check.
|
|
6
|
+
* @param field The field name to use in the error if the value is invalid.
|
|
7
|
+
* @throws OptionsError if the value is not a valid number or is greater than the maximum value for `uint256`.
|
|
8
|
+
* @returns The value as a bigint.
|
|
9
|
+
*/
|
|
10
|
+
export declare function toUint256(value: string, field: string): bigint;
|
|
11
|
+
//# sourceMappingURL=convert-strings.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"convert-strings.d.ts","sourceRoot":"","sources":["../../src/utils/convert-strings.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,WAAW,QAAuC,CAAC;AAEhE;;;;;;;GAOG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,CAc9D"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UINT256_MAX = void 0;
|
|
4
|
+
exports.toUint256 = toUint256;
|
|
5
|
+
const error_1 = require("../error");
|
|
6
|
+
exports.UINT256_MAX = BigInt(2) ** BigInt(256) - BigInt(1);
|
|
7
|
+
/**
|
|
8
|
+
* Checks that a string is a valid `uint256` value and converts it to bigint.
|
|
9
|
+
*
|
|
10
|
+
* @param value The value to check.
|
|
11
|
+
* @param field The field name to use in the error if the value is invalid.
|
|
12
|
+
* @throws OptionsError if the value is not a valid number or is greater than the maximum value for `uint256`.
|
|
13
|
+
* @returns The value as a bigint.
|
|
14
|
+
*/
|
|
15
|
+
function toUint256(value, field) {
|
|
16
|
+
const isValidNumber = /^\d+$/.test(value);
|
|
17
|
+
if (!isValidNumber) {
|
|
18
|
+
throw new error_1.OptionsError({
|
|
19
|
+
[field]: 'Not a valid number',
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
const numValue = BigInt(value);
|
|
23
|
+
if (numValue > exports.UINT256_MAX) {
|
|
24
|
+
throw new error_1.OptionsError({
|
|
25
|
+
[field]: 'Value is greater than uint256 max value',
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
return numValue;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=convert-strings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"convert-strings.js","sourceRoot":"","sources":["../../src/utils/convert-strings.ts"],"names":[],"mappings":";;;AAYA,8BAcC;AA1BD,oCAAwC;AAE3B,QAAA,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAEhE;;;;;;;GAOG;AACH,SAAgB,SAAS,CAAC,KAAa,EAAE,KAAa;IACpD,MAAM,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1C,IAAI,CAAC,aAAa,EAAE,CAAC;QACnB,MAAM,IAAI,oBAAY,CAAC;YACrB,CAAC,KAAK,CAAC,EAAE,oBAAoB;SAC9B,CAAC,CAAC;IACL,CAAC;IACD,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAC/B,IAAI,QAAQ,GAAG,mBAAW,EAAE,CAAC;QAC3B,MAAM,IAAI,oBAAY,CAAC;YACrB,CAAC,KAAK,CAAC,EAAE,yCAAyC;SACnD,CAAC,CAAC;IACL,CAAC;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sanitize.d.ts","sourceRoot":"","sources":["../../src/utils/sanitize.ts"],"names":[],"mappings":"AAAA,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAKxD"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.stringifyUnicodeSafe = stringifyUnicodeSafe;
|
|
4
|
+
function stringifyUnicodeSafe(str) {
|
|
5
|
+
// eslint-disable-next-line no-control-regex
|
|
6
|
+
const containsUnicode = /[^\x00-\x7F]/.test(str);
|
|
7
|
+
return containsUnicode ? `unicode"${str.replace(/"/g, '\\"')}"` : JSON.stringify(str);
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=sanitize.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sanitize.js","sourceRoot":"","sources":["../../src/utils/sanitize.ts"],"names":[],"mappings":";;AAAA,oDAKC;AALD,SAAgB,oBAAoB,CAAC,GAAW;IAC9C,4CAA4C;IAC5C,MAAM,eAAe,GAAG,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAEjD,OAAO,eAAe,CAAC,CAAC,CAAC,WAAW,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;AACxF,CAAC"}
|
package/dist/zip-foundry.js
CHANGED
|
@@ -184,17 +184,17 @@ then
|
|
|
184
184
|
mv README.md README-oz.md
|
|
185
185
|
|
|
186
186
|
# Initialize sample Foundry project
|
|
187
|
-
forge init --force --
|
|
187
|
+
forge init --force --quiet
|
|
188
188
|
|
|
189
189
|
${c.upgradeable
|
|
190
190
|
? `\
|
|
191
191
|
# Install OpenZeppelin Contracts and Upgrades
|
|
192
|
-
forge install OpenZeppelin/openzeppelin-contracts-upgradeable@v${openzeppelin_contracts_1.default.version} --
|
|
193
|
-
forge install OpenZeppelin/openzeppelin-foundry-upgrades --
|
|
192
|
+
forge install OpenZeppelin/openzeppelin-contracts-upgradeable@v${openzeppelin_contracts_1.default.version} --quiet
|
|
193
|
+
forge install OpenZeppelin/openzeppelin-foundry-upgrades --quiet\
|
|
194
194
|
`
|
|
195
195
|
: `\
|
|
196
196
|
# Install OpenZeppelin Contracts
|
|
197
|
-
forge install OpenZeppelin/openzeppelin-contracts@v${openzeppelin_contracts_1.default.version} --
|
|
197
|
+
forge install OpenZeppelin/openzeppelin-contracts@v${openzeppelin_contracts_1.default.version} --quiet\
|
|
198
198
|
`}
|
|
199
199
|
|
|
200
200
|
# Remove unneeded Foundry template files
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@openzeppelin/wizard",
|
|
3
|
-
"version": "0.5.
|
|
3
|
+
"version": "0.5.5",
|
|
4
4
|
"description": "A boilerplate generator to get started with OpenZeppelin Contracts",
|
|
5
5
|
"license": "AGPL-3.0-only",
|
|
6
6
|
"repository": "https://github.com/OpenZeppelin/contracts-wizard",
|
|
@@ -19,17 +19,16 @@
|
|
|
19
19
|
"test": "ava",
|
|
20
20
|
"test:update-snapshots": "ava --update-snapshots",
|
|
21
21
|
"test:watch": "ava --watch",
|
|
22
|
-
"version": "node ../../../scripts/bump-changelog.js",
|
|
23
22
|
"update-env": "rm ./src/environments/hardhat/package-lock.json && npm install --package-lock-only --prefix ./src/environments/hardhat && rm ./src/environments/hardhat/upgradeable/package-lock.json && npm install --package-lock-only --prefix ./src/environments/hardhat/upgradeable"
|
|
24
23
|
},
|
|
25
24
|
"devDependencies": {
|
|
26
25
|
"@openzeppelin/community-contracts": "https://github.com/OpenZeppelin/openzeppelin-community-contracts",
|
|
27
|
-
"@openzeppelin/contracts": "^5.
|
|
28
|
-
"@openzeppelin/contracts-upgradeable": "^5.
|
|
29
|
-
"@types/node": "^
|
|
26
|
+
"@openzeppelin/contracts": "^5.3.0",
|
|
27
|
+
"@openzeppelin/contracts-upgradeable": "^5.3.0",
|
|
28
|
+
"@types/node": "^20.0.0",
|
|
30
29
|
"@types/semver": "^7.5.7",
|
|
31
30
|
"ava": "^6.0.0",
|
|
32
|
-
"hardhat": "^2.
|
|
31
|
+
"hardhat": "^2.22.11",
|
|
33
32
|
"jszip": "^3.6.0",
|
|
34
33
|
"rimraf": "^5.0.0",
|
|
35
34
|
"semver": "^7.6.0",
|
package/src/account.ts
ADDED
|
@@ -0,0 +1,292 @@
|
|
|
1
|
+
import { ContractBuilder } from './contract';
|
|
2
|
+
import type { Contract } from './contract';
|
|
3
|
+
import { defineFunctions } from './utils/define-functions';
|
|
4
|
+
import { printContract } from './print';
|
|
5
|
+
import { defaults as commonDefaults, withCommonDefaults, type CommonOptions } from './common-options';
|
|
6
|
+
import { setInfo } from './set-info';
|
|
7
|
+
import { addSigner, signerFunctions, signers, type SignerOptions } from './signer';
|
|
8
|
+
|
|
9
|
+
export const defaults: Required<AccountOptions> = {
|
|
10
|
+
...commonDefaults,
|
|
11
|
+
name: 'MyAccount',
|
|
12
|
+
signatureValidation: 'ERC7739',
|
|
13
|
+
ERC721Holder: true,
|
|
14
|
+
ERC1155Holder: true,
|
|
15
|
+
signer: 'ECDSA',
|
|
16
|
+
batchedExecution: false,
|
|
17
|
+
ERC7579Modules: false,
|
|
18
|
+
} as const;
|
|
19
|
+
|
|
20
|
+
export const SignatureValidationOptions = [false, 'ERC1271', 'ERC7739'] as const;
|
|
21
|
+
export type SignatureValidationOptions = (typeof SignatureValidationOptions)[number];
|
|
22
|
+
|
|
23
|
+
export const ERC7579ModulesOptions = [false, 'AccountERC7579', 'AccountERC7579Hooked'] as const;
|
|
24
|
+
export type ERC7579ModulesOptions = (typeof ERC7579ModulesOptions)[number];
|
|
25
|
+
|
|
26
|
+
export interface AccountOptions extends CommonOptions {
|
|
27
|
+
name: string;
|
|
28
|
+
signatureValidation?: SignatureValidationOptions;
|
|
29
|
+
ERC721Holder?: boolean;
|
|
30
|
+
ERC1155Holder?: boolean;
|
|
31
|
+
signer?: SignerOptions;
|
|
32
|
+
batchedExecution?: boolean;
|
|
33
|
+
ERC7579Modules?: ERC7579ModulesOptions;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
function withDefaults(opts: AccountOptions): Required<AccountOptions> {
|
|
37
|
+
return {
|
|
38
|
+
...withCommonDefaults(opts),
|
|
39
|
+
name: opts.name ?? defaults.name,
|
|
40
|
+
signatureValidation: opts.signatureValidation ?? defaults.signatureValidation,
|
|
41
|
+
ERC721Holder: opts.ERC721Holder ?? defaults.ERC721Holder,
|
|
42
|
+
ERC1155Holder: opts.ERC1155Holder ?? defaults.ERC1155Holder,
|
|
43
|
+
signer: opts.signer ?? defaults.signer,
|
|
44
|
+
batchedExecution: opts.batchedExecution ?? defaults.batchedExecution,
|
|
45
|
+
ERC7579Modules: opts.ERC7579Modules ?? defaults.ERC7579Modules,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
export function printAccount(opts: AccountOptions = defaults): string {
|
|
50
|
+
return printContract(buildAccount(opts));
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
export function buildAccount(opts: AccountOptions): Contract {
|
|
54
|
+
const allOpts = withDefaults(opts);
|
|
55
|
+
|
|
56
|
+
allOpts.upgradeable = false; // Upgradeability is not yet available for the community contracts
|
|
57
|
+
allOpts.access = false; // Access control options are not used for Account
|
|
58
|
+
|
|
59
|
+
const c = new ContractBuilder(allOpts.name);
|
|
60
|
+
|
|
61
|
+
addParents(c, allOpts);
|
|
62
|
+
overrideRawSignatureValidation(c, allOpts);
|
|
63
|
+
setInfo(c, allOpts.info);
|
|
64
|
+
|
|
65
|
+
if (opts.ERC7579Modules) {
|
|
66
|
+
c.addImportOnly({
|
|
67
|
+
name: 'PackedUserOperation',
|
|
68
|
+
path: '@openzeppelin/contracts/interfaces/draft-IERC4337.sol',
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
return c;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
function addParents(c: ContractBuilder, opts: AccountOptions): void {
|
|
76
|
+
// Base
|
|
77
|
+
c.addParent({
|
|
78
|
+
name: 'Account',
|
|
79
|
+
path: `@openzeppelin/community-contracts/account/Account.sol`,
|
|
80
|
+
});
|
|
81
|
+
c.addOverride({ name: 'Account' }, functions._validateUserOp);
|
|
82
|
+
|
|
83
|
+
if (opts.signatureValidation === 'ERC7739') addEIP712(c, opts);
|
|
84
|
+
|
|
85
|
+
// Extensions
|
|
86
|
+
addSignatureValidation(c, opts);
|
|
87
|
+
addERC7579Modules(c, opts);
|
|
88
|
+
addSigner(c, opts.signer ?? false);
|
|
89
|
+
addMultisigFunctions(c, opts);
|
|
90
|
+
addBatchedExecution(c, opts);
|
|
91
|
+
addERC721Holder(c, opts);
|
|
92
|
+
addERC1155Holder(c, opts);
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
function addSignatureValidation(c: ContractBuilder, opts: AccountOptions) {
|
|
96
|
+
switch (opts.signatureValidation) {
|
|
97
|
+
case 'ERC7739':
|
|
98
|
+
c.addParent({
|
|
99
|
+
name: 'ERC7739',
|
|
100
|
+
path: '@openzeppelin/community-contracts/utils/cryptography/ERC7739.sol',
|
|
101
|
+
});
|
|
102
|
+
break;
|
|
103
|
+
case 'ERC1271':
|
|
104
|
+
c.addParent({
|
|
105
|
+
name: 'IERC1271',
|
|
106
|
+
path: '@openzeppelin/contracts/interfaces/IERC1271.sol',
|
|
107
|
+
});
|
|
108
|
+
c.addOverride({ name: 'IERC1271' }, functions.isValidSignature);
|
|
109
|
+
if (!opts.ERC7579Modules) {
|
|
110
|
+
c.setFunctionBody(
|
|
111
|
+
[
|
|
112
|
+
'return _rawSignatureValidation(hash, signature) ? IERC1271.isValidSignature.selector : bytes4(0xffffffff);',
|
|
113
|
+
],
|
|
114
|
+
functions.isValidSignature,
|
|
115
|
+
);
|
|
116
|
+
}
|
|
117
|
+
break;
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
function addERC721Holder(c: ContractBuilder, opts: AccountOptions): void {
|
|
122
|
+
if (!opts.ERC721Holder) return;
|
|
123
|
+
c.addParent({
|
|
124
|
+
name: 'ERC721Holder',
|
|
125
|
+
path: '@openzeppelin/contracts/token/ERC721/utils/ERC721Holder.sol',
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
function addERC1155Holder(c: ContractBuilder, opts: AccountOptions): void {
|
|
130
|
+
if (!opts.ERC1155Holder) return;
|
|
131
|
+
c.addParent({
|
|
132
|
+
name: 'ERC1155Holder',
|
|
133
|
+
path: '@openzeppelin/contracts/token/ERC1155/utils/ERC1155Holder.sol',
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
function addBatchedExecution(c: ContractBuilder, opts: AccountOptions): void {
|
|
138
|
+
// ERC-7579 is a superset of ERC-7821
|
|
139
|
+
if (!opts.batchedExecution || !!opts.ERC7579Modules) return;
|
|
140
|
+
c.addParent({
|
|
141
|
+
name: 'ERC7821',
|
|
142
|
+
path: '@openzeppelin/community-contracts/account/extensions/ERC7821.sol',
|
|
143
|
+
});
|
|
144
|
+
c.addOverride({ name: 'ERC7821' }, functions._erc7821AuthorizedExecutor);
|
|
145
|
+
c.setFunctionBody(
|
|
146
|
+
['return caller == address(entryPoint()) || super._erc7821AuthorizedExecutor(caller, mode, executionData);'],
|
|
147
|
+
functions._erc7821AuthorizedExecutor,
|
|
148
|
+
);
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
function addERC7579Modules(c: ContractBuilder, opts: AccountOptions): void {
|
|
152
|
+
if (!opts.ERC7579Modules) return;
|
|
153
|
+
c.addParent({
|
|
154
|
+
name: opts.ERC7579Modules,
|
|
155
|
+
path: `@openzeppelin/community-contracts/account/extensions/${opts.ERC7579Modules}.sol`,
|
|
156
|
+
});
|
|
157
|
+
if (opts.ERC7579Modules !== 'AccountERC7579') {
|
|
158
|
+
c.addImportOnly({
|
|
159
|
+
name: 'AccountERC7579',
|
|
160
|
+
path: `@openzeppelin/community-contracts/account/extensions/AccountERC7579.sol`,
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
c.addOverride({ name: 'AccountERC7579' }, functions.isValidSignature);
|
|
164
|
+
c.addOverride({ name: 'AccountERC7579' }, functions._validateUserOp);
|
|
165
|
+
|
|
166
|
+
if (opts.signatureValidation !== 'ERC7739') return;
|
|
167
|
+
c.addOverride({ name: 'ERC7739' }, functions.isValidSignature);
|
|
168
|
+
c.setFunctionBody(
|
|
169
|
+
[
|
|
170
|
+
'// ERC-7739 can return the ERC-1271 magic value, 0xffffffff (invalid) or 0x77390001 (detection).',
|
|
171
|
+
'// If the returned value is 0xffffffff, fallback to ERC-7579 validation.',
|
|
172
|
+
'bytes4 erc7739magic = ERC7739.isValidSignature(hash, signature);',
|
|
173
|
+
'return erc7739magic == bytes4(0xffffffff) ? AccountERC7579.isValidSignature(hash, signature) : erc7739magic;',
|
|
174
|
+
],
|
|
175
|
+
functions.isValidSignature,
|
|
176
|
+
);
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
function addMultisigFunctions(c: ContractBuilder, opts: AccountOptions): void {
|
|
180
|
+
switch (opts.signer) {
|
|
181
|
+
case 'MultisigWeighted':
|
|
182
|
+
c.addFunctionCode(
|
|
183
|
+
`_setSignerWeights(${functions.setSignerWeights.args.map(({ name }) => name).join(', ')});`,
|
|
184
|
+
functions.setSignerWeights,
|
|
185
|
+
);
|
|
186
|
+
// eslint-disable-next-line no-fallthrough
|
|
187
|
+
case 'Multisig':
|
|
188
|
+
c.addFunctionCode(`_addSigners(${functions.addSigners.args[0]!.name});`, functions.addSigners);
|
|
189
|
+
c.addFunctionCode(`_removeSigners(${functions.removeSigners.args[0]!.name});`, functions.removeSigners);
|
|
190
|
+
c.addFunctionCode(`_setThreshold(${functions.setThreshold.args[0]!.name});`, functions.setThreshold);
|
|
191
|
+
break;
|
|
192
|
+
default:
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
function addEIP712(c: ContractBuilder, opts: AccountOptions): void {
|
|
197
|
+
if (opts.signatureValidation != 'ERC7739') return;
|
|
198
|
+
c.addParent(
|
|
199
|
+
{
|
|
200
|
+
name: 'EIP712',
|
|
201
|
+
path: '@openzeppelin/contracts/utils/cryptography/EIP712.sol',
|
|
202
|
+
},
|
|
203
|
+
[opts.name, '1'],
|
|
204
|
+
);
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
function overrideRawSignatureValidation(c: ContractBuilder, opts: AccountOptions): void {
|
|
208
|
+
if (opts.signer && !opts.ERC7579Modules) return; // Signer implements _rawSignatureValidation alone
|
|
209
|
+
if (!opts.signer && opts.ERC7579Modules) return; // AccountERC7579 implements _rawSignatureValidation alone
|
|
210
|
+
|
|
211
|
+
// If no signer or ERC-7579 is used, we need to override the _rawSignatureValidation function
|
|
212
|
+
// to provide a custom validation logic
|
|
213
|
+
if (!opts.signer && !opts.ERC7579Modules) {
|
|
214
|
+
// Custom validation logic
|
|
215
|
+
c.addOverride({ name: 'Account' }, signerFunctions._rawSignatureValidation);
|
|
216
|
+
c.setFunctionBody(['// Custom validation logic', 'return false;'], signerFunctions._rawSignatureValidation);
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
// Dissambiguate between Signer and AccountERC7579
|
|
220
|
+
if (opts.signer && opts.ERC7579Modules) {
|
|
221
|
+
c.addImportOnly({
|
|
222
|
+
name: 'AbstractSigner',
|
|
223
|
+
path: '@openzeppelin/community-contracts/utils/cryptography/AbstractSigner.sol',
|
|
224
|
+
});
|
|
225
|
+
c.addOverride({ name: 'AbstractSigner' }, signerFunctions._rawSignatureValidation);
|
|
226
|
+
c.addOverride({ name: 'AccountERC7579' }, signerFunctions._rawSignatureValidation);
|
|
227
|
+
c.setFunctionComments(
|
|
228
|
+
[
|
|
229
|
+
`// IMPORTANT: Make sure Signer${opts.signer} is most derived than AccountERC7579`,
|
|
230
|
+
`// in the inheritance chain (i.e. contract ... is AccountERC7579, ..., Signer${opts.signer})`,
|
|
231
|
+
'// to ensure the correct order of function resolution.',
|
|
232
|
+
'// AccountERC7579 returns false for `_rawSignatureValidation`',
|
|
233
|
+
],
|
|
234
|
+
signerFunctions._rawSignatureValidation,
|
|
235
|
+
);
|
|
236
|
+
// Base override for `_rawSignatureValidation` given MultiSignerERC7913Weighted is MultiSignerERC7913
|
|
237
|
+
if (opts.signer === 'MultisigWeighted') {
|
|
238
|
+
c.addImportOnly(signers.Multisig);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
|
|
243
|
+
const functions = {
|
|
244
|
+
...defineFunctions({
|
|
245
|
+
isValidSignature: {
|
|
246
|
+
kind: 'public' as const,
|
|
247
|
+
mutability: 'view' as const,
|
|
248
|
+
args: [
|
|
249
|
+
{ name: 'hash', type: 'bytes32' },
|
|
250
|
+
{ name: 'signature', type: 'bytes calldata' },
|
|
251
|
+
],
|
|
252
|
+
returns: ['bytes4'],
|
|
253
|
+
},
|
|
254
|
+
_validateUserOp: {
|
|
255
|
+
kind: 'internal' as const,
|
|
256
|
+
args: [
|
|
257
|
+
{ name: 'userOp', type: 'PackedUserOperation calldata' },
|
|
258
|
+
{ name: 'userOpHash', type: 'bytes32' },
|
|
259
|
+
],
|
|
260
|
+
returns: ['uint256'],
|
|
261
|
+
},
|
|
262
|
+
_erc7821AuthorizedExecutor: {
|
|
263
|
+
kind: 'internal' as const,
|
|
264
|
+
args: [
|
|
265
|
+
{ name: 'caller', type: 'address' },
|
|
266
|
+
{ name: 'mode', type: 'bytes32' },
|
|
267
|
+
{ name: 'executionData', type: 'bytes calldata' },
|
|
268
|
+
],
|
|
269
|
+
returns: ['bool'],
|
|
270
|
+
mutability: 'view' as const,
|
|
271
|
+
},
|
|
272
|
+
addSigners: {
|
|
273
|
+
kind: 'public' as const,
|
|
274
|
+
args: [{ name: 'signers', type: 'bytes[] memory' }],
|
|
275
|
+
},
|
|
276
|
+
removeSigners: {
|
|
277
|
+
kind: 'public' as const,
|
|
278
|
+
args: [{ name: 'signers', type: 'bytes[] memory' }],
|
|
279
|
+
},
|
|
280
|
+
setThreshold: {
|
|
281
|
+
kind: 'public' as const,
|
|
282
|
+
args: [{ name: 'threshold', type: 'uint256' }],
|
|
283
|
+
},
|
|
284
|
+
setSignerWeights: {
|
|
285
|
+
kind: 'public' as const,
|
|
286
|
+
args: [
|
|
287
|
+
{ name: 'signers', type: 'bytes[] memory' },
|
|
288
|
+
{ name: 'weights', type: 'uint256[] memory' },
|
|
289
|
+
],
|
|
290
|
+
},
|
|
291
|
+
}),
|
|
292
|
+
};
|