@aztec/wallet-sdk 0.0.1-commit.001888fc

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 (66) hide show
  1. package/README.md +321 -0
  2. package/dest/base-wallet/base_wallet.d.ts +142 -0
  3. package/dest/base-wallet/base_wallet.d.ts.map +1 -0
  4. package/dest/base-wallet/base_wallet.js +357 -0
  5. package/dest/base-wallet/index.d.ts +3 -0
  6. package/dest/base-wallet/index.d.ts.map +1 -0
  7. package/dest/base-wallet/index.js +2 -0
  8. package/dest/base-wallet/utils.d.ts +49 -0
  9. package/dest/base-wallet/utils.d.ts.map +1 -0
  10. package/dest/base-wallet/utils.js +131 -0
  11. package/dest/crypto.d.ts +192 -0
  12. package/dest/crypto.d.ts.map +1 -0
  13. package/dest/crypto.js +394 -0
  14. package/dest/emoji_alphabet.d.ts +35 -0
  15. package/dest/emoji_alphabet.d.ts.map +1 -0
  16. package/dest/emoji_alphabet.js +299 -0
  17. package/dest/extension/handlers/background_connection_handler.d.ts +158 -0
  18. package/dest/extension/handlers/background_connection_handler.d.ts.map +1 -0
  19. package/dest/extension/handlers/background_connection_handler.js +258 -0
  20. package/dest/extension/handlers/content_script_connection_handler.d.ts +56 -0
  21. package/dest/extension/handlers/content_script_connection_handler.d.ts.map +1 -0
  22. package/dest/extension/handlers/content_script_connection_handler.js +174 -0
  23. package/dest/extension/handlers/index.d.ts +12 -0
  24. package/dest/extension/handlers/index.d.ts.map +1 -0
  25. package/dest/extension/handlers/index.js +10 -0
  26. package/dest/extension/handlers/internal_message_types.d.ts +63 -0
  27. package/dest/extension/handlers/internal_message_types.d.ts.map +1 -0
  28. package/dest/extension/handlers/internal_message_types.js +22 -0
  29. package/dest/extension/provider/extension_provider.d.ts +107 -0
  30. package/dest/extension/provider/extension_provider.d.ts.map +1 -0
  31. package/dest/extension/provider/extension_provider.js +160 -0
  32. package/dest/extension/provider/extension_wallet.d.ts +132 -0
  33. package/dest/extension/provider/extension_wallet.d.ts.map +1 -0
  34. package/dest/extension/provider/extension_wallet.js +278 -0
  35. package/dest/extension/provider/index.d.ts +3 -0
  36. package/dest/extension/provider/index.d.ts.map +1 -0
  37. package/dest/extension/provider/index.js +2 -0
  38. package/dest/manager/index.d.ts +3 -0
  39. package/dest/manager/index.d.ts.map +1 -0
  40. package/dest/manager/index.js +1 -0
  41. package/dest/manager/types.d.ts +167 -0
  42. package/dest/manager/types.d.ts.map +1 -0
  43. package/dest/manager/types.js +19 -0
  44. package/dest/manager/wallet_manager.d.ts +70 -0
  45. package/dest/manager/wallet_manager.d.ts.map +1 -0
  46. package/dest/manager/wallet_manager.js +226 -0
  47. package/dest/types.d.ts +123 -0
  48. package/dest/types.d.ts.map +1 -0
  49. package/dest/types.js +11 -0
  50. package/package.json +105 -0
  51. package/src/base-wallet/base_wallet.ts +498 -0
  52. package/src/base-wallet/index.ts +2 -0
  53. package/src/base-wallet/utils.ts +238 -0
  54. package/src/crypto.ts +499 -0
  55. package/src/emoji_alphabet.ts +317 -0
  56. package/src/extension/handlers/background_connection_handler.ts +423 -0
  57. package/src/extension/handlers/content_script_connection_handler.ts +246 -0
  58. package/src/extension/handlers/index.ts +25 -0
  59. package/src/extension/handlers/internal_message_types.ts +69 -0
  60. package/src/extension/provider/extension_provider.ts +233 -0
  61. package/src/extension/provider/extension_wallet.ts +329 -0
  62. package/src/extension/provider/index.ts +7 -0
  63. package/src/manager/index.ts +12 -0
  64. package/src/manager/types.ts +177 -0
  65. package/src/manager/wallet_manager.ts +257 -0
  66. package/src/types.ts +132 -0
@@ -0,0 +1,226 @@
1
+ import { promiseWithResolvers } from '@aztec/foundation/promise';
2
+ import { ExtensionProvider, ExtensionWallet } from '../extension/provider/index.js';
3
+ import { WalletMessageType } from '../types.js';
4
+ /**
5
+ * Manager for wallet discovery, configuration, and connection.
6
+ *
7
+ * This is the main entry point for dApps to discover and connect to wallets.
8
+ *
9
+ * @example Basic usage with async iterator
10
+ * ```typescript
11
+ * const discovery = WalletManager.configure({ extensions: { enabled: true } })
12
+ * .getAvailableWallets({ chainInfo, appId: 'my-app' });
13
+ *
14
+ * // Iterate over discovered wallets
15
+ * for await (const provider of discovery.wallets) {
16
+ * console.log(`Found wallet: ${provider.name}`);
17
+ * }
18
+ *
19
+ * // Or cancel early when done
20
+ * discovery.cancel();
21
+ * ```
22
+ *
23
+ * @example With callback for discovered wallets
24
+ * ```typescript
25
+ * const discovery = manager.getAvailableWallets({
26
+ * chainInfo,
27
+ * appId: 'my-app',
28
+ * onWalletDiscovered: (provider) => console.log(`Found: ${provider.name}`),
29
+ * });
30
+ *
31
+ * // Wait for discovery to complete or cancel it
32
+ * await discovery.done;
33
+ * ```
34
+ */ export class WalletManager {
35
+ config = {
36
+ extensions: {
37
+ enabled: true
38
+ },
39
+ webWallets: {
40
+ urls: []
41
+ }
42
+ };
43
+ constructor(){}
44
+ /**
45
+ * Configures the WalletManager with provider settings
46
+ * @param config - Configuration options for wallet providers
47
+ */ static configure(config) {
48
+ const instance = new WalletManager();
49
+ instance.config = {
50
+ extensions: config.extensions ?? {
51
+ enabled: true
52
+ },
53
+ webWallets: config.webWallets ?? {
54
+ urls: []
55
+ }
56
+ };
57
+ return instance;
58
+ }
59
+ /**
60
+ * Discovers all available wallets for a given chain and version.
61
+ *
62
+ * Returns a `DiscoverySession` with:
63
+ * - `wallets`: AsyncIterable to iterate over discovered wallets
64
+ * - `done`: Promise that resolves when discovery completes or is cancelled
65
+ * - `cancel()`: Function to stop discovery immediately
66
+ *
67
+ * If `onWalletDiscovered` callback is provided, wallets are also streamed via callback.
68
+ *
69
+ * @param options - Discovery options including chain info, appId, and timeout
70
+ * @returns A cancellable discovery session
71
+ */ getAvailableWallets(options) {
72
+ const { chainInfo, appId } = options;
73
+ const abortController = new AbortController();
74
+ const pendingProviders = [];
75
+ let pendingResolve = null;
76
+ let completed = false;
77
+ const { promise: donePromise, resolve: resolveDone } = promiseWithResolvers();
78
+ const markComplete = ()=>{
79
+ completed = true;
80
+ resolveDone();
81
+ if (pendingResolve) {
82
+ const resolve = pendingResolve;
83
+ pendingResolve = null;
84
+ resolve({
85
+ value: undefined,
86
+ done: true
87
+ });
88
+ }
89
+ };
90
+ if (this.config.extensions?.enabled) {
91
+ const extensionConfig = this.config.extensions;
92
+ void ExtensionProvider.discoverWallets(chainInfo, {
93
+ appId,
94
+ timeout: options.timeout,
95
+ signal: abortController.signal,
96
+ onWalletDiscovered: (discoveredWallet)=>{
97
+ const provider = this.createProviderFromDiscoveredWallet(discoveredWallet, chainInfo, extensionConfig);
98
+ if (!provider) {
99
+ return;
100
+ }
101
+ // Call user's callback if provided
102
+ options.onWalletDiscovered?.(provider);
103
+ // Also queue for async iterator
104
+ if (pendingResolve) {
105
+ const resolve = pendingResolve;
106
+ pendingResolve = null;
107
+ resolve({
108
+ value: provider,
109
+ done: false
110
+ });
111
+ } else {
112
+ pendingProviders.push(provider);
113
+ }
114
+ }
115
+ }).then(markComplete);
116
+ } else {
117
+ markComplete();
118
+ }
119
+ const wallets = {
120
+ // eslint-disable-next-line jsdoc/require-jsdoc
121
+ [Symbol.asyncIterator] () {
122
+ return {
123
+ // eslint-disable-next-line jsdoc/require-jsdoc
124
+ next () {
125
+ if (pendingProviders.length > 0) {
126
+ return Promise.resolve({
127
+ value: pendingProviders.shift(),
128
+ done: false
129
+ });
130
+ }
131
+ if (completed) {
132
+ return Promise.resolve({
133
+ value: undefined,
134
+ done: true
135
+ });
136
+ }
137
+ return new Promise((resolve)=>{
138
+ pendingResolve = resolve;
139
+ });
140
+ }
141
+ };
142
+ }
143
+ };
144
+ return {
145
+ wallets,
146
+ done: donePromise,
147
+ cancel: ()=>abortController.abort()
148
+ };
149
+ }
150
+ /**
151
+ * Creates a WalletProvider from a discovered wallet.
152
+ * Returns null if the wallet is not allowed by config.
153
+ * @param discoveredWallet - The discovered wallet from extension discovery.
154
+ * @param chainInfo - Network information.
155
+ * @param extensionConfig - Extension wallet configuration.
156
+ */ createProviderFromDiscoveredWallet(discoveredWallet, chainInfo, extensionConfig) {
157
+ const { info } = discoveredWallet;
158
+ if (!this.isExtensionAllowed(info.id, extensionConfig)) {
159
+ return null;
160
+ }
161
+ let extensionWallet = null;
162
+ const provider = {
163
+ id: info.id,
164
+ type: 'extension',
165
+ name: info.name,
166
+ icon: info.icon,
167
+ metadata: {
168
+ version: info.version
169
+ },
170
+ establishSecureChannel: async (connectAppId)=>{
171
+ const connection = await discoveredWallet.establishSecureChannel();
172
+ provider.metadata = {
173
+ ...provider.metadata,
174
+ verificationHash: connection.info.verificationHash
175
+ };
176
+ return {
177
+ verificationHash: connection.info.verificationHash,
178
+ confirm: ()=>{
179
+ extensionWallet = ExtensionWallet.create(connection.info.id, connection.port, connection.sharedKey, chainInfo, connectAppId);
180
+ return Promise.resolve(extensionWallet.asWallet());
181
+ },
182
+ cancel: ()=>{
183
+ // Send disconnect to terminate the session on the extension side
184
+ // but keep the port open so we can retry key exchange
185
+ connection.port.postMessage({
186
+ type: WalletMessageType.DISCONNECT,
187
+ requestId: discoveredWallet.requestId
188
+ });
189
+ }
190
+ };
191
+ },
192
+ disconnect: async ()=>{
193
+ if (extensionWallet) {
194
+ await extensionWallet.disconnect();
195
+ extensionWallet = null;
196
+ }
197
+ },
198
+ onDisconnect: (callback)=>{
199
+ if (extensionWallet) {
200
+ return extensionWallet.onDisconnect(callback);
201
+ }
202
+ return ()=>{};
203
+ },
204
+ isDisconnected: ()=>{
205
+ if (extensionWallet) {
206
+ return extensionWallet.isDisconnected();
207
+ }
208
+ return true;
209
+ }
210
+ };
211
+ return provider;
212
+ }
213
+ /**
214
+ * Checks if an extension is allowed based on allow/block lists
215
+ * @param extensionId - The extension ID to check
216
+ * @param config - Extension wallet configuration containing allow/block lists
217
+ */ isExtensionAllowed(extensionId, config) {
218
+ if (config.blockList && config.blockList.includes(extensionId)) {
219
+ return false;
220
+ }
221
+ if (config.allowList && config.allowList.length > 0) {
222
+ return config.allowList.includes(extensionId);
223
+ }
224
+ return true;
225
+ }
226
+ }
@@ -0,0 +1,123 @@
1
+ import type { ChainInfo } from '@aztec/aztec.js/account';
2
+ import type { ExportedPublicKey } from './crypto.js';
3
+ /**
4
+ * Message types for wallet SDK communication.
5
+ * All types are prefixed with 'aztec-wallet-' for namespacing.
6
+ */
7
+ export declare enum WalletMessageType {
8
+ /** Discovery request to find installed wallets */
9
+ DISCOVERY = "aztec-wallet-discovery",
10
+ /** Discovery response from a wallet */
11
+ DISCOVERY_RESPONSE = "aztec-wallet-discovery-response",
12
+ /** Disconnect message (unencrypted control message, bidirectional) */
13
+ DISCONNECT = "aztec-wallet-disconnect",
14
+ /** Key exchange request sent over MessageChannel */
15
+ KEY_EXCHANGE_REQUEST = "aztec-wallet-key-exchange-request",
16
+ /** Key exchange response sent over MessageChannel */
17
+ KEY_EXCHANGE_RESPONSE = "aztec-wallet-key-exchange-response"
18
+ }
19
+ /**
20
+ * Information about an installed Aztec wallet.
21
+ * Used during discovery phase before key exchange.
22
+ */
23
+ export interface WalletInfo {
24
+ /** Unique identifier for the wallet */
25
+ id: string;
26
+ /** Display name of the wallet */
27
+ name: string;
28
+ /** URL to the wallet's icon */
29
+ icon?: string;
30
+ /** Wallet version */
31
+ version: string;
32
+ }
33
+ /**
34
+ * Full information about a connected Aztec wallet including crypto material.
35
+ * Available after key exchange completes.
36
+ */
37
+ export interface ConnectedWalletInfo extends WalletInfo {
38
+ /** Wallet's ECDH public key for secure channel establishment */
39
+ publicKey: ExportedPublicKey;
40
+ /**
41
+ * Verification hash for verification.
42
+ * Both dApp and wallet independently compute this from the ECDH shared secret.
43
+ * Use {@link hashToEmoji} to convert to a visual representation for user verification.
44
+ */
45
+ verificationHash?: string;
46
+ }
47
+ /**
48
+ * Message format for wallet communication (internal, before encryption)
49
+ */
50
+ export interface WalletMessage {
51
+ /** Unique message ID for tracking responses */
52
+ messageId: string;
53
+ /** The wallet method to call */
54
+ type: string;
55
+ /** Arguments for the method */
56
+ args: unknown[];
57
+ /** Chain information */
58
+ chainInfo: ChainInfo;
59
+ /** Application ID making the request */
60
+ appId: string;
61
+ /** Wallet ID to target a specific wallet */
62
+ walletId: string;
63
+ }
64
+ /**
65
+ * Response message from wallet
66
+ */
67
+ export interface WalletResponse {
68
+ /** Message ID matching the request */
69
+ messageId: string;
70
+ /** Result data (if successful) */
71
+ result?: unknown;
72
+ /** Error data (if failed) */
73
+ error?: unknown;
74
+ /** Wallet ID that sent the response */
75
+ walletId: string;
76
+ }
77
+ /**
78
+ * Discovery message for finding installed wallets (public, unencrypted).
79
+ */
80
+ export interface DiscoveryRequest {
81
+ /** Message type for discovery */
82
+ type: WalletMessageType.DISCOVERY;
83
+ /** Request ID */
84
+ requestId: string;
85
+ /** Application ID making the request */
86
+ appId: string;
87
+ /** Chain information to check if wallet supports this network */
88
+ chainInfo: ChainInfo;
89
+ }
90
+ /**
91
+ * Discovery response from a wallet (public, unencrypted).
92
+ */
93
+ export interface DiscoveryResponse {
94
+ /** Message type for discovery response */
95
+ type: WalletMessageType.DISCOVERY_RESPONSE;
96
+ /** Request ID matching the discovery request */
97
+ requestId: string;
98
+ /** Basic wallet information */
99
+ walletInfo: WalletInfo;
100
+ }
101
+ /**
102
+ * Key exchange request sent over MessageChannel after discovery approval.
103
+ */
104
+ export interface KeyExchangeRequest {
105
+ /** Message type */
106
+ type: WalletMessageType.KEY_EXCHANGE_REQUEST;
107
+ /** Request ID matching the discovery request */
108
+ requestId: string;
109
+ /** dApp's ECDH public key for deriving shared secret */
110
+ publicKey: ExportedPublicKey;
111
+ }
112
+ /**
113
+ * Key exchange response sent over MessageChannel.
114
+ */
115
+ export interface KeyExchangeResponse {
116
+ /** Message type */
117
+ type: WalletMessageType.KEY_EXCHANGE_RESPONSE;
118
+ /** Request ID matching the discovery request */
119
+ requestId: string;
120
+ /** Wallet's ECDH public key for deriving shared secret */
121
+ publicKey: ExportedPublicKey;
122
+ }
123
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUV6RCxPQUFPLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUVyRDs7O0dBR0c7QUFDSCxvQkFBWSxpQkFBaUI7SUFDM0Isa0RBQWtEO0lBQ2xELFNBQVMsMkJBQTJCO0lBQ3BDLHVDQUF1QztJQUN2QyxrQkFBa0Isb0NBQW9DO0lBQ3RELHNFQUFzRTtJQUN0RSxVQUFVLDRCQUE0QjtJQUN0QyxvREFBb0Q7SUFDcEQsb0JBQW9CLHNDQUFzQztJQUMxRCxxREFBcUQ7SUFDckQscUJBQXFCLHVDQUF1QztDQUM3RDtBQUVEOzs7R0FHRztBQUNILE1BQU0sV0FBVyxVQUFVO0lBQ3pCLHVDQUF1QztJQUN2QyxFQUFFLEVBQUUsTUFBTSxDQUFDO0lBQ1gsaUNBQWlDO0lBQ2pDLElBQUksRUFBRSxNQUFNLENBQUM7SUFDYiwrQkFBK0I7SUFDL0IsSUFBSSxDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQ2QscUJBQXFCO0lBQ3JCLE9BQU8sRUFBRSxNQUFNLENBQUM7Q0FDakI7QUFFRDs7O0dBR0c7QUFDSCxNQUFNLFdBQVcsbUJBQW9CLFNBQVEsVUFBVTtJQUNyRCxnRUFBZ0U7SUFDaEUsU0FBUyxFQUFFLGlCQUFpQixDQUFDO0lBQzdCOzs7O09BSUc7SUFDSCxnQkFBZ0IsQ0FBQyxFQUFFLE1BQU0sQ0FBQztDQUMzQjtBQUVEOztHQUVHO0FBQ0gsTUFBTSxXQUFXLGFBQWE7SUFDNUIsK0NBQStDO0lBQy9DLFNBQVMsRUFBRSxNQUFNLENBQUM7SUFDbEIsZ0NBQWdDO0lBQ2hDLElBQUksRUFBRSxNQUFNLENBQUM7SUFDYiwrQkFBK0I7SUFDL0IsSUFBSSxFQUFFLE9BQU8sRUFBRSxDQUFDO0lBQ2hCLHdCQUF3QjtJQUN4QixTQUFTLEVBQUUsU0FBUyxDQUFDO0lBQ3JCLHdDQUF3QztJQUN4QyxLQUFLLEVBQUUsTUFBTSxDQUFDO0lBQ2QsNENBQTRDO0lBQzVDLFFBQVEsRUFBRSxNQUFNLENBQUM7Q0FDbEI7QUFFRDs7R0FFRztBQUNILE1BQU0sV0FBVyxjQUFjO0lBQzdCLHNDQUFzQztJQUN0QyxTQUFTLEVBQUUsTUFBTSxDQUFDO0lBQ2xCLGtDQUFrQztJQUNsQyxNQUFNLENBQUMsRUFBRSxPQUFPLENBQUM7SUFDakIsNkJBQTZCO0lBQzdCLEtBQUssQ0FBQyxFQUFFLE9BQU8sQ0FBQztJQUNoQix1Q0FBdUM7SUFDdkMsUUFBUSxFQUFFLE1BQU0sQ0FBQztDQUNsQjtBQUVEOztHQUVHO0FBQ0gsTUFBTSxXQUFXLGdCQUFnQjtJQUMvQixpQ0FBaUM7SUFDakMsSUFBSSxFQUFFLGlCQUFpQixDQUFDLFNBQVMsQ0FBQztJQUNsQyxpQkFBaUI7SUFDakIsU0FBUyxFQUFFLE1BQU0sQ0FBQztJQUNsQix3Q0FBd0M7SUFDeEMsS0FBSyxFQUFFLE1BQU0sQ0FBQztJQUNkLGlFQUFpRTtJQUNqRSxTQUFTLEVBQUUsU0FBUyxDQUFDO0NBQ3RCO0FBRUQ7O0dBRUc7QUFDSCxNQUFNLFdBQVcsaUJBQWlCO0lBQ2hDLDBDQUEwQztJQUMxQyxJQUFJLEVBQUUsaUJBQWlCLENBQUMsa0JBQWtCLENBQUM7SUFDM0MsZ0RBQWdEO0lBQ2hELFNBQVMsRUFBRSxNQUFNLENBQUM7SUFDbEIsK0JBQStCO0lBQy9CLFVBQVUsRUFBRSxVQUFVLENBQUM7Q0FDeEI7QUFFRDs7R0FFRztBQUNILE1BQU0sV0FBVyxrQkFBa0I7SUFDakMsbUJBQW1CO0lBQ25CLElBQUksRUFBRSxpQkFBaUIsQ0FBQyxvQkFBb0IsQ0FBQztJQUM3QyxnREFBZ0Q7SUFDaEQsU0FBUyxFQUFFLE1BQU0sQ0FBQztJQUNsQix3REFBd0Q7SUFDeEQsU0FBUyxFQUFFLGlCQUFpQixDQUFDO0NBQzlCO0FBRUQ7O0dBRUc7QUFDSCxNQUFNLFdBQVcsbUJBQW1CO0lBQ2xDLG1CQUFtQjtJQUNuQixJQUFJLEVBQUUsaUJBQWlCLENBQUMscUJBQXFCLENBQUM7SUFDOUMsZ0RBQWdEO0lBQ2hELFNBQVMsRUFBRSxNQUFNLENBQUM7SUFDbEIsMERBQTBEO0lBQzFELFNBQVMsRUFBRSxpQkFBaUIsQ0FBQztDQUM5QiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAEzD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAErD;;;GAGG;AACH,oBAAY,iBAAiB;IAC3B,kDAAkD;IAClD,SAAS,2BAA2B;IACpC,uCAAuC;IACvC,kBAAkB,oCAAoC;IACtD,sEAAsE;IACtE,UAAU,4BAA4B;IACtC,oDAAoD;IACpD,oBAAoB,sCAAsC;IAC1D,qDAAqD;IACrD,qBAAqB,uCAAuC;CAC7D;AAED;;;GAGG;AACH,MAAM,WAAW,UAAU;IACzB,uCAAuC;IACvC,EAAE,EAAE,MAAM,CAAC;IACX,iCAAiC;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,+BAA+B;IAC/B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,qBAAqB;IACrB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED;;;GAGG;AACH,MAAM,WAAW,mBAAoB,SAAQ,UAAU;IACrD,gEAAgE;IAChE,SAAS,EAAE,iBAAiB,CAAC;IAC7B;;;;OAIG;IACH,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,+CAA+C;IAC/C,SAAS,EAAE,MAAM,CAAC;IAClB,gCAAgC;IAChC,IAAI,EAAE,MAAM,CAAC;IACb,+BAA+B;IAC/B,IAAI,EAAE,OAAO,EAAE,CAAC;IAChB,wBAAwB;IACxB,SAAS,EAAE,SAAS,CAAC;IACrB,wCAAwC;IACxC,KAAK,EAAE,MAAM,CAAC;IACd,4CAA4C;IAC5C,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,sCAAsC;IACtC,SAAS,EAAE,MAAM,CAAC;IAClB,kCAAkC;IAClC,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,6BAA6B;IAC7B,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,uCAAuC;IACvC,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,iCAAiC;IACjC,IAAI,EAAE,iBAAiB,CAAC,SAAS,CAAC;IAClC,iBAAiB;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,wCAAwC;IACxC,KAAK,EAAE,MAAM,CAAC;IACd,iEAAiE;IACjE,SAAS,EAAE,SAAS,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,0CAA0C;IAC1C,IAAI,EAAE,iBAAiB,CAAC,kBAAkB,CAAC;IAC3C,gDAAgD;IAChD,SAAS,EAAE,MAAM,CAAC;IAClB,+BAA+B;IAC/B,UAAU,EAAE,UAAU,CAAC;CACxB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,mBAAmB;IACnB,IAAI,EAAE,iBAAiB,CAAC,oBAAoB,CAAC;IAC7C,gDAAgD;IAChD,SAAS,EAAE,MAAM,CAAC;IAClB,wDAAwD;IACxD,SAAS,EAAE,iBAAiB,CAAC;CAC9B;AAED;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,mBAAmB;IACnB,IAAI,EAAE,iBAAiB,CAAC,qBAAqB,CAAC;IAC9C,gDAAgD;IAChD,SAAS,EAAE,MAAM,CAAC;IAClB,0DAA0D;IAC1D,SAAS,EAAE,iBAAiB,CAAC;CAC9B"}
package/dest/types.js ADDED
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Message types for wallet SDK communication.
3
+ * All types are prefixed with 'aztec-wallet-' for namespacing.
4
+ */ export var WalletMessageType = /*#__PURE__*/ function(WalletMessageType) {
5
+ /** Discovery request to find installed wallets */ WalletMessageType["DISCOVERY"] = "aztec-wallet-discovery";
6
+ /** Discovery response from a wallet */ WalletMessageType["DISCOVERY_RESPONSE"] = "aztec-wallet-discovery-response";
7
+ /** Disconnect message (unencrypted control message, bidirectional) */ WalletMessageType["DISCONNECT"] = "aztec-wallet-disconnect";
8
+ /** Key exchange request sent over MessageChannel */ WalletMessageType["KEY_EXCHANGE_REQUEST"] = "aztec-wallet-key-exchange-request";
9
+ /** Key exchange response sent over MessageChannel */ WalletMessageType["KEY_EXCHANGE_RESPONSE"] = "aztec-wallet-key-exchange-response";
10
+ return WalletMessageType;
11
+ }({});
package/package.json ADDED
@@ -0,0 +1,105 @@
1
+ {
2
+ "name": "@aztec/wallet-sdk",
3
+ "homepage": "https://github.com/AztecProtocol/aztec-packages/tree/master/yarn-project/wallet-sdk",
4
+ "version": "0.0.1-commit.001888fc",
5
+ "type": "module",
6
+ "exports": {
7
+ "./base-wallet": "./dest/base-wallet/index.js",
8
+ "./extension/handlers": "./dest/extension/handlers/index.js",
9
+ "./extension/provider": "./dest/extension/provider/index.js",
10
+ "./crypto": "./dest/crypto.js",
11
+ "./types": "./dest/types.js",
12
+ "./manager": "./dest/manager/index.js"
13
+ },
14
+ "typedocOptions": {
15
+ "entryPoints": [
16
+ "./src/base-wallet/index.ts",
17
+ "./src/extension/handlers/index.ts",
18
+ "./src/extension/provider/index.ts",
19
+ "./src/crypto.ts",
20
+ "./src/types.ts",
21
+ "./src/manager/index.ts"
22
+ ],
23
+ "name": "Wallet SDK",
24
+ "tsconfig": "./tsconfig.json"
25
+ },
26
+ "scripts": {
27
+ "build": "yarn clean && ../scripts/tsc.sh",
28
+ "build:dev": "../scripts/tsc.sh --watch",
29
+ "build:ts": "tsc -b",
30
+ "clean": "rm -rf ./dest .tsbuildinfo",
31
+ "test": "NODE_NO_WARNINGS=1 node --experimental-vm-modules ../node_modules/.bin/jest --passWithNoTests --maxWorkers=${JEST_MAX_WORKERS:-8}"
32
+ },
33
+ "inherits": [
34
+ "../package.common.json"
35
+ ],
36
+ "jest": {
37
+ "moduleNameMapper": {
38
+ "^(\\.{1,2}/.*)\\.[cm]?js$": "$1"
39
+ },
40
+ "testRegex": "./src/.*\\.test\\.(js|mjs|ts)$",
41
+ "rootDir": "./src",
42
+ "transform": {
43
+ "^.+\\.tsx?$": [
44
+ "@swc/jest",
45
+ {
46
+ "jsc": {
47
+ "parser": {
48
+ "syntax": "typescript",
49
+ "decorators": true
50
+ },
51
+ "transform": {
52
+ "decoratorVersion": "2022-03"
53
+ }
54
+ }
55
+ }
56
+ ]
57
+ },
58
+ "extensionsToTreatAsEsm": [
59
+ ".ts"
60
+ ],
61
+ "reporters": [
62
+ "default"
63
+ ],
64
+ "testTimeout": 120000,
65
+ "setupFiles": [
66
+ "../../foundation/src/jest/setup.mjs"
67
+ ],
68
+ "testEnvironment": "../../foundation/src/jest/env.mjs",
69
+ "setupFilesAfterEnv": [
70
+ "../../foundation/src/jest/setupAfterEnv.mjs"
71
+ ]
72
+ },
73
+ "dependencies": {
74
+ "@aztec/aztec.js": "0.0.1-commit.001888fc",
75
+ "@aztec/constants": "0.0.1-commit.001888fc",
76
+ "@aztec/entrypoints": "0.0.1-commit.001888fc",
77
+ "@aztec/foundation": "0.0.1-commit.001888fc",
78
+ "@aztec/pxe": "0.0.1-commit.001888fc",
79
+ "@aztec/stdlib": "0.0.1-commit.001888fc"
80
+ },
81
+ "devDependencies": {
82
+ "@aztec/noir-contracts.js": "0.0.1-commit.001888fc",
83
+ "@jest/globals": "^30.0.0",
84
+ "@types/jest": "^30.0.0",
85
+ "@types/node": "^22.15.17",
86
+ "@typescript/native-preview": "7.0.0-dev.20260113.1",
87
+ "jest": "^30.0.0",
88
+ "jest-mock-extended": "^4.0.0",
89
+ "resolve-typescript-plugin": "^2.0.1",
90
+ "ts-loader": "^9.5.4",
91
+ "ts-node": "^10.9.1",
92
+ "typescript": "^5.3.3",
93
+ "util": "^0.12.5"
94
+ },
95
+ "files": [
96
+ "dest",
97
+ "src",
98
+ "!*.test.*",
99
+ "artifacts"
100
+ ],
101
+ "types": "./dest/index.d.ts",
102
+ "engines": {
103
+ "node": ">=20.10"
104
+ }
105
+ }