@hyperlane-xyz/sdk 0.5.0-beta0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +5 -0
- package/dist/HyperlaneApp.d.ts +13 -0
- package/dist/HyperlaneApp.d.ts.map +1 -0
- package/dist/HyperlaneApp.js +25 -0
- package/dist/HyperlaneApp.js.map +1 -0
- package/dist/consts/chainConnectionConfigs.d.ts +28 -0
- package/dist/consts/chainConnectionConfigs.d.ts.map +1 -0
- package/dist/consts/chainConnectionConfigs.js +130 -0
- package/dist/consts/chainConnectionConfigs.js.map +1 -0
- package/dist/consts/chainMetadata.d.ts +43 -0
- package/dist/consts/chainMetadata.d.ts.map +1 -0
- package/dist/consts/chainMetadata.js +139 -0
- package/dist/consts/chainMetadata.js.map +1 -0
- package/dist/consts/chains.d.ts +28 -0
- package/dist/consts/chains.d.ts.map +1 -0
- package/dist/consts/chains.js +40 -0
- package/dist/consts/chains.js.map +1 -0
- package/dist/consts/environments/index.d.ts +1450 -0
- package/dist/consts/environments/index.d.ts.map +1 -0
- package/dist/consts/environments/index.js +15 -0
- package/dist/consts/environments/index.js.map +1 -0
- package/dist/consts/environments/mainnet.json +513 -0
- package/dist/consts/environments/test.json +113 -0
- package/dist/consts/environments/testnet2.json +821 -0
- 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 +17 -0
- package/dist/contracts.d.ts.map +1 -0
- package/dist/contracts.js +61 -0
- package/dist/contracts.js.map +1 -0
- package/dist/core/HyperlaneCore.d.ts +1491 -0
- package/dist/core/HyperlaneCore.d.ts.map +1 -0
- package/dist/core/HyperlaneCore.js +103 -0
- package/dist/core/HyperlaneCore.js.map +1 -0
- package/dist/core/TestCoreApp.d.ts +27 -0
- package/dist/core/TestCoreApp.d.ts.map +1 -0
- package/dist/core/TestCoreApp.js +63 -0
- package/dist/core/TestCoreApp.js.map +1 -0
- package/dist/core/TestCoreDeployer.d.ts +13 -0
- package/dist/core/TestCoreDeployer.d.ts.map +1 -0
- package/dist/core/TestCoreDeployer.js +85 -0
- package/dist/core/TestCoreDeployer.js.map +1 -0
- package/dist/core/contracts.d.ts +30 -0
- package/dist/core/contracts.d.ts.map +1 -0
- package/dist/core/contracts.js +14 -0
- package/dist/core/contracts.js.map +1 -0
- package/dist/core/events.d.ts +9 -0
- package/dist/core/events.d.ts.map +1 -0
- package/dist/core/events.js +3 -0
- package/dist/core/events.js.map +1 -0
- package/dist/core/message.d.ts +162 -0
- package/dist/core/message.d.ts.map +1 -0
- package/dist/core/message.js +311 -0
- package/dist/core/message.js.map +1 -0
- package/dist/core/testHyperlaneDeploy.hardhat-test.d.ts +3 -0
- package/dist/core/testHyperlaneDeploy.hardhat-test.d.ts.map +1 -0
- package/dist/core/testHyperlaneDeploy.hardhat-test.js +66 -0
- package/dist/core/testHyperlaneDeploy.hardhat-test.js.map +1 -0
- package/dist/deploy/HyperlaneAppChecker.d.ts +22 -0
- package/dist/deploy/HyperlaneAppChecker.d.ts.map +1 -0
- package/dist/deploy/HyperlaneAppChecker.js +76 -0
- package/dist/deploy/HyperlaneAppChecker.js.map +1 -0
- package/dist/deploy/HyperlaneDeployer.d.ts +40 -0
- package/dist/deploy/HyperlaneDeployer.d.ts.map +1 -0
- package/dist/deploy/HyperlaneDeployer.js +153 -0
- package/dist/deploy/HyperlaneDeployer.js.map +1 -0
- package/dist/deploy/core/HyperlaneCoreChecker.d.ts +17 -0
- package/dist/deploy/core/HyperlaneCoreChecker.d.ts.map +1 -0
- package/dist/deploy/core/HyperlaneCoreChecker.js +210 -0
- package/dist/deploy/core/HyperlaneCoreChecker.js.map +1 -0
- package/dist/deploy/core/HyperlaneCoreDeployer.d.ts +30 -0
- package/dist/deploy/core/HyperlaneCoreDeployer.d.ts.map +1 -0
- package/dist/deploy/core/HyperlaneCoreDeployer.js +134 -0
- package/dist/deploy/core/HyperlaneCoreDeployer.js.map +1 -0
- package/dist/deploy/core/types.d.ts +64 -0
- package/dist/deploy/core/types.d.ts.map +1 -0
- package/dist/deploy/core/types.js +23 -0
- package/dist/deploy/core/types.js.map +1 -0
- package/dist/deploy/proxy.d.ts +17 -0
- package/dist/deploy/proxy.d.ts.map +1 -0
- package/dist/deploy/proxy.js +35 -0
- package/dist/deploy/proxy.js.map +1 -0
- package/dist/deploy/router/HyperlaneRouterChecker.d.ts +13 -0
- package/dist/deploy/router/HyperlaneRouterChecker.d.ts.map +1 -0
- package/dist/deploy/router/HyperlaneRouterChecker.js +44 -0
- package/dist/deploy/router/HyperlaneRouterChecker.js.map +1 -0
- package/dist/deploy/router/HyperlaneRouterDeployer.d.ts +13 -0
- package/dist/deploy/router/HyperlaneRouterDeployer.d.ts.map +1 -0
- package/dist/deploy/router/HyperlaneRouterDeployer.js +103 -0
- package/dist/deploy/router/HyperlaneRouterDeployer.js.map +1 -0
- package/dist/deploy/router/types.d.ts +7 -0
- package/dist/deploy/router/types.d.ts.map +1 -0
- package/dist/deploy/router/types.js +3 -0
- package/dist/deploy/router/types.js.map +1 -0
- package/dist/deploy/types.d.ts +19 -0
- package/dist/deploy/types.d.ts.map +1 -0
- package/dist/deploy/types.js +8 -0
- package/dist/deploy/types.js.map +1 -0
- package/dist/deploy/utils.d.ts +10 -0
- package/dist/deploy/utils.d.ts.map +1 -0
- package/dist/deploy/utils.js +38 -0
- package/dist/deploy/utils.js.map +1 -0
- package/dist/deploy/verify/ContractVerifier.d.ts +19 -0
- package/dist/deploy/verify/ContractVerifier.d.ts.map +1 -0
- package/dist/deploy/verify/ContractVerifier.js +129 -0
- package/dist/deploy/verify/ContractVerifier.js.map +1 -0
- package/dist/deploy/verify/types.d.ts +14 -0
- package/dist/deploy/verify/types.d.ts.map +1 -0
- package/dist/deploy/verify/types.js +3 -0
- package/dist/deploy/verify/types.js.map +1 -0
- package/dist/deploy/verify/utils.d.ts +6 -0
- package/dist/deploy/verify/utils.d.ts.map +1 -0
- package/dist/deploy/verify/utils.js +25 -0
- package/dist/deploy/verify/utils.js.map +1 -0
- package/dist/domains.d.ts +4 -0
- package/dist/domains.d.ts.map +1 -0
- package/dist/domains.js +8 -0
- package/dist/domains.js.map +1 -0
- package/dist/events.d.ts +25 -0
- package/dist/events.d.ts.map +1 -0
- package/dist/events.js +161 -0
- package/dist/events.js.map +1 -0
- package/dist/gas/calculator.d.ts +134 -0
- package/dist/gas/calculator.d.ts.map +1 -0
- package/dist/gas/calculator.js +235 -0
- package/dist/gas/calculator.js.map +1 -0
- package/dist/gas/calculator.test.d.ts +2 -0
- package/dist/gas/calculator.test.d.ts.map +1 -0
- package/dist/gas/calculator.test.js +211 -0
- package/dist/gas/calculator.test.js.map +1 -0
- package/dist/gas/token-prices.d.ts +18 -0
- package/dist/gas/token-prices.d.ts.map +1 -0
- package/dist/gas/token-prices.js +63 -0
- package/dist/gas/token-prices.js.map +1 -0
- package/dist/gas/token-prices.test.d.ts +2 -0
- package/dist/gas/token-prices.test.d.ts.map +1 -0
- package/dist/gas/token-prices.test.js +40 -0
- package/dist/gas/token-prices.test.js.map +1 -0
- package/dist/index.d.ts +42 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +119 -0
- package/dist/index.js.map +1 -0
- package/dist/providers/ChainConnection.d.ts +22 -0
- package/dist/providers/ChainConnection.d.ts.map +1 -0
- package/dist/providers/ChainConnection.js +67 -0
- package/dist/providers/ChainConnection.js.map +1 -0
- package/dist/providers/MultiProvider.d.ts +55 -0
- package/dist/providers/MultiProvider.d.ts.map +1 -0
- package/dist/providers/MultiProvider.js +106 -0
- package/dist/providers/MultiProvider.js.map +1 -0
- package/dist/providers/RetryProvider.d.ts +18 -0
- package/dist/providers/RetryProvider.d.ts.map +1 -0
- package/dist/providers/RetryProvider.js +49 -0
- package/dist/providers/RetryProvider.js.map +1 -0
- package/dist/proxy.d.ts +23 -0
- package/dist/proxy.d.ts.map +1 -0
- package/dist/proxy.js +30 -0
- package/dist/proxy.js.map +1 -0
- package/dist/router.d.ts +19 -0
- package/dist/router.d.ts.map +1 -0
- package/dist/router.js +3 -0
- package/dist/router.js.map +1 -0
- package/dist/test/envSubsetDeployer/app.d.ts +36 -0
- package/dist/test/envSubsetDeployer/app.d.ts.map +1 -0
- package/dist/test/envSubsetDeployer/app.js +77 -0
- package/dist/test/envSubsetDeployer/app.js.map +1 -0
- package/dist/test/envSubsetDeployer/check-single-chain.d.ts +2 -0
- package/dist/test/envSubsetDeployer/check-single-chain.d.ts.map +1 -0
- package/dist/test/envSubsetDeployer/check-single-chain.js +49 -0
- package/dist/test/envSubsetDeployer/check-single-chain.js.map +1 -0
- package/dist/test/envSubsetDeployer/deploy-single-chain.d.ts +2 -0
- package/dist/test/envSubsetDeployer/deploy-single-chain.d.ts.map +1 -0
- package/dist/test/envSubsetDeployer/deploy-single-chain.js +42 -0
- package/dist/test/envSubsetDeployer/deploy-single-chain.js.map +1 -0
- package/dist/test/envSubsetDeployer/deploy.hardhat-test.d.ts +2 -0
- package/dist/test/envSubsetDeployer/deploy.hardhat-test.d.ts.map +1 -0
- package/dist/test/envSubsetDeployer/deploy.hardhat-test.js +80 -0
- package/dist/test/envSubsetDeployer/deploy.hardhat-test.js.map +1 -0
- package/dist/test/envSubsetDeployer/utils.d.ts +7 -0
- package/dist/test/envSubsetDeployer/utils.d.ts.map +1 -0
- package/dist/test/envSubsetDeployer/utils.js +25 -0
- package/dist/test/envSubsetDeployer/utils.js.map +1 -0
- package/dist/test/testUtils.d.ts +29 -0
- package/dist/test/testUtils.d.ts.map +1 -0
- package/dist/test/testUtils.js +98 -0
- package/dist/test/testUtils.js.map +1 -0
- package/dist/types.d.ts +20 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/MultiGeneric.d.ts +27 -0
- package/dist/utils/MultiGeneric.d.ts.map +1 -0
- package/dist/utils/MultiGeneric.js +70 -0
- package/dist/utils/MultiGeneric.js.map +1 -0
- package/dist/utils/ids.d.ts +20 -0
- package/dist/utils/ids.d.ts.map +1 -0
- package/dist/utils/ids.js +47 -0
- package/dist/utils/ids.js.map +1 -0
- package/dist/utils/number.d.ts +32 -0
- package/dist/utils/number.d.ts.map +1 -0
- package/dist/utils/number.js +59 -0
- package/dist/utils/number.js.map +1 -0
- package/dist/utils/objects.d.ts +7 -0
- package/dist/utils/objects.d.ts.map +1 -0
- package/dist/utils/objects.js +29 -0
- package/dist/utils/objects.js.map +1 -0
- package/dist/utils/time.d.ts +8 -0
- package/dist/utils/time.d.ts.map +1 -0
- package/dist/utils/time.js +15 -0
- package/dist/utils/time.js.map +1 -0
- package/dist/utils/utils.test.d.ts +2 -0
- package/dist/utils/utils.test.d.ts.map +1 -0
- package/dist/utils/utils.test.js +41 -0
- package/dist/utils/utils.test.js.map +1 -0
- package/package.json +55 -0
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export declare type MetamaskNetwork = {
|
|
2
|
+
chainId: string;
|
|
3
|
+
chainName: string;
|
|
4
|
+
nativeCurrency: {
|
|
5
|
+
name: string;
|
|
6
|
+
symbol: string;
|
|
7
|
+
decimals: number;
|
|
8
|
+
};
|
|
9
|
+
rpcUrls: string[];
|
|
10
|
+
blockExplorerUrls: string[];
|
|
11
|
+
iconUrls: string[];
|
|
12
|
+
};
|
|
13
|
+
export declare const CELO_PARAMS: MetamaskNetwork;
|
|
14
|
+
export declare const ALFAJORES_PARAMS: MetamaskNetwork;
|
|
15
|
+
export declare const BAKLAVA_PARAMS: MetamaskNetwork;
|
|
16
|
+
export declare function connect(params: MetamaskNetwork): Promise<void>;
|
|
17
|
+
//# sourceMappingURL=metamask.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metamask.d.ts","sourceRoot":"","sources":["../../src/consts/metamask.ts"],"names":[],"mappings":"AAAA,oBAAY,eAAe,GAAG;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,CAAC;IACnE,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAC5B,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,eAOzB,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,eAO9B,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,eAO5B,CAAC;AAEF,wBAAsB,OAAO,CAAC,MAAM,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CASpE"}
|
|
@@ -0,0 +1,50 @@
|
|
|
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
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.connect = exports.BAKLAVA_PARAMS = exports.ALFAJORES_PARAMS = exports.CELO_PARAMS = void 0;
|
|
13
|
+
exports.CELO_PARAMS = {
|
|
14
|
+
chainId: '0xa4ec',
|
|
15
|
+
chainName: 'Celo',
|
|
16
|
+
nativeCurrency: { name: 'Celo', symbol: 'CELO', decimals: 18 },
|
|
17
|
+
rpcUrls: ['https://forno.celo.org'],
|
|
18
|
+
blockExplorerUrls: ['https://explorer.celo.org/'],
|
|
19
|
+
iconUrls: ['future'],
|
|
20
|
+
};
|
|
21
|
+
exports.ALFAJORES_PARAMS = {
|
|
22
|
+
chainId: '0xaef3',
|
|
23
|
+
chainName: 'Alfajores Testnet',
|
|
24
|
+
nativeCurrency: { name: 'Alfajores Celo', symbol: 'A-CELO', decimals: 18 },
|
|
25
|
+
rpcUrls: ['https://alfajores-forno.celo-testnet.org'],
|
|
26
|
+
blockExplorerUrls: ['https://alfajores-blockscout.celo-testnet.org/'],
|
|
27
|
+
iconUrls: ['future'],
|
|
28
|
+
};
|
|
29
|
+
exports.BAKLAVA_PARAMS = {
|
|
30
|
+
chainId: '0xf370',
|
|
31
|
+
chainName: 'Baklava Testnet',
|
|
32
|
+
nativeCurrency: { name: 'Baklava Celo', symbol: 'B-CELO', decimals: 18 },
|
|
33
|
+
rpcUrls: ['https://baklava-forno.celo-testnet.org'],
|
|
34
|
+
blockExplorerUrls: ['https://baklava-blockscout.celo-testnet.org/'],
|
|
35
|
+
iconUrls: ['future'],
|
|
36
|
+
};
|
|
37
|
+
function connect(params) {
|
|
38
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
39
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
40
|
+
const w = window;
|
|
41
|
+
if (w.ethereum) {
|
|
42
|
+
yield w.ethereum.request({
|
|
43
|
+
method: 'wallet_addEthereumChain',
|
|
44
|
+
params: [params],
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
exports.connect = connect;
|
|
50
|
+
//# sourceMappingURL=metamask.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metamask.js","sourceRoot":"","sources":["../../src/consts/metamask.ts"],"names":[],"mappings":";;;;;;;;;;;;AASa,QAAA,WAAW,GAAoB;IAC1C,OAAO,EAAE,QAAQ;IACjB,SAAS,EAAE,MAAM;IACjB,cAAc,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE;IAC9D,OAAO,EAAE,CAAC,wBAAwB,CAAC;IACnC,iBAAiB,EAAE,CAAC,4BAA4B,CAAC;IACjD,QAAQ,EAAE,CAAC,QAAQ,CAAC;CACrB,CAAC;AAEW,QAAA,gBAAgB,GAAoB;IAC/C,OAAO,EAAE,QAAQ;IACjB,SAAS,EAAE,mBAAmB;IAC9B,cAAc,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE;IAC1E,OAAO,EAAE,CAAC,0CAA0C,CAAC;IACrD,iBAAiB,EAAE,CAAC,gDAAgD,CAAC;IACrE,QAAQ,EAAE,CAAC,QAAQ,CAAC;CACrB,CAAC;AAEW,QAAA,cAAc,GAAoB;IAC7C,OAAO,EAAE,QAAQ;IACjB,SAAS,EAAE,iBAAiB;IAC5B,cAAc,EAAE,EAAE,IAAI,EAAE,cAAc,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE;IACxE,OAAO,EAAE,CAAC,wCAAwC,CAAC;IACnD,iBAAiB,EAAE,CAAC,8CAA8C,CAAC;IACnE,QAAQ,EAAE,CAAC,QAAQ,CAAC;CACrB,CAAC;AAEF,SAAsB,OAAO,CAAC,MAAuB;;QACnD,8DAA8D;QAC9D,MAAM,CAAC,GAAG,MAAa,CAAC;QACxB,IAAI,CAAC,CAAC,QAAQ,EAAE;YACd,MAAM,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC;gBACvB,MAAM,EAAE,yBAAyB;gBACjC,MAAM,EAAE,CAAC,MAAM,CAAC;aACjB,CAAC,CAAC;SACJ;IACH,CAAC;CAAA;AATD,0BASC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ethers } from 'ethers';
|
|
2
|
+
import type { types } from '@hyperlane-xyz/utils';
|
|
3
|
+
import { ProxiedContract, ProxyAddresses } from './proxy';
|
|
4
|
+
import { Connection } from './types';
|
|
5
|
+
export declare type HyperlaneFactories = {
|
|
6
|
+
[key: string]: ethers.ContractFactory;
|
|
7
|
+
};
|
|
8
|
+
export declare type HyperlaneContracts = {
|
|
9
|
+
[key: Exclude<string, 'address'>]: ethers.Contract | ProxiedContract<any, any> | HyperlaneContracts;
|
|
10
|
+
};
|
|
11
|
+
export declare type HyperlaneAddresses = {
|
|
12
|
+
[key: string]: types.Address | ProxyAddresses<any> | HyperlaneAddresses;
|
|
13
|
+
};
|
|
14
|
+
export declare function serializeContracts(contractOrObject: HyperlaneContracts, max_depth?: number): HyperlaneAddresses;
|
|
15
|
+
export declare function buildContracts(addressOrObject: HyperlaneAddresses, factories: HyperlaneFactories, max_depth?: number): HyperlaneContracts;
|
|
16
|
+
export declare function connectContracts<Contracts extends HyperlaneContracts>(contractOrObject: Contracts, connection: Connection, max_depth?: number): Contracts;
|
|
17
|
+
//# sourceMappingURL=contracts.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contracts.d.ts","sourceRoot":"","sources":["../src/contracts.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAEhC,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAElD,OAAO,EAAE,eAAe,EAAE,cAAc,EAAoB,MAAM,SAAS,CAAC;AAC5E,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAGrC,oBAAY,kBAAkB,GAAG;IAC/B,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAC,eAAe,CAAC;CACvC,CAAC;AAEF,oBAAY,kBAAkB,GAAG;IAC/B,CAAC,GAAG,EAAE,OAAO,CAAC,MAAM,EAAE,SAAS,CAAC,GAC5B,MAAM,CAAC,QAAQ,GACf,eAAe,CAAC,GAAG,EAAE,GAAG,CAAC,GACzB,kBAAkB,CAAC;CACxB,CAAC;AAEF,oBAAY,kBAAkB,GAAG;IAC/B,CAAC,GAAG,EAAE,MAAM,GAAG,KAAK,CAAC,OAAO,GAAG,cAAc,CAAC,GAAG,CAAC,GAAG,kBAAkB,CAAC;CACzE,CAAC;AAEF,wBAAgB,kBAAkB,CAChC,gBAAgB,EAAE,kBAAkB,EACpC,SAAS,SAAI,GACZ,kBAAkB,CAgBpB;AAYD,wBAAgB,cAAc,CAC5B,eAAe,EAAE,kBAAkB,EACnC,SAAS,EAAE,kBAAkB,EAC7B,SAAS,SAAI,GACZ,kBAAkB,CAkBpB;AAED,wBAAgB,gBAAgB,CAAC,SAAS,SAAS,kBAAkB,EACnE,gBAAgB,EAAE,SAAS,EAC3B,UAAU,EAAE,UAAU,EACtB,SAAS,SAAI,GACZ,SAAS,CAWX"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.connectContracts = exports.buildContracts = exports.serializeContracts = void 0;
|
|
4
|
+
const proxy_1 = require("./proxy");
|
|
5
|
+
const objects_1 = require("./utils/objects");
|
|
6
|
+
function serializeContracts(contractOrObject, max_depth = 5) {
|
|
7
|
+
if (max_depth === 0) {
|
|
8
|
+
throw new Error('serializeContracts tried to go too deep');
|
|
9
|
+
}
|
|
10
|
+
return (0, objects_1.objMap)(contractOrObject, (_, contract) => {
|
|
11
|
+
if (contract instanceof proxy_1.ProxiedContract) {
|
|
12
|
+
return contract.addresses;
|
|
13
|
+
}
|
|
14
|
+
else if (contract.address) {
|
|
15
|
+
return contract.address;
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
return serializeContracts(contract, max_depth - 1);
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
exports.serializeContracts = serializeContracts;
|
|
23
|
+
function getFactory(key, factories) {
|
|
24
|
+
if (!(key in factories)) {
|
|
25
|
+
throw new Error(`Factories entry missing for ${key}`);
|
|
26
|
+
}
|
|
27
|
+
return factories[key];
|
|
28
|
+
}
|
|
29
|
+
function buildContracts(addressOrObject, factories, max_depth = 5) {
|
|
30
|
+
if (max_depth === 0) {
|
|
31
|
+
throw new Error('buildContracts tried to go too deep');
|
|
32
|
+
}
|
|
33
|
+
return (0, objects_1.objMap)(addressOrObject, (key, address) => {
|
|
34
|
+
if ((0, proxy_1.isProxyAddresses)(address)) {
|
|
35
|
+
const contract = getFactory(key, factories).attach(address.proxy);
|
|
36
|
+
return new proxy_1.ProxiedContract(contract, address);
|
|
37
|
+
}
|
|
38
|
+
else if (typeof address === 'string') {
|
|
39
|
+
return getFactory(key, factories).attach(address);
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
return buildContracts(address, factories, max_depth - 1);
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
exports.buildContracts = buildContracts;
|
|
47
|
+
function connectContracts(contractOrObject, connection, max_depth = 5) {
|
|
48
|
+
if (max_depth === 0) {
|
|
49
|
+
throw new Error('connectContracts tried to go too deep');
|
|
50
|
+
}
|
|
51
|
+
return (0, objects_1.objMap)(contractOrObject, (_, contract) => {
|
|
52
|
+
if (contract.connect) {
|
|
53
|
+
return contract.connect(connection);
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
return connectContracts(contract, connection, max_depth - 1);
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
exports.connectContracts = connectContracts;
|
|
61
|
+
//# sourceMappingURL=contracts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contracts.js","sourceRoot":"","sources":["../src/contracts.ts"],"names":[],"mappings":";;;AAIA,mCAA4E;AAE5E,6CAAyC;AAiBzC,SAAgB,kBAAkB,CAChC,gBAAoC,EACpC,SAAS,GAAG,CAAC;IAEb,IAAI,SAAS,KAAK,CAAC,EAAE;QACnB,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;KAC5D;IACD,OAAO,IAAA,gBAAM,EACX,gBAAgB,EAChB,CAAC,CAAC,EAAE,QAAa,EAAqD,EAAE;QACtE,IAAI,QAAQ,YAAY,uBAAe,EAAE;YACvC,OAAO,QAAQ,CAAC,SAAS,CAAC;SAC3B;aAAM,IAAI,QAAQ,CAAC,OAAO,EAAE;YAC3B,OAAO,QAAQ,CAAC,OAAO,CAAC;SACzB;aAAM;YACL,OAAO,kBAAkB,CAAC,QAAQ,EAAE,SAAS,GAAG,CAAC,CAAC,CAAC;SACpD;IACH,CAAC,CACF,CAAC;AACJ,CAAC;AAnBD,gDAmBC;AAED,SAAS,UAAU,CACjB,GAAW,EACX,SAA6B;IAE7B,IAAI,CAAC,CAAC,GAAG,IAAI,SAAS,CAAC,EAAE;QACvB,MAAM,IAAI,KAAK,CAAC,+BAA+B,GAAG,EAAE,CAAC,CAAC;KACvD;IACD,OAAO,SAAS,CAAC,GAAG,CAAC,CAAC;AACxB,CAAC;AAED,SAAgB,cAAc,CAC5B,eAAmC,EACnC,SAA6B,EAC7B,SAAS,GAAG,CAAC;IAEb,IAAI,SAAS,KAAK,CAAC,EAAE;QACnB,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;KACxD;IACD,OAAO,IAAA,gBAAM,EAAC,eAAe,EAAE,CAAC,GAAG,EAAE,OAAY,EAAE,EAAE;QACnD,IAAI,IAAA,wBAAgB,EAAC,OAAO,CAAC,EAAE;YAC7B,MAAM,QAAQ,GAAG,UAAU,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YAClE,OAAO,IAAI,uBAAe,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;SAC/C;aAAM,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE;YACtC,OAAO,UAAU,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;SACnD;aAAM;YACL,OAAO,cAAc,CACnB,OAA6B,EAC7B,SAAS,EACT,SAAS,GAAG,CAAC,CACd,CAAC;SACH;IACH,CAAC,CAAC,CAAC;AACL,CAAC;AAtBD,wCAsBC;AAED,SAAgB,gBAAgB,CAC9B,gBAA2B,EAC3B,UAAsB,EACtB,SAAS,GAAG,CAAC;IAEb,IAAI,SAAS,KAAK,CAAC,EAAE;QACnB,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;KAC1D;IACD,OAAO,IAAA,gBAAM,EAAC,gBAAgB,EAAE,CAAC,CAAC,EAAE,QAAa,EAAE,EAAE;QACnD,IAAI,QAAQ,CAAC,OAAO,EAAE;YACpB,OAAO,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;SACrC;aAAM;YACL,OAAO,gBAAgB,CAAC,QAAQ,EAAE,UAAU,EAAE,SAAS,GAAG,CAAC,CAAC,CAAC;SAC9D;IACH,CAAC,CAAc,CAAC;AAClB,CAAC;AAfD,4CAeC"}
|