@hyperlane-xyz/sdk 16.0.0 → 16.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/block-explorer/etherscan.d.ts +1 -12
- package/dist/block-explorer/etherscan.d.ts.map +1 -1
- package/dist/block-explorer/etherscan.js +14 -2
- package/dist/block-explorer/etherscan.js.map +1 -1
- package/dist/block-explorer/utils.d.ts +3 -0
- package/dist/block-explorer/utils.d.ts.map +1 -0
- package/dist/block-explorer/utils.js +16 -0
- package/dist/block-explorer/utils.js.map +1 -0
- package/dist/consts/testChains.d.ts +2 -0
- package/dist/consts/testChains.d.ts.map +1 -1
- package/dist/consts/testChains.js +36 -1
- package/dist/consts/testChains.js.map +1 -1
- package/dist/contracts/contracts.d.ts +9 -1
- package/dist/contracts/contracts.d.ts.map +1 -1
- package/dist/contracts/contracts.js +15 -1
- package/dist/contracts/contracts.js.map +1 -1
- package/dist/deploy/verify/ContractVerifier.d.ts.map +1 -1
- package/dist/deploy/verify/ContractVerifier.js +16 -5
- package/dist/deploy/verify/ContractVerifier.js.map +1 -1
- package/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -1
- package/dist/index.js.map +1 -1
- package/dist/metadata/ChainMetadataManager.d.ts +10 -0
- package/dist/metadata/ChainMetadataManager.d.ts.map +1 -1
- package/dist/metadata/ChainMetadataManager.js +33 -2
- package/dist/metadata/ChainMetadataManager.js.map +1 -1
- package/dist/metadata/blockExplorer.d.ts.map +1 -1
- package/dist/metadata/blockExplorer.js +27 -1
- package/dist/metadata/blockExplorer.js.map +1 -1
- package/dist/metadata/blockExplorer.test.js +176 -1
- package/dist/metadata/blockExplorer.test.js.map +1 -1
- package/dist/providers/transactions/submitter/ethersV5/EV5TimelockSubmitter.d.ts.map +1 -1
- package/dist/providers/transactions/submitter/ethersV5/EV5TimelockSubmitter.js +3 -3
- package/dist/providers/transactions/submitter/ethersV5/EV5TimelockSubmitter.js.map +1 -1
- package/dist/rpc/evm/EvmEventLogsReader.d.ts +79 -0
- package/dist/rpc/evm/EvmEventLogsReader.d.ts.map +1 -0
- package/dist/rpc/evm/EvmEventLogsReader.hardhat-test.d.ts +2 -0
- package/dist/rpc/evm/EvmEventLogsReader.hardhat-test.d.ts.map +1 -0
- package/dist/rpc/evm/EvmEventLogsReader.hardhat-test.js +279 -0
- package/dist/rpc/evm/EvmEventLogsReader.hardhat-test.js.map +1 -0
- package/dist/rpc/evm/EvmEventLogsReader.js +107 -0
- package/dist/rpc/evm/EvmEventLogsReader.js.map +1 -0
- package/dist/rpc/evm/types.d.ts +11 -0
- package/dist/rpc/evm/types.d.ts.map +1 -0
- package/dist/rpc/evm/types.js +2 -0
- package/dist/rpc/evm/types.js.map +1 -0
- package/dist/rpc/evm/utils.d.ts +18 -0
- package/dist/rpc/evm/utils.d.ts.map +1 -0
- package/dist/rpc/evm/utils.hardhat-test.d.ts +2 -0
- package/dist/rpc/evm/utils.hardhat-test.d.ts.map +1 -0
- package/dist/rpc/evm/utils.hardhat-test.js +144 -0
- package/dist/rpc/evm/utils.hardhat-test.js.map +1 -0
- package/dist/rpc/evm/utils.js +67 -0
- package/dist/rpc/evm/utils.js.map +1 -0
- package/dist/timelock/evm/EvmTimelockReader.d.ts +30 -0
- package/dist/timelock/evm/EvmTimelockReader.d.ts.map +1 -0
- package/dist/timelock/evm/EvmTimelockReader.hardhat-test.d.ts +2 -0
- package/dist/timelock/evm/EvmTimelockReader.hardhat-test.d.ts.map +1 -0
- package/dist/timelock/evm/EvmTimelockReader.hardhat-test.js +649 -0
- package/dist/timelock/evm/EvmTimelockReader.hardhat-test.js.map +1 -0
- package/dist/timelock/evm/EvmTimelockReader.js +173 -0
- package/dist/timelock/evm/EvmTimelockReader.js.map +1 -0
- package/dist/timelock/evm/utils.d.ts +4 -0
- package/dist/timelock/evm/utils.d.ts.map +1 -0
- package/dist/timelock/evm/utils.js +11 -0
- package/dist/timelock/evm/utils.js.map +1 -0
- package/dist/timelock/types.d.ts +11 -0
- package/dist/timelock/types.d.ts.map +1 -1
- package/dist/timelock/types.js.map +1 -1
- package/dist/token/checker.js +2 -2
- package/dist/token/checker.js.map +1 -1
- package/dist/token/types.d.ts +1 -1
- package/dist/token/xerc20.d.ts.map +1 -1
- package/dist/token/xerc20.js +3 -35
- package/dist/token/xerc20.js.map +1 -1
- package/package.json +5 -5
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { assertIsContractAddress, isContractAddress, } from '../../contracts/contracts.js';
|
|
2
|
+
// calling getCode until the creation block is found
|
|
3
|
+
export async function getContractCreationBlockFromRpc(chain, contractAddress, multiProvider) {
|
|
4
|
+
await assertIsContractAddress(multiProvider, chain, contractAddress);
|
|
5
|
+
const provider = multiProvider.getProvider(chain);
|
|
6
|
+
const latestBlock = await provider.getBlockNumber();
|
|
7
|
+
let low = 0;
|
|
8
|
+
let high = latestBlock;
|
|
9
|
+
let creationBlock = latestBlock;
|
|
10
|
+
while (low <= high) {
|
|
11
|
+
const mid = Math.floor((low + high) / 2);
|
|
12
|
+
const isContract = await isContractAddress(multiProvider, chain, contractAddress, mid);
|
|
13
|
+
if (isContract) {
|
|
14
|
+
creationBlock = mid;
|
|
15
|
+
high = mid - 1;
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
low = mid + 1;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return creationBlock;
|
|
22
|
+
}
|
|
23
|
+
export async function getLogsFromRpc({ chain, contractAddress, multiProvider, fromBlock, topic, toBlock, range = 500, }) {
|
|
24
|
+
const provider = multiProvider.getProvider(chain);
|
|
25
|
+
let currentStartBlock = fromBlock;
|
|
26
|
+
const endBlock = toBlock ?? (await provider.getBlockNumber());
|
|
27
|
+
const logs = [];
|
|
28
|
+
while (currentStartBlock <= endBlock) {
|
|
29
|
+
const currentEndBlock = currentStartBlock + range < endBlock
|
|
30
|
+
? currentStartBlock + range
|
|
31
|
+
: endBlock;
|
|
32
|
+
const currentLogs = await provider.getLogs({
|
|
33
|
+
address: contractAddress,
|
|
34
|
+
fromBlock: currentStartBlock,
|
|
35
|
+
toBlock: currentEndBlock,
|
|
36
|
+
topics: [topic],
|
|
37
|
+
});
|
|
38
|
+
logs.push(...currentLogs);
|
|
39
|
+
// +1 because getLogs range is inclusive
|
|
40
|
+
currentStartBlock += range + 1;
|
|
41
|
+
}
|
|
42
|
+
return logs.map((rawLog) => {
|
|
43
|
+
return {
|
|
44
|
+
address: rawLog.address,
|
|
45
|
+
blockNumber: rawLog.blockNumber,
|
|
46
|
+
data: rawLog.data,
|
|
47
|
+
logIndex: rawLog.logIndex,
|
|
48
|
+
topics: rawLog.topics,
|
|
49
|
+
transactionHash: rawLog.transactionHash,
|
|
50
|
+
transactionIndex: rawLog.transactionIndex,
|
|
51
|
+
};
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
export function viemLogFromGetEventLogsResponse(log) {
|
|
55
|
+
return {
|
|
56
|
+
address: log.address,
|
|
57
|
+
data: log.data,
|
|
58
|
+
blockNumber: BigInt(log.blockNumber),
|
|
59
|
+
transactionHash: log.transactionHash,
|
|
60
|
+
logIndex: Number(log.logIndex),
|
|
61
|
+
transactionIndex: Number(log.transactionIndex),
|
|
62
|
+
topics: log.topics,
|
|
63
|
+
blockHash: null,
|
|
64
|
+
removed: false,
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/rpc/evm/utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { TimelockController } from '@hyperlane-xyz/core';
|
|
2
|
+
import { Address } from '@hyperlane-xyz/utils';
|
|
3
|
+
import { MultiProvider } from '../../providers/MultiProvider.js';
|
|
4
|
+
import { EvmEventLogsReader, EvmEventLogsReaderConfig } from '../../rpc/evm/EvmEventLogsReader.js';
|
|
5
|
+
import { ChainNameOrId } from '../../types.js';
|
|
6
|
+
import { ExecutableTimelockTx, TimelockTx } from '../types.js';
|
|
7
|
+
export type EvmTimelockReaderConfig = {
|
|
8
|
+
chain: Readonly<ChainNameOrId>;
|
|
9
|
+
timelockAddress: Readonly<Address>;
|
|
10
|
+
multiProvider: Readonly<MultiProvider>;
|
|
11
|
+
} & EvmEventLogsReaderConfig;
|
|
12
|
+
export declare class EvmTimelockReader {
|
|
13
|
+
protected readonly chain: ChainNameOrId;
|
|
14
|
+
protected readonly multiProvider: MultiProvider;
|
|
15
|
+
protected timelockInstance: TimelockController;
|
|
16
|
+
protected evmLogReader: EvmEventLogsReader;
|
|
17
|
+
protected constructor(chain: ChainNameOrId, multiProvider: MultiProvider, timelockInstance: TimelockController, evmLogReader: EvmEventLogsReader);
|
|
18
|
+
static fromConfig(config: EvmTimelockReaderConfig): EvmTimelockReader;
|
|
19
|
+
getOperationsSalt(): Promise<Record<string, string>>;
|
|
20
|
+
getScheduledOperations(): Promise<Record<string, TimelockTx>>;
|
|
21
|
+
getCancelledOperationIds(): Promise<Set<string>>;
|
|
22
|
+
getExecutedOperationIds(): Promise<Set<string>>;
|
|
23
|
+
getReadyOperationIds(operationIds: string[]): Promise<Set<string>>;
|
|
24
|
+
getScheduledExecutableTransactions(): Promise<Record<string, ExecutableTimelockTx>>;
|
|
25
|
+
hasRole(address: Address, role: string): Promise<boolean>;
|
|
26
|
+
canExecuteOperations(address: Address): Promise<boolean>;
|
|
27
|
+
canCancelOperations(address: Address): Promise<boolean>;
|
|
28
|
+
canScheduleOperations(address: Address): Promise<boolean>;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=EvmTimelockReader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EvmTimelockReader.d.ts","sourceRoot":"","sources":["../../../src/timelock/evm/EvmTimelockReader.ts"],"names":[],"mappings":"AAQA,OAAO,EACL,kBAAkB,EAEnB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,OAAO,EAAqB,MAAM,sBAAsB,CAAC;AAElE,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AACjE,OAAO,EACL,kBAAkB,EAClB,wBAAwB,EACzB,MAAM,qCAAqC,CAAC;AAG7C,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAsC/D,MAAM,MAAM,uBAAuB,GAAG;IACpC,KAAK,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;IAC/B,eAAe,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;IACnC,aAAa,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;CACxC,GAAG,wBAAwB,CAAC;AAE7B,qBAAa,iBAAiB;IAE1B,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAE,aAAa;IACvC,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,aAAa;IAC/C,SAAS,CAAC,gBAAgB,EAAE,kBAAkB;IAC9C,SAAS,CAAC,YAAY,EAAE,kBAAkB;IAJ5C,SAAS,aACY,KAAK,EAAE,aAAa,EACpB,aAAa,EAAE,aAAa,EACrC,gBAAgB,EAAE,kBAAkB,EACpC,YAAY,EAAE,kBAAkB;IAG5C,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,uBAAuB,GAAG,iBAAiB;IA2B/D,iBAAiB,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAiBpD,sBAAsB,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;IAe7D,wBAAwB,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAShD,uBAAuB,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAS/C,oBAAoB,CAAC,YAAY,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAalE,kCAAkC,IAAI,OAAO,CACjD,MAAM,CAAC,MAAM,EAAE,oBAAoB,CAAC,CACrC;IAyCK,OAAO,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAUzD,oBAAoB,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAIxD,mBAAmB,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAIvD,qBAAqB,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;CAGhE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EvmTimelockReader.hardhat-test.d.ts","sourceRoot":"","sources":["../../../src/timelock/evm/EvmTimelockReader.hardhat-test.ts"],"names":[],"mappings":""}
|