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