@matterlabs/zksync-js 0.0.1 → 0.0.3

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 (103) 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 +1279 -925
  7. package/dist/adapters/ethers/index.cjs.map +1 -1
  8. package/dist/adapters/ethers/index.d.ts +1 -0
  9. package/dist/adapters/ethers/index.js +9 -8
  10. package/dist/adapters/ethers/resources/contracts/contracts.d.ts +9 -0
  11. package/dist/adapters/ethers/resources/contracts/index.d.ts +2 -0
  12. package/dist/adapters/ethers/resources/contracts/types.d.ts +60 -0
  13. package/dist/adapters/ethers/resources/deposits/context.d.ts +21 -7
  14. package/dist/adapters/ethers/resources/deposits/index.d.ts +3 -1
  15. package/dist/adapters/ethers/resources/deposits/routes/types.d.ts +2 -6
  16. package/dist/adapters/ethers/resources/deposits/services/fee.d.ts +6 -0
  17. package/dist/adapters/ethers/resources/deposits/services/gas.d.ts +41 -0
  18. package/dist/adapters/ethers/resources/tokens/index.d.ts +1 -0
  19. package/dist/adapters/ethers/resources/tokens/tokens.d.ts +10 -0
  20. package/dist/adapters/ethers/resources/utils.d.ts +3 -17
  21. package/dist/adapters/ethers/resources/withdrawals/context.d.ts +15 -7
  22. package/dist/adapters/ethers/resources/withdrawals/index.d.ts +3 -1
  23. package/dist/adapters/ethers/resources/withdrawals/routes/types.d.ts +2 -2
  24. package/dist/adapters/ethers/resources/withdrawals/services/fees.d.ts +14 -0
  25. package/dist/adapters/ethers/resources/withdrawals/services/gas.d.ts +12 -0
  26. package/dist/adapters/ethers/sdk.cjs +1388 -1501
  27. package/dist/adapters/ethers/sdk.cjs.map +1 -1
  28. package/dist/adapters/ethers/sdk.d.ts +5 -22
  29. package/dist/adapters/ethers/sdk.js +7 -6
  30. package/dist/adapters/viem/client.cjs.map +1 -1
  31. package/dist/adapters/viem/client.d.ts +1 -1
  32. package/dist/adapters/viem/client.js +4 -5
  33. package/dist/adapters/viem/estimator.d.ts +4 -0
  34. package/dist/adapters/viem/index.cjs +1233 -744
  35. package/dist/adapters/viem/index.cjs.map +1 -1
  36. package/dist/adapters/viem/index.d.ts +3 -0
  37. package/dist/adapters/viem/index.js +8 -8
  38. package/dist/adapters/viem/resources/contracts/contracts.d.ts +9 -0
  39. package/dist/adapters/viem/resources/contracts/index.d.ts +2 -0
  40. package/dist/adapters/viem/resources/contracts/types.d.ts +61 -0
  41. package/dist/adapters/viem/resources/deposits/context.d.ts +21 -7
  42. package/dist/adapters/viem/resources/deposits/index.d.ts +3 -1
  43. package/dist/adapters/viem/resources/deposits/routes/types.d.ts +2 -6
  44. package/dist/adapters/viem/resources/deposits/services/fee.d.ts +6 -0
  45. package/dist/adapters/viem/resources/deposits/services/gas.d.ts +37 -0
  46. package/dist/adapters/viem/resources/tokens/index.d.ts +1 -0
  47. package/dist/adapters/viem/resources/tokens/tokens.d.ts +3 -0
  48. package/dist/adapters/viem/resources/utils.d.ts +3 -19
  49. package/dist/adapters/viem/resources/withdrawals/context.d.ts +14 -9
  50. package/dist/adapters/viem/resources/withdrawals/index.d.ts +3 -1
  51. package/dist/adapters/viem/resources/withdrawals/routes/types.d.ts +12 -2
  52. package/dist/adapters/viem/resources/withdrawals/services/fee.d.ts +17 -0
  53. package/dist/adapters/viem/resources/withdrawals/services/gas.d.ts +12 -0
  54. package/dist/adapters/viem/sdk.cjs +1225 -699
  55. package/dist/adapters/viem/sdk.cjs.map +1 -1
  56. package/dist/adapters/viem/sdk.d.ts +5 -25
  57. package/dist/adapters/viem/sdk.js +6 -6
  58. package/dist/{chunk-3LALBFFE.js → chunk-3MRGU4HV.js} +9 -5
  59. package/dist/{chunk-CGO27P7F.js → chunk-5YWP4CZP.js} +849 -835
  60. package/dist/{chunk-4HLJJKIY.js → chunk-6K6VJQAL.js} +2 -2
  61. package/dist/{chunk-6GCT6TLS.js → chunk-F2ENUV3A.js} +13 -1
  62. package/dist/{chunk-7M4V3FMT.js → chunk-JXUFGIJG.js} +986 -678
  63. package/dist/chunk-LL3WKCFJ.js +231 -0
  64. package/dist/{chunk-Y75OMFK6.js → chunk-M5J2MM2U.js} +351 -1
  65. package/dist/{chunk-263G6636.js → chunk-NCAIVYBR.js} +1 -14
  66. package/dist/{chunk-DI2CJDPZ.js → chunk-NEC2ZKHI.js} +5 -13
  67. package/dist/chunk-NTEIA5KA.js +13 -0
  68. package/dist/chunk-XRE7H466.js +157 -0
  69. package/dist/{chunk-BD2LUO5T.js → chunk-YUK547UF.js} +3 -3
  70. package/dist/core/abi.d.ts +9 -0
  71. package/dist/core/adapters/interfaces.d.ts +25 -0
  72. package/dist/core/codec/ntv.d.ts +48 -0
  73. package/dist/core/constants.cjs +12 -0
  74. package/dist/core/constants.cjs.map +1 -1
  75. package/dist/core/constants.d.ts +6 -0
  76. package/dist/core/constants.js +1 -1
  77. package/dist/core/index.cjs +4508 -1
  78. package/dist/core/index.cjs.map +1 -1
  79. package/dist/core/index.d.ts +2 -0
  80. package/dist/core/index.js +5 -4
  81. package/dist/core/resources/deposits/fee.d.ts +15 -0
  82. package/dist/core/resources/deposits/gas.d.ts +38 -0
  83. package/dist/core/resources/withdrawals/gas.d.ts +14 -0
  84. package/dist/core/types/errors.d.ts +1 -1
  85. package/dist/core/types/fees.d.ts +40 -0
  86. package/dist/core/types/flows/base.d.ts +0 -10
  87. package/dist/core/types/flows/deposits.d.ts +20 -6
  88. package/dist/core/types/flows/route.d.ts +2 -3
  89. package/dist/core/types/flows/token.d.ts +192 -0
  90. package/dist/core/types/flows/withdrawals.d.ts +12 -6
  91. package/dist/core/utils/addr.d.ts +2 -0
  92. package/dist/index.cjs +4520 -1
  93. package/dist/index.cjs.map +1 -1
  94. package/dist/index.d.ts +2 -0
  95. package/dist/index.js +5 -4
  96. package/package.json +5 -1
  97. package/dist/adapters/ethers/resources/token-info.d.ts +0 -31
  98. package/dist/adapters/ethers/resources/withdrawals/routes/eth-nonbase.d.ts +0 -2
  99. package/dist/adapters/viem/resources/token-info.d.ts +0 -34
  100. package/dist/adapters/viem/resources/withdrawals/routes/eth-nonbase.d.ts +0 -2
  101. package/dist/chunk-B77GWPO5.js +0 -339
  102. package/dist/core/internal/abi-registry.d.ts +0 -9
  103. package/dist/core/utils/gas.d.ts +0 -13
@@ -7,5 +7,8 @@ export type { DepositsResource } from './resources/deposits';
7
7
  export { createWithdrawalsResource } from './resources/withdrawals';
8
8
  export { createFinalizationServices } from './resources/withdrawals';
9
9
  export type { WithdrawalsResource, FinalizationServices } from './resources/withdrawals';
10
+ export { createTokensResource } from './resources/tokens';
11
+ export { createContractsResource } from './resources/contracts';
12
+ export type { ContractsResource, ContractInstances } from './resources/contracts';
10
13
  export * from './errors/error-ops';
11
14
  export * from './errors/revert';
@@ -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 { createViemClient as createClient, createViemClient } from '../../chunk-YUK547UF.js';
2
+ export { buildDirectRequestStruct, classifyReadinessFromRevert, createContractsResource, createDepositsResource, createErrorHandlers, createFinalizationServices, createTokensResource, createViemSdk, createWithdrawalsResource, decodeRevert, encodeNativeTokenVaultTransferData, encodeSecondBridgeArgs, encodeSecondBridgeDataV1, encodeSecondBridgeErc20Args, encodeSecondBridgeEthArgs, registerErrorAbi, toZKsyncError } from '../../chunk-JXUFGIJG.js';
3
+ import '../../chunk-LL3WKCFJ.js';
4
+ import '../../chunk-NEC2ZKHI.js';
5
+ import '../../chunk-6K6VJQAL.js';
6
+ import '../../chunk-NCAIVYBR.js';
7
+ import '../../chunk-M5J2MM2U.js';
8
+ import '../../chunk-F2ENUV3A.js';
@@ -0,0 +1,9 @@
1
+ import type { ViemClient } from '../../client';
2
+ import type { ContractsResource } from './types';
3
+ /**
4
+ * Creates a contracts resource for managing resolved addresses and contract instances.
5
+ *
6
+ * @param client - ViemClient instance
7
+ * @returns ContractsResource instance
8
+ */
9
+ export declare function createContractsResource(client: ViemClient): ContractsResource;
@@ -0,0 +1,2 @@
1
+ export { createContractsResource } from './contracts';
2
+ export type { ContractsResource, ContractInstances } from './types';
@@ -0,0 +1,61 @@
1
+ import type { GetContractReturnType, PublicClient } from 'viem';
2
+ import type { ResolvedAddresses } from '../../client';
3
+ import type { IBridgehubABI, IL1AssetRouterABI, IL1NullifierABI, IL2AssetRouterABI, L2NativeTokenVaultABI, L1NativeTokenVaultABI, IBaseTokenABI } from '../../../../core/abi';
4
+ /**
5
+ * Collection of typed viem contract instances for all bridge contracts.
6
+ */
7
+ export interface ContractInstances {
8
+ bridgehub: GetContractReturnType<typeof IBridgehubABI, PublicClient>;
9
+ l1AssetRouter: GetContractReturnType<typeof IL1AssetRouterABI, PublicClient>;
10
+ l1Nullifier: GetContractReturnType<typeof IL1NullifierABI, PublicClient>;
11
+ l1NativeTokenVault: GetContractReturnType<typeof L1NativeTokenVaultABI, PublicClient>;
12
+ l2AssetRouter: GetContractReturnType<typeof IL2AssetRouterABI, PublicClient>;
13
+ l2NativeTokenVault: GetContractReturnType<typeof L2NativeTokenVaultABI, PublicClient>;
14
+ l2BaseTokenSystem: GetContractReturnType<typeof IBaseTokenABI, PublicClient>;
15
+ }
16
+ /**
17
+ * Contracts resource interface providing access to resolved addresses
18
+ * and contract instances.
19
+ */
20
+ export interface ContractsResource {
21
+ /**
22
+ * Returns resolved addresses for all bridge contracts.
23
+ *
24
+ * @returns Resolved contract addresses
25
+ */
26
+ addresses(): Promise<ResolvedAddresses>;
27
+ /**
28
+ * Returns typed contract instances for all bridge contracts (cached).
29
+ *
30
+ * @returns Contract instances
31
+ */
32
+ instances(): Promise<ContractInstances>;
33
+ /**
34
+ * Returns the Bridgehub contract instance.
35
+ */
36
+ bridgehub(): Promise<ContractInstances['bridgehub']>;
37
+ /**
38
+ * Returns the L1 Asset Router contract instance.
39
+ */
40
+ l1AssetRouter(): Promise<ContractInstances['l1AssetRouter']>;
41
+ /**
42
+ * Returns the L1 Native Token Vault contract instance.
43
+ */
44
+ l1NativeTokenVault(): Promise<ContractInstances['l1NativeTokenVault']>;
45
+ /**
46
+ * Returns the L1 Nullifier contract instance.
47
+ */
48
+ l1Nullifier(): Promise<ContractInstances['l1Nullifier']>;
49
+ /**
50
+ * Returns the L2 Asset Router contract instance.
51
+ */
52
+ l2AssetRouter(): Promise<ContractInstances['l2AssetRouter']>;
53
+ /**
54
+ * Returns the L2 Native Token Vault contract instance.
55
+ */
56
+ l2NativeTokenVault(): Promise<ContractInstances['l2NativeTokenVault']>;
57
+ /**
58
+ * Returns the L2 Base Token System contract instance.
59
+ */
60
+ l2BaseTokenSystem(): Promise<ContractInstances['l2BaseTokenSystem']>;
61
+ }
@@ -1,26 +1,40 @@
1
1
  import type { ViemClient } from '../../client';
2
- import type { Address } from '../../../../core/types/primitives';
3
- import { type FeeOverrides } from '../utils';
2
+ import type { Address, Hex } from '../../../../core/types/primitives';
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
+ import type { ResolvedToken, TokensResource } from '../../../../core/types/flows/token';
7
+ import type { ContractsResource } from '../contracts';
6
8
  export interface BuildCtx extends CommonCtx {
7
9
  client: ViemClient;
10
+ tokens: TokensResource;
11
+ contracts: ContractsResource;
12
+ resolvedToken: ResolvedToken;
13
+ baseTokenAssetId: Hex;
14
+ baseTokenL1: Address;
15
+ baseIsEth: boolean;
8
16
  l1AssetRouter: Address;
9
- fee: FeeOverrides;
10
- l2GasLimit: bigint;
17
+ gasOverrides?: TxOverrides;
18
+ l2GasLimit?: bigint;
11
19
  gasPerPubdata: bigint;
12
20
  operatorTip: bigint;
13
21
  refundRecipient: Address;
14
22
  }
15
- export declare function commonCtx(p: DepositParams, client: ViemClient): Promise<{
23
+ export declare function commonCtx(p: DepositParams, client: ViemClient, tokens: TokensResource, contracts: ContractsResource): Promise<{
16
24
  client: ViemClient;
25
+ tokens: TokensResource;
26
+ contracts: ContractsResource;
27
+ resolvedToken: ResolvedToken;
28
+ baseTokenAssetId: `0x${string}`;
29
+ baseTokenL1: `0x${string}`;
30
+ baseIsEth: boolean;
17
31
  l1AssetRouter: `0x${string}`;
18
32
  route: DepositRoute;
19
33
  bridgehub: `0x${string}`;
20
34
  chainIdL2: bigint;
21
35
  sender: `0x${string}`;
22
- fee: FeeOverrides;
23
- l2GasLimit: bigint;
36
+ gasOverrides: TxOverrides | undefined;
37
+ l2GasLimit: bigint | undefined;
24
38
  gasPerPubdata: bigint;
25
39
  operatorTip: bigint;
26
40
  refundRecipient: `0x${string}`;
@@ -3,6 +3,8 @@ import type { DepositParams, DepositQuote, DepositHandle, DepositWaitable, Depos
3
3
  import type { Hex } from '../../../../core/types/primitives';
4
4
  import type { TransactionReceipt } from 'viem';
5
5
  import type { DepositRouteStrategy, ViemPlanWriteRequest } from './routes/types';
6
+ import type { TokensResource } from '../../../../core/types/flows/token';
7
+ import type { ContractsResource } from '../contracts';
6
8
  export declare const ROUTES: Record<DepositRoute, DepositRouteStrategy>;
7
9
  export interface DepositsResource {
8
10
  quote(p: DepositParams): Promise<DepositQuote>;
@@ -43,4 +45,4 @@ export interface DepositsResource {
43
45
  error: unknown;
44
46
  }>;
45
47
  }
46
- export declare function createDepositsResource(client: ViemClient): DepositsResource;
48
+ export declare function createDepositsResource(client: ViemClient, tokens?: TokensResource, contracts?: ContractsResource): DepositsResource;
@@ -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,37 @@
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 { Address } from '../../../../../core/types/primitives';
6
+ import { type GasQuote } from '../../../../../core/resources/deposits/gas';
7
+ export type { GasQuote };
8
+ export type QuoteL1GasInput = {
9
+ ctx: BuildCtx;
10
+ tx: TransactionRequest;
11
+ overrides?: TxOverrides;
12
+ fallbackGasLimit?: bigint;
13
+ };
14
+ export type QuoteL2GasInput = {
15
+ ctx: BuildCtx;
16
+ route: DepositRoute;
17
+ l2TxForModeling?: TransactionRequest;
18
+ overrideGasLimit?: bigint;
19
+ stateOverrides?: Record<string, unknown>;
20
+ };
21
+ /**
22
+ * Quote L1 gas for a deposit transaction.
23
+ */
24
+ export declare function quoteL1Gas(input: QuoteL1GasInput): Promise<GasQuote | undefined>;
25
+ /**
26
+ * Quote L2 gas for an L2 execution.
27
+ */
28
+ export declare function quoteL2Gas(input: QuoteL2GasInput): Promise<GasQuote | undefined>;
29
+ /**
30
+ * ERC20 deposits have an extra edge case:
31
+ * if the token is not deployed on L2, the deposit includes deployment cost.
32
+ */
33
+ export declare function determineErc20L2Gas(input: {
34
+ ctx: BuildCtx;
35
+ l1Token: Address;
36
+ modelTx?: TransactionRequest;
37
+ }): Promise<GasQuote | undefined>;
@@ -0,0 +1 @@
1
+ export { createTokensResource } from './tokens';
@@ -0,0 +1,3 @@
1
+ import type { ViemClient } from '../../client';
2
+ import type { TokensResource } from '../../../../core/types/flows/token';
3
+ export declare function createTokensResource(client: ViemClient): TokensResource;
@@ -1,23 +1,10 @@
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
- export declare function encodeNativeTokenVaultAssetId(chainId: bigint, address: string): Hex;
6
3
  export declare function encodeNativeTokenVaultTransferData(amount: bigint, receiver: Address, token: Address): Hex;
7
4
  export declare function encodeSecondBridgeDataV1(assetId: Hex, transferData: Hex): Hex;
8
- export declare const encodeNTVAssetId: typeof encodeNativeTokenVaultAssetId;
9
- 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>;
5
+ export declare function encodeSecondBridgeArgs(token: Address, amount: bigint, l2Receiver: Address): Hex;
6
+ export declare function encodeSecondBridgeErc20Args(token: Address, amount: bigint, l2Receiver: Address): Hex;
7
+ export declare function encodeSecondBridgeEthArgs(amount: bigint, l2Receiver: Address, ethToken?: Address): Hex;
21
8
  export declare function buildDirectRequestStruct(args: {
22
9
  chainId: bigint;
23
10
  mintValue: bigint;
@@ -37,6 +24,3 @@ export declare function buildDirectRequestStruct(args: {
37
24
  factoryDeps: Hex[];
38
25
  refundRecipient: `0x${string}`;
39
26
  };
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,22 +1,27 @@
1
1
  import type { ViemClient } from '../../client';
2
2
  import type { Address } from '../../../../core/types/primitives';
3
- import type { WithdrawParams, WithdrawRoute } from '../../../../core/types/flows/withdrawals';
4
- import type { CommonCtx, ResolvedEip1559Fees } from '../../../../core/types/flows/base';
3
+ import { type WithdrawParams, type WithdrawRoute } from '../../../../core/types/flows/withdrawals';
4
+ import type { CommonCtx } from '../../../../core/types/flows/base';
5
+ import type { TxOverrides } from '../../../../core/types/fees';
6
+ import type { Hex } from '../../../../core/types/primitives';
7
+ import type { ResolvedToken, TokensResource } from '../../../../core/types/flows/token';
8
+ import type { ContractsResource } from '../contracts';
5
9
  export interface BuildCtx extends CommonCtx {
6
10
  client: ViemClient;
11
+ tokens: TokensResource;
12
+ contracts: ContractsResource;
13
+ resolvedToken: ResolvedToken;
14
+ baseTokenAssetId: Hex;
15
+ baseTokenL1: Address;
16
+ baseIsEth: boolean;
7
17
  bridgehub: Address;
8
18
  l1AssetRouter: Address;
9
19
  l1Nullifier: Address;
10
20
  l2AssetRouter: Address;
11
21
  l2NativeTokenVault: Address;
12
22
  l2BaseTokenSystem: Address;
13
- baseIsEth: boolean;
14
- chainIdL2: bigint;
15
- sender: Address;
16
- l2GasLimit: bigint;
17
- gasBufferPct: number;
18
- fee: ResolvedEip1559Fees;
23
+ gasOverrides?: TxOverrides;
19
24
  }
20
- export declare function commonCtx(p: WithdrawParams, client: ViemClient): Promise<BuildCtx & {
25
+ export declare function commonCtx(p: WithdrawParams, client: ViemClient, tokens: TokensResource, contracts: ContractsResource): Promise<BuildCtx & {
21
26
  route: WithdrawRoute;
22
27
  }>;
@@ -4,6 +4,8 @@ import type { Hex } from '../../../../core/types/primitives';
4
4
  import type { TransactionReceipt } from 'viem';
5
5
  import type { WithdrawRouteStrategy, TransactionReceiptZKsyncOS, ViemPlanWriteRequest } from './routes/types';
6
6
  import { createFinalizationServices, type FinalizationServices } from './services/finalization';
7
+ import type { TokensResource } from '../../../../core/types/flows/token';
8
+ import type { ContractsResource } from '../contracts';
7
9
  export declare const ROUTES: Record<WithdrawRoute, WithdrawRouteStrategy>;
8
10
  export interface WithdrawalsResource {
9
11
  quote(p: WithdrawParams): Promise<WithdrawQuote>;
@@ -51,6 +53,6 @@ export interface WithdrawalsResource {
51
53
  error: unknown;
52
54
  }>;
53
55
  }
54
- export declare function createWithdrawalsResource(client: ViemClient): WithdrawalsResource;
56
+ export declare function createWithdrawalsResource(client: ViemClient, tokens?: TokensResource, contracts?: ContractsResource): WithdrawalsResource;
55
57
  export { createFinalizationServices };
56
58
  export type { FinalizationServices };
@@ -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>;