@hyperlane-xyz/sdk 1.4.3-beta0 → 1.4.3-beta1
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/HyperlaneApp.d.ts.map +1 -1
- package/dist/HyperlaneApp.js +2 -2
- package/dist/HyperlaneApp.js.map +1 -1
- package/dist/consts/bytecode.js +1 -1
- package/dist/consts/bytecode.js.map +1 -1
- package/dist/consts/chainMetadata.d.ts +2 -1
- package/dist/consts/chainMetadata.d.ts.map +1 -1
- package/dist/consts/chainMetadata.js +26 -25
- package/dist/consts/chainMetadata.js.map +1 -1
- package/dist/consts/chains.d.ts +1 -1
- package/dist/consts/chains.d.ts.map +1 -1
- package/dist/consts/chains.js +2 -2
- package/dist/consts/chains.js.map +1 -1
- package/dist/consts/environments/index.d.ts +2 -2
- package/dist/consts/environments/index.d.ts.map +1 -1
- package/dist/consts/environments/index.js +2 -2
- package/dist/consts/environments/index.js.map +1 -1
- package/dist/contracts.d.ts +7 -7
- package/dist/contracts.d.ts.map +1 -1
- package/dist/contracts.js +33 -22
- package/dist/contracts.js.map +1 -1
- package/dist/core/CoreDeployer.hardhat-test.js +42 -33
- package/dist/core/CoreDeployer.hardhat-test.js.map +1 -1
- package/dist/core/HyperlaneCore.d.ts +3 -3
- package/dist/core/HyperlaneCore.d.ts.map +1 -1
- package/dist/core/HyperlaneCore.js +28 -15
- package/dist/core/HyperlaneCore.js.map +1 -1
- package/dist/core/HyperlaneCore.test.js +13 -4
- package/dist/core/HyperlaneCore.test.js.map +1 -1
- package/dist/core/HyperlaneCoreChecker.js +99 -80
- package/dist/core/HyperlaneCoreChecker.js.map +1 -1
- package/dist/core/HyperlaneCoreDeployer.d.ts +3 -3
- package/dist/core/HyperlaneCoreDeployer.d.ts.map +1 -1
- package/dist/core/HyperlaneCoreDeployer.js +62 -45
- package/dist/core/HyperlaneCoreDeployer.js.map +1 -1
- package/dist/core/TestCoreApp.js +45 -35
- package/dist/core/TestCoreApp.js.map +1 -1
- package/dist/core/TestCoreDeployer.js +27 -14
- package/dist/core/TestCoreDeployer.js.map +1 -1
- package/dist/core/contracts.d.ts +1 -1
- package/dist/core/contracts.d.ts.map +1 -1
- package/dist/core/events.d.ts +1 -1
- package/dist/core/events.d.ts.map +1 -1
- package/dist/core/testHyperlaneDeploy.hardhat-test.js +33 -24
- package/dist/core/testHyperlaneDeploy.hardhat-test.js.map +1 -1
- package/dist/core/types.d.ts +5 -5
- package/dist/core/types.d.ts.map +1 -1
- package/dist/core/types.js +2 -2
- package/dist/core/types.js.map +1 -1
- package/dist/deploy/HyperlaneAppChecker.d.ts +2 -2
- package/dist/deploy/HyperlaneAppChecker.d.ts.map +1 -1
- package/dist/deploy/HyperlaneAppChecker.js +126 -103
- package/dist/deploy/HyperlaneAppChecker.js.map +1 -1
- package/dist/deploy/HyperlaneDeployer.d.ts +3 -3
- package/dist/deploy/HyperlaneDeployer.d.ts.map +1 -1
- package/dist/deploy/HyperlaneDeployer.js +216 -176
- package/dist/deploy/HyperlaneDeployer.js.map +1 -1
- package/dist/deploy/proxy.d.ts +7 -7
- package/dist/deploy/proxy.d.ts.map +1 -1
- package/dist/deploy/proxy.js +27 -12
- package/dist/deploy/proxy.js.map +1 -1
- package/dist/deploy/types.js +1 -1
- package/dist/deploy/types.js.map +1 -1
- package/dist/deploy/verify/ContractVerifier.d.ts.map +1 -1
- package/dist/deploy/verify/ContractVerifier.js +131 -123
- package/dist/deploy/verify/ContractVerifier.js.map +1 -1
- package/dist/deploy/verify/types.d.ts +3 -3
- package/dist/deploy/verify/types.d.ts.map +1 -1
- package/dist/gas/HyperlaneIgp.d.ts +2 -2
- package/dist/gas/HyperlaneIgp.d.ts.map +1 -1
- package/dist/gas/HyperlaneIgp.js.map +1 -1
- package/dist/gas/HyperlaneIgpChecker.d.ts +2 -2
- package/dist/gas/HyperlaneIgpChecker.d.ts.map +1 -1
- package/dist/gas/HyperlaneIgpChecker.js +123 -101
- package/dist/gas/HyperlaneIgpChecker.js.map +1 -1
- package/dist/gas/HyperlaneIgpDeployer.d.ts +2 -2
- package/dist/gas/HyperlaneIgpDeployer.d.ts.map +1 -1
- package/dist/gas/HyperlaneIgpDeployer.js +89 -70
- package/dist/gas/HyperlaneIgpDeployer.js.map +1 -1
- package/dist/gas/contracts.d.ts +1 -1
- package/dist/gas/contracts.d.ts.map +1 -1
- package/dist/gas/contracts.js +1 -6
- package/dist/gas/contracts.js.map +1 -1
- package/dist/gas/token-prices.d.ts +6 -6
- package/dist/gas/token-prices.d.ts.map +1 -1
- package/dist/gas/token-prices.js +54 -37
- package/dist/gas/token-prices.js.map +1 -1
- package/dist/gas/token-prices.test.js +20 -11
- package/dist/gas/token-prices.test.js.map +1 -1
- package/dist/gas/types.d.ts +10 -10
- package/dist/gas/types.d.ts.map +1 -1
- package/dist/gas/types.js +2 -2
- package/dist/gas/types.js.map +1 -1
- package/dist/hook/HyperlaneHookDeployer.d.ts +4 -4
- package/dist/hook/HyperlaneHookDeployer.d.ts.map +1 -1
- package/dist/hook/HyperlaneHookDeployer.js +89 -70
- package/dist/hook/HyperlaneHookDeployer.js.map +1 -1
- package/dist/hook/contracts.d.ts +4 -4
- package/dist/hook/contracts.d.ts.map +1 -1
- package/dist/hook/contracts.js +1 -5
- package/dist/hook/contracts.js.map +1 -1
- package/dist/hook/types.d.ts +7 -7
- package/dist/hook/types.d.ts.map +1 -1
- package/dist/hook/types.js +1 -1
- package/dist/hook/types.js.map +1 -1
- package/dist/index.d.ts +4 -8
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -25
- package/dist/index.js.map +1 -1
- package/dist/ism/HyperlaneIsmFactory.d.ts +3 -3
- package/dist/ism/HyperlaneIsmFactory.d.ts.map +1 -1
- package/dist/ism/HyperlaneIsmFactory.hardhat-test.js +23 -14
- package/dist/ism/HyperlaneIsmFactory.hardhat-test.js.map +1 -1
- package/dist/ism/HyperlaneIsmFactory.js +254 -232
- package/dist/ism/HyperlaneIsmFactory.js.map +1 -1
- package/dist/ism/HyperlaneIsmFactoryDeployer.d.ts.map +1 -1
- package/dist/ism/HyperlaneIsmFactoryDeployer.js +35 -19
- package/dist/ism/HyperlaneIsmFactoryDeployer.js.map +1 -1
- package/dist/ism/contracts.d.ts +1 -1
- package/dist/ism/contracts.d.ts.map +1 -1
- package/dist/ism/types.d.ts +8 -8
- package/dist/ism/types.d.ts.map +1 -1
- package/dist/ism/types.js +1 -1
- package/dist/ism/types.js.map +1 -1
- package/dist/metadata/agentConfig.d.ts +5 -5
- package/dist/metadata/agentConfig.d.ts.map +1 -1
- package/dist/metadata/agentConfig.js +6 -15
- package/dist/metadata/agentConfig.js.map +1 -1
- package/dist/metadata/chainMetadata.test.js +11 -28
- package/dist/metadata/chainMetadata.test.js.map +1 -1
- package/dist/metadata/chainMetadataTypes.d.ts +3 -12
- package/dist/metadata/chainMetadataTypes.d.ts.map +1 -1
- package/dist/metadata/chainMetadataTypes.js +6 -14
- package/dist/metadata/chainMetadataTypes.js.map +1 -1
- package/dist/metadata/deploymentArtifacts.d.ts +5 -5
- package/dist/metadata/deploymentArtifacts.d.ts.map +1 -1
- package/dist/middleware/account/InterchainAccountChecker.d.ts.map +1 -1
- package/dist/middleware/account/InterchainAccountChecker.js +3 -6
- package/dist/middleware/account/InterchainAccountChecker.js.map +1 -1
- package/dist/middleware/account/InterchainAccountDeployer.d.ts +1 -1
- package/dist/middleware/account/InterchainAccountDeployer.d.ts.map +1 -1
- package/dist/middleware/account/InterchainAccountDeployer.js +41 -28
- package/dist/middleware/account/InterchainAccountDeployer.js.map +1 -1
- package/dist/middleware/account/accounts.hardhat-test.js +30 -21
- package/dist/middleware/account/accounts.hardhat-test.js.map +1 -1
- package/dist/middleware/account/contracts.d.ts +1 -1
- package/dist/middleware/account/contracts.d.ts.map +1 -1
- package/dist/middleware/account/contracts.js +1 -5
- package/dist/middleware/account/contracts.js.map +1 -1
- package/dist/middleware/liquidity-layer/LiquidityLayerApp.d.ts.map +1 -1
- package/dist/middleware/liquidity-layer/LiquidityLayerApp.js +151 -129
- package/dist/middleware/liquidity-layer/LiquidityLayerApp.js.map +1 -1
- package/dist/middleware/liquidity-layer/LiquidityLayerRouterDeployer.d.ts +4 -4
- package/dist/middleware/liquidity-layer/LiquidityLayerRouterDeployer.d.ts.map +1 -1
- package/dist/middleware/liquidity-layer/LiquidityLayerRouterDeployer.js +110 -86
- package/dist/middleware/liquidity-layer/LiquidityLayerRouterDeployer.js.map +1 -1
- package/dist/middleware/liquidity-layer/contracts.d.ts +1 -1
- package/dist/middleware/liquidity-layer/contracts.d.ts.map +1 -1
- package/dist/middleware/liquidity-layer/contracts.js +1 -6
- package/dist/middleware/liquidity-layer/contracts.js.map +1 -1
- package/dist/middleware/liquidity-layer/liquidity-layer.hardhat-test.js +47 -43
- package/dist/middleware/liquidity-layer/liquidity-layer.hardhat-test.js.map +1 -1
- package/dist/middleware/query/InterchainQueryDeployer.d.ts +1 -1
- package/dist/middleware/query/InterchainQueryDeployer.d.ts.map +1 -1
- package/dist/middleware/query/InterchainQueryDeployer.js +27 -13
- package/dist/middleware/query/InterchainQueryDeployer.js.map +1 -1
- package/dist/middleware/query/contracts.d.ts +1 -1
- package/dist/middleware/query/contracts.d.ts.map +1 -1
- package/dist/middleware/query/contracts.js +1 -4
- package/dist/middleware/query/contracts.js.map +1 -1
- package/dist/middleware/query/queries.hardhat-test.js +33 -24
- package/dist/middleware/query/queries.hardhat-test.js.map +1 -1
- package/dist/providers/MultiProvider.d.ts +4 -4
- package/dist/providers/MultiProvider.d.ts.map +1 -1
- package/dist/providers/MultiProvider.js +88 -68
- package/dist/providers/MultiProvider.js.map +1 -1
- package/dist/providers/RetryProvider.d.ts +1 -1
- package/dist/providers/RetryProvider.d.ts.map +1 -1
- package/dist/providers/RetryProvider.js +18 -4
- package/dist/providers/RetryProvider.js.map +1 -1
- package/dist/router/GasRouterDeployer.d.ts +2 -2
- package/dist/router/GasRouterDeployer.d.ts.map +1 -1
- package/dist/router/GasRouterDeployer.js +32 -18
- package/dist/router/GasRouterDeployer.js.map +1 -1
- package/dist/router/HyperlaneRouterChecker.js +55 -37
- package/dist/router/HyperlaneRouterChecker.js.map +1 -1
- package/dist/router/HyperlaneRouterDeployer.d.ts +2 -2
- package/dist/router/HyperlaneRouterDeployer.d.ts.map +1 -1
- package/dist/router/HyperlaneRouterDeployer.js +114 -87
- package/dist/router/HyperlaneRouterDeployer.js.map +1 -1
- package/dist/router/ProxiedRouterChecker.js +34 -14
- package/dist/router/ProxiedRouterChecker.js.map +1 -1
- package/dist/router/ProxiedRouterDeployer.js +39 -25
- package/dist/router/ProxiedRouterDeployer.js.map +1 -1
- package/dist/router/RouterApps.d.ts +3 -3
- package/dist/router/RouterApps.d.ts.map +1 -1
- package/dist/router/RouterApps.js +16 -5
- package/dist/router/RouterApps.js.map +1 -1
- package/dist/router/types.d.ts +14 -14
- package/dist/router/types.d.ts.map +1 -1
- package/dist/router/types.js +1 -1
- package/dist/router/types.js.map +1 -1
- package/dist/test/testUtils.d.ts +4 -4
- package/dist/test/testUtils.d.ts.map +1 -1
- package/dist/test/testUtils.js +25 -14
- package/dist/test/testUtils.js.map +1 -1
- package/dist/types.d.ts +5 -5
- package/dist/types.d.ts.map +1 -1
- package/dist/utils/MultiGeneric.js +4 -2
- package/dist/utils/MultiGeneric.js.map +1 -1
- package/dist/utils/fetch.js +16 -8
- package/dist/utils/fetch.js.map +1 -1
- package/dist/utils/filter.d.ts +3 -0
- package/dist/utils/filter.d.ts.map +1 -0
- package/dist/utils/filter.js +13 -0
- package/dist/utils/filter.js.map +1 -0
- package/dist/utils/wagmi.d.ts.map +1 -1
- package/dist/utils/wagmi.js +4 -3
- package/dist/utils/wagmi.js.map +1 -1
- package/package.json +7 -7
- package/dist/consts/agentStartBlocks.d.ts +0 -3
- package/dist/consts/agentStartBlocks.d.ts.map +0 -1
- package/dist/consts/agentStartBlocks.js +0 -28
- package/dist/consts/agentStartBlocks.js.map +0 -1
- package/dist/utils/ids.d.ts +0 -20
- package/dist/utils/ids.d.ts.map +0 -1
- package/dist/utils/ids.js +0 -47
- package/dist/utils/ids.js.map +0 -1
- package/dist/utils/number.d.ts +0 -32
- package/dist/utils/number.d.ts.map +0 -1
- package/dist/utils/number.js +0 -59
- package/dist/utils/number.js.map +0 -1
- package/dist/utils/objects.d.ts +0 -17
- package/dist/utils/objects.d.ts.map +0 -1
- package/dist/utils/objects.js +0 -77
- package/dist/utils/objects.js.map +0 -1
- package/dist/utils/time.d.ts +0 -8
- package/dist/utils/time.d.ts.map +0 -1
- package/dist/utils/time.js +0 -15
- package/dist/utils/time.js.map +0 -1
- package/dist/utils/utils.test.d.ts +0 -2
- package/dist/utils/utils.test.d.ts.map +0 -1
- package/dist/utils/utils.test.js +0 -41
- package/dist/utils/utils.test.js.map +0 -1
|
@@ -1,4 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
2
11
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
12
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
13
|
};
|
|
@@ -18,56 +27,64 @@ class HyperlaneCoreDeployer extends HyperlaneDeployer_1.HyperlaneDeployer {
|
|
|
18
27
|
this.ismFactory = ismFactory;
|
|
19
28
|
this.startingBlockNumbers = {};
|
|
20
29
|
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
30
|
+
deployMailbox(chain, ismConfig, proxyAdmin, owner) {
|
|
31
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
32
|
+
const cachedMailbox = this.readCache(chain, this.factories.mailbox, 'mailbox');
|
|
33
|
+
if (cachedMailbox) {
|
|
34
|
+
// let checker/governor handle cached mailbox default ISM configuration
|
|
35
|
+
// TODO: check if config matches AND deployer is owner?
|
|
36
|
+
return cachedMailbox;
|
|
37
|
+
}
|
|
38
|
+
const defaultIsmAddress = yield this.deployIsm(chain, ismConfig);
|
|
39
|
+
const domain = this.multiProvider.getDomainId(chain);
|
|
40
|
+
return this.deployProxiedContract(chain, 'mailbox', proxyAdmin, [domain], [owner, defaultIsmAddress]);
|
|
41
|
+
});
|
|
31
42
|
}
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
43
|
+
deployValidatorAnnounce(chain, mailboxAddress) {
|
|
44
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
45
|
+
const validatorAnnounce = yield this.deployContract(chain, 'validatorAnnounce', [mailboxAddress]);
|
|
46
|
+
return validatorAnnounce;
|
|
47
|
+
});
|
|
35
48
|
}
|
|
36
|
-
|
|
37
|
-
this
|
|
38
|
-
|
|
39
|
-
|
|
49
|
+
deployIsm(chain, config) {
|
|
50
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
51
|
+
this.logger(`Deploying new ISM to ${chain}`);
|
|
52
|
+
const ism = yield this.ismFactory.deploy(chain, config);
|
|
53
|
+
return ism.address;
|
|
54
|
+
});
|
|
40
55
|
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
.
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
56
|
+
deployContracts(chain, config) {
|
|
57
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
58
|
+
if (config.remove) {
|
|
59
|
+
// skip deploying to chains configured to be removed
|
|
60
|
+
return undefined;
|
|
61
|
+
}
|
|
62
|
+
this.startingBlockNumbers[chain] = yield this.multiProvider
|
|
63
|
+
.getProvider(chain)
|
|
64
|
+
.getBlockNumber();
|
|
65
|
+
const proxyAdmin = yield this.deployContract(chain, 'proxyAdmin', []);
|
|
66
|
+
const mailbox = yield this.deployMailbox(chain, config.defaultIsm, proxyAdmin.address, config.owner);
|
|
67
|
+
const validatorAnnounce = yield this.deployValidatorAnnounce(chain, mailbox.address);
|
|
68
|
+
let timelockController;
|
|
69
|
+
if (config.upgrade) {
|
|
70
|
+
timelockController = yield this.deployTimelock(chain, config.upgrade.timelock);
|
|
71
|
+
yield this.transferOwnershipOfContracts(chain, timelockController.address, { proxyAdmin });
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
// mock this for consistent serialization
|
|
75
|
+
timelockController = core_1.TimelockController__factory.connect(ethers_1.ethers.constants.AddressZero, this.multiProvider.getProvider(chain));
|
|
76
|
+
yield this.transferOwnershipOfContracts(chain, config.owner, {
|
|
77
|
+
mailbox,
|
|
78
|
+
proxyAdmin,
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
return {
|
|
61
82
|
mailbox,
|
|
62
83
|
proxyAdmin,
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
proxyAdmin,
|
|
68
|
-
timelockController,
|
|
69
|
-
validatorAnnounce,
|
|
70
|
-
};
|
|
84
|
+
timelockController,
|
|
85
|
+
validatorAnnounce,
|
|
86
|
+
};
|
|
87
|
+
});
|
|
71
88
|
}
|
|
72
89
|
}
|
|
73
90
|
exports.HyperlaneCoreDeployer = HyperlaneCoreDeployer;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HyperlaneCoreDeployer.js","sourceRoot":"","sources":["../../src/core/HyperlaneCoreDeployer.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"HyperlaneCoreDeployer.js","sourceRoot":"","sources":["../../src/core/HyperlaneCoreDeployer.ts"],"names":[],"mappings":"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"}
|
package/dist/core/TestCoreApp.js
CHANGED
|
@@ -1,51 +1,61 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
2
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
12
|
exports.TestCoreApp = exports.testCoreFactories = void 0;
|
|
4
13
|
const core_1 = require("@hyperlane-xyz/core");
|
|
5
14
|
const utils_1 = require("@hyperlane-xyz/utils");
|
|
6
15
|
const HyperlaneCore_1 = require("./HyperlaneCore");
|
|
7
16
|
const contracts_1 = require("./contracts");
|
|
8
|
-
exports.testCoreFactories = {
|
|
9
|
-
...contracts_1.coreFactories,
|
|
10
|
-
mailbox: new core_1.TestMailbox__factory(),
|
|
11
|
-
};
|
|
17
|
+
exports.testCoreFactories = Object.assign(Object.assign({}, contracts_1.coreFactories), { mailbox: new core_1.TestMailbox__factory() });
|
|
12
18
|
class TestCoreApp extends HyperlaneCore_1.HyperlaneCore {
|
|
13
19
|
getContracts(chain) {
|
|
14
20
|
return super.getContracts(chain);
|
|
15
21
|
}
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
const
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
return responses;
|
|
25
|
-
}
|
|
26
|
-
async processOutboundMessages(origin) {
|
|
27
|
-
const responses = new Map();
|
|
28
|
-
const contracts = this.getContracts(origin);
|
|
29
|
-
const outbox = contracts.mailbox;
|
|
30
|
-
const dispatchFilter = outbox.filters.Dispatch();
|
|
31
|
-
const dispatches = await outbox.queryFilter(dispatchFilter);
|
|
32
|
-
for (const dispatch of dispatches) {
|
|
33
|
-
const destination = dispatch.args.destination;
|
|
34
|
-
if (destination === this.multiProvider.getDomainId(origin)) {
|
|
35
|
-
throw new Error('Dispatched message to local domain');
|
|
22
|
+
processMessages() {
|
|
23
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
24
|
+
const responses = new Map();
|
|
25
|
+
for (const origin of this.chains()) {
|
|
26
|
+
const outbound = yield this.processOutboundMessages(origin);
|
|
27
|
+
const originResponses = new Map();
|
|
28
|
+
this.remoteChains(origin).forEach((destination) => originResponses.set(destination, outbound.get(destination)));
|
|
29
|
+
responses.set(origin, originResponses);
|
|
36
30
|
}
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
31
|
+
return responses;
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
processOutboundMessages(origin) {
|
|
35
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
36
|
+
const responses = new Map();
|
|
37
|
+
const contracts = this.getContracts(origin);
|
|
38
|
+
const outbox = contracts.mailbox;
|
|
39
|
+
const dispatchFilter = outbox.filters.Dispatch();
|
|
40
|
+
const dispatches = yield outbox.queryFilter(dispatchFilter);
|
|
41
|
+
for (const dispatch of dispatches) {
|
|
42
|
+
const destination = dispatch.args.destination;
|
|
43
|
+
if (destination === this.multiProvider.getDomainId(origin)) {
|
|
44
|
+
throw new Error('Dispatched message to local domain');
|
|
45
|
+
}
|
|
46
|
+
const destinationChain = this.multiProvider.getChainName(destination);
|
|
47
|
+
const inbox = this.getContracts(destinationChain).mailbox;
|
|
48
|
+
const id = (0, utils_1.messageId)(dispatch.args.message);
|
|
49
|
+
const delivered = yield inbox.delivered(id);
|
|
50
|
+
if (!delivered) {
|
|
51
|
+
const response = yield inbox.process('0x', dispatch.args.message);
|
|
52
|
+
const destinationResponses = responses.get(destinationChain) || [];
|
|
53
|
+
destinationResponses.push(response);
|
|
54
|
+
responses.set(destinationChain, destinationResponses);
|
|
55
|
+
}
|
|
46
56
|
}
|
|
47
|
-
|
|
48
|
-
|
|
57
|
+
return responses;
|
|
58
|
+
});
|
|
49
59
|
}
|
|
50
60
|
}
|
|
51
61
|
exports.TestCoreApp = TestCoreApp;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TestCoreApp.js","sourceRoot":"","sources":["../../src/core/TestCoreApp.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"TestCoreApp.js","sourceRoot":"","sources":["../../src/core/TestCoreApp.ts"],"names":[],"mappings":";;;;;;;;;;;;AAEA,8CAAwE;AACxE,gDAAiD;AAKjD,mDAAgD;AAChD,2CAA4C;AAE/B,QAAA,iBAAiB,mCACzB,yBAAa,KAChB,OAAO,EAAE,IAAI,2BAAoB,EAAE,IACnC;AAEF,MAAa,WAAY,SAAQ,6BAAa;IAC5C,YAAY,CAAC,KAAgB;QAC3B,OAAO,KAAK,CAAC,YAAY,CAAC,KAAK,CAE9B,CAAC;IACJ,CAAC;IAEK,eAAe;;YAGnB,MAAM,SAAS,GAAG,IAAI,GAAG,EAAE,CAAC;YAC5B,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;gBAClC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,CAAC;gBAC5D,MAAM,eAAe,GAAG,IAAI,GAAG,EAAE,CAAC;gBAClC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,EAAE,CAChD,eAAe,CAAC,GAAG,CAAC,WAAW,EAAE,QAAQ,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,CAC5D,CAAC;gBACF,SAAS,CAAC,GAAG,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;aACxC;YACD,OAAO,SAAS,CAAC;QACnB,CAAC;KAAA;IAEK,uBAAuB,CAC3B,MAAiB;;YAEjB,MAAM,SAAS,GAAG,IAAI,GAAG,EAAkB,CAAC;YAC5C,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;YAC5C,MAAM,MAAM,GAAG,SAAS,CAAC,OAAsB,CAAC;YAEhD,MAAM,cAAc,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YACjD,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;YAC5D,KAAK,MAAM,QAAQ,IAAI,UAAU,EAAE;gBACjC,MAAM,WAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC;gBAC9C,IAAI,WAAW,KAAK,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE;oBAC1D,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;iBACvD;gBACD,MAAM,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;gBACtE,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC,OAAO,CAAC;gBAC1D,MAAM,EAAE,GAAG,IAAA,iBAAS,EAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBAC5C,MAAM,SAAS,GAAG,MAAM,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;gBAC5C,IAAI,CAAC,SAAS,EAAE;oBACd,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;oBAClE,MAAM,oBAAoB,GAAG,SAAS,CAAC,GAAG,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;oBACnE,oBAAoB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;oBACpC,SAAS,CAAC,GAAG,CAAC,gBAAgB,EAAE,oBAAoB,CAAC,CAAC;iBACvD;aACF;YACD,OAAO,SAAS,CAAC;QACnB,CAAC;KAAA;CACF;AAjDD,kCAiDC"}
|
|
@@ -1,4 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
2
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
12
|
exports.TestCoreDeployer = void 0;
|
|
4
13
|
const core_1 = require("@hyperlane-xyz/core");
|
|
@@ -8,12 +17,7 @@ const testUtils_1 = require("../test/testUtils");
|
|
|
8
17
|
const HyperlaneCoreDeployer_1 = require("./HyperlaneCoreDeployer");
|
|
9
18
|
const TestCoreApp_1 = require("./TestCoreApp");
|
|
10
19
|
const contracts_1 = require("./contracts");
|
|
11
|
-
const testCoreFactories = {
|
|
12
|
-
...contracts_1.coreFactories,
|
|
13
|
-
mailbox: new core_1.TestMailbox__factory(),
|
|
14
|
-
interchainGasPaymaster: new core_1.TestInterchainGasPaymaster__factory(),
|
|
15
|
-
testIsm: new core_1.TestMultisigIsm__factory(),
|
|
16
|
-
};
|
|
20
|
+
const testCoreFactories = Object.assign(Object.assign({}, contracts_1.coreFactories), { mailbox: new core_1.TestMailbox__factory(), interchainGasPaymaster: new core_1.TestInterchainGasPaymaster__factory(), testIsm: new core_1.TestMultisigIsm__factory() });
|
|
17
21
|
class TestCoreDeployer extends HyperlaneCoreDeployer_1.HyperlaneCoreDeployer {
|
|
18
22
|
constructor(multiProvider) {
|
|
19
23
|
const ismFactory = new HyperlaneIsmFactory_1.HyperlaneIsmFactory({}, multiProvider);
|
|
@@ -21,16 +25,25 @@ class TestCoreDeployer extends HyperlaneCoreDeployer_1.HyperlaneCoreDeployer {
|
|
|
21
25
|
this.multiProvider = multiProvider;
|
|
22
26
|
}
|
|
23
27
|
// deploy a test ISM instead of a real ISM
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
+
deployIsm(chain) {
|
|
29
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
30
|
+
const testIsm = yield this.deployContractFromFactory(chain, testCoreFactories.testIsm, 'testIsm', []);
|
|
31
|
+
yield testIsm.setAccept(true);
|
|
32
|
+
return testIsm.address;
|
|
33
|
+
});
|
|
28
34
|
}
|
|
29
|
-
|
|
30
|
-
|
|
35
|
+
deploy() {
|
|
36
|
+
const _super = Object.create(null, {
|
|
37
|
+
deploy: { get: () => super.deploy }
|
|
38
|
+
});
|
|
39
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
+
return _super.deploy.call(this, (0, testUtils_1.testCoreConfig)(chains_1.TestChains));
|
|
41
|
+
});
|
|
31
42
|
}
|
|
32
|
-
|
|
33
|
-
return
|
|
43
|
+
deployApp() {
|
|
44
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
45
|
+
return new TestCoreApp_1.TestCoreApp(yield this.deploy(), this.multiProvider);
|
|
46
|
+
});
|
|
34
47
|
}
|
|
35
48
|
}
|
|
36
49
|
exports.TestCoreDeployer = TestCoreDeployer;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TestCoreDeployer.js","sourceRoot":"","sources":["../../src/core/TestCoreDeployer.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"TestCoreDeployer.js","sourceRoot":"","sources":["../../src/core/TestCoreDeployer.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,8CAI6B;AAE7B,6CAA8C;AAE9C,oEAAiE;AAEjE,iDAAmD;AAGnD,mEAAgE;AAChE,+CAA4C;AAC5C,2CAA2D;AAE3D,MAAM,iBAAiB,mCAClB,yBAAa,KAChB,OAAO,EAAE,IAAI,2BAAoB,EAAE,EACnC,sBAAsB,EAAE,IAAI,0CAAmC,EAAE,EACjE,OAAO,EAAE,IAAI,+BAAwB,EAAE,GACxC,CAAC;AAEF,MAAa,gBAAiB,SAAQ,6CAAqB;IACzD,YAA4B,aAA4B;QACtD,MAAM,UAAU,GAAG,IAAI,yCAAmB,CAAC,EAAE,EAAE,aAAa,CAAC,CAAC;QAC9D,KAAK,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;QAFP,kBAAa,GAAb,aAAa,CAAe;IAGxD,CAAC;IAED,0CAA0C;IACpC,SAAS,CAAC,KAAgB;;YAC9B,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,yBAAyB,CAClD,KAAK,EACL,iBAAiB,CAAC,OAAO,EACzB,SAAS,EACT,EAAE,CACH,CAAC;YACF,MAAM,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YAC9B,OAAO,OAAO,CAAC,OAAO,CAAC;QACzB,CAAC;KAAA;IAEK,MAAM;;;;;YACV,OAAO,OAAM,MAAM,YAAC,IAAA,0BAAc,EAAC,mBAAU,CAAC,EAAE;QAClD,CAAC;KAAA;IAEK,SAAS;;YACb,OAAO,IAAI,yBAAW,CAAC,MAAM,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAClE,CAAC;KAAA;CACF;AAzBD,4CAyBC"}
|
package/dist/core/contracts.d.ts
CHANGED
|
@@ -5,5 +5,5 @@ export declare const coreFactories: {
|
|
|
5
5
|
mailbox: Mailbox__factory;
|
|
6
6
|
timelockController: TimelockController__factory;
|
|
7
7
|
};
|
|
8
|
-
export type CoreFactories = typeof coreFactories;
|
|
8
|
+
export declare type CoreFactories = typeof coreFactories;
|
|
9
9
|
//# sourceMappingURL=contracts.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contracts.d.ts","sourceRoot":"","sources":["../../src/core/contracts.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,gBAAgB,EAChB,mBAAmB,EACnB,2BAA2B,EAC3B,0BAA0B,EAC3B,MAAM,qBAAqB,CAAC;AAE7B,eAAO,MAAM,aAAa;;;;;CAKzB,CAAC;AAEF,
|
|
1
|
+
{"version":3,"file":"contracts.d.ts","sourceRoot":"","sources":["../../src/core/contracts.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,gBAAgB,EAChB,mBAAmB,EACnB,2BAA2B,EAC3B,0BAA0B,EAC3B,MAAM,qBAAqB,CAAC;AAE7B,eAAO,MAAM,aAAa;;;;;CAKzB,CAAC;AAEF,oBAAY,aAAa,GAAG,OAAO,aAAa,CAAC"}
|
package/dist/core/events.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import type { DispatchEvent, ProcessEvent } from '@hyperlane-xyz/core/dist/contracts/Mailbox';
|
|
2
2
|
export { DispatchEvent, ProcessEvent };
|
|
3
|
-
export type HyperlaneLifecyleEvent = ProcessEvent | DispatchEvent;
|
|
3
|
+
export declare type HyperlaneLifecyleEvent = ProcessEvent | DispatchEvent;
|
|
4
4
|
//# sourceMappingURL=events.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../src/core/events.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,aAAa,EACb,YAAY,EACb,MAAM,4CAA4C,CAAC;AAEpD,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC;AAEvC,
|
|
1
|
+
{"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../src/core/events.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,aAAa,EACb,YAAY,EACb,MAAM,4CAA4C,CAAC;AAEpD,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC;AAEvC,oBAAY,sBAAsB,GAAG,YAAY,GAAG,aAAa,CAAC"}
|
|
@@ -1,4 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
2
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
12
|
require("@nomiclabs/hardhat-ethers");
|
|
4
13
|
require("@nomiclabs/hardhat-waffle");
|
|
@@ -12,42 +21,42 @@ const TestCoreDeployer_1 = require("./TestCoreDeployer");
|
|
|
12
21
|
const localChain = chains_1.Chains.test1;
|
|
13
22
|
const remoteChain = chains_1.Chains.test2;
|
|
14
23
|
const message = '0xdeadbeef';
|
|
15
|
-
describe('TestCoreDeployer',
|
|
24
|
+
describe('TestCoreDeployer', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
16
25
|
let testCoreApp, localMailbox, remoteMailbox, dispatchReceipt;
|
|
17
|
-
beforeEach(
|
|
18
|
-
const [signer] =
|
|
26
|
+
beforeEach(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
27
|
+
const [signer] = yield hardhat_1.ethers.getSigners();
|
|
19
28
|
const multiProvider = MultiProvider_1.MultiProvider.createTestMultiProvider({ signer });
|
|
20
29
|
const deployer = new TestCoreDeployer_1.TestCoreDeployer(multiProvider);
|
|
21
|
-
testCoreApp =
|
|
22
|
-
const recipient =
|
|
30
|
+
testCoreApp = yield deployer.deployApp();
|
|
31
|
+
const recipient = yield new core_1.TestRecipient__factory(signer).deploy();
|
|
23
32
|
localMailbox = testCoreApp.getContracts(localChain).mailbox;
|
|
24
|
-
const dispatchResponse = localMailbox.dispatch(multiProvider.getDomainId(remoteChain), utils_1.
|
|
25
|
-
|
|
26
|
-
dispatchReceipt =
|
|
33
|
+
const dispatchResponse = localMailbox.dispatch(multiProvider.getDomainId(remoteChain), (0, utils_1.addressToBytes32)(recipient.address), message);
|
|
34
|
+
yield (0, chai_1.expect)(dispatchResponse).to.emit(localMailbox, 'Dispatch');
|
|
35
|
+
dispatchReceipt = yield testCoreApp.multiProvider.handleTx(localChain, dispatchResponse);
|
|
27
36
|
remoteMailbox = testCoreApp.getContracts(remoteChain).mailbox;
|
|
28
|
-
|
|
29
|
-
});
|
|
30
|
-
it('processes outbound messages for a single domain',
|
|
31
|
-
const responses =
|
|
37
|
+
yield (0, chai_1.expect)(remoteMailbox.dispatch(multiProvider.getDomainId(localChain), (0, utils_1.addressToBytes32)(recipient.address), message)).to.emit(remoteMailbox, 'Dispatch');
|
|
38
|
+
}));
|
|
39
|
+
it('processes outbound messages for a single domain', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
40
|
+
const responses = yield testCoreApp.processOutboundMessages(localChain);
|
|
32
41
|
(0, chai_1.expect)(responses.get(remoteChain).length).to.equal(1);
|
|
33
|
-
});
|
|
34
|
-
it('processes outbound messages for two domains',
|
|
35
|
-
const localResponses =
|
|
42
|
+
}));
|
|
43
|
+
it('processes outbound messages for two domains', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
44
|
+
const localResponses = yield testCoreApp.processOutboundMessages(localChain);
|
|
36
45
|
(0, chai_1.expect)(localResponses.get(remoteChain).length).to.equal(1);
|
|
37
|
-
const remoteResponses =
|
|
46
|
+
const remoteResponses = yield testCoreApp.processOutboundMessages(remoteChain);
|
|
38
47
|
(0, chai_1.expect)(remoteResponses.get(localChain).length).to.equal(1);
|
|
39
|
-
});
|
|
40
|
-
it('processes all messages',
|
|
41
|
-
const responses =
|
|
48
|
+
}));
|
|
49
|
+
it('processes all messages', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
50
|
+
const responses = yield testCoreApp.processMessages();
|
|
42
51
|
(0, chai_1.expect)(responses.get(localChain).get(remoteChain).length).to.equal(1);
|
|
43
52
|
(0, chai_1.expect)(responses.get(remoteChain).get(localChain).length).to.equal(1);
|
|
44
|
-
});
|
|
45
|
-
it('waits on message processing receipts',
|
|
46
|
-
const [receipts] =
|
|
53
|
+
}));
|
|
54
|
+
it('waits on message processing receipts', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
55
|
+
const [receipts] = yield Promise.all([
|
|
47
56
|
testCoreApp.waitForMessageProcessing(dispatchReceipt),
|
|
48
57
|
testCoreApp.processOutboundMessages(localChain),
|
|
49
58
|
]);
|
|
50
59
|
(0, chai_1.expect)(receipts).to.have.length(1);
|
|
51
|
-
});
|
|
52
|
-
});
|
|
60
|
+
}));
|
|
61
|
+
}));
|
|
53
62
|
//# sourceMappingURL=testHyperlaneDeploy.hardhat-test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"testHyperlaneDeploy.hardhat-test.js","sourceRoot":"","sources":["../../src/core/testHyperlaneDeploy.hardhat-test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"testHyperlaneDeploy.hardhat-test.js","sourceRoot":"","sources":["../../src/core/testHyperlaneDeploy.hardhat-test.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,qCAAmC;AACnC,qCAAmC;AACnC,+BAA8B;AAE9B,qCAAiC;AAEjC,8CAA0E;AAC1E,gDAAwD;AAExD,6CAA0C;AAC1C,8DAA2D;AAG3D,yDAAsD;AAEtD,MAAM,UAAU,GAAG,eAAM,CAAC,KAAK,CAAC;AAChC,MAAM,WAAW,GAAG,eAAM,CAAC,KAAK,CAAC;AACjC,MAAM,OAAO,GAAG,YAAY,CAAC;AAE7B,QAAQ,CAAC,kBAAkB,EAAE,GAAS,EAAE;IACtC,IAAI,WAAwB,EAC1B,YAAyB,EACzB,aAA0B,EAC1B,eAAgC,CAAC;IAEnC,UAAU,CAAC,GAAS,EAAE;QACpB,MAAM,CAAC,MAAM,CAAC,GAAG,MAAM,gBAAM,CAAC,UAAU,EAAE,CAAC;QAE3C,MAAM,aAAa,GAAG,6BAAa,CAAC,uBAAuB,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QACxE,MAAM,QAAQ,GAAG,IAAI,mCAAgB,CAAC,aAAa,CAAC,CAAC;QACrD,WAAW,GAAG,MAAM,QAAQ,CAAC,SAAS,EAAE,CAAC;QAEzC,MAAM,SAAS,GAAG,MAAM,IAAI,6BAAsB,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC;QACpE,YAAY,GAAG,WAAW,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC;QAE5D,MAAM,gBAAgB,GAAG,YAAY,CAAC,QAAQ,CAC5C,aAAa,CAAC,WAAW,CAAC,WAAW,CAAC,EACtC,IAAA,wBAAgB,EAAC,SAAS,CAAC,OAAO,CAAC,EACnC,OAAO,CACR,CAAC;QACF,MAAM,IAAA,aAAM,EAAC,gBAAgB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;QACjE,eAAe,GAAG,MAAM,WAAW,CAAC,aAAa,CAAC,QAAQ,CACxD,UAAU,EACV,gBAAgB,CACjB,CAAC;QACF,aAAa,GAAG,WAAW,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC;QAC9D,MAAM,IAAA,aAAM,EACV,aAAa,CAAC,QAAQ,CACpB,aAAa,CAAC,WAAW,CAAC,UAAU,CAAC,EACrC,IAAA,wBAAgB,EAAC,SAAS,CAAC,OAAO,CAAC,EACnC,OAAO,CACR,CACF,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;IACvC,CAAC,CAAA,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,GAAS,EAAE;QAC/D,MAAM,SAAS,GAAG,MAAM,WAAW,CAAC,uBAAuB,CAAC,UAAU,CAAC,CAAC;QACxE,IAAA,aAAM,EAAC,SAAS,CAAC,GAAG,CAAC,WAAW,CAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACzD,CAAC,CAAA,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,GAAS,EAAE;QAC3D,MAAM,cAAc,GAAG,MAAM,WAAW,CAAC,uBAAuB,CAC9D,UAAU,CACX,CAAC;QACF,IAAA,aAAM,EAAC,cAAc,CAAC,GAAG,CAAC,WAAW,CAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC5D,MAAM,eAAe,GAAG,MAAM,WAAW,CAAC,uBAAuB,CAC/D,WAAW,CACZ,CAAC;QACF,IAAA,aAAM,EAAC,eAAe,CAAC,GAAG,CAAC,UAAU,CAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC9D,CAAC,CAAA,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE,GAAS,EAAE;QACtC,MAAM,SAAS,GAAG,MAAM,WAAW,CAAC,eAAe,EAAE,CAAC;QACtD,IAAA,aAAM,EAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAE,CAAC,GAAG,CAAC,WAAW,CAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACxE,IAAA,aAAM,EAAC,SAAS,CAAC,GAAG,CAAC,WAAW,CAAE,CAAC,GAAG,CAAC,UAAU,CAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC1E,CAAC,CAAA,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE,GAAS,EAAE;QACpD,MAAM,CAAC,QAAQ,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YACnC,WAAW,CAAC,wBAAwB,CAAC,eAAe,CAAC;YACrD,WAAW,CAAC,uBAAuB,CAAC,UAAU,CAAC;SAChD,CAAC,CAAC;QACH,IAAA,aAAM,EAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;IACrC,CAAC,CAAA,CAAC,CAAC;AACL,CAAC,CAAA,CAAC,CAAC"}
|
package/dist/core/types.d.ts
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { Mailbox } from '@hyperlane-xyz/core';
|
|
2
|
-
import type {
|
|
2
|
+
import type { Address } from '@hyperlane-xyz/utils';
|
|
3
3
|
import { UpgradeConfig } from '../deploy/proxy';
|
|
4
4
|
import type { CheckerViolation } from '../deploy/types';
|
|
5
5
|
import { IsmConfig } from '../ism/types';
|
|
6
6
|
import { ChainName } from '../types';
|
|
7
|
-
export type CoreConfig = {
|
|
7
|
+
export declare type CoreConfig = {
|
|
8
8
|
defaultIsm: IsmConfig;
|
|
9
|
-
owner:
|
|
9
|
+
owner: Address;
|
|
10
10
|
remove?: boolean;
|
|
11
11
|
upgrade?: UpgradeConfig;
|
|
12
12
|
};
|
|
@@ -24,13 +24,13 @@ export interface MailboxViolation extends CheckerViolation {
|
|
|
24
24
|
mailboxType: MailboxViolationType;
|
|
25
25
|
}
|
|
26
26
|
export interface MailboxMultisigIsmViolation extends MailboxViolation {
|
|
27
|
-
actual:
|
|
27
|
+
actual: Address;
|
|
28
28
|
expected: IsmConfig;
|
|
29
29
|
}
|
|
30
30
|
export interface ValidatorAnnounceViolation extends CheckerViolation {
|
|
31
31
|
type: CoreViolationType.ValidatorAnnounce;
|
|
32
32
|
chain: ChainName;
|
|
33
|
-
validator:
|
|
33
|
+
validator: Address;
|
|
34
34
|
actual: boolean;
|
|
35
35
|
expected: boolean;
|
|
36
36
|
}
|
package/dist/core/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/core/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/core/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAEpD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAErC,oBAAY,UAAU,GAAG;IACvB,UAAU,EAAE,SAAS,CAAC;IACtB,KAAK,EAAE,OAAO,CAAC;IACf,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,EAAE,aAAa,CAAC;CACzB,CAAC;AAEF,oBAAY,iBAAiB;IAC3B,OAAO,YAAY;IACnB,iBAAiB,sBAAsB;IACvC,iBAAiB,sBAAsB;CACxC;AAED,oBAAY,oBAAoB;IAC9B,UAAU,eAAe;CAC1B;AAED,MAAM,WAAW,gBAAiB,SAAQ,gBAAgB;IACxD,IAAI,EAAE,iBAAiB,CAAC,OAAO,CAAC;IAChC,QAAQ,EAAE,OAAO,CAAC;IAClB,WAAW,EAAE,oBAAoB,CAAC;CACnC;AAED,MAAM,WAAW,2BAA4B,SAAQ,gBAAgB;IACnE,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,MAAM,WAAW,0BAA2B,SAAQ,gBAAgB;IAClE,IAAI,EAAE,iBAAiB,CAAC,iBAAiB,CAAC;IAC1C,KAAK,EAAE,SAAS,CAAC;IACjB,SAAS,EAAE,OAAO,CAAC;IACnB,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,OAAO,CAAC;CACnB"}
|
package/dist/core/types.js
CHANGED
|
@@ -6,9 +6,9 @@ var CoreViolationType;
|
|
|
6
6
|
CoreViolationType["Mailbox"] = "Mailbox";
|
|
7
7
|
CoreViolationType["ConnectionManager"] = "ConnectionManager";
|
|
8
8
|
CoreViolationType["ValidatorAnnounce"] = "ValidatorAnnounce";
|
|
9
|
-
})(CoreViolationType
|
|
9
|
+
})(CoreViolationType = exports.CoreViolationType || (exports.CoreViolationType = {}));
|
|
10
10
|
var MailboxViolationType;
|
|
11
11
|
(function (MailboxViolationType) {
|
|
12
12
|
MailboxViolationType["DefaultIsm"] = "DefaultIsm";
|
|
13
|
-
})(MailboxViolationType
|
|
13
|
+
})(MailboxViolationType = exports.MailboxViolationType || (exports.MailboxViolationType = {}));
|
|
14
14
|
//# sourceMappingURL=types.js.map
|
package/dist/core/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/core/types.ts"],"names":[],"mappings":";;;AAeA,IAAY,iBAIX;AAJD,WAAY,iBAAiB;IAC3B,wCAAmB,CAAA;IACnB,4DAAuC,CAAA;IACvC,4DAAuC,CAAA;AACzC,CAAC,EAJW,iBAAiB,
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/core/types.ts"],"names":[],"mappings":";;;AAeA,IAAY,iBAIX;AAJD,WAAY,iBAAiB;IAC3B,wCAAmB,CAAA;IACnB,4DAAuC,CAAA;IACvC,4DAAuC,CAAA;AACzC,CAAC,EAJW,iBAAiB,GAAjB,yBAAiB,KAAjB,yBAAiB,QAI5B;AAED,IAAY,oBAEX;AAFD,WAAY,oBAAoB;IAC9B,iDAAyB,CAAA;AAC3B,CAAC,EAFW,oBAAoB,GAApB,4BAAoB,KAApB,4BAAoB,QAE/B"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Ownable } from '@hyperlane-xyz/core';
|
|
2
|
-
import
|
|
2
|
+
import { Address } from '@hyperlane-xyz/utils';
|
|
3
3
|
import { HyperlaneApp } from '../HyperlaneApp';
|
|
4
4
|
import { MultiProvider } from '../providers/MultiProvider';
|
|
5
5
|
import { ChainMap, ChainName } from '../types';
|
|
@@ -21,7 +21,7 @@ export declare abstract class HyperlaneAppChecker<App extends HyperlaneApp<any>,
|
|
|
21
21
|
ownables(chain: ChainName): Promise<{
|
|
22
22
|
[key: string]: Ownable;
|
|
23
23
|
}>;
|
|
24
|
-
protected checkOwnership(chain: ChainName, owner:
|
|
24
|
+
protected checkOwnership(chain: ChainName, owner: Address, ownableOverrides?: Record<string, Address>): Promise<void>;
|
|
25
25
|
expectViolations(violationCounts: Record<string, number>): void;
|
|
26
26
|
expectEmpty(): void;
|
|
27
27
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HyperlaneAppChecker.d.ts","sourceRoot":"","sources":["../../src/deploy/HyperlaneAppChecker.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAsB,MAAM,qBAAqB,CAAC;AAClE,OAAO,
|
|
1
|
+
{"version":3,"file":"HyperlaneAppChecker.d.ts","sourceRoot":"","sources":["../../src/deploy/HyperlaneAppChecker.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAsB,MAAM,qBAAqB,CAAC;AAClE,OAAO,EACL,OAAO,EAKR,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAE/C,OAAO,EAAE,aAAa,EAAuB,MAAM,SAAS,CAAC;AAC7D,OAAO,EAGL,gBAAgB,EAKjB,MAAM,SAAS,CAAC;AAEjB,8BAAsB,mBAAmB,CACvC,GAAG,SAAS,YAAY,CAAC,GAAG,CAAC,EAC7B,MAAM;IAEN,QAAQ,CAAC,aAAa,EAAE,aAAa,CAAC;IACtC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC;IAClB,QAAQ,CAAC,SAAS,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC;IACrC,QAAQ,CAAC,UAAU,EAAE,gBAAgB,EAAE,CAAC;gBAGtC,aAAa,EAAE,aAAa,EAC5B,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,QAAQ,CAAC,MAAM,CAAC;IAQ7B,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAE9C,KAAK,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;IAiB9B,YAAY,CAAC,SAAS,EAAE,gBAAgB,GAAG,IAAI;IAIzC,qBAAqB,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IA6BtD,YAAY,CAChB,KAAK,EAAE,SAAS,EAChB,aAAa,EAAE,aAAa,GAC3B,OAAO,CAAC,IAAI,CAAC;IAoDhB,OAAO,CAAC,sBAAsB;IAOxB,aAAa,CACjB,KAAK,EAAE,SAAS,EAChB,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,MAAM,EACf,sBAAsB,EAAE,MAAM,EAAE,EAChC,yBAAyB,GAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,MAAiB,GACjE,OAAO,CAAC,IAAI,CAAC;IAiBV,QAAQ,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;KAAE,CAAC;cAKrD,cAAc,CAC5B,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE,OAAO,EACd,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GACzC,OAAO,CAAC,IAAI,CAAC;IAmBhB,gBAAgB,CAAC,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,IAAI;IAgB/D,WAAW,IAAI,IAAI;CAIpB"}
|