@dynamic-labs-sdk/solana 0.23.2 → 0.23.4

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 (27) hide show
  1. package/dist/{addSolanaWalletStandardExtension-B26Xpl2O.esm.js → addSolanaWalletStandardExtension-B3sMU6WM.esm.js} +2 -2
  2. package/dist/{addSolanaWalletStandardExtension-B26Xpl2O.esm.js.map → addSolanaWalletStandardExtension-B3sMU6WM.esm.js.map} +1 -1
  3. package/dist/{addSolanaWalletStandardExtension-BYIsol74.cjs.js → addSolanaWalletStandardExtension-DrbtTeR3.cjs.js} +4 -36
  4. package/dist/{addSolanaWalletStandardExtension-BYIsol74.cjs.js.map → addSolanaWalletStandardExtension-DrbtTeR3.cjs.js.map} +1 -1
  5. package/dist/{addWaasSolanaExtension-D4DLAn3x.esm.js → addWaasSolanaExtension-B4u-up-i.esm.js} +2 -2
  6. package/dist/{addWaasSolanaExtension-D4DLAn3x.esm.js.map → addWaasSolanaExtension-B4u-up-i.esm.js.map} +1 -1
  7. package/dist/{addWaasSolanaExtension-FgRBy-56.cjs.js → addWaasSolanaExtension-bhJbhe7B.cjs.js} +3 -3
  8. package/dist/{addWaasSolanaExtension-FgRBy-56.cjs.js.map → addWaasSolanaExtension-bhJbhe7B.cjs.js.map} +1 -1
  9. package/dist/chunk-BFVW7ptc.cjs.js +34 -0
  10. package/dist/index.cjs.js +7 -6
  11. package/dist/index.cjs.js.map +1 -1
  12. package/dist/index.esm.js +3 -3
  13. package/dist/{solanaTransferAmount-BvLEGA-x.esm.js → solanaTransferAmount-EGugT484.esm.js} +2 -2
  14. package/dist/{solanaTransferAmount-BvLEGA-x.esm.js.map → solanaTransferAmount-EGugT484.esm.js.map} +1 -1
  15. package/dist/{solanaTransferAmount-BIEZ3hn_.cjs.js → solanaTransferAmount-d27ooag0.cjs.js} +3 -3
  16. package/dist/{solanaTransferAmount-BIEZ3hn_.cjs.js.map → solanaTransferAmount-d27ooag0.cjs.js.map} +1 -1
  17. package/dist/tsconfig.lib.tsbuildinfo +1 -1
  18. package/dist/waas.cjs.js +3 -3
  19. package/dist/waas.esm.js +2 -2
  20. package/dist/walletConnect.cjs.js +333 -0
  21. package/dist/walletConnect.cjs.js.map +1 -0
  22. package/dist/walletConnect.esm.js +329 -0
  23. package/dist/walletConnect.esm.js.map +1 -0
  24. package/dist/walletStandard.cjs.js +3 -2
  25. package/dist/walletStandard.cjs.js.map +1 -1
  26. package/dist/walletStandard.esm.js +2 -2
  27. package/package.json +5 -5
@@ -0,0 +1,329 @@
1
+ import { c as isVersionedTransaction, d as name, f as version, i as solanaExecuteSwapTransaction, o as solanaConfirmTransaction, t as solanaTransferAmount, u as registerSolanaNetworkProviderBuilder } from "./solanaTransferAmount-EGugT484.esm.js";
2
+ import { assertPackageVersion } from "@dynamic-labs-sdk/assert-package-version";
3
+ import { CHAINS_INFO_MAP, WalletProviderPriority, assertDefined, bufferToBase64, emitEvent, filterDuplicates, formatWalletProviderGroupKey, formatWalletProviderKey, getActiveNetworkIdFromLastKnownRegistry, getDefaultClient, getWalletProviderRegistry, registerExtension, switchActiveNetworkInLastKnownRegistry, waitForProjectSettings } from "@dynamic-labs-sdk/client/core";
4
+ import { PublicKey, Transaction, VersionedTransaction } from "@solana/web3.js";
5
+ import { getActiveNetworkData, getDefaultClient as getDefaultClient$1, hasExtension as hasExtension$1, verifyWalletAccount } from "@dynamic-labs-sdk/client";
6
+ import { WalletProviderEnum } from "@dynamic-labs/sdk-api-core";
7
+ import bs58 from "bs58";
8
+ import { createWalletConnectSessionEventEmitter, getSignClient, importWalletConnectSession, splitCaip10Token } from "@dynamic-labs-sdk/wallet-connect/core";
9
+ import { SessionClosedUnexpectedlyError } from "@dynamic-labs-sdk/wallet-connect";
10
+ import { SDK_ERRORS } from "@walletconnect/utils";
11
+
12
+ //#region src/walletConnect/createWalletProviderFromWalletConnectSolanaSession/createWalletProviderFromWalletConnectSolanaSession.ts
13
+ /**
14
+ * The list of Solana request methods that require user action.
15
+ * We will raise a user action requested event for these methods.
16
+ */
17
+ const methodsThatRequireUserAction = [
18
+ "solana_signMessage",
19
+ "solana_signTransaction",
20
+ "solana_signAllTransactions",
21
+ "solana_signAndSendTransaction"
22
+ ];
23
+ /** @not-instrumented */
24
+ const createWalletProviderFromWalletConnectSolanaSession = async ({ sessionTopic }, client) => {
25
+ const signClient = await getSignClient(client);
26
+ const getSession = () => {
27
+ const session = signClient.session.get(sessionTopic);
28
+ if (!session) {
29
+ disconnect();
30
+ throw new SessionClosedUnexpectedlyError({
31
+ sessionTopic,
32
+ walletDisplayName: displayName
33
+ });
34
+ }
35
+ return session;
36
+ };
37
+ const displayName = getSession().peer.metadata.name;
38
+ const namespaceKey = "solana";
39
+ const walletProviderType = WalletProviderEnum.WalletConnect;
40
+ const key = formatWalletProviderKey({
41
+ chain: "SOL",
42
+ displayName,
43
+ suffix: sessionTopic,
44
+ walletProviderType
45
+ });
46
+ const getActiveNetworkId = async () => {
47
+ getSession();
48
+ return await getActiveNetworkIdFromLastKnownRegistry({
49
+ client,
50
+ walletProviderKey: key
51
+ });
52
+ };
53
+ const switchActiveNetwork = async ({ networkId }) => {
54
+ getSession();
55
+ await switchActiveNetworkInLastKnownRegistry({
56
+ client,
57
+ networkId,
58
+ walletProviderKey: key
59
+ });
60
+ };
61
+ const disconnect = async () => {
62
+ await signClient.disconnect({
63
+ reason: SDK_ERRORS.USER_DISCONNECTED,
64
+ topic: sessionTopic
65
+ });
66
+ getWalletProviderRegistry(client).unregister(key);
67
+ };
68
+ /**
69
+ * We actually clear up the entire WC session and its wallet provider
70
+ */
71
+ const disconnectWalletAccount = async () => disconnect();
72
+ /**
73
+ * Helper function to make WalletConnect requests
74
+ */
75
+ const makeRequest = async (request, walletAccount) => {
76
+ assertDefined(walletAccount, "Wallet account is required");
77
+ const peerMetadata = getSession().peer.metadata;
78
+ if (methodsThatRequireUserAction.includes(request.method)) emitEvent({
79
+ args: {
80
+ walletMetadata: peerMetadata,
81
+ walletProviderKey: key
82
+ },
83
+ event: "walletConnectUserActionRequested"
84
+ }, client);
85
+ const { networkData } = await getActiveNetworkData({ walletAccount }, client);
86
+ assertDefined(networkData, `Failed to get network data for wallet account ${walletAccount.address}`);
87
+ return signClient.request({
88
+ chainId: `${namespaceKey}:${networkData.genesisHash}`,
89
+ request,
90
+ topic: sessionTopic
91
+ });
92
+ };
93
+ /**
94
+ * Serializes a transaction for WalletConnect
95
+ * Reference: https://github.com/reown-com/appkit/blob/552b6b39b46e6c604b4d7d290634b9fa96bf7ed0/packages/adapters/solana/src/providers/AuthProvider.ts#L193
96
+ */
97
+ const serializeTransaction = (transaction) => {
98
+ const serialized = transaction.serialize({
99
+ requireAllSignatures: false,
100
+ verifySignatures: false
101
+ });
102
+ return bs58.encode(new Uint8Array(serialized));
103
+ };
104
+ const signMessage = async ({ message, walletAccount }) => {
105
+ assertDefined(walletAccount, "Wallet account is required");
106
+ const { signature } = await makeRequest({
107
+ method: "solana_signMessage",
108
+ params: {
109
+ message,
110
+ pubkey: new PublicKey(walletAccount.address).toBase58()
111
+ }
112
+ }, walletAccount);
113
+ return { signature: bufferToBase64(bs58.decode(signature)) };
114
+ };
115
+ const getConnectedAddresses = async () => {
116
+ return { addresses: filterDuplicates(getSession().namespaces[namespaceKey].accounts.map((account) => splitCaip10Token(account).address)) };
117
+ };
118
+ const { cleanupEventEmitter, getEventEmitter } = createWalletConnectSessionEventEmitter({
119
+ getSession,
120
+ namespaceKey,
121
+ sessionTopic,
122
+ signClient
123
+ });
124
+ const terminate = async () => cleanupEventEmitter();
125
+ const signTransaction = async ({ transaction, walletAccount }) => {
126
+ assertDefined(walletAccount, "Wallet account is required");
127
+ const { transaction: signedTransaction } = await makeRequest({
128
+ method: "solana_signTransaction",
129
+ params: { transaction: serializeTransaction(transaction) }
130
+ }, walletAccount);
131
+ const decodedTransaction = bs58.decode(signedTransaction);
132
+ if (isVersionedTransaction(transaction)) return { signedTransaction: VersionedTransaction.deserialize(decodedTransaction) };
133
+ return { signedTransaction: Transaction.from(decodedTransaction) };
134
+ };
135
+ const signAllTransactions = async ({ transactions, walletAccount }) => {
136
+ assertDefined(walletAccount, "Wallet account is required");
137
+ const { transactions: signedTransactions } = await makeRequest({
138
+ method: "solana_signAllTransactions",
139
+ params: { transactions: transactions.map(serializeTransaction) }
140
+ }, walletAccount);
141
+ return { signedTransactions: signedTransactions.map((signedTransaction, index) => {
142
+ const originalTransaction = transactions[index];
143
+ const decodedTransaction = bs58.decode(signedTransaction);
144
+ if (isVersionedTransaction(originalTransaction)) return VersionedTransaction.deserialize(decodedTransaction);
145
+ return Transaction.from(decodedTransaction);
146
+ }) };
147
+ };
148
+ const signAndSendTransaction = async ({ transaction, walletAccount }) => {
149
+ assertDefined(walletAccount, "Wallet account is required");
150
+ const { signature } = await makeRequest({
151
+ method: "solana_signAndSendTransaction",
152
+ params: { transaction: serializeTransaction(transaction) }
153
+ }, walletAccount);
154
+ return { signature };
155
+ };
156
+ return {
157
+ chain: "SOL",
158
+ confirmTransaction: (args) => solanaConfirmTransaction(args, client),
159
+ disconnect,
160
+ disconnectWalletAccount,
161
+ get events() {
162
+ return getEventEmitter();
163
+ },
164
+ executeSwapTransaction: (args) => solanaExecuteSwapTransaction(args, client),
165
+ getActiveNetworkId,
166
+ getConnectedAddresses,
167
+ getSession,
168
+ groupKey: formatWalletProviderGroupKey(displayName),
169
+ key,
170
+ metadata: {
171
+ displayName,
172
+ icon: getSession().peer.metadata.icons[0]
173
+ },
174
+ namespaceKey,
175
+ signAllTransactions,
176
+ signAndSendTransaction,
177
+ signMessage,
178
+ signTransaction,
179
+ switchActiveNetwork,
180
+ terminate,
181
+ transferAmount: (args) => solanaTransferAmount(args, client),
182
+ walletProviderType
183
+ };
184
+ };
185
+
186
+ //#endregion
187
+ //#region src/walletConnect/recoverSolanaWalletConnectWalletProviders/recoverSolanaWalletConnectWalletProviders.ts
188
+ /** @not-instrumented */
189
+ const recoverSolanaWalletConnectWalletProviders = async (client) => {
190
+ await waitForProjectSettings(client);
191
+ /**
192
+ * Recreate the wallet providers for all existing Solana sessions
193
+ */
194
+ const sessions = (await getSignClient(client)).session.getAll();
195
+ const currentTime = Math.floor(Date.now() / 1e3);
196
+ for (const session of sessions) {
197
+ if (!("solana" in session.namespaces)) continue;
198
+ if (session.expiry <= currentTime) continue;
199
+ const walletProvider = await createWalletProviderFromWalletConnectSolanaSession({ sessionTopic: session.topic }, client);
200
+ getWalletProviderRegistry(client).register({
201
+ priority: WalletProviderPriority.WALLET_SDK,
202
+ walletProvider
203
+ });
204
+ }
205
+ };
206
+
207
+ //#endregion
208
+ //#region src/walletConnect/addWalletConnectSolanaExtension/addWalletConnectSolanaExtension.ts
209
+ const WALLET_CONNECT_SOLANA_EXTENSION_KEY = "walletConnectSolana";
210
+ /** @not-instrumented */
211
+ const addWalletConnectSolanaExtension = async (client = getDefaultClient$1()) => {
212
+ if (hasExtension$1({ extensionKey: WALLET_CONNECT_SOLANA_EXTENSION_KEY }, client)) return;
213
+ registerExtension({ extensionKey: WALLET_CONNECT_SOLANA_EXTENSION_KEY }, client);
214
+ registerSolanaNetworkProviderBuilder(client);
215
+ await recoverSolanaWalletConnectWalletProviders(client);
216
+ };
217
+
218
+ //#endregion
219
+ //#region src/walletConnect/consts.ts
220
+ const solanaApiChainName = CHAINS_INFO_MAP.SOL.apiChainName;
221
+ /**
222
+ * List of methods that may be requested from Solana wallet applications.
223
+ *
224
+ * Source: https://github.com/reown-com/appkit/blob/fe11a72507af09efcfe89228189aeda04dfe17a9/packages/appkit-utils/src/WCNamespaceUtil.ts#L9
225
+ */
226
+ const solanaMethods = [
227
+ "solana_signMessage",
228
+ "solana_signTransaction",
229
+ "solana_requestAccounts",
230
+ "solana_getAccounts",
231
+ "solana_signAllTransactions",
232
+ "solana_signAndSendTransaction"
233
+ ];
234
+
235
+ //#endregion
236
+ //#region src/walletConnect/connectWithWalletConnectSolana/connectWithWalletConnectSolana.ts
237
+ /** @not-instrumented */
238
+ const connectWithWalletConnectSolana = async ({ addToDynamicWalletAccounts = true } = {}, client = getDefaultClient$1()) => {
239
+ const signClient = await getSignClient(client);
240
+ assertDefined(client.projectSettings, "Project settings unavailable");
241
+ const solanaNetworks = client.projectSettings.networks?.find((network) => network.chainName === solanaApiChainName)?.networks;
242
+ assertDefined(solanaNetworks, "Solana networks not found");
243
+ /**
244
+ * By inspecting the official reown Solana demo, we can see that the genesis hash is used as the chain id.
245
+ * https://lab.reown.com/appkit/?name=multichain-all
246
+ */
247
+ const walletConnectChains = solanaNetworks.map((network) => `solana:${network.genesisHash}`);
248
+ /**
249
+ * A WalletConnect connection request generates a URI and a promise.
250
+ *
251
+ * The URI must be handed to an external wallet application that will use it
252
+ * to establish a connection via a WalletConnect relay server. Typically, this
253
+ * is done by scanning a QR code or deep linking to the wallet application.
254
+ *
255
+ * The promise will resolve when the connection is established.
256
+ */
257
+ const { approval, uri } = await signClient.connect({ optionalNamespaces: { solana: {
258
+ chains: walletConnectChains,
259
+ events: [
260
+ "accountsChanged",
261
+ "chainChanged",
262
+ "disconnected"
263
+ ],
264
+ methods: solanaMethods
265
+ } } });
266
+ assertDefined(uri, "Failed to establish WalletConnect session: no URI returned");
267
+ /**
268
+ * Once the approval promise resolves, the WalletConnect session is established
269
+ * between the wallet application and the dapp (this app).
270
+ */
271
+ const walletAccountsPromise = approval().then(async (session) => {
272
+ assertDefined(session.namespaces.solana, `WalletConnect session did not establish a Solana connection. Found instead: ${Object.keys(session.namespaces).join(", ")}`);
273
+ return importWalletConnectSession({
274
+ addToDynamicWalletAccounts,
275
+ sessionTopic: session.topic,
276
+ walletProviderBuilder: createWalletProviderFromWalletConnectSolanaSession
277
+ }, client);
278
+ });
279
+ return {
280
+ approval: () => walletAccountsPromise,
281
+ uri
282
+ };
283
+ };
284
+
285
+ //#endregion
286
+ //#region src/walletConnect/connectAndVerifyWithWalletConnectSolana/connectAndVerifyWithWalletConnectSolana.ts
287
+ /**
288
+ * Connects to a WalletConnect Solana wallet and verifies ownership through message signing.
289
+ *
290
+ * This function will first perform a regular connect and then verify the wallet accounts via
291
+ * verifyWalletAccount.
292
+ *
293
+ * **Note on connecting and verifying in a single step:**
294
+ * Currently WalletConnect does NOT support the authenticate method for any non eip155 chains.
295
+ * This means there is no way to perform connection and verification in a single step.
296
+ * This can easily be tested by attempting to call `signClient.authenticate` with a solana namespace
297
+ * and checking whether WalletConnect will throw the following error:
298
+ * ```
299
+ * 'Only eip155 namespace is supported for authenticated sessions. Please use .connect() for non-eip155 chains.'
300
+ * ```
301
+ *
302
+ * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
303
+ * @returns A promise that resolves to the connected and verified wallet account.
304
+ * @not-instrumented
305
+ */
306
+ const connectAndVerifyWithWalletConnectSolana = async (client = getDefaultClient()) => {
307
+ const { approval, uri } = await connectWithWalletConnectSolana({ addToDynamicWalletAccounts: false }, client);
308
+ assertDefined(uri, "Failed to establish WalletConnect session: no URI returned");
309
+ /**
310
+ * Once the approval promise resolves, the WalletConnect session is established
311
+ * between the wallet application and the dapp (this app).
312
+ */
313
+ const walletAccountsPromise = approval().then(async ({ walletAccounts }) => {
314
+ for (const walletAccount of walletAccounts) await verifyWalletAccount({ walletAccount }, client);
315
+ return { walletAccounts };
316
+ });
317
+ return {
318
+ approval: () => walletAccountsPromise,
319
+ uri
320
+ };
321
+ };
322
+
323
+ //#endregion
324
+ //#region src/exports/walletConnect.ts
325
+ assertPackageVersion(name, version);
326
+
327
+ //#endregion
328
+ export { addWalletConnectSolanaExtension, connectAndVerifyWithWalletConnectSolana, connectWithWalletConnectSolana };
329
+ //# sourceMappingURL=walletConnect.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"walletConnect.esm.js","names":["methodsThatRequireUserAction: string[]","getActiveNetworkId: WalletConnectSolanaWalletProvider['getActiveNetworkId']","switchActiveNetwork: WalletConnectSolanaWalletProvider['switchActiveNetwork']","disconnect: NonNullable<\n WalletConnectSolanaWalletProvider['disconnect']\n >","disconnectWalletAccount: WalletConnectSolanaWalletProvider['disconnectWalletAccount']","signMessage: WalletConnectSolanaWalletProvider['signMessage']","getConnectedAddresses: WalletConnectSolanaWalletProvider['getConnectedAddresses']","terminate: WalletConnectSolanaWalletProvider['terminate']","signTransaction: WalletConnectSolanaWalletProvider['signTransaction']","signAllTransactions: WalletConnectSolanaWalletProvider['signAllTransactions']","signAndSendTransaction: WalletConnectSolanaWalletProvider['signAndSendTransaction']","getDefaultClient","hasExtension","getDefaultClient","packageName","packageVersion"],"sources":["../src/walletConnect/createWalletProviderFromWalletConnectSolanaSession/createWalletProviderFromWalletConnectSolanaSession.ts","../src/walletConnect/recoverSolanaWalletConnectWalletProviders/recoverSolanaWalletConnectWalletProviders.ts","../src/walletConnect/addWalletConnectSolanaExtension/addWalletConnectSolanaExtension.ts","../src/walletConnect/consts.ts","../src/walletConnect/connectWithWalletConnectSolana/connectWithWalletConnectSolana.ts","../src/walletConnect/connectAndVerifyWithWalletConnectSolana/connectAndVerifyWithWalletConnectSolana.ts","../src/exports/walletConnect.ts"],"sourcesContent":["import {\n type DynamicClient,\n getActiveNetworkData,\n} from '@dynamic-labs-sdk/client';\nimport {\n assertDefined,\n bufferToBase64,\n emitEvent,\n filterDuplicates,\n formatWalletProviderGroupKey,\n formatWalletProviderKey,\n getActiveNetworkIdFromLastKnownRegistry,\n getWalletProviderRegistry,\n switchActiveNetworkInLastKnownRegistry,\n} from '@dynamic-labs-sdk/client/core';\nimport { SessionClosedUnexpectedlyError } from '@dynamic-labs-sdk/wallet-connect';\nimport {\n createWalletConnectSessionEventEmitter,\n getSignClient,\n splitCaip10Token,\n} from '@dynamic-labs-sdk/wallet-connect/core';\nimport { WalletProviderEnum } from '@dynamic-labs/sdk-api-core';\nimport { PublicKey, Transaction, VersionedTransaction } from '@solana/web3.js';\nimport { SDK_ERRORS } from '@walletconnect/utils';\nimport bs58 from 'bs58';\n\nimport type { SolanaWalletAccount } from '../../SolanaWalletAccount.types';\nimport { isVersionedTransaction } from '../../utils/isVersionedTransaction';\nimport { solanaConfirmTransaction } from '../../utils/solanaConfirmTransaction';\nimport { solanaExecuteSwapTransaction } from '../../utils/solanaExecuteSwapTransaction';\nimport { solanaTransferAmount } from '../../utils/solanaTransferAmount';\nimport type { solanaMethods } from '../consts';\nimport type { WalletConnectSolanaWalletProvider } from '../walletConnectSolanaWalletProvider.types';\nimport type {\n AvailableSolanaSessionRequests,\n SolanaSessionRequest,\n SolanaSessionRequestResultMap,\n} from './walletConnectSolanaSessionRequest.types';\n\ntype createWalletProviderFromWalletConnectSolanaSessionParams = {\n sessionTopic: string;\n};\n\n/**\n * The list of Solana request methods that require user action.\n * We will raise a user action requested event for these methods.\n */\nconst methodsThatRequireUserAction: string[] = [\n 'solana_signMessage',\n 'solana_signTransaction',\n 'solana_signAllTransactions',\n 'solana_signAndSendTransaction',\n] satisfies (typeof solanaMethods)[number][];\n\n/** @not-instrumented */\nexport const createWalletProviderFromWalletConnectSolanaSession = async (\n { sessionTopic }: createWalletProviderFromWalletConnectSolanaSessionParams,\n client: DynamicClient\n): Promise<WalletConnectSolanaWalletProvider> => {\n const signClient = await getSignClient(client);\n\n const getSession = () => {\n const session = signClient.session.get(sessionTopic);\n\n if (!session) {\n void disconnect();\n\n throw new SessionClosedUnexpectedlyError({\n sessionTopic,\n walletDisplayName: displayName,\n });\n }\n\n return session;\n };\n\n const displayName = getSession().peer.metadata.name;\n\n const namespaceKey = 'solana';\n\n const walletProviderType = WalletProviderEnum.WalletConnect;\n\n const key = formatWalletProviderKey({\n chain: 'SOL',\n displayName,\n suffix: sessionTopic,\n walletProviderType,\n });\n\n const getActiveNetworkId: WalletConnectSolanaWalletProvider['getActiveNetworkId'] =\n async () => {\n // Assert the session is still valid\n getSession();\n\n return await getActiveNetworkIdFromLastKnownRegistry({\n client,\n walletProviderKey: key,\n });\n };\n\n const switchActiveNetwork: WalletConnectSolanaWalletProvider['switchActiveNetwork'] =\n async ({ networkId }) => {\n // Assert the session is still valid\n getSession();\n\n await switchActiveNetworkInLastKnownRegistry({\n client,\n networkId,\n walletProviderKey: key,\n });\n };\n\n const disconnect: NonNullable<\n WalletConnectSolanaWalletProvider['disconnect']\n > = async () => {\n await signClient.disconnect({\n reason: SDK_ERRORS.USER_DISCONNECTED,\n topic: sessionTopic,\n });\n\n const walletProviderRegistry = getWalletProviderRegistry(client);\n\n walletProviderRegistry.unregister(key);\n };\n\n /**\n * We actually clear up the entire WC session and its wallet provider\n */\n const disconnectWalletAccount: WalletConnectSolanaWalletProvider['disconnectWalletAccount'] =\n async () => disconnect();\n\n /**\n * Helper function to make WalletConnect requests\n */\n const makeRequest = async <T extends AvailableSolanaSessionRequests>(\n request: SolanaSessionRequest<T>,\n walletAccount: SolanaWalletAccount\n ): Promise<SolanaSessionRequestResultMap[T]> => {\n assertDefined(walletAccount, 'Wallet account is required');\n\n const session = getSession();\n\n const peerMetadata = session.peer.metadata;\n\n if (methodsThatRequireUserAction.includes(request.method)) {\n emitEvent(\n {\n args: {\n walletMetadata: peerMetadata,\n walletProviderKey: key,\n },\n event: 'walletConnectUserActionRequested',\n },\n client\n );\n }\n\n const { networkData } = await getActiveNetworkData(\n { walletAccount },\n client\n );\n\n assertDefined(\n networkData,\n `Failed to get network data for wallet account ${walletAccount.address}`\n );\n\n return signClient.request<SolanaSessionRequestResultMap[T]>({\n chainId: `${namespaceKey}:${networkData.genesisHash}`,\n request,\n topic: sessionTopic,\n });\n };\n\n /**\n * Serializes a transaction for WalletConnect\n * Reference: https://github.com/reown-com/appkit/blob/552b6b39b46e6c604b4d7d290634b9fa96bf7ed0/packages/adapters/solana/src/providers/AuthProvider.ts#L193\n */\n const serializeTransaction = (\n transaction: Transaction | VersionedTransaction\n ) => {\n const serialized = transaction.serialize({\n requireAllSignatures: false,\n verifySignatures: false,\n });\n\n return bs58.encode(new Uint8Array(serialized));\n };\n\n const signMessage: WalletConnectSolanaWalletProvider['signMessage'] = async ({\n message,\n walletAccount,\n }) => {\n assertDefined(walletAccount, 'Wallet account is required');\n\n const publicKey = new PublicKey(walletAccount.address);\n\n const { signature } = await makeRequest(\n {\n method: 'solana_signMessage',\n params: { message, pubkey: publicKey.toBase58() },\n },\n walletAccount\n );\n\n const signatureBytes = bs58.decode(signature);\n\n return {\n signature: bufferToBase64(signatureBytes),\n };\n };\n\n const getConnectedAddresses: WalletConnectSolanaWalletProvider['getConnectedAddresses'] =\n async () => {\n const addresses = filterDuplicates(\n getSession().namespaces[namespaceKey].accounts.map(\n (account) => splitCaip10Token(account).address\n )\n );\n\n return { addresses };\n };\n\n const { cleanupEventEmitter, getEventEmitter } =\n createWalletConnectSessionEventEmitter({\n getSession,\n namespaceKey,\n sessionTopic,\n signClient,\n });\n\n const terminate: WalletConnectSolanaWalletProvider['terminate'] = async () =>\n cleanupEventEmitter();\n\n const signTransaction: WalletConnectSolanaWalletProvider['signTransaction'] =\n async ({ transaction, walletAccount }) => {\n assertDefined(walletAccount, 'Wallet account is required');\n\n type T = typeof transaction;\n\n const serializedTransaction = serializeTransaction(transaction);\n\n // Reference: https://github.com/reown-com/appkit/blob/552b6b39b46e6c604b4d7d290634b9fa96bf7ed0/packages/adapters/solana/src/providers/AuthProvider.ts#L98\n const { transaction: signedTransaction } = await makeRequest(\n {\n method: 'solana_signTransaction',\n params: { transaction: serializedTransaction },\n },\n walletAccount\n );\n\n const decodedTransaction = bs58.decode(signedTransaction);\n\n if (isVersionedTransaction(transaction)) {\n return {\n signedTransaction: VersionedTransaction.deserialize(\n decodedTransaction\n ) as T,\n };\n }\n\n return { signedTransaction: Transaction.from(decodedTransaction) as T };\n };\n\n const signAllTransactions: WalletConnectSolanaWalletProvider['signAllTransactions'] =\n async ({ transactions, walletAccount }) => {\n assertDefined(walletAccount, 'Wallet account is required');\n\n type T = (typeof transactions)[number];\n\n const serializedTransactions = transactions.map(serializeTransaction);\n\n // Reference: https://github.com/reown-com/appkit/blob/552b6b39b46e6c604b4d7d290634b9fa96bf7ed0/packages/adapters/solana/src/providers/AuthProvider.ts#L143\n const { transactions: signedTransactions } = await makeRequest(\n {\n method: 'solana_signAllTransactions',\n params: { transactions: serializedTransactions },\n },\n walletAccount\n );\n\n const signedTransactionsArray = signedTransactions.map(\n (signedTransaction, index) => {\n const originalTransaction = transactions[index];\n\n const decodedTransaction = bs58.decode(signedTransaction);\n\n if (isVersionedTransaction(originalTransaction)) {\n return VersionedTransaction.deserialize(decodedTransaction) as T;\n }\n\n return Transaction.from(decodedTransaction) as T;\n }\n );\n\n return { signedTransactions: signedTransactionsArray };\n };\n\n const signAndSendTransaction: WalletConnectSolanaWalletProvider['signAndSendTransaction'] =\n async ({ transaction, walletAccount }) => {\n assertDefined(walletAccount, 'Wallet account is required');\n\n const serializedTransaction = serializeTransaction(transaction);\n\n // Reference: https://github.com/reown-com/appkit/blob/552b6b39b46e6c604b4d7d290634b9fa96bf7ed0/packages/adapters/solana/src/providers/AuthProvider.ts#L114\n const { signature } = await makeRequest(\n {\n method: 'solana_signAndSendTransaction',\n params: { transaction: serializedTransaction },\n },\n walletAccount\n );\n\n return { signature };\n };\n\n return {\n chain: 'SOL',\n confirmTransaction: (args) => solanaConfirmTransaction(args, client),\n disconnect,\n disconnectWalletAccount,\n get events() {\n return getEventEmitter();\n },\n executeSwapTransaction: (args) =>\n solanaExecuteSwapTransaction(args, client),\n getActiveNetworkId,\n getConnectedAddresses,\n getSession,\n groupKey: formatWalletProviderGroupKey(displayName),\n key,\n metadata: {\n displayName,\n icon: getSession().peer.metadata.icons[0],\n },\n namespaceKey,\n signAllTransactions,\n signAndSendTransaction,\n signMessage,\n signTransaction,\n switchActiveNetwork,\n terminate,\n transferAmount: (args) => solanaTransferAmount(args, client),\n walletProviderType,\n };\n};\n","import type { DynamicClient } from '@dynamic-labs-sdk/client';\nimport {\n WalletProviderPriority,\n getWalletProviderRegistry,\n waitForProjectSettings,\n} from '@dynamic-labs-sdk/client/core';\nimport { getSignClient } from '@dynamic-labs-sdk/wallet-connect/core';\n\nimport { createWalletProviderFromWalletConnectSolanaSession } from '../createWalletProviderFromWalletConnectSolanaSession';\n\n/** @not-instrumented */\nexport const recoverSolanaWalletConnectWalletProviders = async (\n client: DynamicClient\n) => {\n await waitForProjectSettings(client);\n\n const signClient = await getSignClient(client);\n\n /**\n * Recreate the wallet providers for all existing Solana sessions\n */\n const sessions = signClient.session.getAll();\n\n const currentTime = Math.floor(Date.now() / 1000);\n\n for (const session of sessions) {\n if (!('solana' in session.namespaces)) {\n continue;\n }\n\n if (session.expiry <= currentTime) {\n continue;\n }\n\n const walletProvider =\n await createWalletProviderFromWalletConnectSolanaSession(\n {\n sessionTopic: session.topic,\n },\n client\n );\n\n getWalletProviderRegistry(client).register({\n priority: WalletProviderPriority.WALLET_SDK,\n walletProvider,\n });\n }\n};\n","import { getDefaultClient, hasExtension } from '@dynamic-labs-sdk/client';\nimport { registerExtension } from '@dynamic-labs-sdk/client/core';\n\nimport { registerSolanaNetworkProviderBuilder } from '../../registerSolanaNetworkProviderBuilder';\nimport { recoverSolanaWalletConnectWalletProviders } from '../recoverSolanaWalletConnectWalletProviders';\n\nexport const WALLET_CONNECT_SOLANA_EXTENSION_KEY = 'walletConnectSolana';\n\n/** @not-instrumented */\nexport const addWalletConnectSolanaExtension = async (\n client = getDefaultClient()\n) => {\n if (\n hasExtension({ extensionKey: WALLET_CONNECT_SOLANA_EXTENSION_KEY }, client)\n ) {\n return;\n }\n\n registerExtension(\n { extensionKey: WALLET_CONNECT_SOLANA_EXTENSION_KEY },\n client\n );\n\n registerSolanaNetworkProviderBuilder(client);\n\n await recoverSolanaWalletConnectWalletProviders(client);\n};\n","import { CHAINS_INFO_MAP } from '@dynamic-labs-sdk/client/core';\n\nexport const solanaApiChainName = CHAINS_INFO_MAP.SOL.apiChainName;\n\n/**\n * List of methods that may be requested from Solana wallet applications.\n *\n * Source: https://github.com/reown-com/appkit/blob/fe11a72507af09efcfe89228189aeda04dfe17a9/packages/appkit-utils/src/WCNamespaceUtil.ts#L9\n */\nexport const solanaMethods = [\n 'solana_signMessage',\n 'solana_signTransaction',\n 'solana_requestAccounts',\n 'solana_getAccounts',\n 'solana_signAllTransactions',\n 'solana_signAndSendTransaction',\n] as const;\n\n/**\n * List of blockchain hashes for all solana networks.\n *\n * You will find the main hashes here: https://namespaces.chainagnostic.org/solana/caip10\n * However, this list also includes the legacy hashes for mainnet and devnet for maximum compatibility.\n * You will find the legacy hashes here: https://chainagnostic.org/CAIPs/caip-30\n *\n * Note that this list was not originally fetched from those sources, however. Instead, we manually inspected\n * which networks were passed as argument to the signClient.connect method in the official reown Solana demo\n * which you can find here: https://lab.reown.com/appkit/?name=multichain-all\n */\nexport const solanaNetworks = [\n // mainnet\n 'solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp',\n // legacy mainnet\n 'solana:4sGjMW1sUnHzSxGspuhpqLDx6wiyjNtZ',\n // testnet\n 'solana:4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z',\n // devnet\n 'solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1',\n // legacy devnet\n 'solana:8E9rvCKLFQia2Y35HXjjpWzj8weVo44K',\n] as const;\n","import { getDefaultClient } from '@dynamic-labs-sdk/client';\nimport { assertDefined } from '@dynamic-labs-sdk/client/core';\nimport type { WalletConnectConnectionResult } from '@dynamic-labs-sdk/wallet-connect';\nimport {\n getSignClient,\n importWalletConnectSession,\n} from '@dynamic-labs-sdk/wallet-connect/core';\n\nimport { solanaApiChainName, solanaMethods } from '../consts';\nimport { createWalletProviderFromWalletConnectSolanaSession } from '../createWalletProviderFromWalletConnectSolanaSession';\n\ntype ConnectWithWalletConnectSolanaParams = {\n /**\n * Whether this session's wallet accounts should be added to the dynamic's wallet accounts.\n */\n addToDynamicWalletAccounts?: boolean;\n};\n\n/** @not-instrumented */\nexport const connectWithWalletConnectSolana = async (\n {\n addToDynamicWalletAccounts = true,\n }: ConnectWithWalletConnectSolanaParams = {},\n client = getDefaultClient()\n): Promise<WalletConnectConnectionResult> => {\n const signClient = await getSignClient(client);\n\n assertDefined(client.projectSettings, 'Project settings unavailable');\n\n const solanaNetworks = client.projectSettings.networks?.find(\n (network) => network.chainName === solanaApiChainName\n )?.networks;\n\n assertDefined(solanaNetworks, 'Solana networks not found');\n\n /**\n * By inspecting the official reown Solana demo, we can see that the genesis hash is used as the chain id.\n * https://lab.reown.com/appkit/?name=multichain-all\n */\n const walletConnectChains = solanaNetworks.map(\n (network) => `solana:${network.genesisHash}`\n );\n\n /**\n * A WalletConnect connection request generates a URI and a promise.\n *\n * The URI must be handed to an external wallet application that will use it\n * to establish a connection via a WalletConnect relay server. Typically, this\n * is done by scanning a QR code or deep linking to the wallet application.\n *\n * The promise will resolve when the connection is established.\n */\n const { approval, uri } = await signClient.connect({\n optionalNamespaces: {\n solana: {\n chains: walletConnectChains,\n events: ['accountsChanged', 'chainChanged', 'disconnected'],\n methods: solanaMethods as unknown as string[],\n },\n },\n });\n\n assertDefined(\n uri,\n 'Failed to establish WalletConnect session: no URI returned'\n );\n\n /**\n * Once the approval promise resolves, the WalletConnect session is established\n * between the wallet application and the dapp (this app).\n */\n const walletAccountsPromise = approval().then(async (session) => {\n assertDefined(\n session.namespaces.solana,\n `WalletConnect session did not establish a Solana connection. Found instead: ${Object.keys(\n session.namespaces\n ).join(', ')}`\n );\n\n return importWalletConnectSession(\n {\n addToDynamicWalletAccounts,\n sessionTopic: session.topic,\n walletProviderBuilder:\n createWalletProviderFromWalletConnectSolanaSession,\n },\n client\n );\n });\n\n return { approval: () => walletAccountsPromise, uri };\n};\n","import { verifyWalletAccount } from '@dynamic-labs-sdk/client';\nimport { assertDefined, getDefaultClient } from '@dynamic-labs-sdk/client/core';\nimport type { WalletConnectConnectionResult } from '@dynamic-labs-sdk/wallet-connect';\n\nimport { connectWithWalletConnectSolana } from '../connectWithWalletConnectSolana';\n\n/**\n * Connects to a WalletConnect Solana wallet and verifies ownership through message signing.\n *\n * This function will first perform a regular connect and then verify the wallet accounts via\n * verifyWalletAccount.\n *\n * **Note on connecting and verifying in a single step:**\n * Currently WalletConnect does NOT support the authenticate method for any non eip155 chains.\n * This means there is no way to perform connection and verification in a single step.\n * This can easily be tested by attempting to call `signClient.authenticate` with a solana namespace\n * and checking whether WalletConnect will throw the following error:\n * ```\n * 'Only eip155 namespace is supported for authenticated sessions. Please use .connect() for non-eip155 chains.'\n * ```\n *\n * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.\n * @returns A promise that resolves to the connected and verified wallet account.\n * @not-instrumented\n */\nexport const connectAndVerifyWithWalletConnectSolana = async (\n client = getDefaultClient()\n): Promise<WalletConnectConnectionResult> => {\n const { approval, uri } = await connectWithWalletConnectSolana(\n // We don't want to add the wallet accounts to the dynamic's wallet accounts state\n // while we are still verifying them.\n { addToDynamicWalletAccounts: false },\n client\n );\n\n assertDefined(\n uri,\n 'Failed to establish WalletConnect session: no URI returned'\n );\n\n /**\n * Once the approval promise resolves, the WalletConnect session is established\n * between the wallet application and the dapp (this app).\n */\n const walletAccountsPromise = approval().then(async ({ walletAccounts }) => {\n // This should not be concurrent because the first will be a verify and the rest will be a link\n for (const walletAccount of walletAccounts) {\n await verifyWalletAccount({ walletAccount }, client);\n }\n\n return { walletAccounts };\n });\n\n return { approval: () => walletAccountsPromise, uri };\n};\n","import { assertPackageVersion } from '@dynamic-labs-sdk/assert-package-version';\n\nimport {\n name as packageName,\n version as packageVersion,\n} from '../../package.json';\nassertPackageVersion(packageName, packageVersion);\n\nexport { addWalletConnectSolanaExtension } from '../walletConnect/addWalletConnectSolanaExtension';\nexport { connectAndVerifyWithWalletConnectSolana } from '../walletConnect/connectAndVerifyWithWalletConnectSolana';\nexport { connectWithWalletConnectSolana } from '../walletConnect/connectWithWalletConnectSolana';\nexport type { WalletConnectSolanaWalletProvider } from '../walletConnect/walletConnectSolanaWalletProvider.types';\n"],"mappings":"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"}
@@ -1,5 +1,6 @@
1
- const require_addSolanaWalletStandardExtension = require('./addSolanaWalletStandardExtension-BYIsol74.cjs.js');
2
- const require_solanaTransferAmount = require('./solanaTransferAmount-BIEZ3hn_.cjs.js');
1
+ const require_chunk = require('./chunk-BFVW7ptc.cjs.js');
2
+ const require_solanaTransferAmount = require('./solanaTransferAmount-d27ooag0.cjs.js');
3
+ const require_addSolanaWalletStandardExtension = require('./addSolanaWalletStandardExtension-DrbtTeR3.cjs.js');
3
4
  let _dynamic_labs_sdk_assert_package_version = require("@dynamic-labs-sdk/assert-package-version");
4
5
 
5
6
  //#region src/exports/walletStandard.ts
@@ -1 +1 @@
1
- {"version":3,"file":"walletStandard.cjs.js","names":["packageName","packageVersion"],"sources":["../src/exports/walletStandard.ts"],"sourcesContent":["import { assertPackageVersion } from '@dynamic-labs-sdk/assert-package-version';\n\nimport {\n name as packageName,\n version as packageVersion,\n} from '../../package.json';\nassertPackageVersion(packageName, packageVersion);\n\nexport { addSolanaWalletStandardExtension } from '../walletStandard/addSolanaWalletStandardExtension';\n"],"mappings":";;;;;mEAMqBA,mCAAaC,qCAAe"}
1
+ {"version":3,"file":"walletStandard.cjs.js","names":["packageName","packageVersion"],"sources":["../src/exports/walletStandard.ts"],"sourcesContent":["import { assertPackageVersion } from '@dynamic-labs-sdk/assert-package-version';\n\nimport {\n name as packageName,\n version as packageVersion,\n} from '../../package.json';\nassertPackageVersion(packageName, packageVersion);\n\nexport { addSolanaWalletStandardExtension } from '../walletStandard/addSolanaWalletStandardExtension';\n"],"mappings":";;;;;;mEAMqBA,mCAAaC,qCAAe"}
@@ -1,5 +1,5 @@
1
- import { d as name, f as version } from "./solanaTransferAmount-BvLEGA-x.esm.js";
2
- import { t as addSolanaWalletStandardExtension } from "./addSolanaWalletStandardExtension-B26Xpl2O.esm.js";
1
+ import { d as name, f as version } from "./solanaTransferAmount-EGugT484.esm.js";
2
+ import { t as addSolanaWalletStandardExtension } from "./addSolanaWalletStandardExtension-B3sMU6WM.esm.js";
3
3
  import { assertPackageVersion } from "@dynamic-labs-sdk/assert-package-version";
4
4
 
5
5
  //#region src/exports/walletStandard.ts
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dynamic-labs-sdk/solana",
3
- "version": "0.23.2",
3
+ "version": "0.23.4",
4
4
  "type": "module",
5
5
  "main": "./dist/index.cjs.js",
6
6
  "module": "./dist/index.esm.js",
@@ -32,7 +32,7 @@
32
32
  }
33
33
  },
34
34
  "dependencies": {
35
- "@dynamic-labs/sdk-api-core": "0.0.923",
35
+ "@dynamic-labs/sdk-api-core": "0.0.925",
36
36
  "@solana/spl-token": "0.4.14",
37
37
  "@solana/web3.js": "1.98.1",
38
38
  "@wallet-standard/app": "1.0.1",
@@ -44,9 +44,9 @@
44
44
  "eventemitter3": "5.0.1",
45
45
  "tweetnacl": "1.0.3",
46
46
  "zod": "4.0.5",
47
- "@dynamic-labs-sdk/assert-package-version": "0.23.2",
48
- "@dynamic-labs-sdk/wallet-connect": "0.23.2",
49
- "@dynamic-labs-sdk/client": "0.23.2"
47
+ "@dynamic-labs-sdk/assert-package-version": "0.23.4",
48
+ "@dynamic-labs-sdk/client": "0.23.4",
49
+ "@dynamic-labs-sdk/wallet-connect": "0.23.4"
50
50
  },
51
51
  "devDependencies": {
52
52
  "vitest": "1.6.1"