@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.
- package/CHANGELOG.md +3952 -0
- package/LICENSE +21 -0
- package/README.md +11 -0
- package/_virtual/_tslib.cjs +36 -0
- package/_virtual/_tslib.js +32 -0
- package/package.json +41 -0
- package/src/connector/SolWalletConnector.cjs +175 -0
- package/src/connector/SolWalletConnector.d.ts +37 -0
- package/src/connector/SolWalletConnector.js +171 -0
- package/src/connector/index.d.ts +1 -0
- package/src/constants.cjs +8 -0
- package/src/constants.d.ts +1 -0
- package/src/constants.js +4 -0
- package/src/index.cjs +36 -0
- package/src/index.d.ts +6 -0
- package/src/index.js +13 -0
- package/src/rpc/RpcProviderSolana/RpcProviderSolana.cjs +29 -0
- package/src/rpc/RpcProviderSolana/RpcProviderSolana.d.ts +18 -0
- package/src/rpc/RpcProviderSolana/RpcProviderSolana.js +27 -0
- package/src/rpc/RpcProviderSolana/index.d.ts +1 -0
- package/src/rpc/index.d.ts +3 -0
- package/src/rpc/solanaProvidersSelector/index.d.ts +1 -0
- package/src/rpc/solanaProvidersSelector/solanaProvidersSelector.cjs +24 -0
- package/src/rpc/solanaProvidersSelector/solanaProvidersSelector.d.ts +7 -0
- package/src/rpc/solanaProvidersSelector/solanaProvidersSelector.js +20 -0
- package/src/types.d.ts +67 -0
- package/src/utils/SolanaUiTransaction/SolanaUiTransaction.cjs +153 -0
- package/src/utils/SolanaUiTransaction/SolanaUiTransaction.d.ts +40 -0
- package/src/utils/SolanaUiTransaction/SolanaUiTransaction.js +148 -0
- package/src/utils/SolanaUiTransaction/index.d.ts +1 -0
- package/src/utils/decodeTransactionFromBase64/decodeTransactionFromBase64.cjs +16 -0
- package/src/utils/decodeTransactionFromBase64/decodeTransactionFromBase64.d.ts +3 -0
- package/src/utils/decodeTransactionFromBase64/decodeTransactionFromBase64.js +12 -0
- package/src/utils/decodeTransactionFromBase64/index.d.ts +1 -0
- package/src/utils/encodeTransactionToBase64/encodeTransactionToBase64.cjs +15 -0
- package/src/utils/encodeTransactionToBase64/encodeTransactionToBase64.d.ts +6 -0
- package/src/utils/encodeTransactionToBase64/encodeTransactionToBase64.js +11 -0
- package/src/utils/encodeTransactionToBase64/index.d.ts +1 -0
- package/src/utils/extractNonce/extractNonce.cjs +14 -0
- package/src/utils/extractNonce/extractNonce.d.ts +1 -0
- package/src/utils/extractNonce/extractNonce.js +10 -0
- package/src/utils/extractNonce/index.d.ts +1 -0
- package/src/utils/getGenesisHashLSKey/getGenesisHashLSKey.cjs +10 -0
- package/src/utils/getGenesisHashLSKey/getGenesisHashLSKey.d.ts +1 -0
- package/src/utils/getGenesisHashLSKey/getGenesisHashLSKey.js +6 -0
- package/src/utils/getGenesisHashLSKey/index.d.ts +1 -0
- package/src/utils/index.d.ts +5 -0
- package/src/utils/isVersionedTransaction/index.d.ts +1 -0
- package/src/utils/isVersionedTransaction/isVersionedTransaction.cjs +8 -0
- package/src/utils/isVersionedTransaction/isVersionedTransaction.d.ts +2 -0
- package/src/utils/isVersionedTransaction/isVersionedTransaction.js +4 -0
- package/src/wallet/SolanaWallet.cjs +52 -0
- package/src/wallet/SolanaWallet.d.ts +17 -0
- package/src/wallet/SolanaWallet.js +48 -0
- package/src/wallet/index.d.ts +2 -0
- package/src/wallet/isSolanaWallet/index.d.ts +1 -0
- package/src/wallet/isSolanaWallet/isSolanaWallet.cjs +8 -0
- package/src/wallet/isSolanaWallet/isSolanaWallet.d.ts +3 -0
- 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,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 @@
|
|
|
1
|
+
export declare const SOLANA_GENESIS_HASH = "genesis-hash";
|
package/src/constants.js
ADDED
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 {};
|