@dynamic-labs-sdk/zerodev 0.1.0-alpha.17 → 0.1.0-alpha.19

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 (51) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/index.cjs.js +463 -18
  3. package/index.esm.js +463 -22
  4. package/package.json +5 -5
  5. package/src/addZerodevExtension/addZerodevExtension.d.ts.map +1 -1
  6. package/src/canSponsorTransaction/canSponsorTransaction.d.ts +29 -0
  7. package/src/canSponsorTransaction/canSponsorTransaction.d.ts.map +1 -0
  8. package/src/canSponsorTransaction/index.d.ts +2 -0
  9. package/src/canSponsorTransaction/index.d.ts.map +1 -0
  10. package/src/constants.d.ts +5 -0
  11. package/src/constants.d.ts.map +1 -1
  12. package/src/createKernelClientForWalletAccount/createKernelClientForWalletAccount.d.ts +27 -0
  13. package/src/createKernelClientForWalletAccount/createKernelClientForWalletAccount.d.ts.map +1 -0
  14. package/src/createKernelClientForWalletAccount/index.d.ts +2 -0
  15. package/src/createKernelClientForWalletAccount/index.d.ts.map +1 -0
  16. package/src/estimateTransactionGas/estimateTransactionGas.d.ts +18 -0
  17. package/src/estimateTransactionGas/estimateTransactionGas.d.ts.map +1 -0
  18. package/src/estimateTransactionGas/index.d.ts +2 -0
  19. package/src/estimateTransactionGas/index.d.ts.map +1 -0
  20. package/src/exports/index.d.ts +5 -0
  21. package/src/exports/index.d.ts.map +1 -1
  22. package/src/isGasSponsorshipError/index.d.ts +2 -0
  23. package/src/isGasSponsorshipError/index.d.ts.map +1 -0
  24. package/src/isGasSponsorshipError/isGasSponsorshipError.d.ts +2 -0
  25. package/src/isGasSponsorshipError/isGasSponsorshipError.d.ts.map +1 -0
  26. package/src/isZerodevWalletAccount/index.d.ts +2 -0
  27. package/src/isZerodevWalletAccount/index.d.ts.map +1 -0
  28. package/src/isZerodevWalletAccount/isZerodevWalletAccount.d.ts +9 -0
  29. package/src/isZerodevWalletAccount/isZerodevWalletAccount.d.ts.map +1 -0
  30. package/src/utils/calculateGasForUserOperation/calculateGasForUserOperation.d.ts +7 -0
  31. package/src/utils/calculateGasForUserOperation/calculateGasForUserOperation.d.ts.map +1 -0
  32. package/src/utils/calculateGasForUserOperation/index.d.ts +2 -0
  33. package/src/utils/calculateGasForUserOperation/index.d.ts.map +1 -0
  34. package/src/utils/createKernelAccount/createKernelAccount.d.ts +1 -1
  35. package/src/utils/createKernelAccount/createKernelAccount.d.ts.map +1 -1
  36. package/src/utils/createZerodevWalletProvider/createZerodevWalletProvider.d.ts +4 -0
  37. package/src/utils/createZerodevWalletProvider/createZerodevWalletProvider.d.ts.map +1 -0
  38. package/src/utils/createZerodevWalletProvider/index.d.ts +2 -0
  39. package/src/utils/createZerodevWalletProvider/index.d.ts.map +1 -0
  40. package/src/utils/getAllUserZerodevAddresses/getAllUserZerodevAddresses.d.ts +3 -0
  41. package/src/utils/getAllUserZerodevAddresses/getAllUserZerodevAddresses.d.ts.map +1 -0
  42. package/src/utils/getAllUserZerodevAddresses/index.d.ts +2 -0
  43. package/src/utils/getAllUserZerodevAddresses/index.d.ts.map +1 -0
  44. package/src/utils/prepareUserOperationWithKernelClient/index.d.ts +2 -0
  45. package/src/utils/prepareUserOperationWithKernelClient/index.d.ts.map +1 -0
  46. package/src/utils/prepareUserOperationWithKernelClient/prepareUserOperationWithKernelClient.d.ts +466 -0
  47. package/src/utils/prepareUserOperationWithKernelClient/prepareUserOperationWithKernelClient.d.ts.map +1 -0
  48. package/src/utils/signMessage/index.d.ts +2 -0
  49. package/src/utils/signMessage/index.d.ts.map +1 -0
  50. package/src/utils/signMessage/signMessage.d.ts +11 -0
  51. package/src/utils/signMessage/signMessage.d.ts.map +1 -0
package/CHANGELOG.md CHANGED
@@ -1,3 +1,13 @@
1
+ ## 0.1.0-alpha.19 (2025-10-10)
2
+
3
+ This was a version bump only, there were no code changes.
4
+
5
+ ## 0.1.0-alpha.18 (2025-10-08)
6
+
7
+ ### 🚀 Features
8
+
9
+ - Add TypeDoc for JavaScript SDK API Reference Documentation ([#512](https://github.com/dynamic-labs/dynamic-sdk/pull/512))
10
+
1
11
  ## 0.1.0-alpha.17 (2025-10-02)
2
12
 
3
13
  ### 🩹 Fixes
package/index.cjs.js CHANGED
@@ -4,30 +4,73 @@ var assertPackageVersion = require('@dynamic-labs-sdk/assert-package-version');
4
4
  var core = require('@dynamic-labs-sdk/client/core');
5
5
  var client = require('@dynamic-labs-sdk/client');
6
6
  var evm = require('@dynamic-labs-sdk/evm');
7
+ var sdkApiCore = require('@dynamic-labs/sdk-api-core');
8
+ var sdk = require('@zerodev/sdk');
7
9
  var viem = require('@dynamic-labs-sdk/evm/viem');
10
+ var viem$1 = require('viem');
11
+ var ecdsaValidator = require('@zerodev/ecdsa-validator');
12
+ var multiChainEcdsaValidator = require('@zerodev/multi-chain-ecdsa-validator');
8
13
 
9
14
  var name = "@dynamic-labs-sdk/zerodev";
10
- var version = "0.1.0-alpha.17";
15
+ var version = "0.1.0-alpha.19";
11
16
 
12
- const ZERODEV_EXTENSION_KEY = 'zerodev';
13
- /**
14
- * Adds the ZeroDev extension to the Dynamic client.
15
- *
16
- * This extension enables Account Abstraction integration with ZeroDev
17
- *
18
- * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
19
- */ const addZerodevExtension = (client = core.getDefaultClient())=>{
20
- if (core.hasExtension({
21
- extensionKey: ZERODEV_EXTENSION_KEY
22
- }, client)) {
23
- return;
24
- }
25
- core.registerExtension({
26
- extensionKey: ZERODEV_EXTENSION_KEY
27
- }, client);
28
- // TODO: implement
17
+ const ZERODEV_METADATA = {
18
+ displayName: 'ZeroDev',
19
+ icon: 'https://iconic.dynamic-static-assets.com/icons/sprite.svg#smartwallet',
20
+ normalizedWalletName: 'zerodev'
21
+ };
22
+ const ZERODEV_RPC_BASE_URL = 'https://rpc.zerodev.app/api/v2';
23
+ const KERNEL_VERSION_MAP = {
24
+ [sdkApiCore.ProviderKernelVersionEnum.V33]: sdk.constants.KERNEL_V3_3,
25
+ [sdkApiCore.ProviderKernelVersionEnum.V32]: sdk.constants.KERNEL_V3_2,
26
+ [sdkApiCore.ProviderKernelVersionEnum.V31]: sdk.constants.KERNEL_V3_1,
27
+ [sdkApiCore.ProviderKernelVersionEnum.V30]: sdk.constants.KERNEL_V3_0,
28
+ [sdkApiCore.ProviderKernelVersionEnum.V24]: sdk.constants.KERNEL_V2_4
29
+ };
30
+ const ENTRY_POINT_VERSION_MAP = {
31
+ 0.6: sdk.constants.KERNEL_V2_4,
32
+ 0.7: sdk.constants.KERNEL_V3_1,
33
+ 0.8: sdk.constants.KERNEL_V3_3
29
34
  };
30
35
 
36
+ const getAllUserZerodevAddresses = (client)=>{
37
+ var _client_user;
38
+ var _client_user_verifiedCredentials_filter;
39
+ const zerodevWalletCredentials = (_client_user_verifiedCredentials_filter = (_client_user = client.user) == null ? void 0 : _client_user.verifiedCredentials.filter((credential)=>{
40
+ var _credential_walletName;
41
+ return credential.walletProvider === sdkApiCore.WalletProviderEnum.SmartContractWallet && ((_credential_walletName = credential.walletName) == null ? void 0 : _credential_walletName.toLowerCase().startsWith(ZERODEV_METADATA.normalizedWalletName)) && credential.address && credential.chain && core.getChainFromVerifiedCredentialChain(credential.chain) === 'EVM';
42
+ })) != null ? _client_user_verifiedCredentials_filter : [];
43
+ const zerodevAddresses = zerodevWalletCredentials.map(// casting because we're already filtering out credentials without an address
44
+ (credential)=>credential.address);
45
+ return zerodevAddresses;
46
+ };
47
+
48
+ const getZerodevProviderFromSettings = (client)=>{
49
+ var _projectSettings_providers;
50
+ const projectSettings = client.projectSettings;
51
+ core.assertDefined(projectSettings, 'Project settings are not available');
52
+ const zerodevProvider = (_projectSettings_providers = projectSettings.providers) == null ? void 0 : _projectSettings_providers.find((provider)=>provider.provider === sdkApiCore.ProviderEnum.Zerodev);
53
+ core.assertDefined(zerodevProvider, 'Zerodev is not configured in project settings');
54
+ return zerodevProvider;
55
+ };
56
+
57
+ const getZerodevChainProviderForNetworkId = ({ networkId }, client)=>{
58
+ var _zerodevProvider_multichainAccountAbstractionProviders;
59
+ const zerodevProvider = getZerodevProviderFromSettings(client);
60
+ return (_zerodevProvider_multichainAccountAbstractionProviders = zerodevProvider.multichainAccountAbstractionProviders) == null ? void 0 : _zerodevProvider_multichainAccountAbstractionProviders.find((provider)=>provider.chain === networkId);
61
+ };
62
+
63
+ function _extends() {
64
+ _extends = Object.assign || function assign(target) {
65
+ for(var i = 1; i < arguments.length; i++){
66
+ var source = arguments[i];
67
+ for(var key in source)if (Object.prototype.hasOwnProperty.call(source, key)) target[key] = source[key];
68
+ }
69
+ return target;
70
+ };
71
+ return _extends.apply(this, arguments);
72
+ }
73
+
31
74
  /**
32
75
  * Gets a WalletClient instance for the EOA of the smart wallet account.
33
76
  * You can use this signer to sign EVM transactions.
@@ -48,7 +91,409 @@ const ZERODEV_EXTENSION_KEY = 'zerodev';
48
91
  }, client$1);
49
92
  };
50
93
 
94
+ const getEcdsaValidator = ({ ecdsaProviderType, publicClient, signer, entryPoint, kernelVersion })=>{
95
+ const params = {
96
+ entryPoint,
97
+ kernelVersion,
98
+ signer
99
+ };
100
+ if (ecdsaProviderType === 'zerodev_multi_chain') {
101
+ return multiChainEcdsaValidator.toMultiChainECDSAValidator(publicClient, params);
102
+ }
103
+ return ecdsaValidator.signerToEcdsaValidator(publicClient, params);
104
+ };
105
+
106
+ const getEntryPoint = (entryPoint)=>{
107
+ if (entryPoint === sdkApiCore.ProviderEntryPointVersionEnum.V6) {
108
+ return sdk.constants.getEntryPoint('0.6');
109
+ }
110
+ // default to v7
111
+ return sdk.constants.getEntryPoint('0.7');
112
+ };
113
+
114
+ const getKernelVersion = ({ kernelVersion, entryPoint })=>{
115
+ // If kernel version is explicitly provided, use it
116
+ if (kernelVersion && kernelVersion in KERNEL_VERSION_MAP) {
117
+ return KERNEL_VERSION_MAP[kernelVersion];
118
+ }
119
+ // If no kernel version provided, determine based on entry point version
120
+ const entryPointVersion = entryPoint.version;
121
+ if (entryPointVersion in ENTRY_POINT_VERSION_MAP) {
122
+ return ENTRY_POINT_VERSION_MAP[entryPointVersion];
123
+ }
124
+ // Fallback to latest version
125
+ return sdk.constants.KERNEL_V3_3;
126
+ };
127
+
128
+ const shouldUseEIP7702 = ({ smartWalletAccount }, client$1)=>{
129
+ const zerodevProvider = getZerodevProviderFromSettings(client$1);
130
+ core.assertDefined(zerodevProvider, 'Zerodev provider is not enabled in project settings');
131
+ const eoaWalletAccount = client.getOwnerWalletAccountForSmartWalletAccount({
132
+ smartWalletAccount
133
+ }, client$1);
134
+ core.assertDefined(eoaWalletAccount, 'EOA wallet account is not found');
135
+ return zerodevProvider.enableEIP7702 && // with EIP7702, the EOA wallet account address is the same as the smart wallet account address
136
+ smartWalletAccount.address === eoaWalletAccount.address;
137
+ };
138
+
139
+ const createKernelAccount = async ({ publicClient, smartWalletAccount }, client)=>{
140
+ var _getVerifiedCredentialForWalletAccount;
141
+ const zerodevProvider = getZerodevProviderFromSettings(client);
142
+ core.assertDefined(zerodevProvider, 'Zerodev provider is not enabled in project settings');
143
+ const signer = await getSignerForSmartWalletAccount({
144
+ smartWalletAccount
145
+ }, client);
146
+ const walletProperties = (_getVerifiedCredentialForWalletAccount = core.getVerifiedCredentialForWalletAccount({
147
+ walletAccount: smartWalletAccount
148
+ }, client)) == null ? void 0 : _getVerifiedCredentialForWalletAccount.walletProperties;
149
+ var _walletProperties_entryPointVersion;
150
+ const entryPointVersion = (_walletProperties_entryPointVersion = walletProperties == null ? void 0 : walletProperties.entryPointVersion) != null ? _walletProperties_entryPointVersion : zerodevProvider.entryPointVersion;
151
+ const entryPoint = getEntryPoint(entryPointVersion);
152
+ const useEIP7702 = shouldUseEIP7702({
153
+ smartWalletAccount
154
+ }, client);
155
+ if (useEIP7702) {
156
+ return sdk.createKernelAccount(publicClient, {
157
+ eip7702Account: signer,
158
+ entryPoint,
159
+ kernelVersion: sdk.constants.KERNEL_V3_3
160
+ });
161
+ }
162
+ var _walletProperties_kernelVersion;
163
+ const kernelVersionValue = (_walletProperties_kernelVersion = walletProperties == null ? void 0 : walletProperties.kernelVersion) != null ? _walletProperties_kernelVersion : zerodevProvider.kernelVersion;
164
+ const kernelVersion = getKernelVersion({
165
+ entryPoint,
166
+ kernelVersion: kernelVersionValue
167
+ });
168
+ var _zerodevProvider_enableKernelV3Migration;
169
+ const kernelV3MigrationEnabled = (_zerodevProvider_enableKernelV3Migration = zerodevProvider.enableKernelV3Migration) != null ? _zerodevProvider_enableKernelV3Migration : false;
170
+ if (kernelV3MigrationEnabled) {
171
+ const apiKernelVersion = getKernelVersion({
172
+ entryPoint,
173
+ kernelVersion: zerodevProvider.kernelVersion
174
+ });
175
+ return ecdsaValidator.createEcdsaKernelMigrationAccount(publicClient, {
176
+ entryPoint,
177
+ migrationVersion: {
178
+ from: kernelVersion,
179
+ to: apiKernelVersion
180
+ },
181
+ signer
182
+ });
183
+ }
184
+ var _walletProperties_ecdsaProviderType;
185
+ const validator = await getEcdsaValidator({
186
+ ecdsaProviderType: (_walletProperties_ecdsaProviderType = walletProperties == null ? void 0 : walletProperties.ecdsaProviderType) != null ? _walletProperties_ecdsaProviderType : zerodevProvider.ecdsaProviderType,
187
+ entryPoint,
188
+ kernelVersion,
189
+ publicClient,
190
+ signer
191
+ });
192
+ return sdk.createKernelAccount(publicClient, {
193
+ entryPoint,
194
+ kernelVersion,
195
+ plugins: {
196
+ sudo: validator
197
+ }
198
+ });
199
+ };
200
+
201
+ const getPaymasterConfig = ({ chain, gasTokenAddress, paymasterRpc })=>{
202
+ const getPaymasterData = (params)=>{
203
+ const zerodevPaymaster = sdk.createZeroDevPaymasterClient({
204
+ chain,
205
+ transport: viem$1.http(paymasterRpc)
206
+ });
207
+ return zerodevPaymaster.sponsorUserOperation({
208
+ gasToken: gasTokenAddress,
209
+ userOperation: params
210
+ });
211
+ };
212
+ return {
213
+ paymaster: {
214
+ getPaymasterData
215
+ }
216
+ };
217
+ };
218
+
219
+ const getZerodevRpc = ({ networkId, bundlerProvider, rpcType }, client)=>{
220
+ const zerodevProvider = getZerodevProviderFromSettings(client);
221
+ if (zerodevProvider == null ? void 0 : zerodevProvider.zerodevPaymasterRpcUrl) {
222
+ return zerodevProvider.zerodevPaymasterRpcUrl;
223
+ }
224
+ const zerodevChainProvider = getZerodevChainProviderForNetworkId({
225
+ networkId
226
+ }, client);
227
+ core.assertDefined(zerodevChainProvider, `No zerodev provider found for network id ${networkId}`);
228
+ var _ref;
229
+ const paymasterProvider = (_ref = bundlerProvider != null ? bundlerProvider : zerodevProvider.zerodevBundlerProvider) != null ? _ref : sdkApiCore.ZerodevBundlerProvider.Pimlico;
230
+ const paramName = rpcType === 'bundler' ? 'bundlerProvider' : 'paymasterProvider';
231
+ return `${ZERODEV_RPC_BASE_URL}/${rpcType}/${zerodevChainProvider.clientId}?${paramName}=${paymasterProvider}`;
232
+ };
233
+
234
+ /**
235
+ * Creates a KernelClient instance for a given smart wallet account.
236
+ *
237
+ * @param params.smartWalletAccount - The smart wallet account to create the KernelClient for.
238
+ * @param [params.bundlerProvider] - A custom bundler provider to use
239
+ * @param [params.bundlerRpc] - A custom bundler RPC to use
240
+ * @param [params.paymasterRpc] - A custom paymaster RPC to use
241
+ * @param [params.gasTokenAddress] - The address of a custom ERC20 token to use as a gas token
242
+ * @param [params.withSponsorship] - Whether to use sponsorship for the KernelClient or not (default is true).
243
+ * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
244
+ * @returns A promise that resolves to a KernelClient instance.
245
+ */ const createKernelClientForWalletAccount = async ({ smartWalletAccount, withSponsorship = true, bundlerProvider, bundlerRpc: bundlerRpcOverride, paymasterRpc: paymasterRpcOverride, gasTokenAddress }, client$1 = core.getDefaultClient())=>{
246
+ const { networkData: activeNetworkData } = await client.getActiveNetworkData({
247
+ walletAccount: smartWalletAccount
248
+ }, client$1);
249
+ core.assertDefined(activeNetworkData, 'No active network data found');
250
+ const viemChain = viem.mapNetworkDataToViemChain(activeNetworkData);
251
+ const bundlerRpc = bundlerRpcOverride != null ? bundlerRpcOverride : getZerodevRpc({
252
+ bundlerProvider,
253
+ networkId: activeNetworkData.networkId,
254
+ rpcType: 'bundler'
255
+ }, client$1);
256
+ const bundlerTransport = viem$1.http(bundlerRpc);
257
+ const publicClient = viem$1.createPublicClient({
258
+ chain: viemChain,
259
+ transport: bundlerTransport
260
+ });
261
+ const account = await createKernelAccount({
262
+ publicClient,
263
+ smartWalletAccount
264
+ }, client$1);
265
+ const paymasterRpc = paymasterRpcOverride != null ? paymasterRpcOverride : getZerodevRpc({
266
+ bundlerProvider,
267
+ networkId: activeNetworkData.networkId,
268
+ rpcType: 'paymaster'
269
+ }, client$1);
270
+ const paymasterConfig = withSponsorship ? getPaymasterConfig({
271
+ chain: viemChain,
272
+ gasTokenAddress,
273
+ paymasterRpc
274
+ }) : {};
275
+ return sdk.createKernelAccountClient(_extends({
276
+ account,
277
+ bundlerTransport,
278
+ chain: viemChain,
279
+ client: publicClient,
280
+ userOperation: {
281
+ estimateFeesPerGas: async ({ bundlerClient })=>sdk.getUserOperationGasPrice(bundlerClient)
282
+ }
283
+ }, paymasterConfig));
284
+ };
285
+
286
+ const shouldSignWithEoa = async ({ kernelClient, smartWalletAccount }, client)=>{
287
+ const useEIP7702 = shouldUseEIP7702({
288
+ smartWalletAccount
289
+ }, client);
290
+ if (!useEIP7702) {
291
+ return false;
292
+ }
293
+ const isDeployed = await kernelClient.account.isDeployed();
294
+ return !isDeployed;
295
+ };
296
+
297
+ const signMessage = async ({ walletAccount, message }, client$1)=>{
298
+ const kernelClient = await createKernelClientForWalletAccount({
299
+ smartWalletAccount: walletAccount
300
+ }, client$1);
301
+ const shouldUseEoa = await shouldSignWithEoa({
302
+ kernelClient,
303
+ smartWalletAccount: walletAccount
304
+ }, client$1);
305
+ if (shouldUseEoa) {
306
+ const eoaWalletAccount = client.getOwnerWalletAccountForSmartWalletAccount({
307
+ smartWalletAccount: walletAccount
308
+ }, client$1);
309
+ core.assertDefined(eoaWalletAccount, 'Eoa wallet account not found');
310
+ const { signature } = await client.signMessage({
311
+ message,
312
+ walletAccount: eoaWalletAccount
313
+ });
314
+ return {
315
+ signature
316
+ };
317
+ }
318
+ const signature = await kernelClient.signMessage({
319
+ message
320
+ });
321
+ return {
322
+ signature
323
+ };
324
+ };
325
+
326
+ const createZerodevWalletProvider = (client$1)=>{
327
+ const chain = 'EVM';
328
+ const walletProviderType = sdkApiCore.WalletProviderEnum.SmartContractWallet;
329
+ const key = core.formatWalletProviderKey({
330
+ chain,
331
+ displayName: ZERODEV_METADATA.displayName,
332
+ walletProviderType
333
+ });
334
+ const getActiveNetworkId = async ()=>core.getActiveNetworkIdFromLastKnownRegistry({
335
+ client: client$1,
336
+ walletProviderKey: key
337
+ });
338
+ const getConnectedAddresses = async ()=>{
339
+ const zerodevAddresses = getAllUserZerodevAddresses(client$1);
340
+ return {
341
+ addresses: zerodevAddresses
342
+ };
343
+ };
344
+ const request = async ()=>{
345
+ throw new core.MethodNotImplementedError('request');
346
+ };
347
+ const signMessage$1 = async ({ walletAccount, message })=>{
348
+ core.assertDefined(walletAccount, 'Wallet account is required');
349
+ if (!evm.isEvmWalletAccount(walletAccount)) {
350
+ throw new client.InvalidParamError(`walletAccount is not an EVM wallet account`);
351
+ }
352
+ return signMessage({
353
+ message,
354
+ walletAccount
355
+ }, client$1);
356
+ };
357
+ const switchActiveNetwork = async ({ networkId })=>{
358
+ const isNetworkEnabled = getZerodevChainProviderForNetworkId({
359
+ networkId
360
+ }, client$1);
361
+ if (!isNetworkEnabled) {
362
+ throw new client.UnrecognizedNetworkError({
363
+ networkId,
364
+ originalError: null,
365
+ walletProviderKey: key
366
+ });
367
+ }
368
+ return core.switchActiveNetworkInLastKnownRegistry({
369
+ client: client$1,
370
+ networkId,
371
+ walletProviderKey: key
372
+ });
373
+ };
374
+ return {
375
+ chain,
376
+ getActiveNetworkId,
377
+ getConnectedAddresses,
378
+ groupKey: core.formatWalletProviderGroupKey(ZERODEV_METADATA.displayName),
379
+ key,
380
+ metadata: {
381
+ displayName: ZERODEV_METADATA.displayName,
382
+ icon: ZERODEV_METADATA.icon
383
+ },
384
+ request,
385
+ signMessage: signMessage$1,
386
+ switchActiveNetwork,
387
+ walletProviderType
388
+ };
389
+ };
390
+
391
+ const ZERODEV_EXTENSION_KEY = 'zerodev';
392
+ /**
393
+ * Adds the ZeroDev extension to the Dynamic client.
394
+ *
395
+ * This extension enables Account Abstraction integration with ZeroDev
396
+ *
397
+ * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
398
+ */ const addZerodevExtension = (client = core.getDefaultClient())=>{
399
+ if (core.hasExtension({
400
+ extensionKey: ZERODEV_EXTENSION_KEY
401
+ }, client)) {
402
+ return;
403
+ }
404
+ core.registerExtension({
405
+ extensionKey: ZERODEV_EXTENSION_KEY
406
+ }, client);
407
+ const walletProviderRegistry = core.getWalletProviderRegistry(client);
408
+ const walletProvider = createZerodevWalletProvider(client);
409
+ walletProviderRegistry.register({
410
+ priority: core.WalletProviderPriority.WALLET_SDK,
411
+ walletProvider
412
+ });
413
+ };
414
+
415
+ const prepareUserOperationWithKernelClient = async ({ kernelClient, transaction })=>{
416
+ var _transaction_data;
417
+ const callData = await kernelClient.account.encodeCalls([
418
+ {
419
+ data: (_transaction_data = transaction.data) != null ? _transaction_data : '0x',
420
+ to: transaction.to,
421
+ value: transaction.value
422
+ }
423
+ ]);
424
+ return kernelClient.prepareUserOperation({
425
+ callData
426
+ });
427
+ };
428
+
429
+ /**
430
+ * Checks if a transaction can be sponsored
431
+ * @param params.transaction - The transaction to check if it can be sponsored
432
+ * @param params.kernelClient - The kernel client to use to check if the transaction can be sponsored. If no provided, a walletAccount is required to create a kernel client with sponsorship.
433
+ * @param params.walletAccount - The wallet account that will be used to send the transaction, Only required if no kernel client is provided
434
+ * @returns True if the transaction can be sponsored, false otherwise
435
+ */ const canSponsorTransaction = async ({ walletAccount, transaction, kernelClient })=>{
436
+ let kernelClientToUse = kernelClient;
437
+ if (!kernelClientToUse) {
438
+ core.assertDefined(walletAccount, 'Please provide either a wallet account or a kernel client in the parameters');
439
+ kernelClientToUse = await createKernelClientForWalletAccount({
440
+ smartWalletAccount: walletAccount
441
+ });
442
+ }
443
+ try {
444
+ const sponsorResult = await prepareUserOperationWithKernelClient({
445
+ kernelClient: kernelClientToUse,
446
+ transaction
447
+ });
448
+ const hasPaymaster = sponsorResult.paymasterAndData !== '0x';
449
+ return hasPaymaster;
450
+ } catch (e) {
451
+ return false;
452
+ }
453
+ };
454
+
455
+ const calculateGasForUserOperation = ({ userOperationData })=>{
456
+ // Sum all gas units
457
+ const totalGasUnits = userOperationData.callGasLimit + userOperationData.verificationGasLimit + userOperationData.preVerificationGas;
458
+ // Multiply by maxFeePerGas to get the total gas cost in wei
459
+ const gasCost = totalGasUnits * userOperationData.maxFeePerGas;
460
+ return gasCost;
461
+ };
462
+
463
+ /**
464
+ * Estimates the total gas for a transaction
465
+ * @param params.transaction - The transaction to estimate the gas for
466
+ * @param params.walletAccount - The wallet account that will be used to send the transaction
467
+ * @returns The gas for the transaction in wei
468
+ */ const estimateTransactionGas = async ({ walletAccount, transaction })=>{
469
+ try {
470
+ const kernelClientWithoutSponsorship = await createKernelClientForWalletAccount({
471
+ smartWalletAccount: walletAccount,
472
+ withSponsorship: false
473
+ });
474
+ const unsponsoredUserOperation = await prepareUserOperationWithKernelClient({
475
+ kernelClient: kernelClientWithoutSponsorship,
476
+ transaction
477
+ });
478
+ return calculateGasForUserOperation({
479
+ userOperationData: unsponsoredUserOperation
480
+ });
481
+ } catch (e) {
482
+ return null;
483
+ }
484
+ };
485
+
486
+ const isGasSponsorshipError = (err)=>{
487
+ var _errorWithMessage_message;
488
+ const errorWithMessage = err;
489
+ return (errorWithMessage == null ? void 0 : (_errorWithMessage_message = errorWithMessage.message) == null ? void 0 : _errorWithMessage_message.includes('userOp did not match any gas sponsoring policies')) || false;
490
+ };
491
+
51
492
  assertPackageVersion.assertPackageVersion(name, version);
52
493
 
53
494
  exports.addZerodevExtension = addZerodevExtension;
495
+ exports.canSponsorTransaction = canSponsorTransaction;
496
+ exports.createKernelClientForWalletAccount = createKernelClientForWalletAccount;
497
+ exports.estimateTransactionGas = estimateTransactionGas;
54
498
  exports.getSignerForSmartWalletAccount = getSignerForSmartWalletAccount;
499
+ exports.isGasSponsorshipError = isGasSponsorshipError;