@reown/appkit-solana-react-native 2.0.0-alpha.0 → 2.0.0-alpha.2
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/lib/commonjs/adapter.js +120 -2
- package/lib/commonjs/adapter.js.map +1 -1
- package/lib/commonjs/connectors/PhantomConnector.js +244 -0
- package/lib/commonjs/connectors/PhantomConnector.js.map +1 -0
- package/lib/commonjs/helpers.js +9 -1
- package/lib/commonjs/helpers.js.map +1 -1
- package/lib/commonjs/index.js +7 -0
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/package.json +1 -0
- package/lib/commonjs/providers/PhantomProvider.js +391 -0
- package/lib/commonjs/providers/PhantomProvider.js.map +1 -0
- package/lib/commonjs/types.js +6 -0
- package/lib/commonjs/types.js.map +1 -0
- package/lib/commonjs/utils/createSendTransaction.js +44 -0
- package/lib/commonjs/utils/createSendTransaction.js.map +1 -0
- package/lib/module/adapter.js +121 -2
- package/lib/module/adapter.js.map +1 -1
- package/lib/module/connectors/PhantomConnector.js +238 -0
- package/lib/module/connectors/PhantomConnector.js.map +1 -0
- package/lib/module/helpers.js +11 -1
- package/lib/module/helpers.js.map +1 -1
- package/lib/module/index.js +9 -2
- package/lib/module/index.js.map +1 -1
- package/lib/module/providers/PhantomProvider.js +385 -0
- package/lib/module/providers/PhantomProvider.js.map +1 -0
- package/lib/module/types.js +4 -0
- package/lib/module/types.js.map +1 -0
- package/lib/module/utils/createSendTransaction.js +41 -0
- package/lib/module/utils/createSendTransaction.js.map +1 -0
- package/lib/typescript/adapter.d.ts +10 -0
- package/lib/typescript/adapter.d.ts.map +1 -1
- package/lib/typescript/connectors/PhantomConnector.d.ts +27 -0
- package/lib/typescript/connectors/PhantomConnector.d.ts.map +1 -0
- package/lib/typescript/helpers.d.ts +8 -7
- package/lib/typescript/helpers.d.ts.map +1 -1
- package/lib/typescript/index.d.ts +3 -2
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/providers/PhantomProvider.d.ts +37 -0
- package/lib/typescript/providers/PhantomProvider.d.ts.map +1 -0
- package/lib/typescript/types.d.ts +96 -0
- package/lib/typescript/types.d.ts.map +1 -0
- package/lib/typescript/utils/createSendTransaction.d.ts +10 -0
- package/lib/typescript/utils/createSendTransaction.d.ts.map +1 -0
- package/package.json +13 -5
- package/src/adapter.ts +152 -6
- package/src/connectors/PhantomConnector.ts +329 -0
- package/src/helpers.ts +9 -7
- package/src/index.ts +8 -0
- package/src/providers/PhantomProvider.ts +532 -0
- package/src/types.ts +131 -0
- package/src/utils/createSendTransaction.ts +57 -0
- package/src/index.tsx +0 -2
|
@@ -0,0 +1,238 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { WalletConnector, solana, solanaDevnet, solanaTestnet, ConstantsUtil } from '@reown/appkit-common-react-native';
|
|
4
|
+
import nacl from 'tweetnacl';
|
|
5
|
+
import bs58 from 'bs58';
|
|
6
|
+
import { PhantomProvider, SOLANA_SIGNING_METHODS } from '../providers/PhantomProvider';
|
|
7
|
+
const SOLANA_CLUSTER_TO_CHAIN_ID_PART = {
|
|
8
|
+
'mainnet-beta': solana.id,
|
|
9
|
+
'testnet': solanaTestnet.id,
|
|
10
|
+
'devnet': solanaDevnet.id
|
|
11
|
+
};
|
|
12
|
+
const PHANTOM_CONNECTOR_STORAGE_KEY = '@appkit/phantom-connector-data';
|
|
13
|
+
const DAPP_KEYPAIR_STORAGE_KEY = '@appkit/phantom-dapp-secret-key';
|
|
14
|
+
export class PhantomConnector extends WalletConnector {
|
|
15
|
+
currentCaipNetworkId = null;
|
|
16
|
+
static SUPPORTED_NAMESPACE = 'solana';
|
|
17
|
+
constructor(config) {
|
|
18
|
+
super({
|
|
19
|
+
type: 'phantom'
|
|
20
|
+
});
|
|
21
|
+
this.config = config ?? {
|
|
22
|
+
cluster: 'mainnet-beta'
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
async init(ops) {
|
|
26
|
+
super.init(ops);
|
|
27
|
+
this.storage = ops.storage;
|
|
28
|
+
await this.initializeKeyPair();
|
|
29
|
+
const appScheme = ops.metadata.redirect?.universal ?? ops.metadata.redirect?.native;
|
|
30
|
+
if (!appScheme) {
|
|
31
|
+
throw new Error('Phantom Connector: No redirect link found in metadata. Please add redirect.universal or redirect.native to the metadata.');
|
|
32
|
+
}
|
|
33
|
+
const providerConfig = {
|
|
34
|
+
appScheme,
|
|
35
|
+
dappUrl: ops.metadata.url,
|
|
36
|
+
storage: ops.storage,
|
|
37
|
+
dappEncryptionKeyPair: this.dappEncryptionKeyPair
|
|
38
|
+
};
|
|
39
|
+
this.provider = new PhantomProvider(providerConfig);
|
|
40
|
+
await this.restoreSession();
|
|
41
|
+
}
|
|
42
|
+
async initializeKeyPair() {
|
|
43
|
+
try {
|
|
44
|
+
const secretKeyB58 = await this.getStorage().getItem(DAPP_KEYPAIR_STORAGE_KEY);
|
|
45
|
+
if (secretKeyB58) {
|
|
46
|
+
const secretKey = bs58.decode(secretKeyB58);
|
|
47
|
+
this.dappEncryptionKeyPair = nacl.box.keyPair.fromSecretKey(secretKey);
|
|
48
|
+
} else {
|
|
49
|
+
const newKeyPair = nacl.box.keyPair();
|
|
50
|
+
this.dappEncryptionKeyPair = newKeyPair;
|
|
51
|
+
await this.getStorage().setItem(DAPP_KEYPAIR_STORAGE_KEY, bs58.encode(newKeyPair.secretKey));
|
|
52
|
+
}
|
|
53
|
+
} catch (error) {
|
|
54
|
+
// disconnect and clear session
|
|
55
|
+
await this.disconnect();
|
|
56
|
+
throw error;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
async connect(opts) {
|
|
60
|
+
if (this.isConnected()) {
|
|
61
|
+
return this.namespaces;
|
|
62
|
+
}
|
|
63
|
+
const defaultChain = opts?.defaultChain?.split(':')?.[0] === 'solana' ? opts?.defaultChain?.split(':')[1] : opts?.namespaces?.['solana']?.chains?.[0]?.split(':')[1];
|
|
64
|
+
const requestedCluster = this.config.cluster ?? Object.keys(SOLANA_CLUSTER_TO_CHAIN_ID_PART).find(key => SOLANA_CLUSTER_TO_CHAIN_ID_PART[key] === defaultChain);
|
|
65
|
+
try {
|
|
66
|
+
const connectResult = await this.getProvider().connect({
|
|
67
|
+
cluster: requestedCluster
|
|
68
|
+
});
|
|
69
|
+
const solanaChainIdPart = SOLANA_CLUSTER_TO_CHAIN_ID_PART[connectResult.cluster];
|
|
70
|
+
if (!solanaChainIdPart) {
|
|
71
|
+
throw new Error(`Phantom Connect: Internal - Unknown cluster mapping for ${connectResult.cluster}`);
|
|
72
|
+
}
|
|
73
|
+
this.currentCaipNetworkId = `solana:${solanaChainIdPart}`;
|
|
74
|
+
this.wallet = ConstantsUtil.PHANTOM_CUSTOM_WALLET;
|
|
75
|
+
const userPublicKey = this.getProvider().getUserPublicKey();
|
|
76
|
+
if (!userPublicKey) {
|
|
77
|
+
throw new Error('Phantom Connect: Provider failed to return a user public key.');
|
|
78
|
+
}
|
|
79
|
+
const caipAddress = `${this.currentCaipNetworkId}:${userPublicKey}`;
|
|
80
|
+
this.namespaces = {
|
|
81
|
+
[PhantomConnector.SUPPORTED_NAMESPACE]: {
|
|
82
|
+
accounts: [caipAddress],
|
|
83
|
+
methods: Object.values(SOLANA_SIGNING_METHODS),
|
|
84
|
+
events: [],
|
|
85
|
+
chains: [this.currentCaipNetworkId]
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
await this.saveSession(); // Save connector-specific session on successful connect
|
|
89
|
+
|
|
90
|
+
return this.namespaces;
|
|
91
|
+
} catch (error) {
|
|
92
|
+
this.clearSession();
|
|
93
|
+
throw error;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
async disconnect() {
|
|
97
|
+
try {
|
|
98
|
+
if (this.isConnected()) {
|
|
99
|
+
await super.disconnect();
|
|
100
|
+
}
|
|
101
|
+
} catch (error) {
|
|
102
|
+
// console.warn(`PhantomConnector: Error during provider disconnect: ${error.message}. Proceeding with local clear.`);
|
|
103
|
+
}
|
|
104
|
+
await this.clearSession();
|
|
105
|
+
}
|
|
106
|
+
async clearSession() {
|
|
107
|
+
this.namespaces = undefined;
|
|
108
|
+
this.wallet = undefined;
|
|
109
|
+
this.currentCaipNetworkId = null;
|
|
110
|
+
await this.clearSessionStorage();
|
|
111
|
+
}
|
|
112
|
+
getProvider() {
|
|
113
|
+
if (!this.provider) {
|
|
114
|
+
throw new Error('Phantom Connector: Provider not initialized. Call init() first.');
|
|
115
|
+
}
|
|
116
|
+
return this.provider;
|
|
117
|
+
}
|
|
118
|
+
getStorage() {
|
|
119
|
+
if (!this.storage) {
|
|
120
|
+
throw new Error('Phantom Connector: Storage not initialized. Call init() first.');
|
|
121
|
+
}
|
|
122
|
+
return this.storage;
|
|
123
|
+
}
|
|
124
|
+
getNamespaces() {
|
|
125
|
+
if (!this.namespaces) {
|
|
126
|
+
throw new Error('Phantom Connector: Not connected. Call connect() first.');
|
|
127
|
+
}
|
|
128
|
+
return this.namespaces;
|
|
129
|
+
}
|
|
130
|
+
getChainId(namespace) {
|
|
131
|
+
if (namespace === PhantomConnector.SUPPORTED_NAMESPACE) {
|
|
132
|
+
return this.currentCaipNetworkId ?? undefined;
|
|
133
|
+
}
|
|
134
|
+
return undefined;
|
|
135
|
+
}
|
|
136
|
+
getProperties() {
|
|
137
|
+
return this.properties;
|
|
138
|
+
}
|
|
139
|
+
getWalletInfo() {
|
|
140
|
+
if (!this.isConnected()) {
|
|
141
|
+
return undefined;
|
|
142
|
+
}
|
|
143
|
+
return this.wallet;
|
|
144
|
+
}
|
|
145
|
+
isConnected() {
|
|
146
|
+
// Rely solely on the provider as the source of truth for connection status.
|
|
147
|
+
return this.getProvider().isConnected() && !!this.getProvider().getUserPublicKey();
|
|
148
|
+
}
|
|
149
|
+
async switchNetwork(network) {
|
|
150
|
+
const targetClusterName = Object.keys(SOLANA_CLUSTER_TO_CHAIN_ID_PART).find(key => SOLANA_CLUSTER_TO_CHAIN_ID_PART[key] === network.id);
|
|
151
|
+
if (!targetClusterName) {
|
|
152
|
+
throw new Error(`Cannot switch to unsupported network ID: ${network.id}`);
|
|
153
|
+
}
|
|
154
|
+
const currentClusterName = Object.keys(SOLANA_CLUSTER_TO_CHAIN_ID_PART).find(key => `solana:${SOLANA_CLUSTER_TO_CHAIN_ID_PART[key]}` === this.currentCaipNetworkId);
|
|
155
|
+
if (targetClusterName === currentClusterName && this.isConnected()) {
|
|
156
|
+
return Promise.resolve();
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
// Phantom doesn't provide a way to switch network, so we need to disconnect and reconnect.
|
|
160
|
+
await this.disconnect(); // Clear current session
|
|
161
|
+
|
|
162
|
+
// Create a temporary options object to guide the new connection
|
|
163
|
+
const tempConnectOpts = {
|
|
164
|
+
defaultChain: `solana:${SOLANA_CLUSTER_TO_CHAIN_ID_PART[targetClusterName]}`
|
|
165
|
+
};
|
|
166
|
+
|
|
167
|
+
// Attempt to connect to the new cluster
|
|
168
|
+
// The connect method will use the defaultChain from opts to determine the cluster.
|
|
169
|
+
await this.connect(tempConnectOpts);
|
|
170
|
+
this.getProvider().emit('chainChanged', network.id);
|
|
171
|
+
|
|
172
|
+
// Verify if the connection was successful and to the correct new network
|
|
173
|
+
if (!this.isConnected() || this.getChainId(PhantomConnector.SUPPORTED_NAMESPACE) !== tempConnectOpts.defaultChain) {
|
|
174
|
+
throw new Error(`Failed to switch network to ${targetClusterName}. Please try connecting manually.`);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
// Orchestrates session restoration
|
|
179
|
+
async restoreSession() {
|
|
180
|
+
try {
|
|
181
|
+
const providerSession = await this.getProvider().restoreSession();
|
|
182
|
+
if (!providerSession) {
|
|
183
|
+
return false;
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
// If provider session is restored, try to restore connector data
|
|
187
|
+
const connectorData = await this.getStorage().getItem(PHANTOM_CONNECTOR_STORAGE_KEY);
|
|
188
|
+
if (!connectorData) {
|
|
189
|
+
return false; // Provider session exists but connector data is missing
|
|
190
|
+
}
|
|
191
|
+
this.namespaces = connectorData.namespaces;
|
|
192
|
+
this.wallet = connectorData.wallet;
|
|
193
|
+
this.currentCaipNetworkId = connectorData.currentCaipNetworkId;
|
|
194
|
+
|
|
195
|
+
// await this.initializeKeyPair();
|
|
196
|
+
|
|
197
|
+
// Final validation
|
|
198
|
+
if (this.isConnected()) {
|
|
199
|
+
return true;
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
// If validation fails, something is out of sync. Clear everything.
|
|
203
|
+
await this.disconnect();
|
|
204
|
+
return false;
|
|
205
|
+
} catch (error) {
|
|
206
|
+
// On any error, disconnect to ensure a clean state
|
|
207
|
+
await this.disconnect();
|
|
208
|
+
return false;
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
// Saves only connector-specific data
|
|
213
|
+
async saveSession() {
|
|
214
|
+
if (!this.namespaces || !this.wallet || !this.currentCaipNetworkId) {
|
|
215
|
+
return;
|
|
216
|
+
}
|
|
217
|
+
const connectorData = {
|
|
218
|
+
namespaces: this.namespaces,
|
|
219
|
+
wallet: this.wallet,
|
|
220
|
+
currentCaipNetworkId: this.currentCaipNetworkId
|
|
221
|
+
};
|
|
222
|
+
try {
|
|
223
|
+
await this.getStorage().setItem(PHANTOM_CONNECTOR_STORAGE_KEY, connectorData);
|
|
224
|
+
} catch (error) {
|
|
225
|
+
// console.error('PhantomConnector: Failed to save session.', error);
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
// Clears only connector-specific data from storage
|
|
230
|
+
async clearSessionStorage() {
|
|
231
|
+
try {
|
|
232
|
+
await this.getStorage().removeItem(PHANTOM_CONNECTOR_STORAGE_KEY);
|
|
233
|
+
} catch (error) {
|
|
234
|
+
// console.error('PhantomConnector: Failed to clear session from storage.', error);
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
//# sourceMappingURL=PhantomConnector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["WalletConnector","solana","solanaDevnet","solanaTestnet","ConstantsUtil","nacl","bs58","PhantomProvider","SOLANA_SIGNING_METHODS","SOLANA_CLUSTER_TO_CHAIN_ID_PART","id","PHANTOM_CONNECTOR_STORAGE_KEY","DAPP_KEYPAIR_STORAGE_KEY","PhantomConnector","currentCaipNetworkId","SUPPORTED_NAMESPACE","constructor","config","type","cluster","init","ops","storage","initializeKeyPair","appScheme","metadata","redirect","universal","native","Error","providerConfig","dappUrl","url","dappEncryptionKeyPair","provider","restoreSession","secretKeyB58","getStorage","getItem","secretKey","decode","box","keyPair","fromSecretKey","newKeyPair","setItem","encode","error","disconnect","connect","opts","isConnected","namespaces","defaultChain","split","chains","requestedCluster","Object","keys","find","key","connectResult","getProvider","solanaChainIdPart","wallet","PHANTOM_CUSTOM_WALLET","userPublicKey","getUserPublicKey","caipAddress","accounts","methods","values","events","saveSession","clearSession","undefined","clearSessionStorage","getNamespaces","getChainId","namespace","getProperties","properties","getWalletInfo","switchNetwork","network","targetClusterName","currentClusterName","Promise","resolve","tempConnectOpts","emit","providerSession","connectorData","removeItem"],"sourceRoot":"../../../src","sources":["connectors/PhantomConnector.ts"],"mappings":";;AAAA,SACEA,eAAe,EAUfC,MAAM,EACNC,YAAY,EACZC,aAAa,EAEbC,aAAa,QACR,mCAAmC;AAC1C,OAAOC,IAAI,MAAM,WAAW;AAC5B,OAAOC,IAAI,MAAM,MAAM;AAEvB,SAASC,eAAe,EAAEC,sBAAsB,QAAQ,8BAA8B;AAQtF,MAAMC,+BAA+D,GAAG;EACtE,cAAc,EAAER,MAAM,CAACS,EAAY;EACnC,SAAS,EAAEP,aAAa,CAACO,EAAY;EACrC,QAAQ,EAAER,YAAY,CAACQ;AACzB,CAAC;AAED,MAAMC,6BAA6B,GAAG,gCAAgC;AACtE,MAAMC,wBAAwB,GAAG,iCAAiC;AAElE,OAAO,MAAMC,gBAAgB,SAASb,eAAe,CAAC;EAG5Cc,oBAAoB,GAAyB,IAAI;EAGzD,OAAwBC,mBAAmB,GAAmB,QAAQ;EAEtEC,WAAWA,CAACC,MAA+B,EAAE;IAC3C,KAAK,CAAC;MAAEC,IAAI,EAAE;IAAU,CAAC,CAAC;IAC1B,IAAI,CAACD,MAAM,GAAGA,MAAM,IAAI;MAAEE,OAAO,EAAE;IAAe,CAAC;EACrD;EAEA,MAAeC,IAAIA,CAACC,GAAyB,EAAE;IAC7C,KAAK,CAACD,IAAI,CAACC,GAAG,CAAC;IACf,IAAI,CAACC,OAAO,GAAGD,GAAG,CAACC,OAAO;IAC1B,MAAM,IAAI,CAACC,iBAAiB,CAAC,CAAC;IAE9B,MAAMC,SAAS,GAAGH,GAAG,CAACI,QAAQ,CAACC,QAAQ,EAAEC,SAAS,IAAIN,GAAG,CAACI,QAAQ,CAACC,QAAQ,EAAEE,MAAM;IACnF,IAAI,CAACJ,SAAS,EAAE;MACd,MAAM,IAAIK,KAAK,CACb,0HACF,CAAC;IACH;IAEA,MAAMC,cAAqC,GAAG;MAC5CN,SAAS;MACTO,OAAO,EAAEV,GAAG,CAACI,QAAQ,CAACO,GAAG;MACzBV,OAAO,EAAED,GAAG,CAACC,OAAO;MACpBW,qBAAqB,EAAE,IAAI,CAACA;IAC9B,CAAC;IAED,IAAI,CAACC,QAAQ,GAAG,IAAI3B,eAAe,CAACuB,cAAc,CAAC;IACnD,MAAM,IAAI,CAACK,cAAc,CAAC,CAAC;EAC7B;EAEA,MAAcZ,iBAAiBA,CAAA,EAAkB;IAC/C,IAAI;MACF,MAAMa,YAAY,GAAG,MAAM,IAAI,CAACC,UAAU,CAAC,CAAC,CAACC,OAAO,CAAC1B,wBAAwB,CAAC;MAC9E,IAAIwB,YAAY,EAAE;QAChB,MAAMG,SAAS,GAAGjC,IAAI,CAACkC,MAAM,CAACJ,YAAY,CAAC;QAC3C,IAAI,CAACH,qBAAqB,GAAG5B,IAAI,CAACoC,GAAG,CAACC,OAAO,CAACC,aAAa,CAACJ,SAAS,CAAC;MACxE,CAAC,MAAM;QACL,MAAMK,UAAU,GAAGvC,IAAI,CAACoC,GAAG,CAACC,OAAO,CAAC,CAAC;QACrC,IAAI,CAACT,qBAAqB,GAAGW,UAAU;QACvC,MAAM,IAAI,CAACP,UAAU,CAAC,CAAC,CAACQ,OAAO,CAC7BjC,wBAAwB,EACxBN,IAAI,CAACwC,MAAM,CAACF,UAAU,CAACL,SAAS,CAClC,CAAC;MACH;IACF,CAAC,CAAC,OAAOQ,KAAK,EAAE;MACd;MACA,MAAM,IAAI,CAACC,UAAU,CAAC,CAAC;MACvB,MAAMD,KAAK;IACb;EACF;EAEA,MAAeE,OAAOA,CAACC,IAAqB,EAAmC;IAC7E,IAAI,IAAI,CAACC,WAAW,CAAC,CAAC,EAAE;MACtB,OAAO,IAAI,CAACC,UAAU;IACxB;IAEA,MAAMC,YAAY,GAChBH,IAAI,EAAEG,YAAY,EAAEC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,QAAQ,GAC5CJ,IAAI,EAAEG,YAAY,EAAEC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GACjCJ,IAAI,EAAEE,UAAU,GAAG,QAAQ,CAAC,EAAEG,MAAM,GAAG,CAAC,CAAC,EAAED,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAE9D,MAAME,gBAAgB,GACpB,IAAI,CAACvC,MAAM,CAACE,OAAO,IAClBsC,MAAM,CAACC,IAAI,CAACjD,+BAA+B,CAAC,CAACkD,IAAI,CAChDC,GAAG,IACDnD,+BAA+B,CAACmD,GAAG,CAAiD,KACpFP,YACJ,CAAgC;IAElC,IAAI;MACF,MAAMQ,aAAa,GAAG,MAAM,IAAI,CAACC,WAAW,CAAC,CAAC,CAACb,OAAO,CAAC;QAAE9B,OAAO,EAAEqC;MAAiB,CAAC,CAAC;MAErF,MAAMO,iBAAiB,GAAGtD,+BAA+B,CAACoD,aAAa,CAAC1C,OAAO,CAAC;MAChF,IAAI,CAAC4C,iBAAiB,EAAE;QACtB,MAAM,IAAIlC,KAAK,CACb,2DAA2DgC,aAAa,CAAC1C,OAAO,EAClF,CAAC;MACH;MACA,IAAI,CAACL,oBAAoB,GAAG,UAAUiD,iBAAiB,EAAmB;MAE1E,IAAI,CAACC,MAAM,GAAG5D,aAAa,CAAC6D,qBAAqB;MAEjD,MAAMC,aAAa,GAAG,IAAI,CAACJ,WAAW,CAAC,CAAC,CAACK,gBAAgB,CAAC,CAAC;MAC3D,IAAI,CAACD,aAAa,EAAE;QAClB,MAAM,IAAIrC,KAAK,CAAC,+DAA+D,CAAC;MAClF;MAEA,MAAMuC,WAAW,GAAG,GAAG,IAAI,CAACtD,oBAAoB,IAAIoD,aAAa,EAAiB;MAClF,IAAI,CAACd,UAAU,GAAG;QAChB,CAACvC,gBAAgB,CAACE,mBAAmB,GAAG;UACtCsD,QAAQ,EAAE,CAACD,WAAW,CAAC;UACvBE,OAAO,EAAEb,MAAM,CAACc,MAAM,CAAC/D,sBAAsB,CAAC;UAC9CgE,MAAM,EAAE,EAAE;UACVjB,MAAM,EAAE,CAAC,IAAI,CAACzC,oBAAoB;QACpC;MACF,CAAC;MAED,MAAM,IAAI,CAAC2D,WAAW,CAAC,CAAC,CAAC,CAAC;;MAE1B,OAAO,IAAI,CAACrB,UAAU;IACxB,CAAC,CAAC,OAAOL,KAAU,EAAE;MACnB,IAAI,CAAC2B,YAAY,CAAC,CAAC;MACnB,MAAM3B,KAAK;IACb;EACF;EAEA,MAAeC,UAAUA,CAAA,EAAkB;IACzC,IAAI;MACF,IAAI,IAAI,CAACG,WAAW,CAAC,CAAC,EAAE;QACtB,MAAM,KAAK,CAACH,UAAU,CAAC,CAAC;MAC1B;IACF,CAAC,CAAC,OAAOD,KAAU,EAAE;MACnB;IAAA;IAEF,MAAM,IAAI,CAAC2B,YAAY,CAAC,CAAC;EAC3B;EAEA,MAAcA,YAAYA,CAAA,EAAkB;IAC1C,IAAI,CAACtB,UAAU,GAAGuB,SAAS;IAC3B,IAAI,CAACX,MAAM,GAAGW,SAAS;IACvB,IAAI,CAAC7D,oBAAoB,GAAG,IAAI;IAChC,MAAM,IAAI,CAAC8D,mBAAmB,CAAC,CAAC;EAClC;EAESd,WAAWA,CAAA,EAAoB;IACtC,IAAI,CAAC,IAAI,CAAC5B,QAAQ,EAAE;MAClB,MAAM,IAAIL,KAAK,CAAC,iEAAiE,CAAC;IACpF;IAEA,OAAO,IAAI,CAACK,QAAQ;EACtB;EAEQG,UAAUA,CAAA,EAAY;IAC5B,IAAI,CAAC,IAAI,CAACf,OAAO,EAAE;MACjB,MAAM,IAAIO,KAAK,CAAC,gEAAgE,CAAC;IACnF;IAEA,OAAO,IAAI,CAACP,OAAO;EACrB;EAESuD,aAAaA,CAAA,EAAe;IACnC,IAAI,CAAC,IAAI,CAACzB,UAAU,EAAE;MACpB,MAAM,IAAIvB,KAAK,CAAC,yDAAyD,CAAC;IAC5E;IAEA,OAAO,IAAI,CAACuB,UAAU;EACxB;EAES0B,UAAUA,CAACC,SAAyB,EAA6B;IACxE,IAAIA,SAAS,KAAKlE,gBAAgB,CAACE,mBAAmB,EAAE;MACtD,OAAO,IAAI,CAACD,oBAAoB,IAAI6D,SAAS;IAC/C;IAEA,OAAOA,SAAS;EAClB;EAESK,aAAaA,CAAA,EAAqC;IACzD,OAAO,IAAI,CAACC,UAAU;EACxB;EAESC,aAAaA,CAAA,EAA2B;IAC/C,IAAI,CAAC,IAAI,CAAC/B,WAAW,CAAC,CAAC,EAAE;MACvB,OAAOwB,SAAS;IAClB;IAEA,OAAO,IAAI,CAACX,MAAM;EACpB;EAEAb,WAAWA,CAAA,EAAY;IACrB;IACA,OAAO,IAAI,CAACW,WAAW,CAAC,CAAC,CAACX,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAACW,WAAW,CAAC,CAAC,CAACK,gBAAgB,CAAC,CAAC;EACpF;EAEA,MAAegB,aAAaA,CAACC,OAAsB,EAAiB;IAClE,MAAMC,iBAAiB,GAAG5B,MAAM,CAACC,IAAI,CAACjD,+BAA+B,CAAC,CAACkD,IAAI,CACzEC,GAAG,IACDnD,+BAA+B,CAACmD,GAAG,CAAiD,KACpFwB,OAAO,CAAC1E,EACZ,CAA+B;IAE/B,IAAI,CAAC2E,iBAAiB,EAAE;MACtB,MAAM,IAAIxD,KAAK,CAAC,4CAA4CuD,OAAO,CAAC1E,EAAE,EAAE,CAAC;IAC3E;IAEA,MAAM4E,kBAAkB,GAAG7B,MAAM,CAACC,IAAI,CAACjD,+BAA+B,CAAC,CAACkD,IAAI,CAC1EC,GAAG,IACD,UACEnD,+BAA+B,CAACmD,GAAG,CAAiD,EACpF,KAAK,IAAI,CAAC9C,oBAChB,CAA+B;IAE/B,IAAIuE,iBAAiB,KAAKC,kBAAkB,IAAI,IAAI,CAACnC,WAAW,CAAC,CAAC,EAAE;MAClE,OAAOoC,OAAO,CAACC,OAAO,CAAC,CAAC;IAC1B;;IAEA;IACA,MAAM,IAAI,CAACxC,UAAU,CAAC,CAAC,CAAC,CAAC;;IAEzB;IACA,MAAMyC,eAA+B,GAAG;MACtCpC,YAAY,EAAE,UAAU5C,+BAA+B,CAAC4E,iBAAiB,CAAC;IAC5E,CAAC;;IAED;IACA;IACA,MAAM,IAAI,CAACpC,OAAO,CAACwC,eAAe,CAAC;IACnC,IAAI,CAAC3B,WAAW,CAAC,CAAC,CAAC4B,IAAI,CAAC,cAAc,EAAEN,OAAO,CAAC1E,EAAE,CAAC;;IAEnD;IACA,IACE,CAAC,IAAI,CAACyC,WAAW,CAAC,CAAC,IACnB,IAAI,CAAC2B,UAAU,CAACjE,gBAAgB,CAACE,mBAAmB,CAAC,KAAK0E,eAAe,CAACpC,YAAY,EACtF;MACA,MAAM,IAAIxB,KAAK,CACb,+BAA+BwD,iBAAiB,mCAClD,CAAC;IACH;EACF;;EAEA;EACA,MAAelD,cAAcA,CAAA,EAAqB;IAChD,IAAI;MACF,MAAMwD,eAAe,GAAG,MAAM,IAAI,CAAC7B,WAAW,CAAC,CAAC,CAAC3B,cAAc,CAAC,CAAC;MACjE,IAAI,CAACwD,eAAe,EAAE;QACpB,OAAO,KAAK;MACd;;MAEA;MACA,MAAMC,aAAa,GAAG,MAAM,IAAI,CAACvD,UAAU,CAAC,CAAC,CAACC,OAAO,CACnD3B,6BACF,CAAC;MACD,IAAI,CAACiF,aAAa,EAAE;QAClB,OAAO,KAAK,CAAC,CAAC;MAChB;MAEA,IAAI,CAACxC,UAAU,GAAGwC,aAAa,CAACxC,UAAU;MAC1C,IAAI,CAACY,MAAM,GAAG4B,aAAa,CAAC5B,MAAM;MAClC,IAAI,CAAClD,oBAAoB,GAAG8E,aAAa,CAAC9E,oBAAoB;;MAE9D;;MAEA;MACA,IAAI,IAAI,CAACqC,WAAW,CAAC,CAAC,EAAE;QACtB,OAAO,IAAI;MACb;;MAEA;MACA,MAAM,IAAI,CAACH,UAAU,CAAC,CAAC;MAEvB,OAAO,KAAK;IACd,CAAC,CAAC,OAAOD,KAAK,EAAE;MACd;MACA,MAAM,IAAI,CAACC,UAAU,CAAC,CAAC;MAEvB,OAAO,KAAK;IACd;EACF;;EAEA;EACA,MAAcyB,WAAWA,CAAA,EAAkB;IACzC,IAAI,CAAC,IAAI,CAACrB,UAAU,IAAI,CAAC,IAAI,CAACY,MAAM,IAAI,CAAC,IAAI,CAAClD,oBAAoB,EAAE;MAClE;IACF;IAEA,MAAM8E,aAA0C,GAAG;MACjDxC,UAAU,EAAE,IAAI,CAACA,UAAU;MAC3BY,MAAM,EAAE,IAAI,CAACA,MAAM;MACnBlD,oBAAoB,EAAE,IAAI,CAACA;IAC7B,CAAC;IAED,IAAI;MACF,MAAM,IAAI,CAACuB,UAAU,CAAC,CAAC,CAACQ,OAAO,CAAClC,6BAA6B,EAAEiF,aAAa,CAAC;IAC/E,CAAC,CAAC,OAAO7C,KAAK,EAAE;MACd;IAAA;EAEJ;;EAEA;EACA,MAAc6B,mBAAmBA,CAAA,EAAkB;IACjD,IAAI;MACF,MAAM,IAAI,CAACvC,UAAU,CAAC,CAAC,CAACwD,UAAU,CAAClF,6BAA6B,CAAC;IACnE,CAAC,CAAC,OAAOoC,KAAK,EAAE;MACd;IAAA;EAEJ;AACF","ignoreList":[]}
|
package/lib/module/helpers.js
CHANGED
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
1
3
|
/**
|
|
2
4
|
* Validates if the given string is a Solana address.
|
|
3
5
|
* @param address The string to validate.
|
|
@@ -33,8 +35,8 @@ export async function getSolanaNativeBalance(rpcUrl, address) {
|
|
|
33
35
|
if (json.error) throw new Error(json.error.message);
|
|
34
36
|
return json.result.value / 1000000000; // Convert lamports to SOL
|
|
35
37
|
}
|
|
36
|
-
|
|
37
38
|
let tokenCache = {};
|
|
39
|
+
|
|
38
40
|
/**
|
|
39
41
|
* Fetch metadata for a Solana SPL token using the Jupiter token list.
|
|
40
42
|
* @param mint - The token's mint address
|
|
@@ -54,6 +56,14 @@ export async function getSolanaTokenMetadata(mint) {
|
|
|
54
56
|
return undefined;
|
|
55
57
|
}
|
|
56
58
|
}
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* Get the balance of a token for a given address
|
|
62
|
+
* @param rpcUrl - The RPC URL to use
|
|
63
|
+
* @param address - The address to get the balance for
|
|
64
|
+
* @param tokenAddress - The address of the token to get the balance for
|
|
65
|
+
* @returns The balance of the token for the given address
|
|
66
|
+
*/
|
|
57
67
|
export async function getSolanaTokenBalance(rpcUrl, address, tokenAddress) {
|
|
58
68
|
if (!isSolanaAddress(address)) {
|
|
59
69
|
throw new Error('Invalid Solana address format');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["isSolanaAddress","address","solanaAddressRegex","test","getSolanaNativeBalance","rpcUrl","Error","response","fetch","method","headers","body","JSON","stringify","jsonrpc","id","params","json","error","message","result","value","tokenCache","getSolanaTokenMetadata","mint","res","list","token","undefined","getSolanaTokenBalance","tokenAddress","encoding","balance","account","data","parsed","info","tokenAmount","uiAmount","amount","toString","symbol"],"sourceRoot":"../../src","sources":["helpers.ts"],"mappings":"
|
|
1
|
+
{"version":3,"names":["isSolanaAddress","address","solanaAddressRegex","test","getSolanaNativeBalance","rpcUrl","Error","response","fetch","method","headers","body","JSON","stringify","jsonrpc","id","params","json","error","message","result","value","tokenCache","getSolanaTokenMetadata","mint","res","list","token","undefined","getSolanaTokenBalance","tokenAddress","encoding","balance","account","data","parsed","info","tokenAmount","uiAmount","amount","toString","symbol"],"sourceRoot":"../../src","sources":["helpers.ts"],"mappings":"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","ignoreList":[]}
|
package/lib/module/index.js
CHANGED
|
@@ -1,3 +1,10 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
// Adapter
|
|
4
|
+
export { SolanaAdapter } from './adapter';
|
|
5
|
+
|
|
6
|
+
// Types
|
|
7
|
+
|
|
8
|
+
// Connectors
|
|
9
|
+
export { PhantomConnector } from './connectors/PhantomConnector';
|
|
3
10
|
//# sourceMappingURL=index.js.map
|
package/lib/module/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["SolanaAdapter"],"sourceRoot":"../../src","sources":["index.
|
|
1
|
+
{"version":3,"names":["SolanaAdapter","PhantomConnector"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":";;AAAA;AACA,SAASA,aAAa,QAAQ,WAAW;;AAEzC;;AAGA;AACA,SAASC,gBAAgB,QAAQ,+BAA+B","ignoreList":[]}
|