@hyperlane-xyz/sdk 1.0.0-beta2 → 1.0.0-beta4
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/consts/chainConnectionConfigs.d.ts +24 -13
- package/dist/consts/chainConnectionConfigs.d.ts.map +1 -1
- package/dist/consts/chainConnectionConfigs.js +139 -26
- package/dist/consts/chainConnectionConfigs.js.map +1 -1
- package/dist/consts/chainMetadata.d.ts +26 -80
- package/dist/consts/chainMetadata.d.ts.map +1 -1
- package/dist/consts/chainMetadata.js +97 -481
- package/dist/consts/chainMetadata.js.map +1 -1
- package/dist/consts/chains.d.ts +16 -18
- package/dist/consts/chains.d.ts.map +1 -1
- package/dist/consts/chains.js +15 -29
- package/dist/consts/chains.js.map +1 -1
- package/dist/consts/environments/index.d.ts +1221 -177
- package/dist/consts/environments/index.d.ts.map +1 -1
- package/dist/consts/environments/index.js +10 -4
- package/dist/consts/environments/index.js.map +1 -1
- package/dist/consts/environments/mainnet.json +600 -56
- package/dist/consts/environments/test.json +96 -27
- package/dist/consts/environments/testnet2.json +610 -66
- package/dist/consts/metamask.d.ts +17 -0
- package/dist/consts/metamask.d.ts.map +1 -0
- package/dist/consts/metamask.js +50 -0
- package/dist/consts/metamask.js.map +1 -0
- package/dist/contracts.d.ts +1 -2
- package/dist/contracts.d.ts.map +1 -1
- package/dist/contracts.js.map +1 -1
- package/dist/core/HyperlaneCore.d.ts +1232 -182
- package/dist/core/HyperlaneCore.d.ts.map +1 -1
- package/dist/core/HyperlaneCore.js +30 -20
- package/dist/core/HyperlaneCore.js.map +1 -1
- package/dist/core/TestCoreApp.d.ts +12 -6
- package/dist/core/TestCoreApp.d.ts.map +1 -1
- package/dist/core/TestCoreApp.js +9 -7
- package/dist/core/TestCoreApp.js.map +1 -1
- package/dist/core/TestCoreDeployer.d.ts +5 -5
- package/dist/core/TestCoreDeployer.d.ts.map +1 -1
- package/dist/core/TestCoreDeployer.js +44 -12
- package/dist/core/TestCoreDeployer.js.map +1 -1
- package/dist/core/contracts.d.ts +22 -10
- package/dist/core/contracts.d.ts.map +1 -1
- package/dist/core/contracts.js +8 -8
- package/dist/core/contracts.js.map +1 -1
- package/dist/core/events.d.ts +2 -1
- package/dist/core/events.d.ts.map +1 -1
- package/dist/core/message.d.ts +21 -6
- package/dist/core/message.d.ts.map +1 -1
- package/dist/core/message.js +34 -9
- package/dist/core/message.js.map +1 -1
- package/dist/core/testHyperlaneDeploy.hardhat-test.js +6 -6
- package/dist/core/testHyperlaneDeploy.hardhat-test.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 +3 -7
- package/dist/deploy/HyperlaneAppChecker.js.map +1 -1
- package/dist/deploy/HyperlaneDeployer.d.ts +12 -7
- package/dist/deploy/HyperlaneDeployer.d.ts.map +1 -1
- package/dist/deploy/HyperlaneDeployer.js +40 -65
- package/dist/deploy/HyperlaneDeployer.js.map +1 -1
- package/dist/deploy/core/HyperlaneCoreChecker.d.ts +7 -3
- package/dist/deploy/core/HyperlaneCoreChecker.d.ts.map +1 -1
- package/dist/deploy/core/HyperlaneCoreChecker.js +127 -41
- package/dist/deploy/core/HyperlaneCoreChecker.js.map +1 -1
- package/dist/deploy/core/HyperlaneCoreDeployer.d.ts +19 -16
- package/dist/deploy/core/HyperlaneCoreDeployer.d.ts.map +1 -1
- package/dist/deploy/core/HyperlaneCoreDeployer.js +71 -50
- package/dist/deploy/core/HyperlaneCoreDeployer.js.map +1 -1
- package/dist/deploy/core/types.d.ts +28 -15
- package/dist/deploy/core/types.d.ts.map +1 -1
- package/dist/deploy/core/types.js +12 -8
- package/dist/deploy/core/types.js.map +1 -1
- package/dist/deploy/middleware/LiquidityLayerApp.d.ts +12 -4
- package/dist/deploy/middleware/LiquidityLayerApp.d.ts.map +1 -1
- package/dist/deploy/middleware/LiquidityLayerApp.js +87 -14
- package/dist/deploy/middleware/LiquidityLayerApp.js.map +1 -1
- package/dist/deploy/middleware/LiquidityLayerRouterDeployer.d.ts +17 -6
- package/dist/deploy/middleware/LiquidityLayerRouterDeployer.d.ts.map +1 -1
- package/dist/deploy/middleware/LiquidityLayerRouterDeployer.js +50 -20
- package/dist/deploy/middleware/LiquidityLayerRouterDeployer.js.map +1 -1
- package/dist/deploy/middleware/TokenBridgeApp.d.ts +26 -0
- package/dist/deploy/middleware/TokenBridgeApp.d.ts.map +1 -0
- package/dist/deploy/middleware/TokenBridgeApp.js +115 -0
- package/dist/deploy/middleware/TokenBridgeApp.js.map +1 -0
- package/dist/deploy/middleware/TokenBridgeRouterDeployer.d.ts +33 -0
- package/dist/deploy/middleware/TokenBridgeRouterDeployer.d.ts.map +1 -0
- package/dist/deploy/middleware/TokenBridgeRouterDeployer.js +93 -0
- package/dist/deploy/middleware/TokenBridgeRouterDeployer.js.map +1 -0
- package/dist/deploy/middleware/V2CompatibilityMiddlewareDeployer.d.ts +17 -0
- package/dist/deploy/middleware/V2CompatibilityMiddlewareDeployer.d.ts.map +1 -0
- package/dist/deploy/middleware/V2CompatibilityMiddlewareDeployer.js +42 -0
- package/dist/deploy/middleware/V2CompatibilityMiddlewareDeployer.js.map +1 -0
- package/dist/deploy/middleware/deploy.d.ts.map +1 -1
- package/dist/deploy/middleware/deploy.js +2 -10
- package/dist/deploy/middleware/deploy.js.map +1 -1
- package/dist/deploy/proxy.d.ts +6 -7
- package/dist/deploy/proxy.d.ts.map +1 -1
- package/dist/deploy/proxy.js +10 -18
- package/dist/deploy/proxy.js.map +1 -1
- package/dist/deploy/router/HyperlaneRouterChecker.d.ts +1 -0
- package/dist/deploy/router/HyperlaneRouterChecker.d.ts.map +1 -1
- package/dist/deploy/router/HyperlaneRouterChecker.js +9 -0
- package/dist/deploy/router/HyperlaneRouterChecker.js.map +1 -1
- package/dist/deploy/router/HyperlaneRouterDeployer.d.ts.map +1 -1
- package/dist/deploy/router/HyperlaneRouterDeployer.js +15 -17
- package/dist/deploy/router/HyperlaneRouterDeployer.js.map +1 -1
- package/dist/domains.d.ts +1 -1
- package/dist/domains.d.ts.map +1 -1
- package/dist/events.js +16 -16
- package/dist/events.js.map +1 -1
- package/dist/gas/calculator.d.ts.map +1 -1
- package/dist/gas/calculator.js +6 -11
- package/dist/gas/calculator.js.map +1 -1
- package/dist/gas/calculator.test.js +9 -6
- package/dist/gas/calculator.test.js.map +1 -1
- package/dist/index.d.ts +11 -10
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +8 -11
- package/dist/index.js.map +1 -1
- package/dist/middleware/accounts.test.d.ts +2 -0
- package/dist/middleware/accounts.test.d.ts.map +1 -0
- package/dist/middleware/accounts.test.js +61 -0
- package/dist/middleware/accounts.test.js.map +1 -0
- package/dist/middleware/liquidity-layer.hardhat-test.js +47 -20
- package/dist/middleware/liquidity-layer.hardhat-test.js.map +1 -1
- package/dist/middleware/queries.test.d.ts +2 -0
- package/dist/middleware/queries.test.d.ts.map +1 -0
- package/dist/middleware/queries.test.js +69 -0
- package/dist/middleware/queries.test.js.map +1 -0
- package/dist/middleware/tokenbridge.hardhat-test.d.ts +2 -0
- package/dist/middleware/tokenbridge.hardhat-test.d.ts.map +1 -0
- package/dist/middleware/tokenbridge.hardhat-test.js +89 -0
- package/dist/middleware/tokenbridge.hardhat-test.js.map +1 -0
- package/dist/middleware.d.ts +6 -1
- package/dist/middleware.d.ts.map +1 -1
- package/dist/middleware.js +5 -1
- package/dist/middleware.js.map +1 -1
- package/dist/providers/ChainConnection.d.ts +1 -1
- package/dist/providers/ChainConnection.d.ts.map +1 -1
- package/dist/providers/ChainConnection.js +3 -2
- package/dist/providers/ChainConnection.js.map +1 -1
- package/dist/providers/MultiProvider.d.ts.map +1 -1
- package/dist/providers/MultiProvider.js +1 -1
- package/dist/providers/MultiProvider.js.map +1 -1
- package/dist/proxy.d.ts +4 -2
- package/dist/proxy.d.ts.map +1 -1
- package/dist/proxy.js +1 -1
- package/dist/proxy.js.map +1 -1
- package/dist/router.d.ts +1 -2
- package/dist/router.d.ts.map +1 -1
- package/dist/test/envSubsetDeployer/app.js +2 -2
- package/dist/test/envSubsetDeployer/app.js.map +1 -1
- package/dist/tokenBridge.d.ts +10 -0
- package/dist/tokenBridge.d.ts.map +1 -0
- package/dist/tokenBridge.js +9 -0
- package/dist/tokenBridge.js.map +1 -0
- package/dist/types.d.ts +3 -3
- package/dist/types.d.ts.map +1 -1
- package/dist/utils/objects.d.ts +1 -0
- package/dist/utils/objects.d.ts.map +1 -1
- package/dist/utils/objects.js +5 -1
- package/dist/utils/objects.js.map +1 -1
- package/package.json +7 -6
package/dist/core/message.js
CHANGED
|
@@ -9,7 +9,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
9
9
|
});
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.HyperlaneMessage = exports.MessageStatus = exports.resolveChains = exports.resolveId = exports.resolveDomain = void 0;
|
|
12
|
+
exports.HyperlaneMessage = exports.InboxMessageStatus = exports.MessageStatus = exports.resolveChains = exports.resolveId = exports.resolveDomain = void 0;
|
|
13
13
|
const ethers_1 = require("ethers");
|
|
14
14
|
const core_1 = require("@hyperlane-xyz/core");
|
|
15
15
|
const utils_1 = require("@hyperlane-xyz/utils");
|
|
@@ -38,6 +38,11 @@ var MessageStatus;
|
|
|
38
38
|
MessageStatus[MessageStatus["Relayed"] = 2] = "Relayed";
|
|
39
39
|
MessageStatus[MessageStatus["Processed"] = 3] = "Processed";
|
|
40
40
|
})(MessageStatus = exports.MessageStatus || (exports.MessageStatus = {}));
|
|
41
|
+
var InboxMessageStatus;
|
|
42
|
+
(function (InboxMessageStatus) {
|
|
43
|
+
InboxMessageStatus[InboxMessageStatus["None"] = 0] = "None";
|
|
44
|
+
InboxMessageStatus[InboxMessageStatus["Processed"] = 1] = "Processed";
|
|
45
|
+
})(InboxMessageStatus = exports.InboxMessageStatus || (exports.InboxMessageStatus = {}));
|
|
41
46
|
// TODO: move HyperlaneMessage into HyperlaneCore app
|
|
42
47
|
/**
|
|
43
48
|
* A deserialized Hyperlane message.
|
|
@@ -49,8 +54,10 @@ class HyperlaneMessage {
|
|
|
49
54
|
this.message = utils_1.utils.parseMessage(dispatch.event.args.message);
|
|
50
55
|
this.dispatch = dispatch;
|
|
51
56
|
const messageChains = (0, exports.resolveChains)(this.message);
|
|
52
|
-
|
|
53
|
-
|
|
57
|
+
const mailboxes = core.getMailboxPair(messageChains.origin, // TODO: Fix never type that results from Exclude<T, T>
|
|
58
|
+
messageChains.destination);
|
|
59
|
+
this.outbox = mailboxes.originOutbox;
|
|
60
|
+
this.inbox = mailboxes.destinationInbox;
|
|
54
61
|
this.cache = {};
|
|
55
62
|
}
|
|
56
63
|
/**
|
|
@@ -69,7 +76,7 @@ class HyperlaneMessage {
|
|
|
69
76
|
*/
|
|
70
77
|
static fromReceipt(multiProvider, core, nameOrDomain, receipt) {
|
|
71
78
|
const messages = [];
|
|
72
|
-
const outbox = new core_1.
|
|
79
|
+
const outbox = new core_1.Outbox__factory().interface;
|
|
73
80
|
const chain = (0, exports.resolveDomain)(nameOrDomain);
|
|
74
81
|
const provider = multiProvider.getChainConnection(chain).provider;
|
|
75
82
|
for (const log of receipt.logs) {
|
|
@@ -157,7 +164,7 @@ class HyperlaneMessage {
|
|
|
157
164
|
return this.cache.process;
|
|
158
165
|
}
|
|
159
166
|
// if not, attempt to query the event
|
|
160
|
-
const processFilter = this.inbox.filters.Process(this.
|
|
167
|
+
const processFilter = this.inbox.filters.Process(this.leaf);
|
|
161
168
|
const processLogs = yield (0, events_1.findAnnotatedSingleEvent)(this.multiProvider, this.destinationName, this.inbox, processFilter);
|
|
162
169
|
if (processLogs.length === 1) {
|
|
163
170
|
// if event is returned, store it to the object
|
|
@@ -196,6 +203,17 @@ class HyperlaneMessage {
|
|
|
196
203
|
};
|
|
197
204
|
});
|
|
198
205
|
}
|
|
206
|
+
/**
|
|
207
|
+
* Retrieve the inbox status of this message.
|
|
208
|
+
*
|
|
209
|
+
* @returns The {@link InboxMessageStatus} corresponding to the solidity
|
|
210
|
+
* status of the message.
|
|
211
|
+
*/
|
|
212
|
+
inboxStatus() {
|
|
213
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
214
|
+
return this.inbox.messages(this.leaf);
|
|
215
|
+
});
|
|
216
|
+
}
|
|
199
217
|
/**
|
|
200
218
|
* Checks whether the message has been delivered.
|
|
201
219
|
*
|
|
@@ -203,7 +221,8 @@ class HyperlaneMessage {
|
|
|
203
221
|
*/
|
|
204
222
|
delivered() {
|
|
205
223
|
return __awaiter(this, void 0, void 0, function* () {
|
|
206
|
-
|
|
224
|
+
const status = yield this.inboxStatus();
|
|
225
|
+
return status === InboxMessageStatus.Processed;
|
|
207
226
|
});
|
|
208
227
|
}
|
|
209
228
|
/**
|
|
@@ -275,10 +294,16 @@ class HyperlaneMessage {
|
|
|
275
294
|
return this.dispatch.event.transactionHash;
|
|
276
295
|
}
|
|
277
296
|
/**
|
|
278
|
-
* The
|
|
297
|
+
* The messageHash committed to the tree in the Outbox contract.
|
|
298
|
+
*/
|
|
299
|
+
get leaf() {
|
|
300
|
+
return utils_1.utils.messageHash(this.dispatch.event.args.message, this.dispatch.event.args.leafIndex.toNumber());
|
|
301
|
+
}
|
|
302
|
+
/**
|
|
303
|
+
* The index of the leaf in the contract.
|
|
279
304
|
*/
|
|
280
|
-
get
|
|
281
|
-
return
|
|
305
|
+
get leafIndex() {
|
|
306
|
+
return this.dispatch.event.args.leafIndex;
|
|
282
307
|
}
|
|
283
308
|
}
|
|
284
309
|
exports.HyperlaneMessage = HyperlaneMessage;
|
package/dist/core/message.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"message.js","sourceRoot":"","sources":["../../src/core/message.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"message.js","sourceRoot":"","sources":["../../src/core/message.ts"],"names":[],"mappings":"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"}
|
|
@@ -24,21 +24,21 @@ const remoteChain = 'test2';
|
|
|
24
24
|
const remoteDomain = chainMetadata_1.chainMetadata[remoteChain].id;
|
|
25
25
|
const message = '0xdeadbeef';
|
|
26
26
|
describe('TestCoreDeployer', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
27
|
-
let testCoreApp,
|
|
27
|
+
let testCoreApp, localOutbox, remoteOutbox, dispatchReceipt;
|
|
28
28
|
beforeEach(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
29
29
|
const [signer] = yield hardhat_1.ethers.getSigners();
|
|
30
30
|
const multiProvider = (0, utils_2.getTestMultiProvider)(signer);
|
|
31
31
|
const deployer = new TestCoreDeployer_1.TestCoreDeployer(multiProvider);
|
|
32
32
|
testCoreApp = yield deployer.deployApp();
|
|
33
33
|
const recipient = yield new core_1.TestRecipient__factory(signer).deploy();
|
|
34
|
-
|
|
35
|
-
const dispatchResponse =
|
|
36
|
-
yield (0, chai_1.expect)(dispatchResponse).to.emit(
|
|
34
|
+
localOutbox = testCoreApp.getContracts(localChain).outbox.contract;
|
|
35
|
+
const dispatchResponse = localOutbox.dispatch(remoteDomain, utils_1.utils.addressToBytes32(recipient.address), message);
|
|
36
|
+
yield (0, chai_1.expect)(dispatchResponse).to.emit(localOutbox, 'Dispatch');
|
|
37
37
|
dispatchReceipt = yield testCoreApp.multiProvider
|
|
38
38
|
.getChainConnection(localChain)
|
|
39
39
|
.handleTx(dispatchResponse);
|
|
40
|
-
|
|
41
|
-
yield (0, chai_1.expect)(
|
|
40
|
+
remoteOutbox = testCoreApp.getContracts(remoteChain).outbox.contract;
|
|
41
|
+
yield (0, chai_1.expect)(remoteOutbox.dispatch(localDomain, utils_1.utils.addressToBytes32(recipient.address), message)).to.emit(remoteOutbox, 'Dispatch');
|
|
42
42
|
}));
|
|
43
43
|
it('processes outbound messages for a single domain', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
44
44
|
const responses = yield testCoreApp.processOutboundMessages(localChain);
|
|
@@ -1 +1 @@
|
|
|
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,
|
|
1
|
+
{"version":3,"file":"testHyperlaneDeploy.hardhat-test.js","sourceRoot":"","sources":["../../src/core/testHyperlaneDeploy.hardhat-test.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,7 +2,7 @@ import { Ownable } from '@hyperlane-xyz/core';
|
|
|
2
2
|
import type { types } from '@hyperlane-xyz/utils';
|
|
3
3
|
import { HyperlaneApp } from '../HyperlaneApp';
|
|
4
4
|
import { MultiProvider } from '../providers/MultiProvider';
|
|
5
|
-
import {
|
|
5
|
+
import { BeaconProxyAddresses } from '../proxy';
|
|
6
6
|
import { ChainMap, ChainName } from '../types';
|
|
7
7
|
import { CheckerViolation } from './types';
|
|
8
8
|
export declare abstract class HyperlaneAppChecker<Chain extends ChainName, App extends HyperlaneApp<any, Chain>, Config> {
|
|
@@ -14,7 +14,7 @@ export declare abstract class HyperlaneAppChecker<Chain extends ChainName, App e
|
|
|
14
14
|
abstract checkChain(chain: Chain): Promise<void>;
|
|
15
15
|
check(): Promise<void[]>;
|
|
16
16
|
addViolation(violation: CheckerViolation): void;
|
|
17
|
-
|
|
17
|
+
checkUpgradeBeacon(chain: Chain, name: string, proxiedAddress: BeaconProxyAddresses): Promise<void>;
|
|
18
18
|
checkOwnership(chain: Chain, owner: types.Address, ownables: Ownable[]): Promise<void>;
|
|
19
19
|
expectViolations(types: string[], expectedMatches: number[]): void;
|
|
20
20
|
expectEmpty(): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HyperlaneAppChecker.d.ts","sourceRoot":"","sources":["../../src/deploy/HyperlaneAppChecker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAE9C,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAElD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"HyperlaneAppChecker.d.ts","sourceRoot":"","sources":["../../src/deploy/HyperlaneAppChecker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAE9C,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAElD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,oBAAoB,EAAE,MAAM,UAAU,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAG/C,OAAO,EAAE,gBAAgB,EAAiC,MAAM,SAAS,CAAC;AAE1E,8BAAsB,mBAAmB,CACvC,KAAK,SAAS,SAAS,EACvB,GAAG,SAAS,YAAY,CAAC,GAAG,EAAE,KAAK,CAAC,EACpC,MAAM;IAEN,QAAQ,CAAC,aAAa,EAAE,aAAa,CAAC,KAAK,CAAC,CAAC;IAC7C,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC;IAClB,QAAQ,CAAC,SAAS,EAAE,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IAC5C,QAAQ,CAAC,UAAU,EAAE,gBAAgB,EAAE,CAAC;gBAGtC,aAAa,EAAE,aAAa,CAAC,KAAK,CAAC,EACnC,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IAQpC,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAE1C,KAAK,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;IAiB9B,YAAY,CAAC,SAAS,EAAE,gBAAgB,GAAG,IAAI;IAIzC,kBAAkB,CACtB,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,MAAM,EACZ,cAAc,EAAE,oBAAoB,GACnC,OAAO,CAAC,IAAI,CAAC;IAaV,cAAc,CAClB,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK,CAAC,OAAO,EACpB,QAAQ,EAAE,OAAO,EAAE,GAClB,OAAO,CAAC,IAAI,CAAC;IAkBhB,gBAAgB,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,eAAe,EAAE,MAAM,EAAE,GAAG,IAAI;IAwBlE,WAAW,IAAI,IAAI;CAIpB"}
|
|
@@ -36,16 +36,12 @@ class HyperlaneAppChecker {
|
|
|
36
36
|
addViolation(violation) {
|
|
37
37
|
this.violations.push(violation);
|
|
38
38
|
}
|
|
39
|
-
|
|
39
|
+
checkUpgradeBeacon(chain, name, proxiedAddress) {
|
|
40
40
|
return __awaiter(this, void 0, void 0, function* () {
|
|
41
41
|
const dc = this.multiProvider.getChainConnection(chain);
|
|
42
|
-
const implementation = yield (0, proxy_1.
|
|
42
|
+
const implementation = yield (0, proxy_1.upgradeBeaconImplementation)(dc.provider, proxiedAddress.beacon);
|
|
43
43
|
if (implementation !== proxiedAddress.implementation) {
|
|
44
|
-
this.addViolation((0, proxy_1.
|
|
45
|
-
}
|
|
46
|
-
if (proxyAdminAddress) {
|
|
47
|
-
const admin = yield (0, proxy_1.proxyAdmin)(dc.provider, proxiedAddress.proxy);
|
|
48
|
-
utils_1.utils.assert(admin === proxyAdminAddress, 'Proxy admin mismatch');
|
|
44
|
+
this.addViolation((0, proxy_1.upgradeBeaconViolation)(chain, name, proxiedAddress, implementation));
|
|
49
45
|
}
|
|
50
46
|
});
|
|
51
47
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HyperlaneAppChecker.js","sourceRoot":"","sources":["../../src/deploy/HyperlaneAppChecker.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,gDAA6C;AAQ7C,
|
|
1
|
+
{"version":3,"file":"HyperlaneAppChecker.js","sourceRoot":"","sources":["../../src/deploy/HyperlaneAppChecker.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { Debugger } from 'debug';
|
|
2
2
|
import { ethers } from 'ethers';
|
|
3
|
-
import { Ownable
|
|
3
|
+
import { Ownable } from '@hyperlane-xyz/core';
|
|
4
|
+
import type { types } from '@hyperlane-xyz/utils';
|
|
4
5
|
import { HyperlaneContracts, HyperlaneFactories } from '../contracts';
|
|
5
6
|
import { MultiProvider } from '../providers/MultiProvider';
|
|
6
|
-
import {
|
|
7
|
+
import { BeaconProxyAddresses, ProxiedContract } from '../proxy';
|
|
7
8
|
import { ChainMap, ChainName } from '../types';
|
|
8
9
|
import { ContractVerificationInput } from './verify/types';
|
|
9
10
|
export interface DeployerOptions {
|
|
@@ -26,15 +27,19 @@ export declare abstract class HyperlaneDeployer<Chain extends ChainName, Config,
|
|
|
26
27
|
abstract deployContracts(chain: Chain, config: Config): Promise<Contracts>;
|
|
27
28
|
deploy(partialDeployment?: Partial<Record<Chain, Partial<Contracts>>>): Promise<Record<Chain, Contracts>>;
|
|
28
29
|
protected runIfOwner(chain: Chain, ownable: Ownable, fn: () => Promise<any>): Promise<void>;
|
|
29
|
-
protected deployContractFromFactory<F extends ethers.ContractFactory>(chain: Chain, factory: F, contractName: string,
|
|
30
|
+
protected deployContractFromFactory<F extends ethers.ContractFactory>(chain: Chain, factory: F, contractName: string, args: Parameters<F['deploy']>, deployOpts?: DeployOptions): Promise<ReturnType<F['deploy']>>;
|
|
30
31
|
deployContract<K extends keyof Factories>(chain: Chain, contractName: K, args: Parameters<Factories[K]['deploy']>, deployOpts?: DeployOptions): Promise<ReturnType<Factories[K]['deploy']>>;
|
|
31
|
-
protected deployProxy<C extends ethers.Contract>(chain: Chain, implementation: C,
|
|
32
|
-
private cacheContract;
|
|
32
|
+
protected deployProxy<C extends ethers.Contract>(chain: Chain, implementation: C, beaconAddress: string, initArgs: Parameters<C['initialize']>): Promise<ProxiedContract<C, BeaconProxyAddresses>>;
|
|
33
33
|
/**
|
|
34
|
-
* Deploys the Implementation and Proxy for a given contract
|
|
34
|
+
* Deploys the UpgradeBeacon, Implementation and Proxy for a given contract
|
|
35
35
|
*
|
|
36
36
|
*/
|
|
37
|
-
deployProxiedContract<K extends keyof Factories, C extends Awaited<ReturnType<Factories[K]['deploy']>>>(chain: Chain, contractName: K,
|
|
37
|
+
deployProxiedContract<K extends keyof Factories, C extends Awaited<ReturnType<Factories[K]['deploy']>>>(chain: Chain, contractName: K, deployArgs: Parameters<Factories[K]['deploy']>, ubcAddress: types.Address, initArgs: Parameters<C['initialize']>): Promise<ProxiedContract<C, BeaconProxyAddresses>>;
|
|
38
|
+
/**
|
|
39
|
+
* Sets up a new proxy with the same beacon and implementation
|
|
40
|
+
*
|
|
41
|
+
*/
|
|
42
|
+
duplicateProxiedContract<C extends ethers.Contract>(chain: Chain, proxy: ProxiedContract<C, BeaconProxyAddresses>, initArgs: Parameters<C['initialize']>): Promise<ProxiedContract<C, BeaconProxyAddresses>>;
|
|
38
43
|
mergeWithExistingVerificationInputs(existingInputsMap: ChainMap<Chain, ContractVerificationInput[]>): ChainMap<Chain, ContractVerificationInput[]>;
|
|
39
44
|
}
|
|
40
45
|
//# sourceMappingURL=HyperlaneDeployer.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HyperlaneDeployer.d.ts","sourceRoot":"","sources":["../../src/deploy/HyperlaneDeployer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAS,MAAM,OAAO,CAAC;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAEhC,OAAO,EAEL,OAAO,
|
|
1
|
+
{"version":3,"file":"HyperlaneDeployer.d.ts","sourceRoot":"","sources":["../../src/deploy/HyperlaneDeployer.ts"],"names":[],"mappings":"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"}
|
|
@@ -56,17 +56,12 @@ class HyperlaneDeployer {
|
|
|
56
56
|
const dc = this.multiProvider.getChainConnection(chain);
|
|
57
57
|
const address = yield dc.signer.getAddress();
|
|
58
58
|
const owner = yield ownable.owner();
|
|
59
|
-
const logObj = { owner, signer: address };
|
|
60
59
|
if (address === owner) {
|
|
61
|
-
this.logger('Owner and signer are equal, proceeding', logObj);
|
|
62
60
|
return fn();
|
|
63
61
|
}
|
|
64
|
-
else {
|
|
65
|
-
this.logger('Owner and signer NOT equal, skipping', logObj);
|
|
66
|
-
}
|
|
67
62
|
});
|
|
68
63
|
}
|
|
69
|
-
deployContractFromFactory(chain, factory, contractName,
|
|
64
|
+
deployContractFromFactory(chain, factory, contractName, args, deployOpts) {
|
|
70
65
|
var _a;
|
|
71
66
|
return __awaiter(this, void 0, void 0, function* () {
|
|
72
67
|
const cachedContract = (_a = this.deployedContracts[chain]) === null || _a === void 0 ? void 0 : _a[contractName];
|
|
@@ -83,29 +78,29 @@ class HyperlaneDeployer {
|
|
|
83
78
|
if (deployOpts &&
|
|
84
79
|
deployOpts.create2Salt &&
|
|
85
80
|
(yield chainConnection.provider.getCode(exports.CREATE2FACTORY_ADDRESS)) != '0x') {
|
|
81
|
+
if (args.length > 0) {
|
|
82
|
+
throw new Error("Can't use CREATE2 with deployment args");
|
|
83
|
+
}
|
|
86
84
|
this.logger(`Deploying with CREATE2 factory`);
|
|
87
85
|
const create2Factory = core_1.Create2Factory__factory.connect(exports.CREATE2FACTORY_ADDRESS, signer);
|
|
88
86
|
const salt = ethers_1.ethers.utils.keccak256(ethers_1.ethers.utils.hexlify(ethers_1.ethers.utils.toUtf8Bytes(deployOpts.create2Salt)));
|
|
89
|
-
const
|
|
90
|
-
const bytecode = ethers_1.ethers.utils.hexlify(ethers_1.ethers.utils.concat([factory.bytecode, encodedConstructorArgs]));
|
|
91
|
-
// TODO: Maybe recover deployed contracts?
|
|
92
|
-
const contractAddr = yield create2Factory.deployedAddress(bytecode, yield signer.getAddress(), salt);
|
|
87
|
+
const contractAddr = yield create2Factory.deployedAddress(factory.bytecode, yield signer.getAddress(), salt);
|
|
93
88
|
const deployTx = deployOpts.initCalldata
|
|
94
|
-
? yield create2Factory.deployAndInit(bytecode, salt, deployOpts.initCalldata, chainConnection.overrides)
|
|
95
|
-
: yield create2Factory.deploy(bytecode, salt, chainConnection.overrides);
|
|
89
|
+
? yield create2Factory.deployAndInit(factory.bytecode, salt, deployOpts.initCalldata, chainConnection.overrides)
|
|
90
|
+
: yield create2Factory.deploy(factory.bytecode, salt, chainConnection.overrides);
|
|
96
91
|
yield chainConnection.handleTx(deployTx);
|
|
97
92
|
this.verificationInputs[chain].push({
|
|
98
93
|
name: contractName,
|
|
99
94
|
address: contractAddr,
|
|
100
95
|
isProxy: false,
|
|
101
|
-
constructorArguments:
|
|
96
|
+
constructorArguments: '',
|
|
102
97
|
});
|
|
103
98
|
return factory.attach(contractAddr).connect(signer);
|
|
104
99
|
}
|
|
105
100
|
else {
|
|
106
101
|
const contract = yield factory
|
|
107
102
|
.connect(signer)
|
|
108
|
-
.deploy(...
|
|
103
|
+
.deploy(...args, chainConnection.overrides);
|
|
109
104
|
yield chainConnection.handleTx(contract.deployTransaction);
|
|
110
105
|
if (deployOpts === null || deployOpts === void 0 ? void 0 : deployOpts.initCalldata) {
|
|
111
106
|
this.logger(`Initialize ${contractName} on ${chain}`);
|
|
@@ -123,64 +118,30 @@ class HyperlaneDeployer {
|
|
|
123
118
|
}
|
|
124
119
|
deployContract(chain, contractName, args, deployOpts) {
|
|
125
120
|
return __awaiter(this, void 0, void 0, function* () {
|
|
126
|
-
|
|
127
|
-
this.cacheContract(chain, contractName, contract);
|
|
128
|
-
return contract;
|
|
121
|
+
return this.deployContractFromFactory(chain, this.factories[contractName], contractName.toString(), args, deployOpts);
|
|
129
122
|
});
|
|
130
123
|
}
|
|
131
|
-
deployProxy(chain, implementation,
|
|
124
|
+
deployProxy(chain, implementation, beaconAddress, initArgs) {
|
|
132
125
|
return __awaiter(this, void 0, void 0, function* () {
|
|
133
126
|
const initData = implementation.interface.encodeFunctionData('initialize', initArgs);
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
// The three constructor arguments we need to configure are:
|
|
143
|
-
// 1. Proxy implementation: This will start as the Create2Factory
|
|
144
|
-
// address, as it needs to be a contract address.
|
|
145
|
-
// After we've taken over as the proxy admin, we will set it
|
|
146
|
-
// to the proper address.
|
|
147
|
-
// 2. Proxy admin: This will start as the Create2Factory contract
|
|
148
|
-
// address. We will change this to the proper address atomically.
|
|
149
|
-
// 3. Initialization data: This will start as null, and we will
|
|
150
|
-
// initialize our proxied contract manually.
|
|
151
|
-
const constructorArgs = [exports.CREATE2FACTORY_ADDRESS, exports.CREATE2FACTORY_ADDRESS, '0x'];
|
|
152
|
-
// We set the initCallData to atomically change admin to the proxyAdmin
|
|
153
|
-
// contract.
|
|
154
|
-
const initCalldata = new core_1.TransparentUpgradeableProxy__factory().interface.encodeFunctionData('changeAdmin', [proxyAdmin.address]);
|
|
155
|
-
proxy = yield this.deployContractFromFactory(chain, new core_1.TransparentUpgradeableProxy__factory(), 'TransparentUpgradableProxy', constructorArgs, Object.assign(Object.assign({}, deployOpts), { initCalldata }));
|
|
156
|
-
this.logger(`Upgrading and initializing transparent upgradable proxy`);
|
|
157
|
-
// We now have a deployed proxy admin'd by ProxyAdmin.
|
|
158
|
-
// Upgrade its implementation and initialize it
|
|
159
|
-
yield proxyAdmin.upgradeAndCall(proxy.address, implementation.address, initData);
|
|
160
|
-
}
|
|
161
|
-
else {
|
|
162
|
-
const constructorArgs = [implementation.address, proxyAdmin.address, initData];
|
|
163
|
-
proxy = yield this.deployContractFromFactory(chain, new core_1.TransparentUpgradeableProxy__factory(), 'TransparentUpgradableProxy', constructorArgs);
|
|
164
|
-
}
|
|
165
|
-
return new proxy_1.ProxiedContract(implementation.attach(proxy.address), {
|
|
166
|
-
kind: proxy_1.ProxyKind.Transparent,
|
|
167
|
-
proxy: proxy.address,
|
|
127
|
+
const deployArgs = [
|
|
128
|
+
beaconAddress,
|
|
129
|
+
initData,
|
|
130
|
+
];
|
|
131
|
+
const beaconProxy = yield this.deployContractFromFactory(chain, new core_1.UpgradeBeaconProxy__factory(), 'UpgradeBeaconProxy', deployArgs);
|
|
132
|
+
return new proxy_1.ProxiedContract(implementation.attach(beaconProxy.address), {
|
|
133
|
+
kind: proxy_1.ProxyKind.UpgradeBeacon,
|
|
134
|
+
proxy: beaconProxy.address,
|
|
168
135
|
implementation: implementation.address,
|
|
136
|
+
beacon: beaconAddress,
|
|
169
137
|
});
|
|
170
138
|
});
|
|
171
139
|
}
|
|
172
|
-
cacheContract(chain, contractName, contract) {
|
|
173
|
-
if (!this.deployedContracts[chain]) {
|
|
174
|
-
this.deployedContracts[chain] = {};
|
|
175
|
-
}
|
|
176
|
-
// @ts-ignore
|
|
177
|
-
this.deployedContracts[chain][contractName] = contract;
|
|
178
|
-
}
|
|
179
140
|
/**
|
|
180
|
-
* Deploys the Implementation and Proxy for a given contract
|
|
141
|
+
* Deploys the UpgradeBeacon, Implementation and Proxy for a given contract
|
|
181
142
|
*
|
|
182
143
|
*/
|
|
183
|
-
deployProxiedContract(chain, contractName,
|
|
144
|
+
deployProxiedContract(chain, contractName, deployArgs, ubcAddress, initArgs) {
|
|
184
145
|
var _a;
|
|
185
146
|
return __awaiter(this, void 0, void 0, function* () {
|
|
186
147
|
const cachedProxy = (_a = this.deployedContracts[chain]) === null || _a === void 0 ? void 0 : _a[contractName];
|
|
@@ -188,10 +149,24 @@ class HyperlaneDeployer {
|
|
|
188
149
|
this.logger(`Recovered proxy ${contractName.toString()} on ${chain}`);
|
|
189
150
|
return cachedProxy;
|
|
190
151
|
}
|
|
191
|
-
const implementation = yield this.deployContract(chain, contractName,
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
152
|
+
const implementation = yield this.deployContract(chain, contractName, deployArgs);
|
|
153
|
+
this.logger(`Proxy ${contractName.toString()} on ${chain}`);
|
|
154
|
+
const beaconDeployArgs = [
|
|
155
|
+
implementation.address,
|
|
156
|
+
ubcAddress,
|
|
157
|
+
];
|
|
158
|
+
const beacon = yield this.deployContractFromFactory(chain, new core_1.UpgradeBeacon__factory(), 'UpgradeBeacon', beaconDeployArgs);
|
|
159
|
+
return this.deployProxy(chain, implementation, beacon.address, initArgs);
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Sets up a new proxy with the same beacon and implementation
|
|
164
|
+
*
|
|
165
|
+
*/
|
|
166
|
+
duplicateProxiedContract(chain, proxy, initArgs) {
|
|
167
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
168
|
+
this.logger(`Duplicate Proxy on ${chain}`);
|
|
169
|
+
return this.deployProxy(chain, proxy.contract.attach(proxy.addresses.implementation), proxy.addresses.beacon, initArgs);
|
|
195
170
|
});
|
|
196
171
|
}
|
|
197
172
|
mergeWithExistingVerificationInputs(existingInputsMap) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HyperlaneDeployer.js","sourceRoot":"","sources":["../../src/deploy/HyperlaneDeployer.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,iCAAwC;AACxC,mCAAgC;AAEhC,
|
|
1
|
+
{"version":3,"file":"HyperlaneDeployer.js","sourceRoot":"","sources":["../../src/deploy/HyperlaneDeployer.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,iCAAwC;AACxC,mCAAgC;AAEhC,8CAK6B;AAG7B,4CAKsB;AAEtB,oCAA4E;AAE5E,8CAA0C;AAG1C,0CAA8D;AAWjD,QAAA,sBAAsB,GACjC,4CAA4C,CAAC;AAC/C,MAAsB,iBAAiB;IAWrC,YACqB,aAAmC,EACnC,SAAkC,EAClC,SAAoB,EACpB,OAAyB;QAHzB,kBAAa,GAAb,aAAa,CAAsB;QACnC,cAAS,GAAT,SAAS,CAAyB;QAClC,cAAS,GAAT,SAAS,CAAW;QACpB,YAAO,GAAP,OAAO,CAAkB;QATvC,sBAAiB,GAA+C,EAAE,CAAC;QAWxE,IAAI,CAAC,kBAAkB,GAAG,IAAA,gBAAM,EAAC,SAAS,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;QACtD,IAAI,CAAC,MAAM,GAAG,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,KAAI,IAAA,aAAK,EAAC,uBAAuB,CAAC,CAAC;IAClE,CAAC;IAIK,MAAM,CACV,oBAAgE,IAAI;SACjE,iBAAiB;;;YAEpB,IAAA,gBAAM,EACJ,iBAA+C,EAC/C,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE;gBACnB,IAAI,CAAC,MAAM,CACT,4BAA4B,KAAK,0BAA0B,CAC5D,CAAC;gBACF,MAAM,eAAe,GAAG,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;gBACrE,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,GAAG,IAAA,4BAAgB,EAC9C,SAAS,EACT,eAAe,CAAC,MAAO,CACxB,CAAC;YACJ,CAAC,CACF,CAAC;YACF,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAY,CAAC;YAC5D,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAC/C,YAAY,EACZ,KAAK,CACN,CAAC,YAAY,CAAC;YAEf,IAAI,CAAC,MAAM,CAAC,mBAAmB,YAAY,EAAE,CAAC,CAAC;YAC/C,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE;gBAChC,MAAM,eAAe,GAAG,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;gBACrE,MAAM,SAAS,GAAG,MAAM,eAAe,CAAC,aAAa,EAAE,CAAC;gBACxD,IAAI,CAAC,MAAM,CAAC,gBAAgB,KAAK,SAAS,SAAS,MAAM,CAAC,CAAC;gBAC3D,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,GAAG,MAAM,IAAI,CAAC,eAAe,CACxD,KAAK,EACL,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CACtB,CAAC;gBACF,uDAAuD;gBACvD,IAAI,CAAC,MAAM,CACT,IAAI,CAAC,SAAS,CACZ,IAAA,8BAAkB,EAChB,MAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAe,mCAAI,EAAE,CACnD,EACD,IAAI,EACJ,CAAC,CACF,CACF,CAAC;aACH;YACD,OAAO,IAAI,CAAC,iBAA+C,CAAC;;KAC7D;IAEe,UAAU,CACxB,KAAY,EACZ,OAAgB,EAChB,EAAsB;;YAEtB,MAAM,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YACxD,MAAM,OAAO,GAAG,MAAM,EAAE,CAAC,MAAO,CAAC,UAAU,EAAE,CAAC;YAC9C,MAAM,KAAK,GAAG,MAAM,OAAO,CAAC,KAAK,EAAE,CAAC;YACpC,IAAI,OAAO,KAAK,KAAK,EAAE;gBACrB,OAAO,EAAE,EAAE,CAAC;aACb;QACH,CAAC;KAAA;IAEe,yBAAyB,CACvC,KAAY,EACZ,OAAU,EACV,YAAoB,EACpB,IAA6B,EAC7B,UAA0B;;;YAE1B,MAAM,cAAc,GAAG,MAAA,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,0CAAG,YAAY,CAAC,CAAC;YACrE,IAAI,cAAc,EAAE;gBAClB,IAAI,CAAC,MAAM,CAAC,sBAAsB,YAAY,OAAO,KAAK,EAAE,CAAC,CAAC;gBAC9D,OAAO,cAAyC,CAAC;aAClD;YAED,MAAM,eAAe,GAAG,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YACrE,MAAM,MAAM,GAAG,eAAe,CAAC,MAAM,CAAC;YACtC,IAAI,CAAC,MAAM,EAAE;gBACX,MAAM,IAAI,KAAK,CAAC,iBAAiB,KAAK,EAAE,CAAC,CAAC;aAC3C;YAED,IAAI,CAAC,MAAM,CAAC,UAAU,YAAY,OAAO,KAAK,EAAE,CAAC,CAAC;YAElD,IACE,UAAU;gBACV,UAAU,CAAC,WAAW;gBACtB,CAAC,MAAM,eAAe,CAAC,QAAQ,CAAC,OAAO,CAAC,8BAAsB,CAAC,CAAC,IAAI,IAAI,EACxE;gBACA,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;oBACnB,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;iBAC3D;gBACD,IAAI,CAAC,MAAM,CAAC,gCAAgC,CAAC,CAAC;gBAE9C,MAAM,cAAc,GAAG,8BAAuB,CAAC,OAAO,CACpD,8BAAsB,EACtB,MAAM,CACP,CAAC;gBACF,MAAM,IAAI,GAAG,eAAM,CAAC,KAAK,CAAC,SAAS,CACjC,eAAM,CAAC,KAAK,CAAC,OAAO,CAAC,eAAM,CAAC,KAAK,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CACvE,CAAC;gBACF,MAAM,YAAY,GAAG,MAAM,cAAc,CAAC,eAAe,CACvD,OAAO,CAAC,QAAQ,EAChB,MAAM,MAAM,CAAC,UAAU,EAAE,EACzB,IAAI,CACL,CAAC;gBAEF,MAAM,QAAQ,GAAG,UAAU,CAAC,YAAY;oBACtC,CAAC,CAAC,MAAM,cAAc,CAAC,aAAa,CAChC,OAAO,CAAC,QAAQ,EAChB,IAAI,EACJ,UAAU,CAAC,YAAY,EACvB,eAAe,CAAC,SAAS,CAC1B;oBACH,CAAC,CAAC,MAAM,cAAc,CAAC,MAAM,CACzB,OAAO,CAAC,QAAQ,EAChB,IAAI,EACJ,eAAe,CAAC,SAAS,CAC1B,CAAC;gBACN,MAAM,eAAe,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;gBAEzC,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC;oBAClC,IAAI,EAAE,YAAY;oBAClB,OAAO,EAAE,YAAY;oBACrB,OAAO,EAAE,KAAK;oBACd,oBAAoB,EAAE,EAAE;iBACzB,CAAC,CAAC;gBAEH,OAAO,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,MAAM,CAEjD,CAAC;aACH;iBAAM;gBACL,MAAM,QAAQ,GAAG,MAAM,OAAO;qBAC3B,OAAO,CAAC,MAAM,CAAC;qBACf,MAAM,CAAC,GAAG,IAAI,EAAE,eAAe,CAAC,SAAS,CAAC,CAAC;gBAE9C,MAAM,eAAe,CAAC,QAAQ,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAC;gBAE3D,IAAI,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,YAAY,EAAE;oBAC5B,IAAI,CAAC,MAAM,CAAC,cAAc,YAAY,OAAO,KAAK,EAAE,CAAC,CAAC;oBACtD,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,eAAe,CAAC;wBAC1C,EAAE,EAAE,QAAQ,CAAC,OAAO;wBACpB,IAAI,EAAE,UAAU,CAAC,YAAY;qBAC9B,CAAC,CAAC;oBACH,MAAM,eAAe,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;iBACxC;gBAED,MAAM,iBAAiB,GAAG,IAAA,oCAA4B,EACpD,YAAY,EACZ,QAAQ,EACR,OAAO,CAAC,QAAQ,CACjB,CAAC;gBACF,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;gBAEvD,OAAO,QAAmC,CAAC;aAC5C;;KACF;IAEK,cAAc,CAClB,KAAY,EACZ,YAAe,EACf,IAAwC,EACxC,UAA0B;;YAE1B,OAAO,IAAI,CAAC,yBAAyB,CACnC,KAAK,EACL,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,EAC5B,YAAY,CAAC,QAAQ,EAAE,EACvB,IAAI,EACJ,UAAU,CACX,CAAC;QACJ,CAAC;KAAA;IAEe,WAAW,CACzB,KAAY,EACZ,cAAiB,EACjB,aAAqB,EACrB,QAAqC;;YAErC,MAAM,QAAQ,GAAG,cAAc,CAAC,SAAS,CAAC,kBAAkB,CAC1D,YAAY,EACZ,QAAQ,CACT,CAAC;YACF,MAAM,UAAU,GAAsD;gBACpE,aAAa;gBACb,QAAQ;aACT,CAAC;YACF,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,yBAAyB,CACtD,KAAK,EACL,IAAI,kCAA2B,EAAE,EACjC,oBAAoB,EACpB,UAAU,CACX,CAAC;YAEF,OAAO,IAAI,uBAAe,CACxB,cAAc,CAAC,MAAM,CAAC,WAAW,CAAC,OAAO,CAAM,EAC/C;gBACE,IAAI,EAAE,iBAAS,CAAC,aAAa;gBAC7B,KAAK,EAAE,WAAW,CAAC,OAAO;gBAC1B,cAAc,EAAE,cAAc,CAAC,OAAO;gBACtC,MAAM,EAAE,aAAa;aACtB,CACF,CAAC;QACJ,CAAC;KAAA;IAED;;;OAGG;IACG,qBAAqB,CAIzB,KAAY,EACZ,YAAe,EACf,UAA8C,EAC9C,UAAyB,EACzB,QAAqC;;;YAErC,MAAM,WAAW,GAAG,MAAA,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,0CAAG,YAAmB,CAAC,CAAC;YACzE,IAAI,WAAW,EAAE;gBACf,IAAI,CAAC,MAAM,CAAC,mBAAmB,YAAY,CAAC,QAAQ,EAAE,OAAO,KAAK,EAAE,CAAC,CAAC;gBACtE,OAAO,WAAuD,CAAC;aAChE;YAED,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,cAAc,CAC9C,KAAK,EACL,YAAY,EACZ,UAAU,CACX,CAAC;YAEF,IAAI,CAAC,MAAM,CAAC,SAAS,YAAY,CAAC,QAAQ,EAAE,OAAO,KAAK,EAAE,CAAC,CAAC;YAC5D,MAAM,gBAAgB,GAAiD;gBACrE,cAAc,CAAC,OAAO;gBACtB,UAAU;aACX,CAAC;YACF,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,yBAAyB,CACjD,KAAK,EACL,IAAI,6BAAsB,EAAE,EAC5B,eAAe,EACf,gBAAgB,CACjB,CAAC;YACF,OAAO,IAAI,CAAC,WAAW,CACrB,KAAK,EACL,cAAmB,EACnB,MAAM,CAAC,OAAO,EACd,QAAQ,CACT,CAAC;;KACH;IAED;;;OAGG;IACG,wBAAwB,CAC5B,KAAY,EACZ,KAA+C,EAC/C,QAAqC;;YAErC,IAAI,CAAC,MAAM,CAAC,sBAAsB,KAAK,EAAE,CAAC,CAAC;YAC3C,OAAO,IAAI,CAAC,WAAW,CACrB,KAAK,EACL,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,cAAc,CAAM,EAC1D,KAAK,CAAC,SAAS,CAAC,MAAM,EACtB,QAAQ,CACT,CAAC;QACJ,CAAC;KAAA;IAED,mCAAmC,CACjC,iBAA+D;QAE/D,MAAM,SAAS,GAAG,IAAI,GAAG,EAAS,CAAC;QACnC,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,CAAU,CAAC,CAAC,CAAC;QACzE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CACjD,SAAS,CAAC,GAAG,CAAC,CAAU,CAAC,CAC1B,CAAC;QAEF,aAAa;QACb,MAAM,GAAG,GAAiD,EAAE,CAAC;QAC7D,KAAK,MAAM,KAAK,IAAI,SAAS,EAAE;YAC7B,MAAM,cAAc,GAAG,iBAAiB,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YACtD,MAAM,SAAS,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YACvD,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,cAAc,EAAE,GAAG,SAAS,CAAC,CAAC;SAChD;QACD,OAAO,GAAG,CAAC;IACb,CAAC;CACF;AAjTD,8CAiTC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { MultisigValidatorManager } from '@hyperlane-xyz/core';
|
|
1
2
|
import { HyperlaneCore } from '../../core/HyperlaneCore';
|
|
2
3
|
import { ChainName } from '../../types';
|
|
3
4
|
import { HyperlaneAppChecker } from '../HyperlaneAppChecker';
|
|
@@ -5,9 +6,12 @@ import { CoreConfig } from './types';
|
|
|
5
6
|
export declare class HyperlaneCoreChecker<Chain extends ChainName> extends HyperlaneAppChecker<Chain, HyperlaneCore<Chain>, CoreConfig> {
|
|
6
7
|
checkChain(chain: Chain): Promise<void>;
|
|
7
8
|
checkDomainOwnership(chain: Chain): Promise<void>;
|
|
8
|
-
|
|
9
|
+
checkOutbox(chain: Chain): Promise<void>;
|
|
10
|
+
checkValidatorManagers(chain: Chain): Promise<void>;
|
|
11
|
+
checkValidatorManager(local: Chain, remote: Chain, validatorManager: MultisigValidatorManager): Promise<void>;
|
|
12
|
+
checkInboxes(chain: Chain): Promise<void>;
|
|
13
|
+
checkConnectionManager(chain: Chain): Promise<void>;
|
|
9
14
|
checkProxiedContracts(chain: Chain): Promise<void>;
|
|
10
|
-
|
|
11
|
-
checkMultisigIsmForRemote(local: Chain, remote: Chain): Promise<void>;
|
|
15
|
+
checkInterchainGasPaymaster(chain: Chain): Promise<void>;
|
|
12
16
|
}
|
|
13
17
|
//# sourceMappingURL=HyperlaneCoreChecker.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HyperlaneCoreChecker.d.ts","sourceRoot":"","sources":["../../../src/deploy/core/HyperlaneCoreChecker.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"HyperlaneCoreChecker.d.ts","sourceRoot":"","sources":["../../../src/deploy/core/HyperlaneCoreChecker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAE,MAAM,qBAAqB,CAAC;AAI/D,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAGzD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAE7D,OAAO,EAEL,UAAU,EASX,MAAM,SAAS,CAAC;AAEjB,qBAAa,oBAAoB,CAC/B,KAAK,SAAS,SAAS,CACvB,SAAQ,mBAAmB,CAAC,KAAK,EAAE,aAAa,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC;IAC9D,UAAU,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAgBvC,oBAAoB,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAoBjD,WAAW,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAuBxC,sBAAsB,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBnD,qBAAqB,CACzB,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,KAAK,EACb,gBAAgB,EAAE,wBAAwB,GACzC,OAAO,CAAC,IAAI,CAAC;IA8CV,YAAY,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAoDzC,sBAAsB,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAqCnD,qBAAqB,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAUlD,2BAA2B,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;CAQ/D"}
|