@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.
- package/CHANGELOG.md +10 -0
- package/index.cjs.js +463 -18
- package/index.esm.js +463 -22
- package/package.json +5 -5
- package/src/addZerodevExtension/addZerodevExtension.d.ts.map +1 -1
- package/src/canSponsorTransaction/canSponsorTransaction.d.ts +29 -0
- package/src/canSponsorTransaction/canSponsorTransaction.d.ts.map +1 -0
- package/src/canSponsorTransaction/index.d.ts +2 -0
- package/src/canSponsorTransaction/index.d.ts.map +1 -0
- package/src/constants.d.ts +5 -0
- package/src/constants.d.ts.map +1 -1
- package/src/createKernelClientForWalletAccount/createKernelClientForWalletAccount.d.ts +27 -0
- package/src/createKernelClientForWalletAccount/createKernelClientForWalletAccount.d.ts.map +1 -0
- package/src/createKernelClientForWalletAccount/index.d.ts +2 -0
- package/src/createKernelClientForWalletAccount/index.d.ts.map +1 -0
- package/src/estimateTransactionGas/estimateTransactionGas.d.ts +18 -0
- package/src/estimateTransactionGas/estimateTransactionGas.d.ts.map +1 -0
- package/src/estimateTransactionGas/index.d.ts +2 -0
- package/src/estimateTransactionGas/index.d.ts.map +1 -0
- package/src/exports/index.d.ts +5 -0
- package/src/exports/index.d.ts.map +1 -1
- package/src/isGasSponsorshipError/index.d.ts +2 -0
- package/src/isGasSponsorshipError/index.d.ts.map +1 -0
- package/src/isGasSponsorshipError/isGasSponsorshipError.d.ts +2 -0
- package/src/isGasSponsorshipError/isGasSponsorshipError.d.ts.map +1 -0
- package/src/isZerodevWalletAccount/index.d.ts +2 -0
- package/src/isZerodevWalletAccount/index.d.ts.map +1 -0
- package/src/isZerodevWalletAccount/isZerodevWalletAccount.d.ts +9 -0
- package/src/isZerodevWalletAccount/isZerodevWalletAccount.d.ts.map +1 -0
- package/src/utils/calculateGasForUserOperation/calculateGasForUserOperation.d.ts +7 -0
- package/src/utils/calculateGasForUserOperation/calculateGasForUserOperation.d.ts.map +1 -0
- package/src/utils/calculateGasForUserOperation/index.d.ts +2 -0
- package/src/utils/calculateGasForUserOperation/index.d.ts.map +1 -0
- package/src/utils/createKernelAccount/createKernelAccount.d.ts +1 -1
- package/src/utils/createKernelAccount/createKernelAccount.d.ts.map +1 -1
- package/src/utils/createZerodevWalletProvider/createZerodevWalletProvider.d.ts +4 -0
- package/src/utils/createZerodevWalletProvider/createZerodevWalletProvider.d.ts.map +1 -0
- package/src/utils/createZerodevWalletProvider/index.d.ts +2 -0
- package/src/utils/createZerodevWalletProvider/index.d.ts.map +1 -0
- package/src/utils/getAllUserZerodevAddresses/getAllUserZerodevAddresses.d.ts +3 -0
- package/src/utils/getAllUserZerodevAddresses/getAllUserZerodevAddresses.d.ts.map +1 -0
- package/src/utils/getAllUserZerodevAddresses/index.d.ts +2 -0
- package/src/utils/getAllUserZerodevAddresses/index.d.ts.map +1 -0
- package/src/utils/prepareUserOperationWithKernelClient/index.d.ts +2 -0
- package/src/utils/prepareUserOperationWithKernelClient/index.d.ts.map +1 -0
- package/src/utils/prepareUserOperationWithKernelClient/prepareUserOperationWithKernelClient.d.ts +466 -0
- package/src/utils/prepareUserOperationWithKernelClient/prepareUserOperationWithKernelClient.d.ts.map +1 -0
- package/src/utils/signMessage/index.d.ts +2 -0
- package/src/utils/signMessage/index.d.ts.map +1 -0
- package/src/utils/signMessage/signMessage.d.ts +11 -0
- 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.
|
|
15
|
+
var version = "0.1.0-alpha.19";
|
|
11
16
|
|
|
12
|
-
const
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
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;
|