@skalenetwork/upgrade-tools 3.0.0-upgrade-multiple-versions.2 → 4.0.0-beacon.0

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.
Files changed (43) hide show
  1. package/dist/src/contractVerifier.d.ts +25 -0
  2. package/dist/src/contractVerifier.js +71 -0
  3. package/dist/src/contractVerifier.js.map +1 -0
  4. package/dist/src/deploy.js +8 -1
  5. package/dist/src/deploy.js.map +1 -1
  6. package/dist/src/index.d.ts +2 -0
  7. package/dist/src/index.js +2 -0
  8. package/dist/src/index.js.map +1 -1
  9. package/dist/src/proxyUpgrader.d.ts +17 -0
  10. package/dist/src/proxyUpgrader.js +69 -0
  11. package/dist/src/proxyUpgrader.js.map +1 -0
  12. package/dist/src/types/upgrader.d.ts +1 -1
  13. package/dist/src/upgrader.d.ts +13 -7
  14. package/dist/src/upgrader.js +38 -70
  15. package/dist/src/upgrader.js.map +1 -1
  16. package/dist/src/upgraders/abstractTransparentProxyUpgrader.d.ts +10 -0
  17. package/dist/src/upgraders/abstractTransparentProxyUpgrader.js +57 -0
  18. package/dist/src/upgraders/abstractTransparentProxyUpgrader.js.map +1 -0
  19. package/dist/src/upgraders/beaconUpgrader.d.ts +7 -0
  20. package/dist/src/upgraders/beaconUpgrader.js +31 -0
  21. package/dist/src/upgraders/beaconUpgrader.js.map +1 -0
  22. package/dist/src/upgraders/transparentProxyUpgrader.d.ts +5 -0
  23. package/dist/src/upgraders/transparentProxyUpgrader.js +20 -0
  24. package/dist/src/upgraders/transparentProxyUpgrader.js.map +1 -0
  25. package/dist/src/upgraders/v4TransparentProxyUpgrader.d.ts +5 -0
  26. package/dist/src/upgraders/v4TransparentProxyUpgrader.js +19 -0
  27. package/dist/src/upgraders/v4TransparentProxyUpgrader.js.map +1 -0
  28. package/dist/src/verification.d.ts +3 -2
  29. package/dist/src/verification.js +57 -40
  30. package/dist/src/verification.js.map +1 -1
  31. package/dist/src/verifiers/blockscoutVerifier.d.ts +11 -0
  32. package/dist/src/verifiers/blockscoutVerifier.js +65 -0
  33. package/dist/src/verifiers/blockscoutVerifier.js.map +1 -0
  34. package/dist/src/verifiers/etherscanVerifier.d.ts +19 -0
  35. package/dist/src/verifiers/etherscanVerifier.js +105 -0
  36. package/dist/src/verifiers/etherscanVerifier.js.map +1 -0
  37. package/dist/src/verifiers/skaleBlockscoutVerifier.d.ts +7 -0
  38. package/dist/src/verifiers/skaleBlockscoutVerifier.js +60 -0
  39. package/dist/src/verifiers/skaleBlockscoutVerifier.js.map +1 -0
  40. package/package.json +10 -13
  41. package/dist/src/proxyAdmin.d.ts +0 -4
  42. package/dist/src/proxyAdmin.js +0 -56
  43. package/dist/src/proxyAdmin.js.map +0 -1
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BeaconUpgrader = void 0;
4
+ const proxyUpgrader_1 = require("../proxyUpgrader");
5
+ const ethers_1 = require("ethers");
6
+ const hardhat_1 = require("hardhat");
7
+ class BeaconUpgrader extends proxyUpgrader_1.ProxyUpgrader {
8
+ async getOwner() {
9
+ const beacon = await this.getBeacon();
10
+ return await beacon.owner();
11
+ }
12
+ async makeUpgradeTransaction() {
13
+ const beacon = await this.getBeacon();
14
+ return ethers_1.Transaction.from({
15
+ "data": beacon.interface.encodeFunctionData("upgradeTo", [
16
+ await hardhat_1.ethers.resolveAddress(this.newImplementationAddress),
17
+ ]),
18
+ "to": await hardhat_1.ethers.resolveAddress(beacon)
19
+ });
20
+ }
21
+ // Private
22
+ async getBeacon() {
23
+ const generalUpgradeableBeaconAbi = [
24
+ "function upgradeTo(address newImplementation)",
25
+ "function owner() returns (address)"
26
+ ];
27
+ return new hardhat_1.ethers.Contract(await hardhat_1.ethers.resolveAddress(this.proxyAddress), generalUpgradeableBeaconAbi, await hardhat_1.ethers.provider.getSigner());
28
+ }
29
+ }
30
+ exports.BeaconUpgrader = BeaconUpgrader;
31
+ //# sourceMappingURL=beaconUpgrader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"beaconUpgrader.js","sourceRoot":"","sources":["../../../src/upgraders/beaconUpgrader.ts"],"names":[],"mappings":";;;AAAA,oDAA+C;AAC/C,mCAAmC;AACnC,qCAA+B;AAG/B,MAAa,cAAe,SAAQ,6BAAa;IACtC,KAAK,CAAC,QAAQ;QACjB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC;QACtC,OAAO,MAAM,MAAM,CAAC,KAAK,EAAE,CAAC;IAChC,CAAC;IAES,KAAK,CAAC,sBAAsB;QAClC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC;QACtC,OAAO,oBAAW,CAAC,IAAI,CAAC;YACpB,MAAM,EAAE,MAAM,CAAC,SAAS,CAAC,kBAAkB,CACvC,WAAW,EACX;gBACI,MAAM,gBAAM,CAAC,cAAc,CAAC,IAAI,CAAC,wBAAyB,CAAC;aAC9D,CACJ;YACD,IAAI,EAAE,MAAM,gBAAM,CAAC,cAAc,CAAC,MAAM,CAAC;SAC5C,CAAC,CAAC;IACP,CAAC;IAED,UAAU;IAEF,KAAK,CAAC,SAAS;QACnB,MAAM,2BAA2B,GAAG;YAChC,+CAA+C;YAC/C,oCAAoC;SACvC,CAAC;QACF,OAAO,IAAI,gBAAM,CAAC,QAAQ,CACtB,MAAM,gBAAM,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,EAC9C,2BAA2B,EAC3B,MAAM,gBAAM,CAAC,QAAQ,CAAC,SAAS,EAAE,CACpC,CAAC;IACN,CAAC;CACJ;AAhCD,wCAgCC"}
@@ -0,0 +1,5 @@
1
+ import { AbstractTransparentProxyUpgrader } from "./abstractTransparentProxyUpgrader";
2
+ import { Transaction } from "ethers";
3
+ export declare class TransparentProxyUpgrader extends AbstractTransparentProxyUpgrader {
4
+ protected makeUpgradeTransaction(): Promise<Transaction>;
5
+ }
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TransparentProxyUpgrader = void 0;
4
+ const abstractTransparentProxyUpgrader_1 = require("./abstractTransparentProxyUpgrader");
5
+ const ethers_1 = require("ethers");
6
+ const hardhat_1 = require("hardhat");
7
+ class TransparentProxyUpgrader extends abstractTransparentProxyUpgrader_1.AbstractTransparentProxyUpgrader {
8
+ async makeUpgradeTransaction() {
9
+ return ethers_1.Transaction.from({
10
+ "data": this.proxyAdmin.interface.encodeFunctionData("upgradeAndCall", [
11
+ await hardhat_1.ethers.resolveAddress(this.proxyAddress),
12
+ await hardhat_1.ethers.resolveAddress(this.newImplementationAddress),
13
+ "0x"
14
+ ]),
15
+ "to": await hardhat_1.ethers.resolveAddress(this.proxyAdmin)
16
+ });
17
+ }
18
+ }
19
+ exports.TransparentProxyUpgrader = TransparentProxyUpgrader;
20
+ //# sourceMappingURL=transparentProxyUpgrader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transparentProxyUpgrader.js","sourceRoot":"","sources":["../../../src/upgraders/transparentProxyUpgrader.ts"],"names":[],"mappings":";;;AAAA,yFAAoF;AACpF,mCAAmC;AACnC,qCAA+B;AAE/B,MAAa,wBAAyB,SAAQ,mEAAgC;IAChE,KAAK,CAAC,sBAAsB;QAClC,OAAO,oBAAW,CAAC,IAAI,CAAC;YACpB,MAAM,EAAE,IAAI,CAAC,UAAW,CAAC,SAAS,CAAC,kBAAkB,CACjD,gBAAgB,EAChB;gBACI,MAAM,gBAAM,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC;gBAC9C,MAAM,gBAAM,CAAC,cAAc,CAAC,IAAI,CAAC,wBAAyB,CAAC;gBAC3D,IAAI;aACP,CACJ;YACD,IAAI,EAAE,MAAM,gBAAM,CAAC,cAAc,CAAC,IAAI,CAAC,UAAW,CAAC;SACtD,CAAC,CAAC;IACP,CAAC;CACJ;AAdD,4DAcC"}
@@ -0,0 +1,5 @@
1
+ import { AbstractTransparentProxyUpgrader } from "./abstractTransparentProxyUpgrader";
2
+ import { Transaction } from "ethers";
3
+ export declare class V4TransparentProxyUpgrader extends AbstractTransparentProxyUpgrader {
4
+ protected makeUpgradeTransaction(): Promise<Transaction>;
5
+ }
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.V4TransparentProxyUpgrader = void 0;
4
+ const abstractTransparentProxyUpgrader_1 = require("./abstractTransparentProxyUpgrader");
5
+ const ethers_1 = require("ethers");
6
+ const hardhat_1 = require("hardhat");
7
+ class V4TransparentProxyUpgrader extends abstractTransparentProxyUpgrader_1.AbstractTransparentProxyUpgrader {
8
+ async makeUpgradeTransaction() {
9
+ return ethers_1.Transaction.from({
10
+ "data": this.proxyAdmin.interface.encodeFunctionData("upgrade", [
11
+ await hardhat_1.ethers.resolveAddress(this.proxyAddress),
12
+ await hardhat_1.ethers.resolveAddress(this.newImplementationAddress),
13
+ ]),
14
+ "to": await hardhat_1.ethers.resolveAddress(this.proxyAdmin)
15
+ });
16
+ }
17
+ }
18
+ exports.V4TransparentProxyUpgrader = V4TransparentProxyUpgrader;
19
+ //# sourceMappingURL=v4TransparentProxyUpgrader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"v4TransparentProxyUpgrader.js","sourceRoot":"","sources":["../../../src/upgraders/v4TransparentProxyUpgrader.ts"],"names":[],"mappings":";;;AAAA,yFAAoF;AACpF,mCAAmC;AACnC,qCAA+B;AAE/B,MAAa,0BAA2B,SAAQ,mEAAgC;IAClE,KAAK,CAAC,sBAAsB;QAClC,OAAO,oBAAW,CAAC,IAAI,CAAC;YACpB,MAAM,EAAE,IAAI,CAAC,UAAW,CAAC,SAAS,CAAC,kBAAkB,CACjD,SAAS,EACT;gBACI,MAAM,gBAAM,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC;gBAC9C,MAAM,gBAAM,CAAC,cAAc,CAAC,IAAI,CAAC,wBAAyB,CAAC;aAC9D,CACJ;YACD,IAAI,EAAE,MAAM,gBAAM,CAAC,cAAc,CAAC,IAAI,CAAC,UAAW,CAAC;SACtD,CAAC,CAAC;IACP,CAAC;CACJ;AAbD,gEAaC"}
@@ -1,2 +1,3 @@
1
- export declare const verify: (contractName: string, contractAddress: string, constructorArguments: object) => Promise<void>;
2
- export declare const verifyProxy: (contractName: string, proxyAddress: string, constructorArguments: object) => Promise<void>;
1
+ import { AddressLike } from "ethers";
2
+ export declare const verify: (contractName: string, contractAddress: AddressLike) => Promise<void>;
3
+ export declare const verifyProxy: (contractName: string, proxyAddress: string) => Promise<void>;
@@ -5,63 +5,80 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.verifyProxy = exports.verify = void 0;
7
7
  const hardhat_1 = require("hardhat");
8
- const chain_config_1 = require("@nomicfoundation/hardhat-verify/internal/chain-config");
8
+ const blockscoutVerifier_1 = require("./verifiers/blockscoutVerifier");
9
+ const etherscanVerifier_1 = require("./verifiers/etherscanVerifier");
10
+ const skaleBlockscoutVerifier_1 = require("./verifiers/skaleBlockscoutVerifier");
9
11
  const chalk_1 = __importDefault(require("chalk"));
10
12
  const upgrades_core_1 = require("@openzeppelin/upgrades-core");
11
- const RETRIES_AMOUNT = 5;
12
- const processError = (error, contractName) => {
13
- if (error instanceof Error) {
14
- const alreadyVerifiedErrorLine = "Contract source code already verified";
15
- if (error.toString().includes(alreadyVerifiedErrorLine)) {
16
- const infoMessage = `${contractName} is already verified`;
17
- console.log(chalk_1.default.grey(infoMessage));
18
- return;
13
+ const setupEtherscan = async (chainId) => {
14
+ if (process.env.ETHERSCAN) {
15
+ if (await etherscanVerifier_1.EtherscanVerifier.isChainSupported(chainId)) {
16
+ return new etherscanVerifier_1.EtherscanVerifier(process.env.ETHERSCAN, chainId);
19
17
  }
20
- const errorMessage = `Contract ${contractName} was not verified on etherscan`;
21
- console.log(chalk_1.default.red(errorMessage));
22
- console.log(error.toString());
18
+ console.log(chalk_1.default.gray(`Etherscan does not support chainId ${chainId}. Skipping verification on Etherscan.`));
23
19
  }
24
20
  else {
25
- console.log("Unknown exception type:", error);
21
+ console.log(chalk_1.default.yellow(`No etherscan API key provided. Skipping verification on Etherscan.`));
26
22
  }
23
+ return null;
27
24
  };
28
- const verificationAttempt = async (contractName, contractAddress, constructorArguments) => {
29
- try {
30
- await (0, hardhat_1.run)("verify:verify", {
31
- "address": contractAddress,
32
- constructorArguments
33
- });
34
- return true;
25
+ const setupBlockscout = (chainId) => {
26
+ const verifier = blockscoutVerifier_1.BlockscoutVerifier.createFromChainId(chainId);
27
+ if (verifier) {
28
+ return verifier;
35
29
  }
36
- catch (error) {
37
- processError(error, contractName);
30
+ console.log(chalk_1.default.gray(`Blockscout API url is not known for chainId ${chainId}.`));
31
+ if (process.env.EXPLORER_URL) {
32
+ console.log(chalk_1.default.gray("Using EXPLORER_URL to setup verification."));
33
+ return new blockscoutVerifier_1.BlockscoutVerifier(`${process.env.EXPLORER_URL}/api`, process.env.EXPLORER_URL);
38
34
  }
39
- return false;
35
+ console.log(chalk_1.default.gray("Skipping verification on Blockscout."));
36
+ return null;
40
37
  };
41
- const verifyWithRetry = async (verificationTarget, attempts) => {
42
- if (attempts) {
43
- if (!await verificationAttempt(verificationTarget.contractName, verificationTarget.contractAddress, verificationTarget.constructorArguments)) {
44
- const failedAttempts = 1;
45
- await verifyWithRetry(verificationTarget, attempts - failedAttempts);
38
+ const setupSkale = async () => {
39
+ if (process.env.ENDPOINT) {
40
+ try {
41
+ const verifier = await skaleBlockscoutVerifier_1.SkaleBlockscoutVerifier.createFromEndpoint(process.env.ENDPOINT);
42
+ if (verifier) {
43
+ return verifier;
44
+ }
46
45
  }
46
+ catch (error) {
47
+ console.log(chalk_1.default.yellow(error));
48
+ }
49
+ }
50
+ else {
51
+ console.log(chalk_1.default.gray("ENDPOINT is not provided. Can't determine SKALE block explorer API url."));
47
52
  }
53
+ console.log(chalk_1.default.gray("Skipping verification on SKALE block explorer."));
54
+ return null;
48
55
  };
49
- const verify = async (contractName, contractAddress, constructorArguments) => {
50
- const { chainId } = await hardhat_1.ethers.provider.getNetwork();
51
- if (!chain_config_1.builtinChains.map((chain) => chain.chainId).includes(Number(chainId))) {
52
- const errorMessage = "Verification on this network is not supported";
53
- console.log(chalk_1.default.grey(errorMessage));
54
- return;
56
+ const verifiers = [];
57
+ let verifiersSetup = false;
58
+ const setupVerifiers = async () => {
59
+ if (!verifiersSetup) {
60
+ verifiersSetup = true;
61
+ const { chainId } = await hardhat_1.ethers.provider.getNetwork();
62
+ const candidates = [
63
+ await setupEtherscan(chainId),
64
+ setupBlockscout(chainId),
65
+ await setupSkale()
66
+ ];
67
+ verifiers.push(...candidates.filter(item => item !== null));
55
68
  }
56
- await verifyWithRetry({
57
- constructorArguments,
58
- contractAddress,
69
+ };
70
+ const verify = async (contractName, contractAddress) => {
71
+ await setupVerifiers();
72
+ const contractAddressString = await hardhat_1.ethers.resolveAddress(contractAddress);
73
+ await Promise.all(verifiers.map(verifier => verifier.verify({
74
+ contractAddress: contractAddressString,
59
75
  contractName
60
- }, RETRIES_AMOUNT);
76
+ })));
61
77
  };
62
78
  exports.verify = verify;
63
- const verifyProxy = async (contractName, proxyAddress, constructorArguments) => {
64
- await (0, exports.verify)(contractName, await (0, upgrades_core_1.getImplementationAddress)(hardhat_1.network.provider, proxyAddress), constructorArguments);
79
+ const verifyProxy = async (contractName, proxyAddress) => {
80
+ await (0, exports.verify)(contractName, await (0, upgrades_core_1.getImplementationAddress)(hardhat_1.network.provider, proxyAddress));
81
+ await (0, exports.verify)("TransparentUpgradeableProxy", proxyAddress);
65
82
  };
66
83
  exports.verifyProxy = verifyProxy;
67
84
  //# sourceMappingURL=verification.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"verification.js","sourceRoot":"","sources":["../../src/verification.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"verification.js","sourceRoot":"","sources":["../../src/verification.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import { ContractVerifier, VerificationRequestParameters, VerificationTarget } from "../contractVerifier";
2
+ import { ValidationResponse } from "@nomicfoundation/hardhat-verify/internal/utilities";
3
+ export declare class BlockscoutVerifier extends ContractVerifier {
4
+ name: string;
5
+ private readonly blockscout;
6
+ constructor(apiURL: string, browserURL: string);
7
+ static createFromChainId(chainId: bigint): BlockscoutVerifier | null;
8
+ protected isAlreadyVerified(verificationTarget: VerificationTarget): Promise<boolean>;
9
+ protected submitVerificationRequest(target: VerificationTarget, params: VerificationRequestParameters): Promise<ValidationResponse>;
10
+ protected getContractUrl(verificationTarget: VerificationTarget): string;
11
+ }
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ // Cspell:words holesky hoodi
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.BlockscoutVerifier = void 0;
5
+ const contractVerifier_1 = require("../contractVerifier");
6
+ const blockscout_1 = require("@nomicfoundation/hardhat-verify/blockscout");
7
+ const BLOCKSCOUT_CHAINS = [
8
+ {
9
+ chainId: 1,
10
+ network: "mainnet",
11
+ urls: {
12
+ apiURL: "https://eth.blockscout.com/api",
13
+ browserURL: "https://eth.blockscout.com",
14
+ }
15
+ },
16
+ {
17
+ chainId: 11155111,
18
+ network: "sepolia",
19
+ urls: {
20
+ apiURL: "https://eth-sepolia.blockscout.com/api",
21
+ browserURL: "https://eth-sepolia.blockscout.com",
22
+ }
23
+ },
24
+ {
25
+ chainId: 17000,
26
+ network: "holesky",
27
+ urls: {
28
+ apiURL: "https://eth-holesky.blockscout.com/api",
29
+ browserURL: "https://eth-holesky.blockscout.com",
30
+ }
31
+ },
32
+ {
33
+ chainId: 560048,
34
+ network: "hoodi",
35
+ urls: {
36
+ apiURL: "https://eth-hoodi.blockscout.com/api",
37
+ browserURL: "https://eth-hoodi.blockscout.com",
38
+ }
39
+ }
40
+ ];
41
+ class BlockscoutVerifier extends contractVerifier_1.ContractVerifier {
42
+ constructor(apiURL, browserURL) {
43
+ super();
44
+ this.name = "Blockscout";
45
+ this.blockscout = new blockscout_1.Blockscout(apiURL, browserURL);
46
+ }
47
+ static createFromChainId(chainId) {
48
+ const config = BLOCKSCOUT_CHAINS.find(chain => chain.chainId === Number(chainId));
49
+ if (config) {
50
+ return new BlockscoutVerifier(config.urls.apiURL, config.urls.browserURL);
51
+ }
52
+ return null;
53
+ }
54
+ async isAlreadyVerified(verificationTarget) {
55
+ return await this.blockscout.isVerified(verificationTarget.contractAddress);
56
+ }
57
+ async submitVerificationRequest(target, params) {
58
+ return await this.blockscout.verify(target.contractAddress, params.solcInputJson, params.fullContractName, params.compilerVersion);
59
+ }
60
+ getContractUrl(verificationTarget) {
61
+ return this.blockscout.getContractUrl(verificationTarget.contractAddress);
62
+ }
63
+ }
64
+ exports.BlockscoutVerifier = BlockscoutVerifier;
65
+ //# sourceMappingURL=blockscoutVerifier.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blockscoutVerifier.js","sourceRoot":"","sources":["../../../src/verifiers/blockscoutVerifier.ts"],"names":[],"mappings":";AAAA,6BAA6B;;;AAE7B,0DAAwG;AACxG,2EAAsE;AAItE,MAAM,iBAAiB,GAAkB;IACrC;QACI,OAAO,EAAE,CAAC;QACV,OAAO,EAAE,SAAS;QAClB,IAAI,EAAE;YACF,MAAM,EAAE,gCAAgC;YACxC,UAAU,EAAE,4BAA4B;SAC3C;KACJ;IACD;QACI,OAAO,EAAE,QAAQ;QACjB,OAAO,EAAE,SAAS;QAClB,IAAI,EAAE;YACF,MAAM,EAAE,wCAAwC;YAChD,UAAU,EAAE,oCAAoC;SACnD;KACJ;IACD;QACI,OAAO,EAAE,KAAK;QACd,OAAO,EAAE,SAAS;QAClB,IAAI,EAAE;YACF,MAAM,EAAE,wCAAwC;YAChD,UAAU,EAAE,oCAAoC;SACnD;KACJ;IACD;QACI,OAAO,EAAE,MAAM;QACf,OAAO,EAAE,OAAO;QAChB,IAAI,EAAE;YACF,MAAM,EAAE,sCAAsC;YAC9C,UAAU,EAAE,kCAAkC;SACjD;KACJ;CACJ,CAAA;AAED,MAAa,kBAAmB,SAAQ,mCAAgB;IAIpD,YAAY,MAAc,EAAE,UAAkB;QAC1C,KAAK,EAAE,CAAC;QAJL,SAAI,GAAG,YAAY,CAAC;QAKvB,IAAI,CAAC,UAAU,GAAG,IAAI,uBAAU,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;IACzD,CAAC;IAEM,MAAM,CAAC,iBAAiB,CAAC,OAAe;QAC3C,MAAM,MAAM,GAAG,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,KAAK,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;QAClF,IAAI,MAAM,EAAE,CAAC;YACT,OAAO,IAAI,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC9E,CAAC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAES,KAAK,CAAC,iBAAiB,CAAC,kBAAsC;QACpE,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC;IAChF,CAAC;IAES,KAAK,CAAC,yBAAyB,CAAC,MAA0B,EAAE,MAAqC;QACvG,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAC/B,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,gBAAgB,EACvB,MAAM,CAAC,eAAe,CACzB,CAAC;IACN,CAAC;IAES,cAAc,CAAC,kBAAsC;QAC3D,OAAO,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC;IAC9E,CAAC;CACJ;AAjCD,gDAiCC"}
@@ -0,0 +1,19 @@
1
+ import { ContractVerifier, VerificationRequestParameters, VerificationTarget } from '../contractVerifier';
2
+ import { ValidationResponse } from '@nomicfoundation/hardhat-verify/internal/utilities';
3
+ export declare class EtherscanVerifier extends ContractVerifier {
4
+ readonly name = "Etherscan";
5
+ private readonly etherscan;
6
+ constructor(apiKey: string, chainId: bigint);
7
+ static isChainSupported(chainId: bigint): Promise<boolean>;
8
+ protected isAlreadyVerified(verificationTarget: VerificationTarget): Promise<boolean>;
9
+ protected submitVerificationRequest(target: VerificationTarget, params: VerificationRequestParameters, retries?: number): Promise<ValidationResponse>;
10
+ protected getContractUrl(verificationTarget: VerificationTarget): string;
11
+ protected getVerifyParameters(contractName: string): Promise<{
12
+ compilerVersion: string;
13
+ fullContractName: string;
14
+ solcInputJson: string;
15
+ }>;
16
+ private static loadEtherscanSupportedChains;
17
+ private processContractVerificationMissingBytecodeError;
18
+ private static waitForBlocks;
19
+ }
@@ -0,0 +1,105 @@
1
+ "use strict";
2
+ // Cspell:words apiurl blockexplorer chainname
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod };
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.EtherscanVerifier = void 0;
8
+ const contractVerifier_1 = require("../contractVerifier");
9
+ const etherscan_1 = require("@nomicfoundation/hardhat-verify/etherscan");
10
+ const semaphore_async_await_1 = __importDefault(require("semaphore-async-await"));
11
+ const chalk_1 = __importDefault(require("chalk"));
12
+ const hardhat_1 = require("hardhat");
13
+ const MAX_CONCURRENCY = 1;
14
+ const DEFAULT_RETRIES_AMOUNT = 5;
15
+ const BLOCKS_TO_WAIT = 5;
16
+ const ZERO_ATTEMPTS = 0;
17
+ const ONE_ATTEMPT = 1;
18
+ const lock = new semaphore_async_await_1.default(MAX_CONCURRENCY);
19
+ class EtherscanVerifier extends contractVerifier_1.ContractVerifier {
20
+ constructor(apiKey, chainId) {
21
+ super();
22
+ this.name = "Etherscan";
23
+ this.etherscan = new etherscan_1.Etherscan(apiKey,
24
+ // API url is set automatically because chainId is provided
25
+ "", "https://etherscan.io", Number(chainId));
26
+ }
27
+ static async isChainSupported(chainId) {
28
+ const supportedChains = await EtherscanVerifier.loadEtherscanSupportedChains();
29
+ return supportedChains.some(config => config.chainId === Number(chainId));
30
+ }
31
+ // Protected
32
+ async isAlreadyVerified(verificationTarget) {
33
+ return await this.etherscan.isVerified(verificationTarget.contractAddress);
34
+ }
35
+ async submitVerificationRequest(target, params, retries = DEFAULT_RETRIES_AMOUNT) {
36
+ try {
37
+ await lock.acquire();
38
+ return await this.etherscan.verify(target.contractAddress, params.solcInputJson, params.fullContractName, params.compilerVersion, "");
39
+ }
40
+ catch (error) {
41
+ if (error instanceof Error && error.name === 'ContractVerificationMissingBytecodeError') {
42
+ lock.release();
43
+ return await this.processContractVerificationMissingBytecodeError(error, { params, target }, retries);
44
+ }
45
+ throw error;
46
+ }
47
+ finally {
48
+ lock.release();
49
+ }
50
+ }
51
+ getContractUrl(verificationTarget) {
52
+ return this.etherscan.getContractUrl(verificationTarget.contractAddress);
53
+ }
54
+ async getVerifyParameters(contractName) {
55
+ const parameters = await super.getVerifyParameters(contractName);
56
+ return { ...parameters, compilerVersion: `v${parameters.compilerVersion}` };
57
+ }
58
+ // Private
59
+ static async loadEtherscanSupportedChains() {
60
+ await lock.acquire();
61
+ try {
62
+ const resp = await fetch("https://api.etherscan.io/v2/chainlist");
63
+ if (!resp.ok) {
64
+ throw new Error(`Etherscan API error: ${resp.status} ${resp.statusText}`);
65
+ }
66
+ const data = await resp.json();
67
+ return data.result.map((element) => ({
68
+ chainId: parseInt(element.chainid, 10),
69
+ network: element.chainname,
70
+ urls: {
71
+ apiURL: element.apiurl,
72
+ browserURL: element.blockexplorer
73
+ }
74
+ }));
75
+ }
76
+ finally {
77
+ lock.release();
78
+ }
79
+ }
80
+ async processContractVerificationMissingBytecodeError(error, data, retries) {
81
+ if (retries > ZERO_ATTEMPTS) {
82
+ console.log(chalk_1.default.gray(error.message));
83
+ console.log(chalk_1.default.gray(`Waiting for ${BLOCKS_TO_WAIT} blocks before retrying...`));
84
+ await EtherscanVerifier.waitForBlocks(BLOCKS_TO_WAIT);
85
+ return this.submitVerificationRequest(data.target, data.params, retries - ONE_ATTEMPT);
86
+ }
87
+ throw error;
88
+ }
89
+ static waitForBlocks(numBlocks) {
90
+ return new Promise((resolve) => {
91
+ hardhat_1.ethers.provider.getBlockNumber().then((currentBlockNumber) => {
92
+ const targetBlock = currentBlockNumber + numBlocks;
93
+ const listener = (blockNumber) => {
94
+ if (blockNumber >= targetBlock) {
95
+ hardhat_1.ethers.provider.removeListener("block", listener);
96
+ resolve();
97
+ }
98
+ };
99
+ hardhat_1.ethers.provider.on("block", listener);
100
+ });
101
+ });
102
+ }
103
+ }
104
+ exports.EtherscanVerifier = EtherscanVerifier;
105
+ //# sourceMappingURL=etherscanVerifier.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"etherscanVerifier.js","sourceRoot":"","sources":["../../../src/verifiers/etherscanVerifier.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import { BlockscoutVerifier } from "./blockscoutVerifier";
2
+ export declare class SkaleBlockscoutVerifier extends BlockscoutVerifier {
3
+ name: string;
4
+ static createFromEndpoint(endpoint: string): Promise<SkaleBlockscoutVerifier | null>;
5
+ private static parseEndpoint;
6
+ private static pingExplorer;
7
+ }
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+ // Cspell:words skalenodes
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.SkaleBlockscoutVerifier = void 0;
5
+ const blockscoutVerifier_1 = require("./blockscoutVerifier");
6
+ const BASE_EXPLORER_URLS = {
7
+ legacy: "legacy-explorer.skalenodes.com",
8
+ mainnet: "explorer.mainnet.skalenodes.com",
9
+ testnet: "explorer.testnet.skalenodes.com"
10
+ };
11
+ class SkaleBlockscoutVerifier extends blockscoutVerifier_1.BlockscoutVerifier {
12
+ constructor() {
13
+ super(...arguments);
14
+ this.name = "SKALE Blockscout";
15
+ }
16
+ static async createFromEndpoint(endpoint) {
17
+ const { schainName, networkType } = SkaleBlockscoutVerifier.parseEndpoint(endpoint);
18
+ const browserURL = `https://${schainName}.${BASE_EXPLORER_URLS[networkType]}`;
19
+ const apiURL = `${browserURL}/api`;
20
+ if (!await SkaleBlockscoutVerifier.pingExplorer(browserURL)) {
21
+ throw new Error(`SKALE block explorer (${browserURL}) is not reachable, set EXPLORER_URL`);
22
+ }
23
+ return new SkaleBlockscoutVerifier(apiURL, browserURL);
24
+ }
25
+ // Private
26
+ static parseEndpoint(endpoint) {
27
+ const { host, pathname } = new URL(endpoint);
28
+ const schainName = pathname.split("/").filter(Boolean).pop();
29
+ let networkType = "mainnet";
30
+ if (host.includes("mainnet.")) {
31
+ networkType = "mainnet";
32
+ }
33
+ else if (host.includes("testnet.")) {
34
+ networkType = "testnet";
35
+ }
36
+ else if (host.includes("legacy-proxy.")) {
37
+ networkType = "legacy";
38
+ }
39
+ else {
40
+ throw new Error(`The chain is not supported by SKALE block explorer or unknown network in ENDPOINT: ${endpoint}`);
41
+ }
42
+ return { networkType, schainName };
43
+ }
44
+ static async pingExplorer(baseUrl) {
45
+ const url = `${baseUrl}/api/health`;
46
+ try {
47
+ const res = await fetch(url);
48
+ if (!res.ok) {
49
+ return false;
50
+ }
51
+ const jsonResponse = await res.json();
52
+ return jsonResponse.healthy;
53
+ }
54
+ catch {
55
+ return false;
56
+ }
57
+ }
58
+ }
59
+ exports.SkaleBlockscoutVerifier = SkaleBlockscoutVerifier;
60
+ //# sourceMappingURL=skaleBlockscoutVerifier.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"skaleBlockscoutVerifier.js","sourceRoot":"","sources":["../../../src/verifiers/skaleBlockscoutVerifier.ts"],"names":[],"mappings":";AAAA,0BAA0B;;;AAE1B,6DAAwD;AAExD,MAAM,kBAAkB,GAAG;IACvB,MAAM,EAAE,gCAAgC;IACxC,OAAO,EAAE,iCAAiC;IAC1C,OAAO,EAAE,iCAAiC;CAC7C,CAAC;AAEF,MAAa,uBAAwB,SAAQ,uCAAkB;IAA/D;;QACW,SAAI,GAAG,kBAAkB,CAAC;IA6CrC,CAAC;IA3CU,MAAM,CAAC,KAAK,CAAC,kBAAkB,CAAC,QAAgB;QACnD,MAAM,EAAC,UAAU,EAAE,WAAW,EAAC,GAAG,uBAAuB,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAClF,MAAM,UAAU,GAAG,WAAW,UAAU,IAAI,kBAAkB,CAAC,WAAW,CAAC,EAAE,CAAC;QAC9E,MAAM,MAAM,GAAG,GAAG,UAAU,MAAM,CAAC;QACnC,IAAI,CAAC,MAAM,uBAAuB,CAAC,YAAY,CAAC,UAAU,CAAC,EAAE,CAAC;YAC1D,MAAM,IAAI,KAAK,CAAC,yBAAyB,UAAU,sCAAsC,CAAC,CAAC;QAC/F,CAAC;QACD,OAAO,IAAI,uBAAuB,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;IAC3D,CAAC;IAED,UAAU;IAEF,MAAM,CAAC,aAAa,CAAC,QAAgB;QACzC,MAAM,EAAC,IAAI,EAAE,QAAQ,EAAC,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC3C,MAAM,UAAU,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,GAAG,EAAG,CAAC;QAE9D,IAAI,WAAW,GAAoC,SAAS,CAAC;QAC7D,IAAI,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;YAC5B,WAAW,GAAG,SAAS,CAAC;QAC5B,CAAC;aAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;YACnC,WAAW,GAAG,SAAS,CAAC;QAC5B,CAAC;aAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAE,CAAC;YACxC,WAAW,GAAG,QAAQ,CAAC;QAC3B,CAAC;aAAM,CAAC;YACJ,MAAM,IAAI,KAAK,CACX,sFAAsF,QAAQ,EAAE,CAAC,CAAC;QAC1G,CAAC;QACD,OAAO,EAAC,WAAW,EAAE,UAAU,EAAC,CAAC;IACrC,CAAC;IAEO,MAAM,CAAC,KAAK,CAAC,YAAY,CAAE,OAAe;QAC9C,MAAM,GAAG,GAAG,GAAG,OAAO,aAAa,CAAC;QACpC,IAAI,CAAC;YACD,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC;YAC7B,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;gBACV,OAAO,KAAK,CAAC;YACjB,CAAC;YACD,MAAM,YAAY,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC;YACtC,OAAO,YAAY,CAAC,OAAO,CAAC;QAChC,CAAC;QAAC,MAAM,CAAC;YACL,OAAO,KAAK,CAAC;QACjB,CAAC;IACL,CAAC;CACJ;AA9CD,0DA8CC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@skalenetwork/upgrade-tools",
3
- "version": "3.0.0-upgrade-multiple-versions.2",
3
+ "version": "4.0.0-beacon.0",
4
4
  "description": "Scripts to support upgrades of smart contracts",
5
5
  "files": [
6
6
  "dist/**/*"
@@ -10,7 +10,7 @@
10
10
  "repository": "git@github.com:skalenetwork/upgrade-tools.git",
11
11
  "author": "Dmytro Stebaiev <dmytro@skalelabs.com>",
12
12
  "license": "AGPL-3.0",
13
- "private": false,
13
+ "packageManager": "yarn@3.5.1",
14
14
  "scripts": {
15
15
  "prepare": "yarn hooks && yarn install-peers",
16
16
  "compile": "npx hardhat typechain && tsc",
@@ -38,21 +38,18 @@
38
38
  "typescript": "^5.1.6"
39
39
  },
40
40
  "dependencies": {
41
+ "@nomicfoundation/hardhat-ethers": "^3.0.0",
42
+ "@nomicfoundation/hardhat-verify": "2.0.14",
43
+ "@openzeppelin/hardhat-upgrades": "^3.1.1",
44
+ "@openzeppelin/upgrades-core": "^1.27.1",
41
45
  "@safe-global/api-kit": "^2.4.1",
42
46
  "@safe-global/protocol-kit": "^5.0.1",
43
47
  "@safe-global/safe-core-sdk-types": "^5.0.1",
44
- "@skalenetwork/skale-contracts-ethers-v6": "^1.0.2-develop.61",
48
+ "@skalenetwork/skale-contracts-ethers-v6": "^2.0.0-develop.1",
49
+ "@types/mocha": "^9.1.0",
45
50
  "axios": "^1.4.0",
46
51
  "ethereumjs-util": "^7.1.4",
52
+ "hardhat": "^2.9.9",
47
53
  "semaphore-async-await": "^1.5.1"
48
- },
49
- "peerDependencies": {
50
- "@nomicfoundation/hardhat-ethers": "^3.0.0",
51
- "@nomicfoundation/hardhat-verify": "^2.0.0",
52
- "@openzeppelin/hardhat-upgrades": "^3.1.1",
53
- "@openzeppelin/upgrades-core": "^1.27.1",
54
- "@types/mocha": "^9.1.0",
55
- "ethers": "^6.13.4",
56
- "hardhat": "^2.9.9"
57
54
  }
58
- }
55
+ }
@@ -1,4 +0,0 @@
1
- import { AddressLike, Contract, Transaction } from "ethers";
2
- export declare const getProxyAdmin: (proxy: AddressLike) => Promise<Contract>;
3
- export declare const isNewProxyAdmin: (proxyAdmin: Contract) => Promise<boolean>;
4
- export declare const getUpgradeTransaction: (proxy: AddressLike, implementation: AddressLike) => Promise<Transaction>;