@provablehq/aleo-wallet-adaptor-soter 0.1.1-alpha.0

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/README.md ADDED
@@ -0,0 +1,31 @@
1
+ # @provablehq/aleo-wallet-adaptor-soter
2
+
3
+ Adapter that connects the Soter wallet to the Aleo wallet adaptor ecosystem.
4
+
5
+ ## When to use it
6
+
7
+ - Provide Soter wallet support in projects that already use the adaptor core/provider.
8
+ - Offer Soter as one of several selectable wallets in the React UI kit.
9
+ - Test Soter-specific behaviours without adding custom integration code.
10
+
11
+ ## Installation
12
+
13
+ ```bash
14
+ pnpm add @provablehq/aleo-wallet-adaptor-soter
15
+ ```
16
+
17
+ ## Usage
18
+
19
+ ```tsx
20
+ import { SoterWalletAdapter } from '@provablehq/aleo-wallet-adaptor-soter';
21
+
22
+ const wallets = [new SoterWalletAdapter()];
23
+ ```
24
+
25
+ ## Related packages
26
+
27
+ - `@provablehq/aleo-wallet-adaptor-core` – shared base implementation.
28
+ - `@provablehq/aleo-wallet-adaptor-react` – React provider that consumes the adapter.
29
+ - `@provablehq/aleo-wallet-adaptor-react-ui` – optional UI components for wallet selection.
30
+
31
+ Live demo: https://aleo-dev-toolkit-react-app.vercel.app/
@@ -0,0 +1,100 @@
1
+ import { Network, Account, TransactionOptions, TransactionStatusResponse } from '@provablehq/aleo-types';
2
+ import { WalletName, WalletDecryptPermission, WalletReadyState } from '@provablehq/aleo-wallet-standard';
3
+ import { BaseAleoWalletAdapter } from '@provablehq/aleo-wallet-adaptor-core';
4
+ import { LeoWallet, LeoWalletAdapterConfig } from '@provablehq/aleo-wallet-adaptor-leo';
5
+
6
+ interface SoterWindow extends Window {
7
+ soterWallet?: LeoWallet;
8
+ soter?: LeoWallet;
9
+ }
10
+ /**
11
+ * Soter wallet adapter
12
+ */
13
+ declare class SoterWalletAdapter extends BaseAleoWalletAdapter {
14
+ /**
15
+ * The wallet name
16
+ */
17
+ readonly name: WalletName<"Soter Wallet">;
18
+ /**
19
+ * The wallet URL
20
+ */
21
+ url: string;
22
+ /**
23
+ * The wallet icon (base64-encoded SVG)
24
+ */
25
+ readonly icon = "";
26
+ /**
27
+ * The window object
28
+ */
29
+ private _window;
30
+ /**
31
+ * Current network
32
+ */
33
+ network: Network;
34
+ /**
35
+ * The wallet's decrypt permission
36
+ */
37
+ decryptPermission: WalletDecryptPermission;
38
+ /**
39
+ * Public key
40
+ */
41
+ private _publicKey;
42
+ _readyState: WalletReadyState;
43
+ /**
44
+ * Soter wallet instance
45
+ */
46
+ private _soterWallet;
47
+ /**
48
+ * Create a new Soter wallet adapter
49
+ * @param config Adapter configuration
50
+ */
51
+ constructor(config?: LeoWalletAdapterConfig);
52
+ /**
53
+ * Check if Soter wallet is available
54
+ */
55
+ private _checkAvailability;
56
+ /**
57
+ * Connect to Soter wallet
58
+ * @returns The connected account
59
+ */
60
+ connect(network: Network, decryptPermission: WalletDecryptPermission, programs?: string[]): Promise<Account>;
61
+ /**
62
+ * Disconnect from Soter wallet
63
+ */
64
+ disconnect(): Promise<void>;
65
+ /**
66
+ * Sign a transaction with Soter wallet
67
+ * @param options Transaction options
68
+ * @returns The signed transaction
69
+ */
70
+ signMessage(message: Uint8Array): Promise<Uint8Array>;
71
+ decrypt(cipherText: string, tpk?: string, programId?: string, functionName?: string, index?: number): Promise<string>;
72
+ /**
73
+ * Execute a transaction with Soter wallet
74
+ * @param options Transaction options
75
+ * @returns The executed temporary transaction ID
76
+ */
77
+ executeTransaction(options: TransactionOptions): Promise<{
78
+ transactionId: string;
79
+ }>;
80
+ /**
81
+ * Get transaction status
82
+ * @param transactionId The transaction ID
83
+ * @returns The transaction status
84
+ */
85
+ transactionStatus(transactionId: string): Promise<TransactionStatusResponse>;
86
+ /**
87
+ * Request records from Soter wallet
88
+ * @param program The program to request records from
89
+ * @param includePlaintext Whether to include plaintext on each record
90
+ * @returns The records
91
+ */
92
+ requestRecords(program: string, includePlaintext: boolean): Promise<unknown[]>;
93
+ /**
94
+ * Switch the network
95
+ * @param network The network to switch to
96
+ */
97
+ switchNetwork(_network: Network): Promise<void>;
98
+ }
99
+
100
+ export { SoterWalletAdapter, type SoterWindow };
@@ -0,0 +1,100 @@
1
+ import { Network, Account, TransactionOptions, TransactionStatusResponse } from '@provablehq/aleo-types';
2
+ import { WalletName, WalletDecryptPermission, WalletReadyState } from '@provablehq/aleo-wallet-standard';
3
+ import { BaseAleoWalletAdapter } from '@provablehq/aleo-wallet-adaptor-core';
4
+ import { LeoWallet, LeoWalletAdapterConfig } from '@provablehq/aleo-wallet-adaptor-leo';
5
+
6
+ interface SoterWindow extends Window {
7
+ soterWallet?: LeoWallet;
8
+ soter?: LeoWallet;
9
+ }
10
+ /**
11
+ * Soter wallet adapter
12
+ */
13
+ declare class SoterWalletAdapter extends BaseAleoWalletAdapter {
14
+ /**
15
+ * The wallet name
16
+ */
17
+ readonly name: WalletName<"Soter Wallet">;
18
+ /**
19
+ * The wallet URL
20
+ */
21
+ url: string;
22
+ /**
23
+ * The wallet icon (base64-encoded SVG)
24
+ */
25
+ readonly icon = "";
26
+ /**
27
+ * The window object
28
+ */
29
+ private _window;
30
+ /**
31
+ * Current network
32
+ */
33
+ network: Network;
34
+ /**
35
+ * The wallet's decrypt permission
36
+ */
37
+ decryptPermission: WalletDecryptPermission;
38
+ /**
39
+ * Public key
40
+ */
41
+ private _publicKey;
42
+ _readyState: WalletReadyState;
43
+ /**
44
+ * Soter wallet instance
45
+ */
46
+ private _soterWallet;
47
+ /**
48
+ * Create a new Soter wallet adapter
49
+ * @param config Adapter configuration
50
+ */
51
+ constructor(config?: LeoWalletAdapterConfig);
52
+ /**
53
+ * Check if Soter wallet is available
54
+ */
55
+ private _checkAvailability;
56
+ /**
57
+ * Connect to Soter wallet
58
+ * @returns The connected account
59
+ */
60
+ connect(network: Network, decryptPermission: WalletDecryptPermission, programs?: string[]): Promise<Account>;
61
+ /**
62
+ * Disconnect from Soter wallet
63
+ */
64
+ disconnect(): Promise<void>;
65
+ /**
66
+ * Sign a transaction with Soter wallet
67
+ * @param options Transaction options
68
+ * @returns The signed transaction
69
+ */
70
+ signMessage(message: Uint8Array): Promise<Uint8Array>;
71
+ decrypt(cipherText: string, tpk?: string, programId?: string, functionName?: string, index?: number): Promise<string>;
72
+ /**
73
+ * Execute a transaction with Soter wallet
74
+ * @param options Transaction options
75
+ * @returns The executed temporary transaction ID
76
+ */
77
+ executeTransaction(options: TransactionOptions): Promise<{
78
+ transactionId: string;
79
+ }>;
80
+ /**
81
+ * Get transaction status
82
+ * @param transactionId The transaction ID
83
+ * @returns The transaction status
84
+ */
85
+ transactionStatus(transactionId: string): Promise<TransactionStatusResponse>;
86
+ /**
87
+ * Request records from Soter wallet
88
+ * @param program The program to request records from
89
+ * @param includePlaintext Whether to include plaintext on each record
90
+ * @returns The records
91
+ */
92
+ requestRecords(program: string, includePlaintext: boolean): Promise<unknown[]>;
93
+ /**
94
+ * Switch the network
95
+ * @param network The network to switch to
96
+ */
97
+ switchNetwork(_network: Network): Promise<void>;
98
+ }
99
+
100
+ export { SoterWalletAdapter, type SoterWindow };
package/dist/index.js ADDED
@@ -0,0 +1,287 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/index.ts
21
+ var src_exports = {};
22
+ __export(src_exports, {
23
+ SoterWalletAdapter: () => SoterWalletAdapter
24
+ });
25
+ module.exports = __toCommonJS(src_exports);
26
+
27
+ // src/SoterWalletAdapter.ts
28
+ var import_aleo_types = require("@provablehq/aleo-types");
29
+ var import_aleo_wallet_standard = require("@provablehq/aleo-wallet-standard");
30
+ var import_aleo_wallet_adaptor_core = require("@provablehq/aleo-wallet-adaptor-core");
31
+ var import_aleo_wallet_adaptor_leo = require("@provablehq/aleo-wallet-adaptor-leo");
32
+ var SoterWalletAdapter = class extends import_aleo_wallet_adaptor_core.BaseAleoWalletAdapter {
33
+ /**
34
+ * Create a new Soter wallet adapter
35
+ * @param config Adapter configuration
36
+ */
37
+ constructor(config) {
38
+ super();
39
+ /**
40
+ * The wallet name
41
+ */
42
+ this.name = "Soter Wallet";
43
+ /**
44
+ * The wallet URL
45
+ */
46
+ this.url = "https://chromewebstore.google.com/detail/soter-aleo-wallet/gkodhkbmiflnmkipcmlhhgadebbeijhh";
47
+ /**
48
+ * The wallet icon (base64-encoded SVG)
49
+ */
50
+ this.icon = "";
51
+ /**
52
+ * Current network
53
+ */
54
+ this.network = import_aleo_types.Network.MAINNET;
55
+ /**
56
+ * The wallet's decrypt permission
57
+ */
58
+ this.decryptPermission = import_aleo_wallet_standard.WalletDecryptPermission.NoDecrypt;
59
+ /**
60
+ * Public key
61
+ */
62
+ this._publicKey = "";
63
+ this._readyState = typeof window === "undefined" || typeof document === "undefined" ? import_aleo_wallet_standard.WalletReadyState.UNSUPPORTED : import_aleo_wallet_standard.WalletReadyState.NOT_DETECTED;
64
+ console.debug("SoterWalletAdapter constructor", config);
65
+ this.network = import_aleo_types.Network.MAINNET;
66
+ this._checkAvailability();
67
+ this._soterWallet = this._window?.soter || this._window?.soterWallet;
68
+ }
69
+ /**
70
+ * Check if Soter wallet is available
71
+ */
72
+ _checkAvailability() {
73
+ if (typeof window === "undefined" || typeof document === "undefined") {
74
+ this.readyState = import_aleo_wallet_standard.WalletReadyState.UNSUPPORTED;
75
+ return;
76
+ }
77
+ this._window = window;
78
+ if (this._window.soter || this._window.soterWallet) {
79
+ this.readyState = import_aleo_wallet_standard.WalletReadyState.INSTALLED;
80
+ this._soterWallet = this._window?.soter || this._window?.soterWallet;
81
+ } else {
82
+ const isMobile = /iPhone|iPad|iPod|Android/i.test(navigator.userAgent);
83
+ if (isMobile) {
84
+ this.readyState = import_aleo_wallet_standard.WalletReadyState.LOADABLE;
85
+ }
86
+ }
87
+ }
88
+ /**
89
+ * Connect to Soter wallet
90
+ * @returns The connected account
91
+ */
92
+ async connect(network, decryptPermission, programs) {
93
+ try {
94
+ if (this.readyState !== import_aleo_wallet_standard.WalletReadyState.INSTALLED) {
95
+ throw new import_aleo_wallet_adaptor_core.WalletConnectionError("Soter Wallet is not available");
96
+ }
97
+ if (network !== import_aleo_types.Network.MAINNET) {
98
+ throw new import_aleo_wallet_adaptor_core.WalletConnectionError("Soter Wallet only support mainnet");
99
+ }
100
+ try {
101
+ await this._soterWallet?.connect(decryptPermission, import_aleo_wallet_adaptor_leo.LEO_NETWORK_MAP[network], programs);
102
+ if (!this._soterWallet?.publicKey) {
103
+ throw new import_aleo_wallet_adaptor_core.WalletConnectionError(
104
+ "Soter Wallet did not return address, maybe canceled by user"
105
+ );
106
+ }
107
+ } catch (error) {
108
+ throw new import_aleo_wallet_adaptor_core.WalletConnectionError(
109
+ error instanceof Error ? error.message : "Connection failed"
110
+ );
111
+ }
112
+ this._publicKey = this._soterWallet?.publicKey || "";
113
+ if (!this._publicKey) {
114
+ throw new import_aleo_wallet_adaptor_core.WalletConnectionError("No address returned from wallet");
115
+ }
116
+ const account = {
117
+ address: this._publicKey
118
+ };
119
+ this.account = account;
120
+ this.decryptPermission = decryptPermission;
121
+ this.emit("connect", account);
122
+ return account;
123
+ } catch (err) {
124
+ this.emit("error", err instanceof Error ? err : new Error(String(err)));
125
+ throw new import_aleo_wallet_adaptor_core.WalletConnectionError(err instanceof Error ? err.message : "Connection failed");
126
+ }
127
+ }
128
+ /**
129
+ * Disconnect from Soter wallet
130
+ */
131
+ async disconnect() {
132
+ try {
133
+ await this._soterWallet?.disconnect();
134
+ this._publicKey = "";
135
+ this.account = void 0;
136
+ this.emit("disconnect");
137
+ } catch (err) {
138
+ this.emit("error", err instanceof Error ? err : new Error(String(err)));
139
+ throw new import_aleo_wallet_adaptor_core.WalletDisconnectionError(
140
+ err instanceof Error ? err.message : "Disconnection failed"
141
+ );
142
+ }
143
+ }
144
+ /**
145
+ * Sign a transaction with Soter wallet
146
+ * @param options Transaction options
147
+ * @returns The signed transaction
148
+ */
149
+ async signMessage(message) {
150
+ if (!this._publicKey || !this.account) {
151
+ throw new import_aleo_wallet_adaptor_core.WalletNotConnectedError();
152
+ }
153
+ try {
154
+ const signature = await this._soterWallet?.signMessage(message);
155
+ if (signature.signature.errorCode != 0) {
156
+ throw new Error("Permission Not Granted");
157
+ }
158
+ return new TextEncoder().encode(signature.signature.result);
159
+ } catch (error) {
160
+ throw new import_aleo_wallet_adaptor_core.WalletSignMessageError(
161
+ error instanceof Error ? error.message : "Failed to sign message"
162
+ );
163
+ }
164
+ }
165
+ async decrypt(cipherText, tpk, programId, functionName, index) {
166
+ if (!this._soterWallet || !this._publicKey) {
167
+ throw new import_aleo_wallet_adaptor_core.WalletNotConnectedError();
168
+ }
169
+ switch (this.decryptPermission) {
170
+ case import_aleo_wallet_standard.WalletDecryptPermission.NoDecrypt:
171
+ throw new import_aleo_wallet_adaptor_core.WalletDecryptionNotAllowedError();
172
+ case import_aleo_wallet_standard.WalletDecryptPermission.UponRequest:
173
+ case import_aleo_wallet_standard.WalletDecryptPermission.AutoDecrypt:
174
+ case import_aleo_wallet_standard.WalletDecryptPermission.OnChainHistory: {
175
+ try {
176
+ const result = await this._soterWallet.decrypt(
177
+ cipherText,
178
+ tpk,
179
+ programId,
180
+ functionName,
181
+ index
182
+ );
183
+ return result.text;
184
+ } catch (error) {
185
+ throw new import_aleo_wallet_adaptor_core.WalletDecryptionError(
186
+ error instanceof Error ? error.message : "Failed to decrypt"
187
+ );
188
+ }
189
+ }
190
+ default:
191
+ throw new import_aleo_wallet_adaptor_core.WalletDecryptionError();
192
+ }
193
+ }
194
+ /**
195
+ * Execute a transaction with Soter wallet
196
+ * @param options Transaction options
197
+ * @returns The executed temporary transaction ID
198
+ */
199
+ async executeTransaction(options) {
200
+ if (!this._publicKey || !this.account) {
201
+ throw new import_aleo_wallet_adaptor_core.WalletNotConnectedError();
202
+ }
203
+ try {
204
+ const requestData = {
205
+ address: this._publicKey,
206
+ chainId: import_aleo_wallet_adaptor_leo.LEO_NETWORK_MAP[this.network],
207
+ fee: options.fee ? options.fee : 1e-3,
208
+ feePrivate: false,
209
+ transitions: [
210
+ {
211
+ program: options.program,
212
+ functionName: options.function,
213
+ inputs: options.inputs
214
+ }
215
+ ]
216
+ };
217
+ const result = await this._soterWallet?.requestTransaction(requestData);
218
+ if (!result?.transactionId) {
219
+ throw new import_aleo_wallet_adaptor_core.WalletTransactionError("Could not create transaction");
220
+ }
221
+ return {
222
+ transactionId: result.transactionId
223
+ };
224
+ } catch (error) {
225
+ console.error("Soter Wallet executeTransaction error", error);
226
+ if (error instanceof import_aleo_wallet_adaptor_core.WalletError) {
227
+ throw error;
228
+ }
229
+ throw new import_aleo_wallet_adaptor_core.WalletTransactionError(
230
+ error instanceof Error ? error.message : "Failed to execute transaction"
231
+ );
232
+ }
233
+ }
234
+ /**
235
+ * Get transaction status
236
+ * @param transactionId The transaction ID
237
+ * @returns The transaction status
238
+ */
239
+ async transactionStatus(transactionId) {
240
+ if (!this._publicKey || !this.account) {
241
+ throw new import_aleo_wallet_adaptor_core.WalletNotConnectedError();
242
+ }
243
+ try {
244
+ const result = await this._soterWallet?.transactionStatus(transactionId);
245
+ if (!result?.status) {
246
+ throw new import_aleo_wallet_adaptor_core.WalletTransactionError("Could not get transaction status");
247
+ }
248
+ return {
249
+ status: result.status
250
+ };
251
+ } catch (error) {
252
+ throw new import_aleo_wallet_adaptor_core.WalletTransactionError(
253
+ error instanceof Error ? error.message : "Failed to get transaction status"
254
+ );
255
+ }
256
+ }
257
+ /**
258
+ * Request records from Soter wallet
259
+ * @param program The program to request records from
260
+ * @param includePlaintext Whether to include plaintext on each record
261
+ * @returns The records
262
+ */
263
+ async requestRecords(program, includePlaintext) {
264
+ if (!this._publicKey || !this.account) {
265
+ throw new import_aleo_wallet_adaptor_core.WalletNotConnectedError();
266
+ }
267
+ try {
268
+ const result = includePlaintext ? await this._soterWallet?.requestRecordPlaintexts(program) : await this._soterWallet?.requestRecords(program);
269
+ return result?.records || [];
270
+ } catch (error) {
271
+ throw new import_aleo_wallet_adaptor_core.WalletError(error instanceof Error ? error.message : "Failed to request records");
272
+ }
273
+ }
274
+ /**
275
+ * Switch the network
276
+ * @param network The network to switch to
277
+ */
278
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
279
+ async switchNetwork(_network) {
280
+ console.error("Soter Wallet does not support switching networks");
281
+ throw new import_aleo_wallet_adaptor_core.MethodNotImplementedError("switchNetwork");
282
+ }
283
+ };
284
+ // Annotate the CommonJS export names for ESM import in node:
285
+ 0 && (module.exports = {
286
+ SoterWalletAdapter
287
+ });