viem 2.0.0-beta.15 → 2.0.0-beta.16
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/CHANGELOG.md +44 -0
- package/README.md +9 -3
- package/_cjs/actions/ens/getEnsName.js +4 -2
- package/_cjs/actions/ens/getEnsName.js.map +1 -1
- package/_cjs/actions/index.js +16 -2
- package/_cjs/actions/index.js.map +1 -1
- package/_cjs/chains/definitions/arbitrumSepolia.js +4 -0
- package/_cjs/chains/definitions/arbitrumSepolia.js.map +1 -1
- package/_cjs/chains/definitions/fantomSonicTestnet.js +26 -0
- package/_cjs/chains/definitions/fantomSonicTestnet.js.map +1 -0
- package/_cjs/chains/definitions/zilliqa.js +26 -0
- package/_cjs/chains/definitions/zilliqa.js.map +1 -0
- package/_cjs/chains/definitions/zilliqaTestnet.js +26 -0
- package/_cjs/chains/definitions/zilliqaTestnet.js.map +1 -0
- package/_cjs/chains/definitions/zkSyncSepoliaTestnet.js +35 -0
- package/_cjs/chains/definitions/zkSyncSepoliaTestnet.js.map +1 -0
- package/_cjs/chains/definitions/zkSyncTestnet.js +4 -0
- package/_cjs/chains/definitions/zkSyncTestnet.js.map +1 -1
- package/_cjs/chains/index.js +12 -4
- package/_cjs/chains/index.js.map +1 -1
- package/_cjs/chains/opStack/index.js +3 -3
- package/_cjs/chains/opStack/index.js.map +1 -1
- package/_cjs/chains/opStack/utils/getL2TransactionHash.js +2 -2
- package/_cjs/chains/opStack/utils/getL2TransactionHash.js.map +1 -1
- package/_cjs/chains/opStack/utils/{fromOpaqueData.js → opaqueDataToDepositData.js} +4 -4
- package/_cjs/chains/opStack/utils/opaqueDataToDepositData.js.map +1 -0
- package/_cjs/errors/abi.js +21 -1
- package/_cjs/errors/abi.js.map +1 -1
- package/_cjs/errors/version.js +1 -1
- package/_cjs/index.js +6 -2
- package/_cjs/index.js.map +1 -1
- package/_cjs/utils/abi/getAbiItem.js +46 -3
- package/_cjs/utils/abi/getAbiItem.js.map +1 -1
- package/_cjs/utils/hash/ripemd160.js +16 -0
- package/_cjs/utils/hash/ripemd160.js.map +1 -0
- package/_cjs/utils/hash/sha256.js +16 -0
- package/_cjs/utils/hash/sha256.js.map +1 -0
- package/_cjs/utils/index.js +5 -1
- package/_cjs/utils/index.js.map +1 -1
- package/_esm/actions/ens/getEnsName.js +4 -2
- package/_esm/actions/ens/getEnsName.js.map +1 -1
- package/_esm/actions/index.js +7 -0
- package/_esm/actions/index.js.map +1 -1
- package/_esm/chains/definitions/arbitrumSepolia.js +4 -0
- package/_esm/chains/definitions/arbitrumSepolia.js.map +1 -1
- package/_esm/chains/definitions/fantomSonicTestnet.js +23 -0
- package/_esm/chains/definitions/fantomSonicTestnet.js.map +1 -0
- package/_esm/chains/definitions/zilliqa.js +23 -0
- package/_esm/chains/definitions/zilliqa.js.map +1 -0
- package/_esm/chains/definitions/zilliqaTestnet.js +23 -0
- package/_esm/chains/definitions/zilliqaTestnet.js.map +1 -0
- package/_esm/chains/definitions/zkSyncSepoliaTestnet.js +32 -0
- package/_esm/chains/definitions/zkSyncSepoliaTestnet.js.map +1 -0
- package/_esm/chains/definitions/zkSyncTestnet.js +5 -0
- package/_esm/chains/definitions/zkSyncTestnet.js.map +1 -1
- package/_esm/chains/index.js +4 -0
- package/_esm/chains/index.js.map +1 -1
- package/_esm/chains/opStack/index.js +1 -1
- package/_esm/chains/opStack/index.js.map +1 -1
- package/_esm/chains/opStack/utils/getL2TransactionHash.js +2 -2
- package/_esm/chains/opStack/utils/getL2TransactionHash.js.map +1 -1
- package/_esm/chains/opStack/utils/{fromOpaqueData.js → opaqueDataToDepositData.js} +2 -2
- package/_esm/chains/opStack/utils/opaqueDataToDepositData.js.map +1 -0
- package/_esm/errors/abi.js +19 -0
- package/_esm/errors/abi.js.map +1 -1
- package/_esm/errors/version.js +1 -1
- package/_esm/index.js +2 -0
- package/_esm/index.js.map +1 -1
- package/_esm/utils/abi/getAbiItem.js +46 -2
- package/_esm/utils/abi/getAbiItem.js.map +1 -1
- package/_esm/utils/hash/ripemd160.js +12 -0
- package/_esm/utils/hash/ripemd160.js.map +1 -0
- package/_esm/utils/hash/sha256.js +12 -0
- package/_esm/utils/hash/sha256.js.map +1 -0
- package/_esm/utils/index.js +2 -0
- package/_esm/utils/index.js.map +1 -1
- package/_types/actions/ens/getEnsName.d.ts.map +1 -1
- package/_types/actions/index.d.ts +7 -0
- package/_types/actions/index.d.ts.map +1 -1
- package/_types/chains/definitions/arbitrumSepolia.d.ts +4 -0
- package/_types/chains/definitions/arbitrumSepolia.d.ts.map +1 -1
- package/_types/chains/definitions/fantomSonicTestnet.d.ts +38 -0
- package/_types/chains/definitions/fantomSonicTestnet.d.ts.map +1 -0
- package/_types/chains/definitions/zilliqa.d.ts +38 -0
- package/_types/chains/definitions/zilliqa.d.ts.map +1 -0
- package/_types/chains/definitions/zilliqaTestnet.d.ts +38 -0
- package/_types/chains/definitions/zilliqaTestnet.d.ts.map +1 -0
- package/_types/chains/definitions/zkSyncSepoliaTestnet.d.ts +533 -0
- package/_types/chains/definitions/zkSyncSepoliaTestnet.d.ts.map +1 -0
- package/_types/chains/definitions/zkSyncTestnet.d.ts +5 -0
- package/_types/chains/definitions/zkSyncTestnet.d.ts.map +1 -1
- package/_types/chains/index.d.ts +4 -0
- package/_types/chains/index.d.ts.map +1 -1
- package/_types/chains/opStack/index.d.ts +1 -1
- package/_types/chains/opStack/index.d.ts.map +1 -1
- package/_types/chains/opStack/utils/opaqueDataToDepositData.d.ts +15 -0
- package/_types/chains/opStack/utils/opaqueDataToDepositData.d.ts.map +1 -0
- package/_types/errors/abi.d.ts +14 -1
- package/_types/errors/abi.d.ts.map +1 -1
- package/_types/errors/version.d.ts +1 -1
- package/_types/index.d.ts +12 -0
- package/_types/index.d.ts.map +1 -1
- package/_types/types/eip1193.d.ts +12 -0
- package/_types/types/eip1193.d.ts.map +1 -1
- package/_types/utils/abi/getAbiItem.d.ts +2 -1
- package/_types/utils/abi/getAbiItem.d.ts.map +1 -1
- package/_types/utils/hash/ripemd160.d.ts +11 -0
- package/_types/utils/hash/ripemd160.d.ts.map +1 -0
- package/_types/utils/hash/sha256.d.ts +11 -0
- package/_types/utils/hash/sha256.d.ts.map +1 -0
- package/_types/utils/index.d.ts +2 -0
- package/_types/utils/index.d.ts.map +1 -1
- package/actions/ens/getEnsName.ts +3 -2
- package/actions/index.ts +31 -0
- package/chains/definitions/arbitrumSepolia.ts +4 -0
- package/chains/definitions/fantomSonicTestnet.ts +23 -0
- package/chains/definitions/zilliqa.ts +23 -0
- package/chains/definitions/zilliqaTestnet.ts +23 -0
- package/chains/definitions/zkSyncSepoliaTestnet.ts +32 -0
- package/chains/definitions/zkSyncTestnet.ts +5 -0
- package/chains/index.ts +4 -0
- package/chains/opStack/index.ts +5 -5
- package/chains/opStack/utils/getL2TransactionHash.ts +2 -2
- package/chains/opStack/utils/{fromOpaqueData.ts → opaqueDataToDepositData.ts} +9 -4
- package/errors/abi.ts +22 -1
- package/errors/version.ts +1 -1
- package/index.ts +31 -0
- package/package.json +1 -1
- package/types/eip1193.ts +12 -0
- package/utils/abi/getAbiItem.ts +71 -2
- package/utils/hash/ripemd160.ts +31 -0
- package/utils/hash/sha256.ts +31 -0
- package/utils/index.ts +2 -0
- package/_cjs/chains/opStack/utils/fromOpaqueData.js.map +0 -1
- package/_esm/chains/opStack/utils/fromOpaqueData.js.map +0 -1
- package/_types/chains/opStack/utils/fromOpaqueData.d.ts +0 -15
- package/_types/chains/opStack/utils/fromOpaqueData.d.ts.map +0 -1
@@ -0,0 +1,23 @@
|
|
1
|
+
import { defineChain } from '../../utils/chain/defineChain.js'
|
2
|
+
|
3
|
+
export const fantomSonicTestnet = /*#__PURE__*/ defineChain({
|
4
|
+
id: 64_240,
|
5
|
+
name: 'Fantom Sonic Open Testnet',
|
6
|
+
network: 'fantom-sonic-testnet',
|
7
|
+
nativeCurrency: {
|
8
|
+
decimals: 18,
|
9
|
+
name: 'Fantom',
|
10
|
+
symbol: 'FTM',
|
11
|
+
},
|
12
|
+
rpcUrls: {
|
13
|
+
default: { http: ['https://rpcapi.sonic.fantom.network'] },
|
14
|
+
public: { http: ['https://rpcapi.sonic.fantom.network'] },
|
15
|
+
},
|
16
|
+
blockExplorers: {
|
17
|
+
default: {
|
18
|
+
name: 'Fantom Sonic Open Testnet Explorer',
|
19
|
+
url: 'https://public-sonic.fantom.network',
|
20
|
+
},
|
21
|
+
},
|
22
|
+
testnet: true,
|
23
|
+
})
|
@@ -0,0 +1,23 @@
|
|
1
|
+
import { defineChain } from '../../utils/chain/defineChain.js'
|
2
|
+
|
3
|
+
export const zilliqa = /*#__PURE__*/ defineChain({
|
4
|
+
id: 32769,
|
5
|
+
name: 'Zilliqa',
|
6
|
+
network: 'zilliqa',
|
7
|
+
nativeCurrency: { name: 'Zilliqa', symbol: 'ZIL', decimals: 18 },
|
8
|
+
rpcUrls: {
|
9
|
+
default: {
|
10
|
+
http: ['https://api.zilliqa.com'],
|
11
|
+
},
|
12
|
+
public: {
|
13
|
+
http: ['https://api.zilliqa.com'],
|
14
|
+
},
|
15
|
+
},
|
16
|
+
blockExplorers: {
|
17
|
+
default: {
|
18
|
+
name: 'Ethernal',
|
19
|
+
url: 'https://evmx.zilliqa.com',
|
20
|
+
},
|
21
|
+
},
|
22
|
+
testnet: false,
|
23
|
+
})
|
@@ -0,0 +1,23 @@
|
|
1
|
+
import { defineChain } from '../../utils/chain/defineChain.js'
|
2
|
+
|
3
|
+
export const zilliqaTestnet = /*#__PURE__*/ defineChain({
|
4
|
+
id: 33101,
|
5
|
+
name: 'Zilliqa Testnet',
|
6
|
+
network: 'zilliqa-testnet',
|
7
|
+
nativeCurrency: { name: 'Zilliqa', symbol: 'ZIL', decimals: 18 },
|
8
|
+
rpcUrls: {
|
9
|
+
default: {
|
10
|
+
http: ['https://dev-api.zilliqa.com'],
|
11
|
+
},
|
12
|
+
public: {
|
13
|
+
http: ['https://dev-api.zilliqa.com'],
|
14
|
+
},
|
15
|
+
},
|
16
|
+
blockExplorers: {
|
17
|
+
default: {
|
18
|
+
name: 'Ethernal',
|
19
|
+
url: 'https://evmx.testnet.zilliqa.com',
|
20
|
+
},
|
21
|
+
},
|
22
|
+
testnet: true,
|
23
|
+
})
|
@@ -0,0 +1,32 @@
|
|
1
|
+
import { defineChain } from '../../utils/chain/defineChain.js'
|
2
|
+
import { chainConfig } from '../zksync/chainConfig.js'
|
3
|
+
|
4
|
+
export const zkSyncSepoliaTestnet = /*#__PURE__*/ defineChain({
|
5
|
+
...chainConfig,
|
6
|
+
id: 300,
|
7
|
+
name: 'zkSync Sepolia Testnet',
|
8
|
+
network: 'zksync-sepolia-testnet',
|
9
|
+
nativeCurrency: { name: 'Ether', symbol: 'ETH', decimals: 18 },
|
10
|
+
rpcUrls: {
|
11
|
+
default: {
|
12
|
+
http: ['https://sepolia.era.zksync.dev'],
|
13
|
+
webSocket: ['wss://sepolia.era.zksync.dev/ws'],
|
14
|
+
},
|
15
|
+
public: {
|
16
|
+
http: ['https://sepolia.era.zksync.dev'],
|
17
|
+
webSocket: ['wss://sepolia.era.zksync.dev/ws'],
|
18
|
+
},
|
19
|
+
},
|
20
|
+
blockExplorers: {
|
21
|
+
default: {
|
22
|
+
name: 'zkExplorer',
|
23
|
+
url: 'https://sepolia.explorer.zksync.io/',
|
24
|
+
},
|
25
|
+
},
|
26
|
+
contracts: {
|
27
|
+
multicall3: {
|
28
|
+
address: '0xF9cda624FBC7e059355ce98a31693d299FACd963',
|
29
|
+
},
|
30
|
+
},
|
31
|
+
testnet: true,
|
32
|
+
})
|
@@ -1,6 +1,7 @@
|
|
1
1
|
import { defineChain } from '../../utils/chain/defineChain.js'
|
2
2
|
import { chainConfig } from '../zksync/chainConfig.js'
|
3
3
|
|
4
|
+
/** @deprecated Use `zkSyncSepoliaTestnet` */
|
4
5
|
export const zkSyncTestnet = /*#__PURE__*/ defineChain({
|
5
6
|
...chainConfig,
|
6
7
|
id: 280,
|
@@ -12,6 +13,10 @@ export const zkSyncTestnet = /*#__PURE__*/ defineChain({
|
|
12
13
|
http: ['https://testnet.era.zksync.dev'],
|
13
14
|
webSocket: ['wss://testnet.era.zksync.dev/ws'],
|
14
15
|
},
|
16
|
+
public: {
|
17
|
+
http: ['https://testnet.era.zksync.dev'],
|
18
|
+
webSocket: ['wss://testnet.era.zksync.dev/ws'],
|
19
|
+
},
|
15
20
|
},
|
16
21
|
blockExplorers: {
|
17
22
|
default: {
|
package/chains/index.ts
CHANGED
@@ -45,6 +45,7 @@ export { evmosTestnet } from './definitions/evmosTestnet.js'
|
|
45
45
|
export { ekta } from './definitions/ekta.js'
|
46
46
|
export { ektaTestnet } from './definitions/ektaTestnet.js'
|
47
47
|
export { fantom } from './definitions/fantom.js'
|
48
|
+
export { fantomSonicTestnet } from './definitions/fantomSonicTestnet.js'
|
48
49
|
export { fantomTestnet } from './definitions/fantomTestnet.js'
|
49
50
|
export { fibo } from './definitions/fibo.js'
|
50
51
|
export { filecoin } from './definitions/filecoin.js'
|
@@ -165,7 +166,10 @@ export { xdcTestnet } from './definitions/xdcTestnet.js'
|
|
165
166
|
export { zhejiang } from './definitions/zhejiang.js'
|
166
167
|
export { zkSync } from './definitions/zkSync.js'
|
167
168
|
export { zkSyncTestnet } from './definitions/zkSyncTestnet.js'
|
169
|
+
export { zkSyncSepoliaTestnet } from './definitions/zkSyncSepoliaTestnet.js'
|
168
170
|
export { zetachainAthensTestnet } from './definitions/zetachainAthensTestnet.js'
|
171
|
+
export { zilliqa } from './definitions/zilliqa.js'
|
172
|
+
export { zilliqaTestnet } from './definitions/zilliqaTestnet.js'
|
169
173
|
export { zora } from './definitions/zora.js'
|
170
174
|
export { zoraSepolia } from './definitions/zoraSepolia.js'
|
171
175
|
export { zoraTestnet } from './definitions/zoraTestnet.js'
|
package/chains/opStack/index.ts
CHANGED
@@ -114,11 +114,11 @@ export {
|
|
114
114
|
} from './utils/extractTransactionDepositedLogs.js'
|
115
115
|
|
116
116
|
export {
|
117
|
-
|
118
|
-
type
|
119
|
-
type
|
120
|
-
type
|
121
|
-
} from './utils/
|
117
|
+
opaqueDataToDepositData,
|
118
|
+
type OpaqueDataToDepositDataErrorType,
|
119
|
+
type OpaqueDataToDepositDataParameters,
|
120
|
+
type OpaqueDataToDepositDataReturnType,
|
121
|
+
} from './utils/opaqueDataToDepositData.js'
|
122
122
|
|
123
123
|
export {
|
124
124
|
getL2TransactionHash,
|
@@ -6,8 +6,8 @@ import type { Hex } from '../../../types/misc.js'
|
|
6
6
|
import { keccak256 } from '../../../utils/hash/keccak256.js'
|
7
7
|
import type { portalAbi } from '../abis.js'
|
8
8
|
import { serializeTransaction } from '../serializers.js'
|
9
|
-
import { fromOpaqueData } from './fromOpaqueData.js'
|
10
9
|
import { getSourceHash } from './getSourceHash.js'
|
10
|
+
import { opaqueDataToDepositData } from './opaqueDataToDepositData.js'
|
11
11
|
|
12
12
|
export type GetL2TransactionHashParameters = {
|
13
13
|
/** The "TransactionDeposited" log to compute the L2 hash from. */
|
@@ -32,7 +32,7 @@ export function getL2TransactionHash({ log }: GetL2TransactionHashParameters) {
|
|
32
32
|
l1BlockHash: log.blockHash,
|
33
33
|
l1LogIndex: log.logIndex,
|
34
34
|
})
|
35
|
-
const { data, gas, isCreation, mint, value } =
|
35
|
+
const { data, gas, isCreation, mint, value } = opaqueDataToDepositData(
|
36
36
|
log.args.opaqueData,
|
37
37
|
)
|
38
38
|
|
@@ -4,9 +4,9 @@ import { type SizeErrorType, size } from '../../../utils/data/size.js'
|
|
4
4
|
import { type SliceErrorType, slice } from '../../../utils/data/slice.js'
|
5
5
|
import { hexToBigInt } from '../../../utils/encoding/fromHex.js'
|
6
6
|
|
7
|
-
export type
|
7
|
+
export type OpaqueDataToDepositDataParameters = Hex
|
8
8
|
|
9
|
-
export type
|
9
|
+
export type OpaqueDataToDepositDataReturnType = {
|
10
10
|
mint: bigint
|
11
11
|
value: bigint
|
12
12
|
gas: bigint
|
@@ -14,9 +14,14 @@ export type FromOpaqueDataReturnType = {
|
|
14
14
|
data: Hex
|
15
15
|
}
|
16
16
|
|
17
|
-
export type
|
17
|
+
export type OpaqueDataToDepositDataErrorType =
|
18
|
+
| SliceErrorType
|
19
|
+
| SizeErrorType
|
20
|
+
| ErrorType
|
18
21
|
|
19
|
-
export function
|
22
|
+
export function opaqueDataToDepositData(
|
23
|
+
opaqueData: Hex,
|
24
|
+
): OpaqueDataToDepositDataReturnType {
|
20
25
|
let offset = 0
|
21
26
|
const mint = slice(opaqueData, offset, offset + 32)
|
22
27
|
offset += 32
|
package/errors/abi.ts
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
import type { AbiEvent, AbiParameter } from 'abitype'
|
1
|
+
import type { Abi, AbiEvent, AbiParameter } from 'abitype'
|
2
2
|
|
3
3
|
import type { Hex } from '../types/misc.js'
|
4
4
|
import { formatAbiItem, formatAbiParams } from '../utils/abi/formatAbiItem.js'
|
@@ -331,6 +331,27 @@ export class AbiFunctionSignatureNotFoundError extends BaseError {
|
|
331
331
|
}
|
332
332
|
}
|
333
333
|
|
334
|
+
export type AbiItemAmbiguityErrorType = AbiItemAmbiguityError & {
|
335
|
+
name: 'AbiItemAmbiguityError'
|
336
|
+
}
|
337
|
+
export class AbiItemAmbiguityError extends BaseError {
|
338
|
+
override name = 'AbiItemAmbiguityError'
|
339
|
+
constructor(
|
340
|
+
x: { abiItem: Abi[number]; type: string },
|
341
|
+
y: { abiItem: Abi[number]; type: string },
|
342
|
+
) {
|
343
|
+
super('Found ambiguous types in overloaded ABI items.', {
|
344
|
+
metaMessages: [
|
345
|
+
`\`${x.type}\` in \`${formatAbiItem(x.abiItem)}\`, and`,
|
346
|
+
`\`${y.type}\` in \`${formatAbiItem(y.abiItem)}\``,
|
347
|
+
'',
|
348
|
+
'These types encode differently and cannot be distinguished at runtime.',
|
349
|
+
'Remove one of the ambiguous items in the ABI.',
|
350
|
+
],
|
351
|
+
})
|
352
|
+
}
|
353
|
+
}
|
354
|
+
|
334
355
|
export type BytesSizeMismatchErrorType = BytesSizeMismatchError & {
|
335
356
|
name: 'BytesSizeMismatchError'
|
336
357
|
}
|
package/errors/version.ts
CHANGED
@@ -1 +1 @@
|
|
1
|
-
export const version = '2.0.0-beta.
|
1
|
+
export const version = '2.0.0-beta.16'
|
package/index.ts
CHANGED
@@ -77,6 +77,10 @@ export type {
|
|
77
77
|
DropTransactionErrorType,
|
78
78
|
DropTransactionParameters,
|
79
79
|
} from './actions/test/dropTransaction.js'
|
80
|
+
export type {
|
81
|
+
DumpStateErrorType,
|
82
|
+
DumpStateReturnType,
|
83
|
+
} from './actions/test/dumpState.js'
|
80
84
|
export type {
|
81
85
|
GetAutomineErrorType,
|
82
86
|
GetAutomineReturnType,
|
@@ -177,6 +181,11 @@ export type {
|
|
177
181
|
GetPermissionsErrorType,
|
178
182
|
GetPermissionsReturnType,
|
179
183
|
} from './actions/wallet/getPermissions.js'
|
184
|
+
export type {
|
185
|
+
GetProofErrorType,
|
186
|
+
GetProofParameters,
|
187
|
+
GetProofReturnType,
|
188
|
+
} from './actions/public/getProof.js'
|
180
189
|
export type {
|
181
190
|
GetStorageAtErrorType,
|
182
191
|
GetStorageAtParameters,
|
@@ -210,12 +219,18 @@ export type {
|
|
210
219
|
IncreaseTimeErrorType,
|
211
220
|
IncreaseTimeParameters,
|
212
221
|
} from './actions/test/increaseTime.js'
|
222
|
+
export type {
|
223
|
+
LoadStateErrorType,
|
224
|
+
LoadStateParameters,
|
225
|
+
LoadStateReturnType,
|
226
|
+
} from './actions/test/loadState.js'
|
213
227
|
export type { MineErrorType, MineParameters } from './actions/test/mine.js'
|
214
228
|
export type {
|
215
229
|
MulticallErrorType,
|
216
230
|
MulticallParameters,
|
217
231
|
MulticallReturnType,
|
218
232
|
} from './actions/public/multicall.js'
|
233
|
+
export type { SnapshotErrorType } from './actions/test/snapshot.js'
|
219
234
|
export type {
|
220
235
|
OnBlock,
|
221
236
|
OnBlockParameter,
|
@@ -277,16 +292,27 @@ export type {
|
|
277
292
|
InspectTxpoolErrorType,
|
278
293
|
InspectTxpoolReturnType,
|
279
294
|
} from './actions/test/inspectTxpool.js'
|
295
|
+
export type { RemoveBlockTimestampIntervalErrorType } from './actions/test/removeBlockTimestampInterval.js'
|
280
296
|
export type { ResetErrorType, ResetParameters } from './actions/test/reset.js'
|
281
297
|
export type {
|
282
298
|
RevertErrorType,
|
283
299
|
RevertParameters,
|
284
300
|
} from './actions/test/revert.js'
|
301
|
+
export type {
|
302
|
+
SendRawTransactionErrorType,
|
303
|
+
SendRawTransactionParameters,
|
304
|
+
SendRawTransactionReturnType,
|
305
|
+
} from './actions/wallet/sendRawTransaction.js'
|
285
306
|
export type {
|
286
307
|
SendTransactionErrorType,
|
287
308
|
SendTransactionParameters,
|
288
309
|
SendTransactionReturnType,
|
289
310
|
} from './actions/wallet/sendTransaction.js'
|
311
|
+
export type {
|
312
|
+
SignTransactionErrorType,
|
313
|
+
SignTransactionParameters,
|
314
|
+
SignTransactionReturnType,
|
315
|
+
} from './actions/wallet/signTransaction.js'
|
290
316
|
export type {
|
291
317
|
PrepareTransactionRequestErrorType,
|
292
318
|
PrepareTransactionRequestParameters,
|
@@ -298,6 +324,7 @@ export type {
|
|
298
324
|
SendUnsignedTransactionParameters,
|
299
325
|
SendUnsignedTransactionReturnType,
|
300
326
|
} from './actions/test/sendUnsignedTransaction.js'
|
327
|
+
export type { SetAutomineErrorType } from './actions/test/setAutomine.js'
|
301
328
|
export type {
|
302
329
|
SetBalanceErrorType,
|
303
330
|
SetBalanceParameters,
|
@@ -322,6 +349,7 @@ export type {
|
|
322
349
|
SetIntervalMiningErrorType,
|
323
350
|
SetIntervalMiningParameters,
|
324
351
|
} from './actions/test/setIntervalMining.js'
|
352
|
+
export type { SetLoggingEnabledErrorType } from './actions/test/setLoggingEnabled.js'
|
325
353
|
export type {
|
326
354
|
SetMinGasPriceErrorType,
|
327
355
|
SetMinGasPriceParameters,
|
@@ -338,6 +366,7 @@ export type {
|
|
338
366
|
SetNonceErrorType,
|
339
367
|
SetNonceParameters,
|
340
368
|
} from './actions/test/setNonce.js'
|
369
|
+
export type { SetRpcUrlErrorType } from './actions/test/setRpcUrl.js'
|
341
370
|
export type {
|
342
371
|
SetStorageAtErrorType,
|
343
372
|
SetStorageAtParameters,
|
@@ -1320,6 +1349,8 @@ export { type IsBytesErrorType, isBytes } from './utils/data/isBytes.js'
|
|
1320
1349
|
export { type IsHashErrorType, isHash } from './utils/hash/isHash.js'
|
1321
1350
|
export { type IsHexErrorType, isHex } from './utils/data/isHex.js'
|
1322
1351
|
export { type Keccak256ErrorType, keccak256 } from './utils/hash/keccak256.js'
|
1352
|
+
export { type Sha256ErrorType, sha256 } from './utils/hash/sha256.js'
|
1353
|
+
export { type Ripemd160ErrorType, ripemd160 } from './utils/hash/ripemd160.js'
|
1323
1354
|
export {
|
1324
1355
|
type PadBytesErrorType,
|
1325
1356
|
type PadErrorType,
|
package/package.json
CHANGED
package/types/eip1193.ts
CHANGED
@@ -193,6 +193,18 @@ export type PublicRpcSchema = [
|
|
193
193
|
Parameters?: undefined
|
194
194
|
ReturnType: Quantity
|
195
195
|
},
|
196
|
+
/**
|
197
|
+
* @description Returns the current blob price of gas expressed in wei
|
198
|
+
*
|
199
|
+
* @example
|
200
|
+
* provider.request({ method: 'eth_blobGasPrice' })
|
201
|
+
* // => '0x09184e72a000'
|
202
|
+
*/
|
203
|
+
{
|
204
|
+
Method: 'eth_blobGasPrice'
|
205
|
+
Parameters?: undefined
|
206
|
+
ReturnType: Quantity
|
207
|
+
},
|
196
208
|
/**
|
197
209
|
* @description Returns the number of the most recent block seen by this client
|
198
210
|
*
|
package/utils/abi/getAbiItem.ts
CHANGED
@@ -1,5 +1,6 @@
|
|
1
|
-
import type
|
1
|
+
import { type Abi, type AbiParameter, type Address } from 'abitype'
|
2
2
|
|
3
|
+
import { AbiItemAmbiguityError } from '../../errors/abi.js'
|
3
4
|
import type { ErrorType } from '../../errors/utils.js'
|
4
5
|
import type {
|
5
6
|
AbiItem,
|
@@ -97,6 +98,7 @@ export function getAbiItem<
|
|
97
98
|
if (abiItems.length === 1)
|
98
99
|
return abiItems[0] as GetAbiItemReturnType<abi, name, args>
|
99
100
|
|
101
|
+
let matchedAbiItem: AbiItem | undefined = undefined
|
100
102
|
for (const abiItem of abiItems) {
|
101
103
|
if (!('inputs' in abiItem)) continue
|
102
104
|
if (!args || args.length === 0) {
|
@@ -112,8 +114,37 @@ export function getAbiItem<
|
|
112
114
|
if (!abiParameter) return false
|
113
115
|
return isArgOfType(arg, abiParameter)
|
114
116
|
})
|
115
|
-
if (matched)
|
117
|
+
if (matched) {
|
118
|
+
// Check for ambiguity against already matched parameters (e.g. `address` vs `bytes20`).
|
119
|
+
if (
|
120
|
+
matchedAbiItem &&
|
121
|
+
'inputs' in matchedAbiItem &&
|
122
|
+
matchedAbiItem.inputs
|
123
|
+
) {
|
124
|
+
const ambiguousTypes = getAmbiguousTypes(
|
125
|
+
abiItem.inputs,
|
126
|
+
matchedAbiItem.inputs,
|
127
|
+
args as readonly unknown[],
|
128
|
+
)
|
129
|
+
if (ambiguousTypes)
|
130
|
+
throw new AbiItemAmbiguityError(
|
131
|
+
{
|
132
|
+
abiItem,
|
133
|
+
type: ambiguousTypes[0],
|
134
|
+
},
|
135
|
+
{
|
136
|
+
abiItem: matchedAbiItem,
|
137
|
+
type: ambiguousTypes[1],
|
138
|
+
},
|
139
|
+
)
|
140
|
+
}
|
141
|
+
|
142
|
+
matchedAbiItem = abiItem
|
143
|
+
}
|
116
144
|
}
|
145
|
+
|
146
|
+
if (matchedAbiItem)
|
147
|
+
return matchedAbiItem as GetAbiItemReturnType<abi, name, args>
|
117
148
|
return abiItems[0] as GetAbiItemReturnType<abi, name, args>
|
118
149
|
}
|
119
150
|
|
@@ -175,3 +206,41 @@ export function isArgOfType(arg: unknown, abiParameter: AbiParameter): boolean {
|
|
175
206
|
}
|
176
207
|
}
|
177
208
|
}
|
209
|
+
|
210
|
+
export function getAmbiguousTypes(
|
211
|
+
sourceParameters: readonly AbiParameter[],
|
212
|
+
targetParameters: readonly AbiParameter[],
|
213
|
+
args: AbiItemArgs,
|
214
|
+
): AbiParameter['type'][] | undefined {
|
215
|
+
for (const parameterIndex in sourceParameters) {
|
216
|
+
const sourceParameter = sourceParameters[parameterIndex]
|
217
|
+
const targetParameter = targetParameters[parameterIndex]
|
218
|
+
|
219
|
+
if (
|
220
|
+
sourceParameter.type === 'tuple' &&
|
221
|
+
targetParameter.type === 'tuple' &&
|
222
|
+
'components' in sourceParameter &&
|
223
|
+
'components' in targetParameter
|
224
|
+
)
|
225
|
+
return getAmbiguousTypes(
|
226
|
+
sourceParameter.components,
|
227
|
+
targetParameter.components,
|
228
|
+
(args as any)[parameterIndex],
|
229
|
+
)
|
230
|
+
|
231
|
+
const types = [sourceParameter.type, targetParameter.type]
|
232
|
+
|
233
|
+
const ambiguous = (() => {
|
234
|
+
if (types.includes('address') && types.includes('bytes20')) return true
|
235
|
+
if (types.includes('address') && types.includes('string'))
|
236
|
+
return isAddress(args[parameterIndex] as Address)
|
237
|
+
if (types.includes('address') && types.includes('bytes'))
|
238
|
+
return isAddress(args[parameterIndex] as Address)
|
239
|
+
return false
|
240
|
+
})()
|
241
|
+
|
242
|
+
if (ambiguous) return types
|
243
|
+
}
|
244
|
+
|
245
|
+
return
|
246
|
+
}
|
@@ -0,0 +1,31 @@
|
|
1
|
+
import { ripemd160 as noble_ripemd160 } from '@noble/hashes/ripemd160'
|
2
|
+
|
3
|
+
import type { ErrorType } from '../../errors/utils.js'
|
4
|
+
import type { ByteArray, Hex } from '../../types/misc.js'
|
5
|
+
import { type IsHexErrorType, isHex } from '../data/isHex.js'
|
6
|
+
import { type ToBytesErrorType, toBytes } from '../encoding/toBytes.js'
|
7
|
+
import { type ToHexErrorType, toHex } from '../encoding/toHex.js'
|
8
|
+
|
9
|
+
type To = 'hex' | 'bytes'
|
10
|
+
|
11
|
+
export type Ripemd160Hash<TTo extends To> =
|
12
|
+
| (TTo extends 'bytes' ? ByteArray : never)
|
13
|
+
| (TTo extends 'hex' ? Hex : never)
|
14
|
+
|
15
|
+
export type Ripemd160ErrorType =
|
16
|
+
| IsHexErrorType
|
17
|
+
| ToBytesErrorType
|
18
|
+
| ToHexErrorType
|
19
|
+
| ErrorType
|
20
|
+
|
21
|
+
export function ripemd160<TTo extends To = 'hex'>(
|
22
|
+
value: Hex | ByteArray,
|
23
|
+
to_?: TTo,
|
24
|
+
): Ripemd160Hash<TTo> {
|
25
|
+
const to = to_ || 'hex'
|
26
|
+
const bytes = noble_ripemd160(
|
27
|
+
isHex(value, { strict: false }) ? toBytes(value) : value,
|
28
|
+
)
|
29
|
+
if (to === 'bytes') return bytes as Ripemd160Hash<TTo>
|
30
|
+
return toHex(bytes) as Ripemd160Hash<TTo>
|
31
|
+
}
|
@@ -0,0 +1,31 @@
|
|
1
|
+
import { sha256 as noble_sha256 } from '@noble/hashes/sha256'
|
2
|
+
|
3
|
+
import type { ErrorType } from '../../errors/utils.js'
|
4
|
+
import type { ByteArray, Hex } from '../../types/misc.js'
|
5
|
+
import { type IsHexErrorType, isHex } from '../data/isHex.js'
|
6
|
+
import { type ToBytesErrorType, toBytes } from '../encoding/toBytes.js'
|
7
|
+
import { type ToHexErrorType, toHex } from '../encoding/toHex.js'
|
8
|
+
|
9
|
+
type To = 'hex' | 'bytes'
|
10
|
+
|
11
|
+
export type Sha256Hash<TTo extends To> =
|
12
|
+
| (TTo extends 'bytes' ? ByteArray : never)
|
13
|
+
| (TTo extends 'hex' ? Hex : never)
|
14
|
+
|
15
|
+
export type Sha256ErrorType =
|
16
|
+
| IsHexErrorType
|
17
|
+
| ToBytesErrorType
|
18
|
+
| ToHexErrorType
|
19
|
+
| ErrorType
|
20
|
+
|
21
|
+
export function sha256<TTo extends To = 'hex'>(
|
22
|
+
value: Hex | ByteArray,
|
23
|
+
to_?: TTo,
|
24
|
+
): Sha256Hash<TTo> {
|
25
|
+
const to = to_ || 'hex'
|
26
|
+
const bytes = noble_sha256(
|
27
|
+
isHex(value, { strict: false }) ? toBytes(value) : value,
|
28
|
+
)
|
29
|
+
if (to === 'bytes') return bytes as Sha256Hash<TTo>
|
30
|
+
return toHex(bytes) as Sha256Hash<TTo>
|
31
|
+
}
|
package/utils/index.ts
CHANGED
@@ -351,6 +351,8 @@ export {
|
|
351
351
|
} from './hash/getFunctionSelector.js'
|
352
352
|
export { type IsHashErrorType, isHash } from './hash/isHash.js'
|
353
353
|
export { type Keccak256ErrorType, keccak256 } from './hash/keccak256.js'
|
354
|
+
export { type Sha256ErrorType, sha256 } from './hash/sha256.js'
|
355
|
+
export { type Ripemd160ErrorType, ripemd160 } from './hash/ripemd160.js'
|
354
356
|
export {
|
355
357
|
type HashDomainErrorType,
|
356
358
|
type HashTypedDataParameters,
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"fromOpaqueData.js","sourceRoot":"","sources":["../../../../chains/opStack/utils/fromOpaqueData.ts"],"names":[],"mappings":";;;AAEA,yDAAsE;AACtE,2DAAyE;AACzE,mEAAgE;AAchE,SAAgB,cAAc,CAAC,UAAe;IAC5C,IAAI,MAAM,GAAG,CAAC,CAAA;IACd,MAAM,IAAI,GAAG,IAAA,gBAAK,EAAC,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,EAAE,CAAC,CAAA;IACnD,MAAM,IAAI,EAAE,CAAA;IACZ,MAAM,KAAK,GAAG,IAAA,gBAAK,EAAC,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,EAAE,CAAC,CAAA;IACpD,MAAM,IAAI,EAAE,CAAA;IACZ,MAAM,GAAG,GAAG,IAAA,gBAAK,EAAC,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC,CAAA;IACjD,MAAM,IAAI,CAAC,CAAA;IACX,MAAM,UAAU,GAAG,MAAM,CAAC,IAAA,gBAAK,EAAC,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAA;IACvE,MAAM,IAAI,CAAC,CAAA;IACX,MAAM,IAAI,GACR,MAAM,GAAG,IAAA,cAAI,EAAC,UAAU,CAAC,GAAG,CAAC;QAC3B,CAAC,CAAC,IAAI;QACN,CAAC,CAAC,IAAA,gBAAK,EAAC,UAAU,EAAE,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC,CAAA;IAClD,OAAO;QACL,IAAI,EAAE,IAAA,wBAAW,EAAC,IAAI,CAAC;QACvB,KAAK,EAAE,IAAA,wBAAW,EAAC,KAAK,CAAC;QACzB,GAAG,EAAE,IAAA,wBAAW,EAAC,GAAG,CAAC;QACrB,UAAU;QACV,IAAI;KACL,CAAA;AACH,CAAC;AArBD,wCAqBC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"fromOpaqueData.js","sourceRoot":"","sources":["../../../../chains/opStack/utils/fromOpaqueData.ts"],"names":[],"mappings":"AAEA,OAAO,EAAsB,IAAI,EAAE,MAAM,6BAA6B,CAAA;AACtE,OAAO,EAAuB,KAAK,EAAE,MAAM,8BAA8B,CAAA;AACzE,OAAO,EAAE,WAAW,EAAE,MAAM,oCAAoC,CAAA;AAchE,MAAM,UAAU,cAAc,CAAC,UAAe;IAC5C,IAAI,MAAM,GAAG,CAAC,CAAA;IACd,MAAM,IAAI,GAAG,KAAK,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,EAAE,CAAC,CAAA;IACnD,MAAM,IAAI,EAAE,CAAA;IACZ,MAAM,KAAK,GAAG,KAAK,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,EAAE,CAAC,CAAA;IACpD,MAAM,IAAI,EAAE,CAAA;IACZ,MAAM,GAAG,GAAG,KAAK,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC,CAAA;IACjD,MAAM,IAAI,CAAC,CAAA;IACX,MAAM,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAA;IACvE,MAAM,IAAI,CAAC,CAAA;IACX,MAAM,IAAI,GACR,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;QAC3B,CAAC,CAAC,IAAI;QACN,CAAC,CAAC,KAAK,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC,CAAA;IAClD,OAAO;QACL,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC;QACvB,KAAK,EAAE,WAAW,CAAC,KAAK,CAAC;QACzB,GAAG,EAAE,WAAW,CAAC,GAAG,CAAC;QACrB,UAAU;QACV,IAAI;KACL,CAAA;AACH,CAAC"}
|
@@ -1,15 +0,0 @@
|
|
1
|
-
import type { ErrorType } from '../../../errors/utils.js';
|
2
|
-
import type { Hex } from '../../../types/misc.js';
|
3
|
-
import { type SizeErrorType } from '../../../utils/data/size.js';
|
4
|
-
import { type SliceErrorType } from '../../../utils/data/slice.js';
|
5
|
-
export type FromOpaqueDataParameters = Hex;
|
6
|
-
export type FromOpaqueDataReturnType = {
|
7
|
-
mint: bigint;
|
8
|
-
value: bigint;
|
9
|
-
gas: bigint;
|
10
|
-
isCreation: boolean;
|
11
|
-
data: Hex;
|
12
|
-
};
|
13
|
-
export type FromOpaqueDataErrorType = SliceErrorType | SizeErrorType | ErrorType;
|
14
|
-
export declare function fromOpaqueData(opaqueData: Hex): FromOpaqueDataReturnType;
|
15
|
-
//# sourceMappingURL=fromOpaqueData.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"fromOpaqueData.d.ts","sourceRoot":"","sources":["../../../../chains/opStack/utils/fromOpaqueData.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAA;AACzD,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,wBAAwB,CAAA;AACjD,OAAO,EAAE,KAAK,aAAa,EAAQ,MAAM,6BAA6B,CAAA;AACtE,OAAO,EAAE,KAAK,cAAc,EAAS,MAAM,8BAA8B,CAAA;AAGzE,MAAM,MAAM,wBAAwB,GAAG,GAAG,CAAA;AAE1C,MAAM,MAAM,wBAAwB,GAAG;IACrC,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,EAAE,MAAM,CAAA;IACb,GAAG,EAAE,MAAM,CAAA;IACX,UAAU,EAAE,OAAO,CAAA;IACnB,IAAI,EAAE,GAAG,CAAA;CACV,CAAA;AAED,MAAM,MAAM,uBAAuB,GAAG,cAAc,GAAG,aAAa,GAAG,SAAS,CAAA;AAEhF,wBAAgB,cAAc,CAAC,UAAU,EAAE,GAAG,GAAG,wBAAwB,CAqBxE"}
|