@skalenetwork/upgrade-tools 4.0.0-update-gnosis-service.0 → 4.0.0-update-gnosis-service.1
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/dist/src/contractVerifier.d.ts +1 -0
- package/dist/src/contractVerifier.js.map +1 -1
- package/dist/src/gnosis-safe.js +1 -1
- package/dist/src/gnosis-safe.js.map +1 -1
- package/dist/src/index.d.ts +1 -0
- package/dist/src/index.js +1 -0
- package/dist/src/index.js.map +1 -1
- package/dist/src/ownership-transfer/constants.d.ts +8 -0
- package/dist/src/ownership-transfer/constants.js +33 -0
- package/dist/src/ownership-transfer/constants.js.map +1 -0
- package/dist/src/ownership-transfer/contractAdmin.d.ts +55 -0
- package/dist/src/ownership-transfer/contractAdmin.js +206 -0
- package/dist/src/ownership-transfer/contractAdmin.js.map +1 -0
- package/dist/src/ownership-transfer/instanceAdmin.d.ts +51 -0
- package/dist/src/ownership-transfer/instanceAdmin.js +223 -0
- package/dist/src/ownership-transfer/instanceAdmin.js.map +1 -0
- package/dist/src/ownership-transfer/permission-utils.d.ts +32 -0
- package/dist/src/ownership-transfer/permission-utils.js +192 -0
- package/dist/src/ownership-transfer/permission-utils.js.map +1 -0
- package/dist/src/ownership-transfer/utils.d.ts +19 -0
- package/dist/src/ownership-transfer/utils.js +201 -0
- package/dist/src/ownership-transfer/utils.js.map +1 -0
- package/dist/src/verification.d.ts +1 -1
- package/dist/src/verification.js +2 -1
- package/dist/src/verification.js.map +1 -1
- package/dist/src/verifiers/blockscoutVerifier.js +4 -0
- package/dist/src/verifiers/blockscoutVerifier.js.map +1 -1
- package/dist/src/verifiers/etherscanVerifier.js +1 -1
- package/dist/src/verifiers/etherscanVerifier.js.map +1 -1
- package/dist/src/verifiers/skaleBlockscoutVerifier.js +2 -2
- package/dist/src/verifiers/skaleBlockscoutVerifier.js.map +1 -1
- package/package.json +2 -2
|
@@ -2,6 +2,7 @@ import { ValidationResponse } from "@nomicfoundation/hardhat-verify/internal/uti
|
|
|
2
2
|
export interface VerificationTarget {
|
|
3
3
|
contractName: string;
|
|
4
4
|
contractAddress: string;
|
|
5
|
+
constructorArguments?: string;
|
|
5
6
|
}
|
|
6
7
|
export interface VerificationRequestParameters {
|
|
7
8
|
solcInputJson: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contractVerifier.js","sourceRoot":"","sources":["../../src/contractVerifier.ts"],"names":[],"mappings":";;;;;;AACA,qCAAkC;AAClC,kDAA0B;AAC1B,2NACsJ;AACtJ,kHAAsF;AAEtF,MAAM,sBAAsB,GAAG,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"contractVerifier.js","sourceRoot":"","sources":["../../src/contractVerifier.ts"],"names":[],"mappings":"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"}
|
package/dist/src/gnosis-safe.js
CHANGED
|
@@ -48,7 +48,7 @@ const getSafeService = (chainId) => {
|
|
|
48
48
|
const safeService = new api_kit_1.default({
|
|
49
49
|
apiKey: process.env.GNOSIS_API_KEY,
|
|
50
50
|
chainId,
|
|
51
|
-
// Does not need the URL
|
|
51
|
+
// Does not need the URL - chainId is enough
|
|
52
52
|
});
|
|
53
53
|
return safeService;
|
|
54
54
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"gnosis-safe.js","sourceRoot":"","sources":["../../src/gnosis-safe.ts"],"names":[],"mappings":";;;;;;AAAA,0EAI0C;AAC1C,qCAAwC;AACxC,6EAA6C;AAC7C,mEAA8C;AAG9C,kDAAkD;AAElD,MAAM,cAAc,GAAG;IAEnB;;;OAGG;IACH,SAAS,EAAE,GAAG;IAEd,4CAA4C;IAC5C,UAAU,EAAE,GAAG;IAEf;;;;OAIG;IACH,UAAU,EAAE,gBAAM,CAAC,WAAW;IAE9B,8DAA8D;IAC9D,gBAAgB,EAAE,gBAAM,CAAC,WAAW;IAEpC,oCAAoC;IACpC,WAAW,EAAE,GAAG;CACnB,CAAC;AAEF,oBAAoB;AAEpB,MAAM,sBAAsB,GAAG,CAAC,YAA2B,EAAE,EAAE;IAC3D,MAAM,mBAAmB,GAA0B,EAAE,CAAC;IACtD,KAAK,MAAM,WAAW,IAAI,YAAY,EAAE,CAAC;QACrC,mBAAmB,CAAC,IAAI,CAAC;YACrB,MAAM,EAAE,WAAW,CAAC,IAAI;YACxB,WAAW,EAAE,mCAAa,CAAC,IAAI;YAC/B,IAAI,EAAE,WAAW,CAAC,EAAE,IAAI,gBAAM,CAAC,WAAW;YAC1C,OAAO,EAAE,WAAW,CAAC,KAAK,CAAC,QAAQ,EAAE;SACxC,CAAC,CAAC;IACP,CAAC;IACD,OAAO,mBAAmB,CAAC;AAC/B,CAAC,CAAC;AAEF,MAAM,cAAc,GAAG,CAAC,OAAe,EAAE,EAAE;IACvC,IAAG,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,CAAC;QAC7B,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;IACjD,CAAC;IACD,MAAM,WAAW,GAAG,IAAI,iBAAU,CAAC;QAC/B,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,cAAc;QAClC,OAAO;QACP,
|
|
1
|
+
{"version":3,"file":"gnosis-safe.js","sourceRoot":"","sources":["../../src/gnosis-safe.ts"],"names":[],"mappings":"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"}
|
package/dist/src/index.d.ts
CHANGED
package/dist/src/index.js
CHANGED
|
@@ -24,4 +24,5 @@ __exportStar(require("./version"), exports);
|
|
|
24
24
|
__exportStar(require("./upgrader"), exports);
|
|
25
25
|
__exportStar(require("./upgraders/abstractTransparentProxyUpgrader"), exports);
|
|
26
26
|
__exportStar(require("./upgraders/beaconUpgrader"), exports);
|
|
27
|
+
__exportStar(require("./ownership-transfer/instanceAdmin"), exports);
|
|
27
28
|
//# sourceMappingURL=index.js.map
|
package/dist/src/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wCAAsB;AACtB,2CAAyB;AACzB,gDAA8B;AAC9B,kDAAgC;AAChC,+CAA6B;AAC7B,iDAA+B;AAC/B,4CAA0B;AAC1B,6CAA2B;AAC3B,+EAA6D;AAC7D,6DAA0C"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wCAAsB;AACtB,2CAAyB;AACzB,gDAA8B;AAC9B,kDAAgC;AAChC,+CAA6B;AAC7B,iDAA+B;AAC/B,4CAA0B;AAC1B,6CAA2B;AAC3B,+EAA6D;AAC7D,6DAA0C;AAC1C,qEAAmD"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export declare const ERC1967_ADMIN_SLOT = "0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103";
|
|
2
|
+
export declare const ERC1967_IMPLEMENTATION_SLOT = "0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc";
|
|
3
|
+
export declare const UPGRADEABLE_BEACON_ABI: string[];
|
|
4
|
+
export declare const OWNABLE_ABI: string[];
|
|
5
|
+
export declare const ACCESS_CONTROL_ABI: string[];
|
|
6
|
+
export declare const ACCESS_MANAGER_ABI: string[];
|
|
7
|
+
export declare const ACCESS_MANAGED_ABI: string[];
|
|
8
|
+
export declare const MULTISIG_ABI: string[];
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MULTISIG_ABI = exports.ACCESS_MANAGED_ABI = exports.ACCESS_MANAGER_ABI = exports.ACCESS_CONTROL_ABI = exports.OWNABLE_ABI = exports.UPGRADEABLE_BEACON_ABI = exports.ERC1967_IMPLEMENTATION_SLOT = exports.ERC1967_ADMIN_SLOT = void 0;
|
|
4
|
+
exports.ERC1967_ADMIN_SLOT = "0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103";
|
|
5
|
+
exports.ERC1967_IMPLEMENTATION_SLOT = "0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc";
|
|
6
|
+
exports.UPGRADEABLE_BEACON_ABI = [
|
|
7
|
+
"function owner() view returns (address)",
|
|
8
|
+
"function implementation() view returns (address)",
|
|
9
|
+
"function upgradeTo(address newImplementation)"
|
|
10
|
+
];
|
|
11
|
+
exports.OWNABLE_ABI = [
|
|
12
|
+
"function transferOwnership(address newOwner)",
|
|
13
|
+
"function owner() view returns (address)"
|
|
14
|
+
];
|
|
15
|
+
exports.ACCESS_CONTROL_ABI = [
|
|
16
|
+
"function hasRole(bytes32 role, address account) view returns (bool)",
|
|
17
|
+
"function grantRole(bytes32 role, address account)",
|
|
18
|
+
"function renounceRole(bytes32 role, address account)",
|
|
19
|
+
"function getRoleMemberCount(bytes32 role) view returns (uint256)"
|
|
20
|
+
];
|
|
21
|
+
exports.ACCESS_MANAGER_ABI = [
|
|
22
|
+
"function hasRole(uint64 role, address account) view returns (bool)",
|
|
23
|
+
"function grantRole(uint64 role, address account, uint32 executionDelay)",
|
|
24
|
+
"function renounceRole(uint64 role, address account)"
|
|
25
|
+
];
|
|
26
|
+
exports.ACCESS_MANAGED_ABI = [
|
|
27
|
+
"function authority() view returns (address)"
|
|
28
|
+
];
|
|
29
|
+
exports.MULTISIG_ABI = [
|
|
30
|
+
"function getOwners() view returns (address[])",
|
|
31
|
+
"function getThreshold() view returns (uint256)"
|
|
32
|
+
];
|
|
33
|
+
//# sourceMappingURL=constants.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../src/ownership-transfer/constants.ts"],"names":[],"mappings":";;;AAEa,QAAA,kBAAkB,GAAG,oEAAoE,CAAC;AAC1F,QAAA,2BAA2B,GAAG,oEAAoE,CAAC;AAGnG,QAAA,sBAAsB,GAAG;IAClC,yCAAyC;IACzC,kDAAkD;IAClD,+CAA+C;CAClD,CAAC;AAEW,QAAA,WAAW,GAAG;IACvB,8CAA8C;IAC9C,yCAAyC;CAC5C,CAAC;AAEW,QAAA,kBAAkB,GAAG;IAC9B,qEAAqE;IACrE,mDAAmD;IACnD,sDAAsD;IACtD,kEAAkE;CACrE,CAAC;AAEW,QAAA,kBAAkB,GAAG;IAC9B,oEAAoE;IACpE,yEAAyE;IACzE,qDAAqD;CACxD,CAAC;AAEW,QAAA,kBAAkB,GAAG;IAC9B,6CAA6C;CAChD,CAAC;AAEW,QAAA,YAAY,GAAG;IACxB,+CAA+C;IAC/C,gDAAgD;CACnD,CAAC"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Pattern } from "./utils";
|
|
2
|
+
import { PermissionModel } from "./permission-utils";
|
|
3
|
+
import { Transaction } from "ethers";
|
|
4
|
+
export interface BytesRole {
|
|
5
|
+
name: string;
|
|
6
|
+
identifier: string;
|
|
7
|
+
}
|
|
8
|
+
export interface UintRole {
|
|
9
|
+
name: string;
|
|
10
|
+
identifier: bigint;
|
|
11
|
+
}
|
|
12
|
+
export interface ContractMetadataDetails {
|
|
13
|
+
name: string;
|
|
14
|
+
address: string;
|
|
15
|
+
pattern?: Pattern;
|
|
16
|
+
permissionModel?: PermissionModel[];
|
|
17
|
+
}
|
|
18
|
+
export interface TransactionData {
|
|
19
|
+
transaction: Transaction;
|
|
20
|
+
description?: string;
|
|
21
|
+
}
|
|
22
|
+
export declare class ContractAdmin {
|
|
23
|
+
contractName: string;
|
|
24
|
+
pattern?: Pattern;
|
|
25
|
+
address: string;
|
|
26
|
+
permissionModel: PermissionModel[];
|
|
27
|
+
private oldOwner;
|
|
28
|
+
private newOwner;
|
|
29
|
+
private grantOwnershipRoleTxs;
|
|
30
|
+
private renounceOwnershipTxs;
|
|
31
|
+
constructor(details: ContractMetadataDetails, oldOwner: string, newOwner: string);
|
|
32
|
+
scanPatternAndPermissionModels(): Promise<void>;
|
|
33
|
+
createGrantOwnershipTransactions(bytes32RolesToCheck: BytesRole[], managerRolesToCheck: UintRole[]): Promise<void>;
|
|
34
|
+
createRenounceOwnershipTransactions(bytes32RolesToCheck: BytesRole[], managerRolesToCheck: UintRole[]): Promise<void>;
|
|
35
|
+
getGrantOwnershipTransactions(): TransactionData[];
|
|
36
|
+
getRenounceOwnershipTransactions(): TransactionData[];
|
|
37
|
+
clearRenounceTransactions(): void;
|
|
38
|
+
clearGrantTransactions(): void;
|
|
39
|
+
requiresGrantingOwnership(): boolean;
|
|
40
|
+
requiresRenouncingOwnership(): boolean;
|
|
41
|
+
displayData(columnWidths: {
|
|
42
|
+
maxNameWidth: number;
|
|
43
|
+
maxAddressWidth: number;
|
|
44
|
+
maxPermissionsWidth: number;
|
|
45
|
+
}): void;
|
|
46
|
+
private checkFindings;
|
|
47
|
+
private createTUPPGrantOwnershipTransaction;
|
|
48
|
+
private createOwnableOwnershipTransaction;
|
|
49
|
+
private createAssignUint64RolesTransactions;
|
|
50
|
+
private handleRenounceOwnershipTransaction;
|
|
51
|
+
private createRenounceUint64RolesTransactions;
|
|
52
|
+
private createAssignBytes32RolesTransactions;
|
|
53
|
+
private createRenounceBytes32RolesTransactions;
|
|
54
|
+
private isDuplicateTransaction;
|
|
55
|
+
}
|
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.ContractAdmin = void 0;
|
|
7
|
+
// Cspell:words TUPP
|
|
8
|
+
const utils_1 = require("./utils");
|
|
9
|
+
const permission_utils_1 = require("./permission-utils");
|
|
10
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
11
|
+
class ContractAdmin {
|
|
12
|
+
constructor(details, oldOwner, newOwner) {
|
|
13
|
+
this.permissionModel = [];
|
|
14
|
+
this.grantOwnershipRoleTxs = [];
|
|
15
|
+
this.renounceOwnershipTxs = [];
|
|
16
|
+
this.contractName = details.name;
|
|
17
|
+
this.pattern = details.pattern;
|
|
18
|
+
this.address = details.address;
|
|
19
|
+
this.permissionModel = details.permissionModel ?? [];
|
|
20
|
+
this.oldOwner = oldOwner;
|
|
21
|
+
this.newOwner = newOwner;
|
|
22
|
+
// Validate manual inputs if any
|
|
23
|
+
this.checkFindings();
|
|
24
|
+
}
|
|
25
|
+
async scanPatternAndPermissionModels() {
|
|
26
|
+
if (!this.pattern || !this.permissionModel.length) {
|
|
27
|
+
this.pattern = await (0, utils_1.detectPattern)(this.address);
|
|
28
|
+
this.permissionModel = await (0, permission_utils_1.getPermissionModels)(this.address);
|
|
29
|
+
this.checkFindings();
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
async createGrantOwnershipTransactions(bytes32RolesToCheck, managerRolesToCheck) {
|
|
33
|
+
this.clearGrantTransactions();
|
|
34
|
+
console.log(chalk_1.default.white(`* Creating Transactions to grant Ownership in ${this.contractName}.`));
|
|
35
|
+
if (this.pattern === utils_1.Pattern.TUPP) {
|
|
36
|
+
await this.createTUPPGrantOwnershipTransaction();
|
|
37
|
+
}
|
|
38
|
+
// UpgradeableBeacon is detected also as OWNABLE
|
|
39
|
+
if (this.permissionModel.includes(permission_utils_1.PermissionModel.OWNABLE)) {
|
|
40
|
+
await this.createOwnableOwnershipTransaction();
|
|
41
|
+
}
|
|
42
|
+
if (this.permissionModel.includes(permission_utils_1.PermissionModel.ROLE_BASED)) {
|
|
43
|
+
await this.createAssignBytes32RolesTransactions(bytes32RolesToCheck);
|
|
44
|
+
}
|
|
45
|
+
if (this.permissionModel.includes(permission_utils_1.PermissionModel.ACCESS_MANAGER)) {
|
|
46
|
+
await this.createAssignUint64RolesTransactions(managerRolesToCheck);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
async createRenounceOwnershipTransactions(bytes32RolesToCheck, managerRolesToCheck) {
|
|
50
|
+
this.clearRenounceTransactions();
|
|
51
|
+
console.log(chalk_1.default.white(`* Creating Transactions to renounce Ownership in ${this.contractName}.`));
|
|
52
|
+
if (this.permissionModel.includes(permission_utils_1.PermissionModel.ROLE_BASED)) {
|
|
53
|
+
await this.createRenounceBytes32RolesTransactions(bytes32RolesToCheck);
|
|
54
|
+
}
|
|
55
|
+
if (this.permissionModel.includes(permission_utils_1.PermissionModel.ACCESS_MANAGER)) {
|
|
56
|
+
await this.createRenounceUint64RolesTransactions(managerRolesToCheck);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
getGrantOwnershipTransactions() {
|
|
60
|
+
return this.grantOwnershipRoleTxs;
|
|
61
|
+
}
|
|
62
|
+
getRenounceOwnershipTransactions() {
|
|
63
|
+
return this.renounceOwnershipTxs;
|
|
64
|
+
}
|
|
65
|
+
clearRenounceTransactions() {
|
|
66
|
+
this.renounceOwnershipTxs = [];
|
|
67
|
+
}
|
|
68
|
+
clearGrantTransactions() {
|
|
69
|
+
this.grantOwnershipRoleTxs = [];
|
|
70
|
+
}
|
|
71
|
+
requiresGrantingOwnership() {
|
|
72
|
+
return Boolean(this.grantOwnershipRoleTxs.length);
|
|
73
|
+
}
|
|
74
|
+
requiresRenouncingOwnership() {
|
|
75
|
+
return Boolean(this.renounceOwnershipTxs.length);
|
|
76
|
+
}
|
|
77
|
+
displayData(columnWidths) {
|
|
78
|
+
const { maxNameWidth, maxAddressWidth, maxPermissionsWidth } = columnWidths;
|
|
79
|
+
const name = this.contractName.padEnd(maxNameWidth);
|
|
80
|
+
const address = this.address.padEnd(maxAddressWidth);
|
|
81
|
+
const permissions = (this.permissionModel?.join(", ") || "None").padEnd(maxPermissionsWidth);
|
|
82
|
+
let status = chalk_1.default.green("ALL DONE");
|
|
83
|
+
if (this.grantOwnershipRoleTxs.length) {
|
|
84
|
+
status = chalk_1.default.yellow("GRANT OWNERSHIP REQUIRED");
|
|
85
|
+
}
|
|
86
|
+
else if (this.renounceOwnershipTxs.length) {
|
|
87
|
+
status = chalk_1.default.yellow("REVOKE ROLES REQUIRED");
|
|
88
|
+
}
|
|
89
|
+
console.log(chalk_1.default.gray(` ${name} ${address} ${permissions} `) + status);
|
|
90
|
+
}
|
|
91
|
+
checkFindings() {
|
|
92
|
+
const maxPermissionsIfBeacon = 1;
|
|
93
|
+
if (this.pattern === utils_1.Pattern.BEACON &&
|
|
94
|
+
!this.permissionModel?.includes(permission_utils_1.PermissionModel.OWNABLE) &&
|
|
95
|
+
this.permissionModel?.length !== maxPermissionsIfBeacon) {
|
|
96
|
+
throw new Error(`UpgradeableBeacon at address ${this.address} should ONLY have OWNABLE permission model.`);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
async createTUPPGrantOwnershipTransaction() {
|
|
100
|
+
const admin = await (0, utils_1.getAdminAddress)(this.address);
|
|
101
|
+
await this.createOwnableOwnershipTransaction({ address: admin, name: `${this.contractName} Proxy Admin` });
|
|
102
|
+
}
|
|
103
|
+
async createOwnableOwnershipTransaction(contractId = { address: this.address, name: this.contractName }) {
|
|
104
|
+
const tx = await (0, permission_utils_1.transferOwnership)(contractId.address, this.newOwner, this.oldOwner);
|
|
105
|
+
if (tx) {
|
|
106
|
+
if (this.isDuplicateTransaction({ transaction: tx })) {
|
|
107
|
+
throw new Error(`Error: Duplicate transaction to transfer ownership of ${contractId.name} at ${contractId.address} was already created.`);
|
|
108
|
+
}
|
|
109
|
+
const description = `-> Tx to change ${contractId.name} Owner at ${contractId.address} to ${this.newOwner}`;
|
|
110
|
+
console.log(chalk_1.default.yellow(` ${description} created.`));
|
|
111
|
+
this.grantOwnershipRoleTxs.push({
|
|
112
|
+
description,
|
|
113
|
+
transaction: tx
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
async createAssignUint64RolesTransactions(managerRolesToCheck) {
|
|
118
|
+
for (const role of managerRolesToCheck) {
|
|
119
|
+
// Required to process sequentially as it access shared memory state and RPC rate limits
|
|
120
|
+
// eslint-disable-next-line no-await-in-loop
|
|
121
|
+
const tx = await (0, permission_utils_1.grantAccessManagerRole)({
|
|
122
|
+
contractAddress: this.address,
|
|
123
|
+
newAccount: this.newOwner,
|
|
124
|
+
oldAccount: this.oldOwner,
|
|
125
|
+
role: role.identifier,
|
|
126
|
+
});
|
|
127
|
+
if (tx) {
|
|
128
|
+
if (this.isDuplicateTransaction({ transaction: tx })) {
|
|
129
|
+
throw new Error(`Error: Transaction to grant manager role ${role.name} in ${this.contractName} was already created.`);
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
const description = `-> Tx to grant role ${role.name} to ${this.newOwner} in ${this.contractName}`;
|
|
133
|
+
console.log(chalk_1.default.yellow(` ${description} created.`));
|
|
134
|
+
this.grantOwnershipRoleTxs.push({ description, transaction: tx });
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
handleRenounceOwnershipTransaction(tx, roleName) {
|
|
140
|
+
if (typeof tx !== "boolean" && tx) {
|
|
141
|
+
if (this.isDuplicateTransaction({ transaction: tx })) {
|
|
142
|
+
throw new Error(`Error: Transaction to renounce role ${roleName} in ${this.contractName} was already created.`);
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
const description = `-> Tx to renounce role ${roleName} from ${this.oldOwner} in ${this.contractName}`;
|
|
146
|
+
console.log(chalk_1.default.yellow(` ${description} created.`));
|
|
147
|
+
this.renounceOwnershipTxs.push({ description, transaction: tx });
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
else if (!tx) {
|
|
151
|
+
console.log(chalk_1.default.yellow(` WARNING: Skipping revocation of role ${roleName} in ${this.contractName} as it requires at least 1 member left.`));
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
async createRenounceUint64RolesTransactions(managerRolesToCheck) {
|
|
155
|
+
for (const role of managerRolesToCheck) {
|
|
156
|
+
// Required to process sequentially as it access shared memory state and RPC rate limits
|
|
157
|
+
// eslint-disable-next-line no-await-in-loop
|
|
158
|
+
const tx = await (0, permission_utils_1.renounceAccessManagerRole)({
|
|
159
|
+
contractAddress: this.address,
|
|
160
|
+
newAccount: this.newOwner,
|
|
161
|
+
oldAccount: this.oldOwner,
|
|
162
|
+
role: role.identifier,
|
|
163
|
+
});
|
|
164
|
+
this.handleRenounceOwnershipTransaction(tx, role.name);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
async createAssignBytes32RolesTransactions(bytes32RolesToCheck) {
|
|
168
|
+
for (const role of bytes32RolesToCheck) {
|
|
169
|
+
// Required to process sequentially as it access shared memory state and RPC rate limits
|
|
170
|
+
// eslint-disable-next-line no-await-in-loop
|
|
171
|
+
const tx = await (0, permission_utils_1.grantRole)({
|
|
172
|
+
contractAddress: this.address,
|
|
173
|
+
newAccount: this.newOwner,
|
|
174
|
+
oldAccount: this.oldOwner,
|
|
175
|
+
role: role.identifier,
|
|
176
|
+
});
|
|
177
|
+
if (tx) {
|
|
178
|
+
if (this.isDuplicateTransaction({ transaction: tx })) {
|
|
179
|
+
throw new Error(`Error: Transaction to grant role ${role.name} in ${this.contractName} was already created.`);
|
|
180
|
+
}
|
|
181
|
+
else {
|
|
182
|
+
const description = `-> Tx to grant role ${role.name} to ${this.newOwner} in ${this.contractName}`;
|
|
183
|
+
console.log(chalk_1.default.yellow(` ${description} created.`));
|
|
184
|
+
this.grantOwnershipRoleTxs.push({ description, transaction: tx });
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
async createRenounceBytes32RolesTransactions(bytes32RolesToCheck) {
|
|
190
|
+
for (const role of bytes32RolesToCheck) {
|
|
191
|
+
// Required to process sequentially as it access shared memory state and due to RPC rate limits
|
|
192
|
+
// eslint-disable-next-line no-await-in-loop
|
|
193
|
+
const tx = await (0, permission_utils_1.renounceRole)(this.address, role.identifier, this.oldOwner);
|
|
194
|
+
this.handleRenounceOwnershipTransaction(tx, role.name);
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
isDuplicateTransaction(transaction) {
|
|
198
|
+
const isGrantDuplicate = this.grantOwnershipRoleTxs.some((existingTx) => existingTx.transaction.to === transaction.transaction.to &&
|
|
199
|
+
existingTx.transaction.data === transaction.transaction.data);
|
|
200
|
+
const isRenounceDuplicate = this.renounceOwnershipTxs.some((existingTx) => existingTx.transaction.to === transaction.transaction.to &&
|
|
201
|
+
existingTx.transaction.data === transaction.transaction.data);
|
|
202
|
+
return isGrantDuplicate || isRenounceDuplicate;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
exports.ContractAdmin = ContractAdmin;
|
|
206
|
+
//# sourceMappingURL=contractAdmin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contractAdmin.js","sourceRoot":"","sources":["../../../src/ownership-transfer/contractAdmin.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { EoaSubmitter, SafeSubmitter } from "../submitters";
|
|
2
|
+
import { Instance } from "@skalenetwork/skale-contracts-ethers-v6";
|
|
3
|
+
export interface InstanceAdminOptions {
|
|
4
|
+
oldOwner: string;
|
|
5
|
+
submitter: SafeSubmitter | EoaSubmitter;
|
|
6
|
+
renounceRoles: boolean;
|
|
7
|
+
newOwner: string;
|
|
8
|
+
readonly: boolean;
|
|
9
|
+
testMode: boolean;
|
|
10
|
+
rolesToCheck?: string[];
|
|
11
|
+
managerRolesToCheck?: bigint[];
|
|
12
|
+
}
|
|
13
|
+
interface ContractId {
|
|
14
|
+
name: string;
|
|
15
|
+
address?: string;
|
|
16
|
+
}
|
|
17
|
+
export declare class InstanceAdmin {
|
|
18
|
+
private instance?;
|
|
19
|
+
private contractMetadata;
|
|
20
|
+
private contractIds;
|
|
21
|
+
private bytes32RolesToCheck;
|
|
22
|
+
private managerRolesToCheck;
|
|
23
|
+
private oldOwner;
|
|
24
|
+
private newOwner;
|
|
25
|
+
private readonly;
|
|
26
|
+
private submitter;
|
|
27
|
+
private renounceRoles;
|
|
28
|
+
private testMode;
|
|
29
|
+
constructor(contractIds: ContractId[], options: InstanceAdminOptions, instance?: Instance);
|
|
30
|
+
executeOwnershipTransfer(): Promise<void>;
|
|
31
|
+
private initialize;
|
|
32
|
+
private processGrantStepIfRequired;
|
|
33
|
+
private processRenounceStepIfRequired;
|
|
34
|
+
private submitRenounceRolesTransactions;
|
|
35
|
+
private confirmAndSubmitTransactions;
|
|
36
|
+
private submitGrantOwnershipTransactions;
|
|
37
|
+
private ownershipGrantingRequired;
|
|
38
|
+
private ownershipRevokingRequired;
|
|
39
|
+
private resolveContractAddress;
|
|
40
|
+
private loadContractMetadataAndCreateTransactions;
|
|
41
|
+
private confirmData;
|
|
42
|
+
private processOptions;
|
|
43
|
+
private createRequiredTransactions;
|
|
44
|
+
private getColumnWidths;
|
|
45
|
+
private displayPatternGroup;
|
|
46
|
+
private displayFindings;
|
|
47
|
+
private handleUserRejection;
|
|
48
|
+
private groupMetadataByPattern;
|
|
49
|
+
private promptConfirmation;
|
|
50
|
+
}
|
|
51
|
+
export {};
|