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.
Files changed (137) hide show
  1. package/CHANGELOG.md +44 -0
  2. package/README.md +9 -3
  3. package/_cjs/actions/ens/getEnsName.js +4 -2
  4. package/_cjs/actions/ens/getEnsName.js.map +1 -1
  5. package/_cjs/actions/index.js +16 -2
  6. package/_cjs/actions/index.js.map +1 -1
  7. package/_cjs/chains/definitions/arbitrumSepolia.js +4 -0
  8. package/_cjs/chains/definitions/arbitrumSepolia.js.map +1 -1
  9. package/_cjs/chains/definitions/fantomSonicTestnet.js +26 -0
  10. package/_cjs/chains/definitions/fantomSonicTestnet.js.map +1 -0
  11. package/_cjs/chains/definitions/zilliqa.js +26 -0
  12. package/_cjs/chains/definitions/zilliqa.js.map +1 -0
  13. package/_cjs/chains/definitions/zilliqaTestnet.js +26 -0
  14. package/_cjs/chains/definitions/zilliqaTestnet.js.map +1 -0
  15. package/_cjs/chains/definitions/zkSyncSepoliaTestnet.js +35 -0
  16. package/_cjs/chains/definitions/zkSyncSepoliaTestnet.js.map +1 -0
  17. package/_cjs/chains/definitions/zkSyncTestnet.js +4 -0
  18. package/_cjs/chains/definitions/zkSyncTestnet.js.map +1 -1
  19. package/_cjs/chains/index.js +12 -4
  20. package/_cjs/chains/index.js.map +1 -1
  21. package/_cjs/chains/opStack/index.js +3 -3
  22. package/_cjs/chains/opStack/index.js.map +1 -1
  23. package/_cjs/chains/opStack/utils/getL2TransactionHash.js +2 -2
  24. package/_cjs/chains/opStack/utils/getL2TransactionHash.js.map +1 -1
  25. package/_cjs/chains/opStack/utils/{fromOpaqueData.js → opaqueDataToDepositData.js} +4 -4
  26. package/_cjs/chains/opStack/utils/opaqueDataToDepositData.js.map +1 -0
  27. package/_cjs/errors/abi.js +21 -1
  28. package/_cjs/errors/abi.js.map +1 -1
  29. package/_cjs/errors/version.js +1 -1
  30. package/_cjs/index.js +6 -2
  31. package/_cjs/index.js.map +1 -1
  32. package/_cjs/utils/abi/getAbiItem.js +46 -3
  33. package/_cjs/utils/abi/getAbiItem.js.map +1 -1
  34. package/_cjs/utils/hash/ripemd160.js +16 -0
  35. package/_cjs/utils/hash/ripemd160.js.map +1 -0
  36. package/_cjs/utils/hash/sha256.js +16 -0
  37. package/_cjs/utils/hash/sha256.js.map +1 -0
  38. package/_cjs/utils/index.js +5 -1
  39. package/_cjs/utils/index.js.map +1 -1
  40. package/_esm/actions/ens/getEnsName.js +4 -2
  41. package/_esm/actions/ens/getEnsName.js.map +1 -1
  42. package/_esm/actions/index.js +7 -0
  43. package/_esm/actions/index.js.map +1 -1
  44. package/_esm/chains/definitions/arbitrumSepolia.js +4 -0
  45. package/_esm/chains/definitions/arbitrumSepolia.js.map +1 -1
  46. package/_esm/chains/definitions/fantomSonicTestnet.js +23 -0
  47. package/_esm/chains/definitions/fantomSonicTestnet.js.map +1 -0
  48. package/_esm/chains/definitions/zilliqa.js +23 -0
  49. package/_esm/chains/definitions/zilliqa.js.map +1 -0
  50. package/_esm/chains/definitions/zilliqaTestnet.js +23 -0
  51. package/_esm/chains/definitions/zilliqaTestnet.js.map +1 -0
  52. package/_esm/chains/definitions/zkSyncSepoliaTestnet.js +32 -0
  53. package/_esm/chains/definitions/zkSyncSepoliaTestnet.js.map +1 -0
  54. package/_esm/chains/definitions/zkSyncTestnet.js +5 -0
  55. package/_esm/chains/definitions/zkSyncTestnet.js.map +1 -1
  56. package/_esm/chains/index.js +4 -0
  57. package/_esm/chains/index.js.map +1 -1
  58. package/_esm/chains/opStack/index.js +1 -1
  59. package/_esm/chains/opStack/index.js.map +1 -1
  60. package/_esm/chains/opStack/utils/getL2TransactionHash.js +2 -2
  61. package/_esm/chains/opStack/utils/getL2TransactionHash.js.map +1 -1
  62. package/_esm/chains/opStack/utils/{fromOpaqueData.js → opaqueDataToDepositData.js} +2 -2
  63. package/_esm/chains/opStack/utils/opaqueDataToDepositData.js.map +1 -0
  64. package/_esm/errors/abi.js +19 -0
  65. package/_esm/errors/abi.js.map +1 -1
  66. package/_esm/errors/version.js +1 -1
  67. package/_esm/index.js +2 -0
  68. package/_esm/index.js.map +1 -1
  69. package/_esm/utils/abi/getAbiItem.js +46 -2
  70. package/_esm/utils/abi/getAbiItem.js.map +1 -1
  71. package/_esm/utils/hash/ripemd160.js +12 -0
  72. package/_esm/utils/hash/ripemd160.js.map +1 -0
  73. package/_esm/utils/hash/sha256.js +12 -0
  74. package/_esm/utils/hash/sha256.js.map +1 -0
  75. package/_esm/utils/index.js +2 -0
  76. package/_esm/utils/index.js.map +1 -1
  77. package/_types/actions/ens/getEnsName.d.ts.map +1 -1
  78. package/_types/actions/index.d.ts +7 -0
  79. package/_types/actions/index.d.ts.map +1 -1
  80. package/_types/chains/definitions/arbitrumSepolia.d.ts +4 -0
  81. package/_types/chains/definitions/arbitrumSepolia.d.ts.map +1 -1
  82. package/_types/chains/definitions/fantomSonicTestnet.d.ts +38 -0
  83. package/_types/chains/definitions/fantomSonicTestnet.d.ts.map +1 -0
  84. package/_types/chains/definitions/zilliqa.d.ts +38 -0
  85. package/_types/chains/definitions/zilliqa.d.ts.map +1 -0
  86. package/_types/chains/definitions/zilliqaTestnet.d.ts +38 -0
  87. package/_types/chains/definitions/zilliqaTestnet.d.ts.map +1 -0
  88. package/_types/chains/definitions/zkSyncSepoliaTestnet.d.ts +533 -0
  89. package/_types/chains/definitions/zkSyncSepoliaTestnet.d.ts.map +1 -0
  90. package/_types/chains/definitions/zkSyncTestnet.d.ts +5 -0
  91. package/_types/chains/definitions/zkSyncTestnet.d.ts.map +1 -1
  92. package/_types/chains/index.d.ts +4 -0
  93. package/_types/chains/index.d.ts.map +1 -1
  94. package/_types/chains/opStack/index.d.ts +1 -1
  95. package/_types/chains/opStack/index.d.ts.map +1 -1
  96. package/_types/chains/opStack/utils/opaqueDataToDepositData.d.ts +15 -0
  97. package/_types/chains/opStack/utils/opaqueDataToDepositData.d.ts.map +1 -0
  98. package/_types/errors/abi.d.ts +14 -1
  99. package/_types/errors/abi.d.ts.map +1 -1
  100. package/_types/errors/version.d.ts +1 -1
  101. package/_types/index.d.ts +12 -0
  102. package/_types/index.d.ts.map +1 -1
  103. package/_types/types/eip1193.d.ts +12 -0
  104. package/_types/types/eip1193.d.ts.map +1 -1
  105. package/_types/utils/abi/getAbiItem.d.ts +2 -1
  106. package/_types/utils/abi/getAbiItem.d.ts.map +1 -1
  107. package/_types/utils/hash/ripemd160.d.ts +11 -0
  108. package/_types/utils/hash/ripemd160.d.ts.map +1 -0
  109. package/_types/utils/hash/sha256.d.ts +11 -0
  110. package/_types/utils/hash/sha256.d.ts.map +1 -0
  111. package/_types/utils/index.d.ts +2 -0
  112. package/_types/utils/index.d.ts.map +1 -1
  113. package/actions/ens/getEnsName.ts +3 -2
  114. package/actions/index.ts +31 -0
  115. package/chains/definitions/arbitrumSepolia.ts +4 -0
  116. package/chains/definitions/fantomSonicTestnet.ts +23 -0
  117. package/chains/definitions/zilliqa.ts +23 -0
  118. package/chains/definitions/zilliqaTestnet.ts +23 -0
  119. package/chains/definitions/zkSyncSepoliaTestnet.ts +32 -0
  120. package/chains/definitions/zkSyncTestnet.ts +5 -0
  121. package/chains/index.ts +4 -0
  122. package/chains/opStack/index.ts +5 -5
  123. package/chains/opStack/utils/getL2TransactionHash.ts +2 -2
  124. package/chains/opStack/utils/{fromOpaqueData.ts → opaqueDataToDepositData.ts} +9 -4
  125. package/errors/abi.ts +22 -1
  126. package/errors/version.ts +1 -1
  127. package/index.ts +31 -0
  128. package/package.json +1 -1
  129. package/types/eip1193.ts +12 -0
  130. package/utils/abi/getAbiItem.ts +71 -2
  131. package/utils/hash/ripemd160.ts +31 -0
  132. package/utils/hash/sha256.ts +31 -0
  133. package/utils/index.ts +2 -0
  134. package/_cjs/chains/opStack/utils/fromOpaqueData.js.map +0 -1
  135. package/_esm/chains/opStack/utils/fromOpaqueData.js.map +0 -1
  136. package/_types/chains/opStack/utils/fromOpaqueData.d.ts +0 -15
  137. 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'
@@ -114,11 +114,11 @@ export {
114
114
  } from './utils/extractTransactionDepositedLogs.js'
115
115
 
116
116
  export {
117
- fromOpaqueData,
118
- type FromOpaqueDataErrorType,
119
- type FromOpaqueDataParameters,
120
- type FromOpaqueDataReturnType,
121
- } from './utils/fromOpaqueData.js'
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 } = fromOpaqueData(
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 FromOpaqueDataParameters = Hex
7
+ export type OpaqueDataToDepositDataParameters = Hex
8
8
 
9
- export type FromOpaqueDataReturnType = {
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 FromOpaqueDataErrorType = SliceErrorType | SizeErrorType | ErrorType
17
+ export type OpaqueDataToDepositDataErrorType =
18
+ | SliceErrorType
19
+ | SizeErrorType
20
+ | ErrorType
18
21
 
19
- export function fromOpaqueData(opaqueData: Hex): FromOpaqueDataReturnType {
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.15'
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
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "viem",
3
3
  "description": "TypeScript Interface for Ethereum",
4
- "version": "2.0.0-beta.15",
4
+ "version": "2.0.0-beta.16",
5
5
  "type": "module",
6
6
  "main": "./_cjs/index.js",
7
7
  "module": "./_esm/index.js",
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
  *
@@ -1,5 +1,6 @@
1
- import type { Abi, AbiParameter, Address } from 'abitype'
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) return abiItem as GetAbiItemReturnType<abi, name, args>
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"}