@dynamic-labs/solana-core 0.0.0-exp20240827.1

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 (59) hide show
  1. package/CHANGELOG.md +3952 -0
  2. package/LICENSE +21 -0
  3. package/README.md +11 -0
  4. package/_virtual/_tslib.cjs +36 -0
  5. package/_virtual/_tslib.js +32 -0
  6. package/package.json +41 -0
  7. package/src/connector/SolWalletConnector.cjs +175 -0
  8. package/src/connector/SolWalletConnector.d.ts +37 -0
  9. package/src/connector/SolWalletConnector.js +171 -0
  10. package/src/connector/index.d.ts +1 -0
  11. package/src/constants.cjs +8 -0
  12. package/src/constants.d.ts +1 -0
  13. package/src/constants.js +4 -0
  14. package/src/index.cjs +36 -0
  15. package/src/index.d.ts +6 -0
  16. package/src/index.js +13 -0
  17. package/src/rpc/RpcProviderSolana/RpcProviderSolana.cjs +29 -0
  18. package/src/rpc/RpcProviderSolana/RpcProviderSolana.d.ts +18 -0
  19. package/src/rpc/RpcProviderSolana/RpcProviderSolana.js +27 -0
  20. package/src/rpc/RpcProviderSolana/index.d.ts +1 -0
  21. package/src/rpc/index.d.ts +3 -0
  22. package/src/rpc/solanaProvidersSelector/index.d.ts +1 -0
  23. package/src/rpc/solanaProvidersSelector/solanaProvidersSelector.cjs +24 -0
  24. package/src/rpc/solanaProvidersSelector/solanaProvidersSelector.d.ts +7 -0
  25. package/src/rpc/solanaProvidersSelector/solanaProvidersSelector.js +20 -0
  26. package/src/types.d.ts +67 -0
  27. package/src/utils/SolanaUiTransaction/SolanaUiTransaction.cjs +153 -0
  28. package/src/utils/SolanaUiTransaction/SolanaUiTransaction.d.ts +40 -0
  29. package/src/utils/SolanaUiTransaction/SolanaUiTransaction.js +148 -0
  30. package/src/utils/SolanaUiTransaction/index.d.ts +1 -0
  31. package/src/utils/decodeTransactionFromBase64/decodeTransactionFromBase64.cjs +16 -0
  32. package/src/utils/decodeTransactionFromBase64/decodeTransactionFromBase64.d.ts +3 -0
  33. package/src/utils/decodeTransactionFromBase64/decodeTransactionFromBase64.js +12 -0
  34. package/src/utils/decodeTransactionFromBase64/index.d.ts +1 -0
  35. package/src/utils/encodeTransactionToBase64/encodeTransactionToBase64.cjs +15 -0
  36. package/src/utils/encodeTransactionToBase64/encodeTransactionToBase64.d.ts +6 -0
  37. package/src/utils/encodeTransactionToBase64/encodeTransactionToBase64.js +11 -0
  38. package/src/utils/encodeTransactionToBase64/index.d.ts +1 -0
  39. package/src/utils/extractNonce/extractNonce.cjs +14 -0
  40. package/src/utils/extractNonce/extractNonce.d.ts +1 -0
  41. package/src/utils/extractNonce/extractNonce.js +10 -0
  42. package/src/utils/extractNonce/index.d.ts +1 -0
  43. package/src/utils/getGenesisHashLSKey/getGenesisHashLSKey.cjs +10 -0
  44. package/src/utils/getGenesisHashLSKey/getGenesisHashLSKey.d.ts +1 -0
  45. package/src/utils/getGenesisHashLSKey/getGenesisHashLSKey.js +6 -0
  46. package/src/utils/getGenesisHashLSKey/index.d.ts +1 -0
  47. package/src/utils/index.d.ts +5 -0
  48. package/src/utils/isVersionedTransaction/index.d.ts +1 -0
  49. package/src/utils/isVersionedTransaction/isVersionedTransaction.cjs +8 -0
  50. package/src/utils/isVersionedTransaction/isVersionedTransaction.d.ts +2 -0
  51. package/src/utils/isVersionedTransaction/isVersionedTransaction.js +4 -0
  52. package/src/wallet/SolanaWallet.cjs +52 -0
  53. package/src/wallet/SolanaWallet.d.ts +17 -0
  54. package/src/wallet/SolanaWallet.js +48 -0
  55. package/src/wallet/index.d.ts +2 -0
  56. package/src/wallet/isSolanaWallet/index.d.ts +1 -0
  57. package/src/wallet/isSolanaWallet/isSolanaWallet.cjs +8 -0
  58. package/src/wallet/isSolanaWallet/isSolanaWallet.d.ts +3 -0
  59. package/src/wallet/isSolanaWallet/isSolanaWallet.js +4 -0
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2022 Dynamic Labs, Inc.
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,11 @@
1
+ # solana core
2
+
3
+ This library was generated with [Nx](https://nx.dev).
4
+
5
+ ## Building
6
+
7
+ Run `nx build solana-core` to build the library.
8
+
9
+ ## Running unit tests
10
+
11
+ Run `nx test solana-core` to execute the unit tests via [Jest](https://jestjs.io).
@@ -0,0 +1,36 @@
1
+ 'use client'
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, '__esModule', { value: true });
5
+
6
+ /******************************************************************************
7
+ Copyright (c) Microsoft Corporation.
8
+
9
+ Permission to use, copy, modify, and/or distribute this software for any
10
+ purpose with or without fee is hereby granted.
11
+
12
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
13
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
14
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
15
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
16
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
17
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
18
+ PERFORMANCE OF THIS SOFTWARE.
19
+ ***************************************************************************** */
20
+
21
+ function __awaiter(thisArg, _arguments, P, generator) {
22
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
23
+ return new (P || (P = Promise))(function (resolve, reject) {
24
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
25
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
26
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
27
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
28
+ });
29
+ }
30
+
31
+ typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
32
+ var e = new Error(message);
33
+ return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
34
+ };
35
+
36
+ exports.__awaiter = __awaiter;
@@ -0,0 +1,32 @@
1
+ 'use client'
2
+ /******************************************************************************
3
+ Copyright (c) Microsoft Corporation.
4
+
5
+ Permission to use, copy, modify, and/or distribute this software for any
6
+ purpose with or without fee is hereby granted.
7
+
8
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
9
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
10
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
11
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
12
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
13
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
14
+ PERFORMANCE OF THIS SOFTWARE.
15
+ ***************************************************************************** */
16
+
17
+ function __awaiter(thisArg, _arguments, P, generator) {
18
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
19
+ return new (P || (P = Promise))(function (resolve, reject) {
20
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
21
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
22
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
23
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
24
+ });
25
+ }
26
+
27
+ typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
28
+ var e = new Error(message);
29
+ return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
30
+ };
31
+
32
+ export { __awaiter };
package/package.json ADDED
@@ -0,0 +1,41 @@
1
+ {
2
+ "name": "@dynamic-labs/solana-core",
3
+ "version": "0.0.0-exp20240827.1",
4
+ "repository": {
5
+ "type": "git",
6
+ "url": "git+https://github.com/dynamic-labs/dynamic-auth.git",
7
+ "directory": "packages/solana-core"
8
+ },
9
+ "description": "Core package for utilities and types for solana",
10
+ "bugs": {
11
+ "url": "https://github.com/dynamic-labs/DynamicAuth/issues"
12
+ },
13
+ "homepage": "https://github.com/dynamic-labs/DynamicAuth/main/packages/solana-core#readme",
14
+ "author": "Dynamic Labs, Inc.",
15
+ "license": "MIT",
16
+ "main": "./src/index.cjs",
17
+ "module": "./src/index.js",
18
+ "types": "./src/index.d.ts",
19
+ "type": "module",
20
+ "exports": {
21
+ ".": {
22
+ "types": "./src/index.d.ts",
23
+ "import": "./src/index.js",
24
+ "require": "./src/index.cjs"
25
+ },
26
+ "./package.json": "./package.json"
27
+ },
28
+ "dependencies": {
29
+ "@dynamic-labs/sdk-api-core": "0.0.519",
30
+ "@solana/web3.js": "1.92.1",
31
+ "@solana/spl-token": "0.4.6"
32
+ },
33
+ "peerDependencies": {
34
+ "@dynamic-labs/rpc-providers": "0.0.0-exp20240827.1",
35
+ "@dynamic-labs/types": "0.0.0-exp20240827.1",
36
+ "@dynamic-labs/utils": "0.0.0-exp20240827.1",
37
+ "@dynamic-labs/wallet-book": "0.0.0-exp20240827.1",
38
+ "@dynamic-labs/wallet-connector-core": "0.0.0-exp20240827.1",
39
+ "eventemitter3": "5.0.1"
40
+ }
41
+ }
@@ -0,0 +1,175 @@
1
+ 'use client'
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, '__esModule', { value: true });
5
+
6
+ var _tslib = require('../../_virtual/_tslib.cjs');
7
+ var web3_js = require('@solana/web3.js');
8
+ var walletConnectorCore = require('@dynamic-labs/wallet-connector-core');
9
+ var utils = require('@dynamic-labs/utils');
10
+ var walletBook = require('@dynamic-labs/wallet-book');
11
+ var SolanaWallet = require('../wallet/SolanaWallet.cjs');
12
+ var extractNonce = require('../utils/extractNonce/extractNonce.cjs');
13
+ var getGenesisHashLSKey = require('../utils/getGenesisHashLSKey/getGenesisHashLSKey.cjs');
14
+
15
+ const MEMO_PROGRAM_ID = new web3_js.PublicKey('MemoSq4gqABAXKb96qnH8TysNcWxMyWCqXgDLGmfcHr');
16
+ class SolWalletConnector extends walletConnectorCore.WalletConnectorBase {
17
+ constructor(opts) {
18
+ var _a;
19
+ super(opts);
20
+ this.isHardwareWalletEnabled = false;
21
+ this.verifiedCredentials = [];
22
+ this.ChainWallet = SolanaWallet.SolanaWallet;
23
+ this.supportedChains = ['SOL'];
24
+ this.connectedChain = 'SOL';
25
+ this.solNetworks = opts.solNetworks;
26
+ this.chainRpcProviders = opts.chainRpcProviders;
27
+ (_a = this.chainRpcProviders) === null || _a === void 0 ? void 0 : _a.registerSolanaProviders();
28
+ }
29
+ getNetwork() {
30
+ return _tslib.__awaiter(this, void 0, void 0, function* () {
31
+ const provider = this.getWalletClient();
32
+ let genesisHash = localStorage.getItem(getGenesisHashLSKey.getGenesisHashLSKey(provider.rpcEndpoint));
33
+ if (!genesisHash) {
34
+ genesisHash = yield provider.getGenesisHash();
35
+ localStorage.setItem(getGenesisHashLSKey.getGenesisHashLSKey(provider.rpcEndpoint), genesisHash);
36
+ }
37
+ genesisHash = genesisHash.substring(0, 32);
38
+ // see: https://github.com/ChainAgnostic/namespaces/blob/main/solana/caip2.md
39
+ let network;
40
+ if (genesisHash === '5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp') {
41
+ network = 'mainnet';
42
+ }
43
+ else if (genesisHash === 'EtWTRABZaYq6iMfeYKouRu166VU2xqa1') {
44
+ network = 'devnet';
45
+ }
46
+ else {
47
+ network = 'testnet';
48
+ }
49
+ return network;
50
+ });
51
+ }
52
+ endSession() {
53
+ return _tslib.__awaiter(this, void 0, void 0, function* () {
54
+ localStorage.removeItem(getGenesisHashLSKey.getGenesisHashLSKey(this.getWalletClient().rpcEndpoint));
55
+ });
56
+ }
57
+ getWalletClient() {
58
+ var _a;
59
+ const [network] = this.solNetworks;
60
+ if (!network) {
61
+ throw new utils.DynamicError('No enabled networks');
62
+ }
63
+ const rpcUrl = ((_a = network.privateCustomerRpcUrls) === null || _a === void 0 ? void 0 : _a[0]) || network.rpcUrls[0];
64
+ return new web3_js.Connection(rpcUrl, 'confirmed');
65
+ }
66
+ getPublicClient() {
67
+ return _tslib.__awaiter(this, void 0, void 0, function* () {
68
+ var _a;
69
+ if (this.solNetworks.length === 0)
70
+ return;
71
+ const configurations = {
72
+ cosmos: [],
73
+ evm: undefined,
74
+ solana: this.solNetworks,
75
+ starknet: undefined,
76
+ };
77
+ if (!this.chainRpcProviders)
78
+ return undefined;
79
+ const providers = this.chainRpcProviders.getProviders(configurations);
80
+ return (_a = this.chainRpcProviders.getSolanaProviderByChainId(providers, '101')) === null || _a === void 0 ? void 0 : _a.provider;
81
+ });
82
+ }
83
+ getBalance(address) {
84
+ return _tslib.__awaiter(this, void 0, void 0, function* () {
85
+ const publicKey = new web3_js.PublicKey(address);
86
+ const balance = this.lamportsToSol(yield this.getWalletClient().getBalance(publicKey));
87
+ return balance.toString();
88
+ });
89
+ }
90
+ // Solana uses lamports as the smallest unit of currency. This converts lamports to SOL.
91
+ lamportsToSol(lamports) {
92
+ return lamports / 1000000000;
93
+ }
94
+ canConnectWithHardwareWallet() {
95
+ const wallet = walletBook.findWalletBookWallet(this.walletBook, this.key);
96
+ if (!wallet || !wallet.hardwareWallets)
97
+ return false;
98
+ return wallet.hardwareWallets.includes('ledger');
99
+ }
100
+ signMessage(messageToSign) {
101
+ const _super = Object.create(null, {
102
+ signMessage: { get: () => super.signMessage }
103
+ });
104
+ return _tslib.__awaiter(this, void 0, void 0, function* () {
105
+ if (this.isHardwareWalletEnabled) {
106
+ throw new utils.NotSupportedError(`Message signing is currently not supported on ${this.name} hardware wallet.
107
+ You can use signMessageViaTransaction instead to achieve similar functionality
108
+ by signing a transaction with a memo instruction.
109
+ You can read more about it here https://github.com/solana-labs/solana/issues/21366`);
110
+ }
111
+ return _super.signMessage.call(this, messageToSign);
112
+ });
113
+ }
114
+ proveOwnership(address, messageToSign) {
115
+ const _super = Object.create(null, {
116
+ proveOwnership: { get: () => super.proveOwnership }
117
+ });
118
+ return _tslib.__awaiter(this, void 0, void 0, function* () {
119
+ yield this.validateActiveWallet(address);
120
+ if (this.isHardwareWalletEnabled) {
121
+ const nonce = extractNonce.extractNonce(messageToSign);
122
+ if (!nonce) {
123
+ throw new utils.DynamicError('Nonce missing');
124
+ }
125
+ return this.signMessageViaTransaction(nonce);
126
+ }
127
+ return _super.proveOwnership.call(this, address, messageToSign);
128
+ });
129
+ }
130
+ signMessageViaTransaction(messageToSign) {
131
+ return _tslib.__awaiter(this, void 0, void 0, function* () {
132
+ const address = yield this.getAddress();
133
+ if (!address) {
134
+ throw new utils.DynamicError('Address missing');
135
+ }
136
+ const transaction = this.buildAuthTx(messageToSign);
137
+ transaction.feePayer = new web3_js.PublicKey(address);
138
+ transaction.recentBlockhash = (yield this.getWalletClient().getLatestBlockhash()).blockhash;
139
+ const signer = yield this.getSigner();
140
+ if (!signer) {
141
+ throw new utils.DynamicError('Signer not found');
142
+ }
143
+ const signedTransaction = yield signer.signTransaction(transaction);
144
+ const serializedSignedTransaction = signedTransaction.serialize();
145
+ /**
146
+ * Serializing the transaction and adding the type 'Buffer' is required
147
+ * when connecting with backpack + Ledger, because the returned object is not correctly
148
+ * serialized
149
+ */
150
+ return JSON.stringify({
151
+ signedTransaction: {
152
+ data: Array.from(serializedSignedTransaction),
153
+ type: 'Buffer',
154
+ },
155
+ });
156
+ });
157
+ }
158
+ buildAuthTx(message) {
159
+ const transaction = new web3_js.Transaction();
160
+ transaction.add(new web3_js.TransactionInstruction({
161
+ data: Buffer.from(message, 'utf8'),
162
+ keys: [],
163
+ programId: MEMO_PROGRAM_ID,
164
+ }));
165
+ return transaction;
166
+ }
167
+ setVerifiedCredentials(verifiedCredentials) {
168
+ this.verifiedCredentials = verifiedCredentials;
169
+ }
170
+ isLedgerAddress(address) {
171
+ return utils.isLedgerAddressViaVerifiedCredentials(address, this.verifiedCredentials);
172
+ }
173
+ }
174
+
175
+ exports.SolWalletConnector = SolWalletConnector;
@@ -0,0 +1,37 @@
1
+ import { Connection } from '@solana/web3.js';
2
+ import { Chain, IHardwareWalletConnector, WalletConnectorBase } from '@dynamic-labs/wallet-connector-core';
3
+ import { GenericNetwork } from '@dynamic-labs/types';
4
+ import { WalletBookSchema } from '@dynamic-labs/wallet-book';
5
+ import { JwtVerifiedCredential } from '@dynamic-labs/sdk-api-core';
6
+ import { IChainRpcProviders } from '../rpc';
7
+ import { SolanaWallet } from '../wallet';
8
+ import { ISolana } from '../types';
9
+ export type SolWalletConnectorOpts = {
10
+ chainRpcProviders: IChainRpcProviders;
11
+ solNetworks: GenericNetwork[];
12
+ walletBook: WalletBookSchema;
13
+ };
14
+ export declare abstract class SolWalletConnector extends WalletConnectorBase<typeof SolanaWallet> implements IHardwareWalletConnector {
15
+ isHardwareWalletEnabled: boolean;
16
+ verifiedCredentials: JwtVerifiedCredential[];
17
+ solNetworks: GenericNetwork[];
18
+ ChainWallet: typeof SolanaWallet;
19
+ supportedChains: Chain[];
20
+ connectedChain: Chain;
21
+ constructor(opts: SolWalletConnectorOpts);
22
+ getNetwork(): Promise<string>;
23
+ endSession(): Promise<void>;
24
+ getWalletClient(): Connection;
25
+ getPublicClient(): Promise<Connection | undefined>;
26
+ abstract getSigner(): Promise<ISolana | undefined>;
27
+ abstract connect(): Promise<void>;
28
+ getBalance(address: string): Promise<string | undefined>;
29
+ lamportsToSol(lamports: number): number;
30
+ canConnectWithHardwareWallet(): boolean;
31
+ signMessage(messageToSign: string): Promise<string | undefined>;
32
+ proveOwnership(address: string, messageToSign: string): Promise<string | undefined>;
33
+ signMessageViaTransaction(messageToSign: string): Promise<string>;
34
+ private buildAuthTx;
35
+ setVerifiedCredentials(verifiedCredentials: JwtVerifiedCredential[]): void;
36
+ isLedgerAddress(address: string): boolean;
37
+ }
@@ -0,0 +1,171 @@
1
+ 'use client'
2
+ import { __awaiter } from '../../_virtual/_tslib.js';
3
+ import { PublicKey, Connection, Transaction, TransactionInstruction } from '@solana/web3.js';
4
+ import { WalletConnectorBase } from '@dynamic-labs/wallet-connector-core';
5
+ import { DynamicError, isLedgerAddressViaVerifiedCredentials, NotSupportedError } from '@dynamic-labs/utils';
6
+ import { findWalletBookWallet } from '@dynamic-labs/wallet-book';
7
+ import { SolanaWallet } from '../wallet/SolanaWallet.js';
8
+ import { extractNonce } from '../utils/extractNonce/extractNonce.js';
9
+ import { getGenesisHashLSKey } from '../utils/getGenesisHashLSKey/getGenesisHashLSKey.js';
10
+
11
+ const MEMO_PROGRAM_ID = new PublicKey('MemoSq4gqABAXKb96qnH8TysNcWxMyWCqXgDLGmfcHr');
12
+ class SolWalletConnector extends WalletConnectorBase {
13
+ constructor(opts) {
14
+ var _a;
15
+ super(opts);
16
+ this.isHardwareWalletEnabled = false;
17
+ this.verifiedCredentials = [];
18
+ this.ChainWallet = SolanaWallet;
19
+ this.supportedChains = ['SOL'];
20
+ this.connectedChain = 'SOL';
21
+ this.solNetworks = opts.solNetworks;
22
+ this.chainRpcProviders = opts.chainRpcProviders;
23
+ (_a = this.chainRpcProviders) === null || _a === void 0 ? void 0 : _a.registerSolanaProviders();
24
+ }
25
+ getNetwork() {
26
+ return __awaiter(this, void 0, void 0, function* () {
27
+ const provider = this.getWalletClient();
28
+ let genesisHash = localStorage.getItem(getGenesisHashLSKey(provider.rpcEndpoint));
29
+ if (!genesisHash) {
30
+ genesisHash = yield provider.getGenesisHash();
31
+ localStorage.setItem(getGenesisHashLSKey(provider.rpcEndpoint), genesisHash);
32
+ }
33
+ genesisHash = genesisHash.substring(0, 32);
34
+ // see: https://github.com/ChainAgnostic/namespaces/blob/main/solana/caip2.md
35
+ let network;
36
+ if (genesisHash === '5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp') {
37
+ network = 'mainnet';
38
+ }
39
+ else if (genesisHash === 'EtWTRABZaYq6iMfeYKouRu166VU2xqa1') {
40
+ network = 'devnet';
41
+ }
42
+ else {
43
+ network = 'testnet';
44
+ }
45
+ return network;
46
+ });
47
+ }
48
+ endSession() {
49
+ return __awaiter(this, void 0, void 0, function* () {
50
+ localStorage.removeItem(getGenesisHashLSKey(this.getWalletClient().rpcEndpoint));
51
+ });
52
+ }
53
+ getWalletClient() {
54
+ var _a;
55
+ const [network] = this.solNetworks;
56
+ if (!network) {
57
+ throw new DynamicError('No enabled networks');
58
+ }
59
+ const rpcUrl = ((_a = network.privateCustomerRpcUrls) === null || _a === void 0 ? void 0 : _a[0]) || network.rpcUrls[0];
60
+ return new Connection(rpcUrl, 'confirmed');
61
+ }
62
+ getPublicClient() {
63
+ return __awaiter(this, void 0, void 0, function* () {
64
+ var _a;
65
+ if (this.solNetworks.length === 0)
66
+ return;
67
+ const configurations = {
68
+ cosmos: [],
69
+ evm: undefined,
70
+ solana: this.solNetworks,
71
+ starknet: undefined,
72
+ };
73
+ if (!this.chainRpcProviders)
74
+ return undefined;
75
+ const providers = this.chainRpcProviders.getProviders(configurations);
76
+ return (_a = this.chainRpcProviders.getSolanaProviderByChainId(providers, '101')) === null || _a === void 0 ? void 0 : _a.provider;
77
+ });
78
+ }
79
+ getBalance(address) {
80
+ return __awaiter(this, void 0, void 0, function* () {
81
+ const publicKey = new PublicKey(address);
82
+ const balance = this.lamportsToSol(yield this.getWalletClient().getBalance(publicKey));
83
+ return balance.toString();
84
+ });
85
+ }
86
+ // Solana uses lamports as the smallest unit of currency. This converts lamports to SOL.
87
+ lamportsToSol(lamports) {
88
+ return lamports / 1000000000;
89
+ }
90
+ canConnectWithHardwareWallet() {
91
+ const wallet = findWalletBookWallet(this.walletBook, this.key);
92
+ if (!wallet || !wallet.hardwareWallets)
93
+ return false;
94
+ return wallet.hardwareWallets.includes('ledger');
95
+ }
96
+ signMessage(messageToSign) {
97
+ const _super = Object.create(null, {
98
+ signMessage: { get: () => super.signMessage }
99
+ });
100
+ return __awaiter(this, void 0, void 0, function* () {
101
+ if (this.isHardwareWalletEnabled) {
102
+ throw new NotSupportedError(`Message signing is currently not supported on ${this.name} hardware wallet.
103
+ You can use signMessageViaTransaction instead to achieve similar functionality
104
+ by signing a transaction with a memo instruction.
105
+ You can read more about it here https://github.com/solana-labs/solana/issues/21366`);
106
+ }
107
+ return _super.signMessage.call(this, messageToSign);
108
+ });
109
+ }
110
+ proveOwnership(address, messageToSign) {
111
+ const _super = Object.create(null, {
112
+ proveOwnership: { get: () => super.proveOwnership }
113
+ });
114
+ return __awaiter(this, void 0, void 0, function* () {
115
+ yield this.validateActiveWallet(address);
116
+ if (this.isHardwareWalletEnabled) {
117
+ const nonce = extractNonce(messageToSign);
118
+ if (!nonce) {
119
+ throw new DynamicError('Nonce missing');
120
+ }
121
+ return this.signMessageViaTransaction(nonce);
122
+ }
123
+ return _super.proveOwnership.call(this, address, messageToSign);
124
+ });
125
+ }
126
+ signMessageViaTransaction(messageToSign) {
127
+ return __awaiter(this, void 0, void 0, function* () {
128
+ const address = yield this.getAddress();
129
+ if (!address) {
130
+ throw new DynamicError('Address missing');
131
+ }
132
+ const transaction = this.buildAuthTx(messageToSign);
133
+ transaction.feePayer = new PublicKey(address);
134
+ transaction.recentBlockhash = (yield this.getWalletClient().getLatestBlockhash()).blockhash;
135
+ const signer = yield this.getSigner();
136
+ if (!signer) {
137
+ throw new DynamicError('Signer not found');
138
+ }
139
+ const signedTransaction = yield signer.signTransaction(transaction);
140
+ const serializedSignedTransaction = signedTransaction.serialize();
141
+ /**
142
+ * Serializing the transaction and adding the type 'Buffer' is required
143
+ * when connecting with backpack + Ledger, because the returned object is not correctly
144
+ * serialized
145
+ */
146
+ return JSON.stringify({
147
+ signedTransaction: {
148
+ data: Array.from(serializedSignedTransaction),
149
+ type: 'Buffer',
150
+ },
151
+ });
152
+ });
153
+ }
154
+ buildAuthTx(message) {
155
+ const transaction = new Transaction();
156
+ transaction.add(new TransactionInstruction({
157
+ data: Buffer.from(message, 'utf8'),
158
+ keys: [],
159
+ programId: MEMO_PROGRAM_ID,
160
+ }));
161
+ return transaction;
162
+ }
163
+ setVerifiedCredentials(verifiedCredentials) {
164
+ this.verifiedCredentials = verifiedCredentials;
165
+ }
166
+ isLedgerAddress(address) {
167
+ return isLedgerAddressViaVerifiedCredentials(address, this.verifiedCredentials);
168
+ }
169
+ }
170
+
171
+ export { SolWalletConnector };
@@ -0,0 +1 @@
1
+ export * from './SolWalletConnector';
@@ -0,0 +1,8 @@
1
+ 'use client'
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, '__esModule', { value: true });
5
+
6
+ const SOLANA_GENESIS_HASH = 'genesis-hash';
7
+
8
+ exports.SOLANA_GENESIS_HASH = SOLANA_GENESIS_HASH;
@@ -0,0 +1 @@
1
+ export declare const SOLANA_GENESIS_HASH = "genesis-hash";
@@ -0,0 +1,4 @@
1
+ 'use client'
2
+ const SOLANA_GENESIS_HASH = 'genesis-hash';
3
+
4
+ export { SOLANA_GENESIS_HASH };
package/src/index.cjs ADDED
@@ -0,0 +1,36 @@
1
+ 'use client'
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, '__esModule', { value: true });
5
+
6
+ var SolWalletConnector = require('./connector/SolWalletConnector.cjs');
7
+ require('./rpc/RpcProviderSolana/RpcProviderSolana.cjs');
8
+ var rpcProviders = require('@dynamic-labs/rpc-providers');
9
+ var solanaProvidersSelector = require('./rpc/solanaProvidersSelector/solanaProvidersSelector.cjs');
10
+ var SolanaUiTransaction = require('./utils/SolanaUiTransaction/SolanaUiTransaction.cjs');
11
+ var decodeTransactionFromBase64 = require('./utils/decodeTransactionFromBase64/decodeTransactionFromBase64.cjs');
12
+ var isVersionedTransaction = require('./utils/isVersionedTransaction/isVersionedTransaction.cjs');
13
+ var encodeTransactionToBase64 = require('./utils/encodeTransactionToBase64/encodeTransactionToBase64.cjs');
14
+ var getGenesisHashLSKey = require('./utils/getGenesisHashLSKey/getGenesisHashLSKey.cjs');
15
+ var SolanaWallet = require('./wallet/SolanaWallet.cjs');
16
+ var isSolanaWallet = require('./wallet/isSolanaWallet/isSolanaWallet.cjs');
17
+ var constants = require('./constants.cjs');
18
+
19
+
20
+
21
+ exports.SolWalletConnector = SolWalletConnector.SolWalletConnector;
22
+ exports.solanaProvidersSelector = solanaProvidersSelector.solanaProvidersSelector;
23
+ exports.SolanaUiTransaction = SolanaUiTransaction.SolanaUiTransaction;
24
+ exports.decodeTransactionFromBase64 = decodeTransactionFromBase64.decodeTransactionFromBase64;
25
+ exports.isVersionedTransaction = isVersionedTransaction.isVersionedTransaction;
26
+ exports.encodeTransactionToBase64 = encodeTransactionToBase64.encodeTransactionToBase64;
27
+ exports.getGenesisHashLSKey = getGenesisHashLSKey.getGenesisHashLSKey;
28
+ exports.SolanaWallet = SolanaWallet.SolanaWallet;
29
+ exports.isSolanaWallet = isSolanaWallet.isSolanaWallet;
30
+ exports.SOLANA_GENESIS_HASH = constants.SOLANA_GENESIS_HASH;
31
+ Object.keys(rpcProviders).forEach(function (k) {
32
+ if (k !== 'default' && !exports.hasOwnProperty(k)) Object.defineProperty(exports, k, {
33
+ enumerable: true,
34
+ get: function () { return rpcProviders[k]; }
35
+ });
36
+ });
package/src/index.d.ts ADDED
@@ -0,0 +1,6 @@
1
+ export * from './connector';
2
+ export * from './rpc';
3
+ export * from './utils';
4
+ export * from './wallet';
5
+ export { SOLANA_GENESIS_HASH } from './constants';
6
+ export type { ConnectionResult, ExtensionLocator, ISolana, IBackpackSolanaSigner, ICoinbaseSolanaSigner, SignedMessage, ISolanaSigner, } from './types';
package/src/index.js ADDED
@@ -0,0 +1,13 @@
1
+ 'use client'
2
+ export { SolWalletConnector } from './connector/SolWalletConnector.js';
3
+ import './rpc/RpcProviderSolana/RpcProviderSolana.js';
4
+ export * from '@dynamic-labs/rpc-providers';
5
+ export { solanaProvidersSelector } from './rpc/solanaProvidersSelector/solanaProvidersSelector.js';
6
+ export { SolanaUiTransaction } from './utils/SolanaUiTransaction/SolanaUiTransaction.js';
7
+ export { decodeTransactionFromBase64 } from './utils/decodeTransactionFromBase64/decodeTransactionFromBase64.js';
8
+ export { isVersionedTransaction } from './utils/isVersionedTransaction/isVersionedTransaction.js';
9
+ export { encodeTransactionToBase64 } from './utils/encodeTransactionToBase64/encodeTransactionToBase64.js';
10
+ export { getGenesisHashLSKey } from './utils/getGenesisHashLSKey/getGenesisHashLSKey.js';
11
+ export { SolanaWallet } from './wallet/SolanaWallet.js';
12
+ export { isSolanaWallet } from './wallet/isSolanaWallet/isSolanaWallet.js';
13
+ export { SOLANA_GENESIS_HASH } from './constants.js';
@@ -0,0 +1,29 @@
1
+ 'use client'
2
+ 'use strict';
3
+
4
+ var web3_js = require('@solana/web3.js');
5
+ var rpcProviders = require('@dynamic-labs/rpc-providers');
6
+
7
+ rpcProviders.ChainRpcProviders.getSolanaProviderByChainId = (rpcProviders, chainId) => {
8
+ var _a;
9
+ const provider = (_a = rpcProviders['solana']) === null || _a === void 0 ? void 0 : _a.find((rpcProvider) => rpcProvider.chainId === chainId);
10
+ return provider;
11
+ };
12
+ rpcProviders.ChainRpcProviders.registerSolanaProviders = () => {
13
+ rpcProviders.ChainRpcProviders.registerChainProviders(rpcProviders.ProviderChain.SOLANA, (config) => {
14
+ const rpcProviders = {};
15
+ if (config === null || config === void 0 ? void 0 : config.solana) {
16
+ rpcProviders.solana = config.solana.map((network) => {
17
+ var _a;
18
+ const rpcUrl = ((_a = network.privateCustomerRpcUrls) === null || _a === void 0 ? void 0 : _a[0]) || network.rpcUrls[0];
19
+ const provider = new web3_js.Connection(rpcUrl);
20
+ return {
21
+ chainId: network.chainId.toString(),
22
+ chainName: network.name,
23
+ provider,
24
+ };
25
+ });
26
+ }
27
+ return rpcProviders.solana;
28
+ });
29
+ };
@@ -0,0 +1,18 @@
1
+ import { Connection } from '@solana/web3.js';
2
+ import { RpcProviders } from '@dynamic-labs/rpc-providers';
3
+ type ISolanaRpcProvider = {
4
+ chainId: string;
5
+ chainName: string;
6
+ provider: Connection;
7
+ };
8
+ declare module '@dynamic-labs/rpc-providers' {
9
+ type SolanaRpcProvider = ISolanaRpcProvider;
10
+ interface RpcProviderLookup {
11
+ solana: SolanaRpcProvider[];
12
+ }
13
+ interface IChainRpcProviders {
14
+ getSolanaProviderByChainId(rpcProviders: RpcProviders, chainId: string): SolanaRpcProvider | undefined;
15
+ registerSolanaProviders(): void;
16
+ }
17
+ }
18
+ export {};