@matterlabs/zksync-js 0.0.1 → 0.0.2

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 (80) hide show
  1. package/README.md +12 -12
  2. package/dist/adapters/ethers/client.cjs +642 -1
  3. package/dist/adapters/ethers/client.cjs.map +1 -1
  4. package/dist/adapters/ethers/client.js +6 -5
  5. package/dist/adapters/ethers/estimator.d.ts +4 -0
  6. package/dist/adapters/ethers/index.cjs +934 -801
  7. package/dist/adapters/ethers/index.cjs.map +1 -1
  8. package/dist/adapters/ethers/index.js +9 -8
  9. package/dist/adapters/ethers/resources/deposits/context.d.ts +5 -5
  10. package/dist/adapters/ethers/resources/deposits/routes/types.d.ts +2 -6
  11. package/dist/adapters/ethers/resources/deposits/services/fee.d.ts +6 -0
  12. package/dist/adapters/ethers/resources/deposits/services/gas.d.ts +40 -0
  13. package/dist/adapters/ethers/resources/utils.d.ts +4 -15
  14. package/dist/adapters/ethers/resources/withdrawals/context.d.ts +4 -4
  15. package/dist/adapters/ethers/resources/withdrawals/routes/types.d.ts +2 -2
  16. package/dist/adapters/ethers/resources/withdrawals/services/fees.d.ts +14 -0
  17. package/dist/adapters/ethers/resources/withdrawals/services/gas.d.ts +12 -0
  18. package/dist/adapters/ethers/sdk.cjs +947 -1292
  19. package/dist/adapters/ethers/sdk.cjs.map +1 -1
  20. package/dist/adapters/ethers/sdk.js +7 -6
  21. package/dist/adapters/viem/client.cjs.map +1 -1
  22. package/dist/adapters/viem/client.d.ts +1 -1
  23. package/dist/adapters/viem/client.js +4 -5
  24. package/dist/adapters/viem/estimator.d.ts +4 -0
  25. package/dist/adapters/viem/index.cjs +944 -662
  26. package/dist/adapters/viem/index.cjs.map +1 -1
  27. package/dist/adapters/viem/index.js +8 -8
  28. package/dist/adapters/viem/resources/deposits/context.d.ts +5 -5
  29. package/dist/adapters/viem/resources/deposits/routes/types.d.ts +2 -6
  30. package/dist/adapters/viem/resources/deposits/services/fee.d.ts +6 -0
  31. package/dist/adapters/viem/resources/deposits/services/gas.d.ts +36 -0
  32. package/dist/adapters/viem/resources/utils.d.ts +3 -16
  33. package/dist/adapters/viem/resources/withdrawals/context.d.ts +3 -6
  34. package/dist/adapters/viem/resources/withdrawals/routes/types.d.ts +12 -2
  35. package/dist/adapters/viem/resources/withdrawals/services/fee.d.ts +17 -0
  36. package/dist/adapters/viem/resources/withdrawals/services/gas.d.ts +12 -0
  37. package/dist/adapters/viem/sdk.cjs +877 -563
  38. package/dist/adapters/viem/sdk.cjs.map +1 -1
  39. package/dist/adapters/viem/sdk.d.ts +1 -1
  40. package/dist/adapters/viem/sdk.js +6 -6
  41. package/dist/{chunk-3LALBFFE.js → chunk-3MRGU4HV.js} +9 -5
  42. package/dist/{chunk-4HLJJKIY.js → chunk-6K6VJQAL.js} +2 -2
  43. package/dist/{chunk-CGO27P7F.js → chunk-BCCKWWOX.js} +540 -741
  44. package/dist/{chunk-6GCT6TLS.js → chunk-F2ENUV3A.js} +13 -1
  45. package/dist/{chunk-DI2CJDPZ.js → chunk-HLUANWGN.js} +2 -2
  46. package/dist/{chunk-Y75OMFK6.js → chunk-M5J2MM2U.js} +351 -1
  47. package/dist/{chunk-263G6636.js → chunk-NCAIVYBR.js} +1 -14
  48. package/dist/{chunk-7M4V3FMT.js → chunk-OC6ZVLSP.js} +669 -559
  49. package/dist/chunk-QJS6ETEE.js +217 -0
  50. package/dist/chunk-XRE7H466.js +157 -0
  51. package/dist/{chunk-BD2LUO5T.js → chunk-YUK547UF.js} +3 -3
  52. package/dist/core/abi.d.ts +9 -0
  53. package/dist/core/adapters/interfaces.d.ts +25 -0
  54. package/dist/core/constants.cjs +12 -0
  55. package/dist/core/constants.cjs.map +1 -1
  56. package/dist/core/constants.d.ts +6 -0
  57. package/dist/core/constants.js +1 -1
  58. package/dist/core/index.cjs +4504 -1
  59. package/dist/core/index.cjs.map +1 -1
  60. package/dist/core/index.d.ts +1 -0
  61. package/dist/core/index.js +4 -4
  62. package/dist/core/resources/deposits/fee.d.ts +15 -0
  63. package/dist/core/resources/deposits/gas.d.ts +38 -0
  64. package/dist/core/resources/withdrawals/gas.d.ts +14 -0
  65. package/dist/core/types/errors.d.ts +1 -1
  66. package/dist/core/types/fees.d.ts +40 -0
  67. package/dist/core/types/flows/base.d.ts +0 -10
  68. package/dist/core/types/flows/deposits.d.ts +20 -6
  69. package/dist/core/types/flows/route.d.ts +2 -3
  70. package/dist/core/types/flows/withdrawals.d.ts +12 -6
  71. package/dist/index.cjs +4516 -1
  72. package/dist/index.cjs.map +1 -1
  73. package/dist/index.d.ts +1 -0
  74. package/dist/index.js +4 -4
  75. package/package.json +5 -1
  76. package/dist/adapters/ethers/resources/withdrawals/routes/eth-nonbase.d.ts +0 -2
  77. package/dist/adapters/viem/resources/withdrawals/routes/eth-nonbase.d.ts +0 -2
  78. package/dist/chunk-B77GWPO5.js +0 -339
  79. package/dist/core/internal/abi-registry.d.ts +0 -9
  80. package/dist/core/utils/gas.d.ts +0 -13
@@ -1,8 +1,8 @@
1
- export { buildDirectRequestStruct, buildViemFeeOverrides, checkBaseCost, classifyReadinessFromRevert, createDepositsResource, createErrorHandlers, createFinalizationServices, createViemSdk, createWithdrawalsResource, decodeRevert, encodeNTVAssetId, encodeNTVTransferData, encodeNativeTokenVaultAssetId, encodeNativeTokenVaultTransferData, encodeSecondBridgeArgs, encodeSecondBridgeDataV1, encodeSecondBridgeErc20Args, encodeSecondBridgeEthArgs, getFeeOverrides, getGasPriceWei, getL2FeeOverrides, registerErrorAbi, scaleGasLimit, toZKsyncError } from '../../chunk-7M4V3FMT.js';
2
- import '../../chunk-263G6636.js';
3
- import '../../chunk-DI2CJDPZ.js';
4
- export { createViemClient as createClient, createViemClient } from '../../chunk-BD2LUO5T.js';
5
- import '../../chunk-4HLJJKIY.js';
6
- import '../../chunk-Y75OMFK6.js';
7
- import '../../chunk-B77GWPO5.js';
8
- import '../../chunk-6GCT6TLS.js';
1
+ export { buildDirectRequestStruct, classifyReadinessFromRevert, createDepositsResource, createErrorHandlers, createFinalizationServices, createViemSdk, createWithdrawalsResource, decodeRevert, encodeNTVAssetId, encodeNTVTransferData, encodeNativeTokenVaultAssetId, encodeNativeTokenVaultTransferData, encodeSecondBridgeArgs, encodeSecondBridgeDataV1, encodeSecondBridgeErc20Args, encodeSecondBridgeEthArgs, registerErrorAbi, toZKsyncError } from '../../chunk-OC6ZVLSP.js';
2
+ import '../../chunk-QJS6ETEE.js';
3
+ import '../../chunk-HLUANWGN.js';
4
+ import '../../chunk-NCAIVYBR.js';
5
+ export { createViemClient as createClient, createViemClient } from '../../chunk-YUK547UF.js';
6
+ import '../../chunk-6K6VJQAL.js';
7
+ import '../../chunk-M5J2MM2U.js';
8
+ import '../../chunk-F2ENUV3A.js';
@@ -1,13 +1,13 @@
1
1
  import type { ViemClient } from '../../client';
2
2
  import type { Address } from '../../../../core/types/primitives';
3
- import { type FeeOverrides } from '../utils';
4
3
  import type { DepositParams, DepositRoute } from '../../../../core/types/flows/deposits';
5
4
  import type { CommonCtx } from '../../../../core/types/flows/base';
5
+ import type { TxOverrides } from '../../../../core/types/fees';
6
6
  export interface BuildCtx extends CommonCtx {
7
7
  client: ViemClient;
8
8
  l1AssetRouter: Address;
9
- fee: FeeOverrides;
10
- l2GasLimit: bigint;
9
+ gasOverrides?: TxOverrides;
10
+ l2GasLimit?: bigint;
11
11
  gasPerPubdata: bigint;
12
12
  operatorTip: bigint;
13
13
  refundRecipient: Address;
@@ -19,8 +19,8 @@ export declare function commonCtx(p: DepositParams, client: ViemClient): Promise
19
19
  bridgehub: `0x${string}`;
20
20
  chainIdL2: bigint;
21
21
  sender: `0x${string}`;
22
- fee: FeeOverrides;
23
- l2GasLimit: bigint;
22
+ gasOverrides: TxOverrides | undefined;
23
+ l2GasLimit: bigint | undefined;
24
24
  gasPerPubdata: bigint;
25
25
  operatorTip: bigint;
26
26
  refundRecipient: `0x${string}`;
@@ -2,6 +2,7 @@ import type { WalletClient, Transport, Chain, Account } from 'viem';
2
2
  import type { DepositParams } from '../../../../../core/types/flows/deposits';
3
3
  import type { RouteStrategy } from '../../../../../core/types/flows/route';
4
4
  import type { BuildCtx as DepositBuildCtx } from '../context';
5
+ import type { DepositFeeBreakdown } from '../../../../../core/types/fees';
5
6
  type WriteParams = Parameters<WalletClient<Transport, Chain, Account>['writeContract']>[0];
6
7
  /**
7
8
  * viem specific
@@ -11,10 +12,5 @@ type WriteParams = Parameters<WalletClient<Transport, Chain, Account>['writeCont
11
12
  export type ViemPlanWriteRequest = Omit<WriteParams, 'value'> & {
12
13
  value?: bigint;
13
14
  };
14
- export type DepositQuoteExtras = {
15
- baseCost: bigint;
16
- mintValue: bigint;
17
- l1GasLimit?: bigint;
18
- };
19
- export type DepositRouteStrategy = RouteStrategy<DepositParams, ViemPlanWriteRequest, DepositQuoteExtras, DepositBuildCtx>;
15
+ export type DepositRouteStrategy = RouteStrategy<DepositParams, ViemPlanWriteRequest, DepositFeeBreakdown, DepositBuildCtx>;
20
16
  export {};
@@ -0,0 +1,6 @@
1
+ import type { BuildCtx } from '../context';
2
+ export type QuoteL2BaseCostInput = {
3
+ ctx: BuildCtx;
4
+ l2GasLimit: bigint;
5
+ };
6
+ export declare function quoteL2BaseCost(input: QuoteL2BaseCostInput): Promise<bigint>;
@@ -0,0 +1,36 @@
1
+ import { type TransactionRequest } from 'viem';
2
+ import type { BuildCtx } from '../context';
3
+ import type { DepositRoute } from '../../../../../core/types/flows/deposits';
4
+ import type { TxOverrides } from '../../../../../core/types/fees';
5
+ import { type GasQuote } from '../../../../../core/resources/deposits/gas';
6
+ export type { GasQuote };
7
+ export type QuoteL1GasInput = {
8
+ ctx: BuildCtx;
9
+ tx: TransactionRequest;
10
+ overrides?: TxOverrides;
11
+ fallbackGasLimit?: bigint;
12
+ };
13
+ export type QuoteL2GasInput = {
14
+ ctx: BuildCtx;
15
+ route: DepositRoute;
16
+ l2TxForModeling?: TransactionRequest;
17
+ overrideGasLimit?: bigint;
18
+ stateOverrides?: Record<string, unknown>;
19
+ };
20
+ /**
21
+ * Quote L1 gas for a deposit transaction.
22
+ */
23
+ export declare function quoteL1Gas(input: QuoteL1GasInput): Promise<GasQuote | undefined>;
24
+ /**
25
+ * Quote L2 gas for an L2 execution.
26
+ */
27
+ export declare function quoteL2Gas(input: QuoteL2GasInput): Promise<GasQuote | undefined>;
28
+ /**
29
+ * ERC20 deposits have an extra edge case:
30
+ * if the token is not deployed on L2, the deposit includes deployment cost.
31
+ */
32
+ export declare function determineErc20L2Gas(input: {
33
+ ctx: BuildCtx;
34
+ l1Token: string;
35
+ modelTx?: TransactionRequest;
36
+ }): Promise<GasQuote | undefined>;
@@ -1,23 +1,13 @@
1
1
  import { type Hex } from 'viem';
2
2
  import type { Address } from '../../../core/types';
3
- import type { ViemClient } from '../client';
4
- import type { Eip1559GasOverrides, ResolvedEip1559Fees } from '../../../core/types/flows/base';
5
3
  export declare function encodeNativeTokenVaultAssetId(chainId: bigint, address: string): Hex;
6
4
  export declare function encodeNativeTokenVaultTransferData(amount: bigint, receiver: Address, token: Address): Hex;
7
5
  export declare function encodeSecondBridgeDataV1(assetId: Hex, transferData: Hex): Hex;
8
6
  export declare const encodeNTVAssetId: typeof encodeNativeTokenVaultAssetId;
9
7
  export declare const encodeNTVTransferData: typeof encodeNativeTokenVaultTransferData;
10
- export declare function scaleGasLimit(gasLimit: bigint): bigint;
11
- /** Throws if baseCost > value */
12
- export declare function checkBaseCost(baseCost: bigint, value: bigint | Promise<bigint>): Promise<void>;
13
- export type FeeOverrides = ResolvedEip1559Fees & {
14
- gasPriceForBaseCost: bigint;
15
- };
16
- export declare function getFeeOverrides(client: ViemClient, overrides?: Eip1559GasOverrides): Promise<FeeOverrides>;
17
- export declare function getL2FeeOverrides(client: ViemClient, overrides?: Eip1559GasOverrides): Promise<ResolvedEip1559Fees>;
18
- export declare function buildViemFeeOverrides(fees: ResolvedEip1559Fees): Record<string, unknown>;
19
- /** Fetches the gas price in wei (legacy) or falls back to maxFeePerGas. */
20
- export declare function getGasPriceWei(client: ViemClient): Promise<bigint>;
8
+ export declare function encodeSecondBridgeArgs(token: Address, amount: bigint, l2Receiver: Address): Hex;
9
+ export declare function encodeSecondBridgeErc20Args(token: Address, amount: bigint, l2Receiver: Address): Hex;
10
+ export declare function encodeSecondBridgeEthArgs(amount: bigint, l2Receiver: Address, ethToken?: Address): Hex;
21
11
  export declare function buildDirectRequestStruct(args: {
22
12
  chainId: bigint;
23
13
  mintValue: bigint;
@@ -37,6 +27,3 @@ export declare function buildDirectRequestStruct(args: {
37
27
  factoryDeps: Hex[];
38
28
  refundRecipient: `0x${string}`;
39
29
  };
40
- export declare function encodeSecondBridgeArgs(token: Address, amount: bigint, l2Receiver: Address): Hex;
41
- export declare function encodeSecondBridgeErc20Args(token: Address, amount: bigint, l2Receiver: Address): Hex;
42
- export declare function encodeSecondBridgeEthArgs(amount: bigint, l2Receiver: Address, ethToken?: Address): Hex;
@@ -1,7 +1,8 @@
1
1
  import type { ViemClient } from '../../client';
2
2
  import type { Address } from '../../../../core/types/primitives';
3
3
  import type { WithdrawParams, WithdrawRoute } from '../../../../core/types/flows/withdrawals';
4
- import type { CommonCtx, ResolvedEip1559Fees } from '../../../../core/types/flows/base';
4
+ import type { CommonCtx } from '../../../../core/types/flows/base';
5
+ import type { TxOverrides } from '../../../../core/types/fees';
5
6
  export interface BuildCtx extends CommonCtx {
6
7
  client: ViemClient;
7
8
  bridgehub: Address;
@@ -11,11 +12,7 @@ export interface BuildCtx extends CommonCtx {
11
12
  l2NativeTokenVault: Address;
12
13
  l2BaseTokenSystem: Address;
13
14
  baseIsEth: boolean;
14
- chainIdL2: bigint;
15
- sender: Address;
16
- l2GasLimit: bigint;
17
- gasBufferPct: number;
18
- fee: ResolvedEip1559Fees;
15
+ gasOverrides?: TxOverrides;
19
16
  }
20
17
  export declare function commonCtx(p: WithdrawParams, client: ViemClient): Promise<BuildCtx & {
21
18
  route: WithdrawRoute;
@@ -3,9 +3,18 @@ import type { WithdrawParams } from '../../../../../core/types/flows/withdrawals
3
3
  import type { RouteStrategy } from '../../../../../core/types/flows/route';
4
4
  import type { BuildCtx as WithdrawBuildCtx } from '../context';
5
5
  import type { Address, Hex } from '../../../../../core/types';
6
- export type ViemPlanWriteRequest = Parameters<WalletClient<Transport, Chain, Account>['writeContract']>[0];
6
+ import type { WithdrawalFeeBreakdown } from '../../../../../core/types/fees';
7
+ type ViemWriteParams = Parameters<WalletClient<Transport, Chain, Account>['writeContract']>[0];
8
+ /**
9
+ * viem specific
10
+ * Plan-time write request: relax 'value' so a single type can hold both
11
+ * non-payable (no value) and payable (value: bigint) requests.
12
+ */
13
+ export type ViemPlanWriteRequest = Omit<ViemWriteParams, 'value'> & {
14
+ value?: bigint;
15
+ };
7
16
  export type WithdrawQuoteExtras = Record<string, never>;
8
- export type WithdrawRouteStrategy = RouteStrategy<WithdrawParams, ViemPlanWriteRequest, WithdrawQuoteExtras, WithdrawBuildCtx>;
17
+ export type WithdrawRouteStrategy = RouteStrategy<WithdrawParams, ViemPlanWriteRequest, WithdrawalFeeBreakdown, WithdrawBuildCtx>;
9
18
  export interface L2ToL1Log {
10
19
  l2ShardId?: number;
11
20
  isService?: boolean;
@@ -17,3 +26,4 @@ export interface L2ToL1Log {
17
26
  export type TransactionReceiptZKsyncOS = TransactionReceipt & {
18
27
  l2ToL1Logs?: L2ToL1Log[];
19
28
  };
29
+ export {};
@@ -0,0 +1,17 @@
1
+ import type { Address } from '../../../../../core/types/primitives';
2
+ import type { WithdrawalFeeBreakdown } from '../../../../../core/types/fees';
3
+ import type { GasQuote } from './gas';
4
+ export type BuildWithdrawFeeBreakdownInput = {
5
+ /** Token used to pay the L2 transaction fee */
6
+ feeToken: Address;
7
+ /** L2 withdrawal transaction gas quote */
8
+ l2Gas?: GasQuote;
9
+ };
10
+ /**
11
+ * Builds FeeBreakdown for withdrawals.
12
+ *
13
+ * Withdrawals represent a single L2 transaction:
14
+ * - fees.l2 = cost of the withdraw tx on L2
15
+ * - fees.l1 is intentionally omitted
16
+ */
17
+ export declare function buildFeeBreakdown(p: BuildWithdrawFeeBreakdownInput): WithdrawalFeeBreakdown;
@@ -0,0 +1,12 @@
1
+ import type { TransactionRequest } from 'viem';
2
+ import type { BuildCtx } from '../context';
3
+ import { type GasQuote } from '../../../../../core/resources/withdrawals/gas';
4
+ export type { GasQuote };
5
+ export type QuoteWithdrawL2GasInput = {
6
+ ctx: BuildCtx;
7
+ tx: TransactionRequest;
8
+ };
9
+ /**
10
+ * Quotes L2 gas for a withdrawal tx.
11
+ */
12
+ export declare function quoteL2Gas(input: QuoteWithdrawL2GasInput): Promise<GasQuote | undefined>;