@metamask-previews/keyring-api 8.1.0-38c4bd5

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 (105) hide show
  1. package/CHANGELOG.md +428 -0
  2. package/README.md +401 -0
  3. package/dist/JsonRpcRequest.d.ts +16 -0
  4. package/dist/JsonRpcRequest.js +13 -0
  5. package/dist/JsonRpcRequest.js.map +1 -0
  6. package/dist/KeyringClient.d.ts +28 -0
  7. package/dist/KeyringClient.js +124 -0
  8. package/dist/KeyringClient.js.map +1 -0
  9. package/dist/KeyringSnapRpcClient.d.ts +39 -0
  10. package/dist/KeyringSnapRpcClient.js +68 -0
  11. package/dist/KeyringSnapRpcClient.js.map +1 -0
  12. package/dist/api/account.d.ts +62 -0
  13. package/dist/api/account.js +56 -0
  14. package/dist/api/account.js.map +1 -0
  15. package/dist/api/balance.d.ts +9 -0
  16. package/dist/api/balance.js +11 -0
  17. package/dist/api/balance.js.map +1 -0
  18. package/dist/api/caip.d.ts +37 -0
  19. package/dist/api/caip.js +48 -0
  20. package/dist/api/caip.js.map +1 -0
  21. package/dist/api/export.d.ts +8 -0
  22. package/dist/api/export.js +7 -0
  23. package/dist/api/export.js.map +1 -0
  24. package/dist/api/index.d.ts +7 -0
  25. package/dist/api/index.js +24 -0
  26. package/dist/api/index.js.map +1 -0
  27. package/dist/api/keyring.d.ts +159 -0
  28. package/dist/api/keyring.js +3 -0
  29. package/dist/api/keyring.js.map +1 -0
  30. package/dist/api/request.d.ts +39 -0
  31. package/dist/api/request.js +29 -0
  32. package/dist/api/request.js.map +1 -0
  33. package/dist/api/response.d.ts +24 -0
  34. package/dist/api/response.js +44 -0
  35. package/dist/api/response.js.map +1 -0
  36. package/dist/btc/index.d.ts +1 -0
  37. package/dist/btc/index.js +18 -0
  38. package/dist/btc/index.js.map +1 -0
  39. package/dist/btc/types.d.ts +33 -0
  40. package/dist/btc/types.js +40 -0
  41. package/dist/btc/types.js.map +1 -0
  42. package/dist/contexts.d.ts +7 -0
  43. package/dist/contexts.js +3 -0
  44. package/dist/contexts.js.map +1 -0
  45. package/dist/eth/erc4337/index.d.ts +1 -0
  46. package/dist/eth/erc4337/index.js +18 -0
  47. package/dist/eth/erc4337/index.js.map +1 -0
  48. package/dist/eth/erc4337/types.d.ts +96 -0
  49. package/dist/eth/erc4337/types.js +61 -0
  50. package/dist/eth/erc4337/types.js.map +1 -0
  51. package/dist/eth/index.d.ts +3 -0
  52. package/dist/eth/index.js +20 -0
  53. package/dist/eth/index.js.map +1 -0
  54. package/dist/eth/types.d.ts +80 -0
  55. package/dist/eth/types.js +73 -0
  56. package/dist/eth/types.js.map +1 -0
  57. package/dist/eth/utils.d.ts +8 -0
  58. package/dist/eth/utils.js +15 -0
  59. package/dist/eth/utils.js.map +1 -0
  60. package/dist/events.d.ts +10 -0
  61. package/dist/events.js +17 -0
  62. package/dist/events.js.map +1 -0
  63. package/dist/index.d.ts +11 -0
  64. package/dist/index.js +28 -0
  65. package/dist/index.js.map +1 -0
  66. package/dist/internal/api.d.ts +415 -0
  67. package/dist/internal/api.js +139 -0
  68. package/dist/internal/api.js.map +1 -0
  69. package/dist/internal/eth/EthKeyring.d.ts +33 -0
  70. package/dist/internal/eth/EthKeyring.js +3 -0
  71. package/dist/internal/eth/EthKeyring.js.map +1 -0
  72. package/dist/internal/eth/index.d.ts +1 -0
  73. package/dist/internal/eth/index.js +18 -0
  74. package/dist/internal/eth/index.js.map +1 -0
  75. package/dist/internal/events.d.ts +159 -0
  76. package/dist/internal/events.js +72 -0
  77. package/dist/internal/events.js.map +1 -0
  78. package/dist/internal/index.d.ts +5 -0
  79. package/dist/internal/index.js +22 -0
  80. package/dist/internal/index.js.map +1 -0
  81. package/dist/internal/rpc.d.ts +25 -0
  82. package/dist/internal/rpc.js +33 -0
  83. package/dist/internal/rpc.js.map +1 -0
  84. package/dist/internal/types.d.ts +330 -0
  85. package/dist/internal/types.js +49 -0
  86. package/dist/internal/types.js.map +1 -0
  87. package/dist/rpc-handler.d.ts +29 -0
  88. package/dist/rpc-handler.js +136 -0
  89. package/dist/rpc-handler.js.map +1 -0
  90. package/dist/snap-utils.d.ts +11 -0
  91. package/dist/snap-utils.js +21 -0
  92. package/dist/snap-utils.js.map +1 -0
  93. package/dist/superstruct.d.ts +83 -0
  94. package/dist/superstruct.js +81 -0
  95. package/dist/superstruct.js.map +1 -0
  96. package/dist/utils/index.d.ts +2 -0
  97. package/dist/utils/index.js +19 -0
  98. package/dist/utils/index.js.map +1 -0
  99. package/dist/utils/types.d.ts +17 -0
  100. package/dist/utils/types.js +29 -0
  101. package/dist/utils/types.js.map +1 -0
  102. package/dist/utils/typing.d.ts +32 -0
  103. package/dist/utils/typing.js +21 -0
  104. package/dist/utils/typing.js.map +1 -0
  105. package/package.json +84 -0
@@ -0,0 +1,330 @@
1
+ import type { Infer, Struct } from '@metamask/superstruct';
2
+ import { BtcAccountType, EthAccountType } from '../api';
3
+ export declare type InternalAccountType = EthAccountType | BtcAccountType;
4
+ export declare const InternalAccountMetadataStruct: Struct<{
5
+ metadata: {
6
+ name: string;
7
+ importTime: number;
8
+ keyring: {
9
+ type: string;
10
+ };
11
+ nameLastUpdatedAt?: number;
12
+ snap?: {
13
+ id: string;
14
+ name: string;
15
+ enabled: boolean;
16
+ };
17
+ lastSelected?: number;
18
+ };
19
+ }, {
20
+ metadata: Struct<{
21
+ name: string;
22
+ importTime: number;
23
+ keyring: {
24
+ type: string;
25
+ };
26
+ nameLastUpdatedAt?: number;
27
+ snap?: {
28
+ id: string;
29
+ name: string;
30
+ enabled: boolean;
31
+ };
32
+ lastSelected?: number;
33
+ }, {
34
+ name: Struct<string, null>;
35
+ nameLastUpdatedAt: Struct<number | import("../superstruct").ExactOptionalTag, null>;
36
+ snap: Struct<import("../superstruct").ExactOptionalTag | {
37
+ id: string;
38
+ name: string;
39
+ enabled: boolean;
40
+ }, {
41
+ id: Struct<string, null>;
42
+ enabled: Struct<boolean, null>;
43
+ name: Struct<string, null>;
44
+ }>;
45
+ lastSelected: Struct<number | import("../superstruct").ExactOptionalTag, null>;
46
+ importTime: Struct<number, null>;
47
+ keyring: Struct<{
48
+ type: string;
49
+ }, {
50
+ type: Struct<string, null>;
51
+ }>;
52
+ }>;
53
+ }>;
54
+ export declare const InternalEthEoaAccountStruct: Struct<{
55
+ type: "eip155:eoa";
56
+ id: string;
57
+ address: string;
58
+ options: Record<string, import("@metamask/utils").Json>;
59
+ methods: ("personal_sign" | "eth_sign" | "eth_signTransaction" | "eth_signTypedData_v1" | "eth_signTypedData_v3" | "eth_signTypedData_v4")[];
60
+ metadata: {
61
+ name: string;
62
+ importTime: number;
63
+ keyring: {
64
+ type: string;
65
+ };
66
+ nameLastUpdatedAt?: number;
67
+ snap?: {
68
+ id: string;
69
+ name: string;
70
+ enabled: boolean;
71
+ };
72
+ lastSelected?: number;
73
+ };
74
+ }, {
75
+ address: Struct<string, null>;
76
+ type: Struct<"eip155:eoa", "eip155:eoa">;
77
+ methods: Struct<("personal_sign" | "eth_sign" | "eth_signTransaction" | "eth_signTypedData_v1" | "eth_signTypedData_v3" | "eth_signTypedData_v4")[], Struct<"personal_sign" | "eth_sign" | "eth_signTransaction" | "eth_signTypedData_v1" | "eth_signTypedData_v3" | "eth_signTypedData_v4", {
78
+ personal_sign: "personal_sign";
79
+ eth_sign: "eth_sign";
80
+ eth_signTransaction: "eth_signTransaction";
81
+ eth_signTypedData_v1: "eth_signTypedData_v1";
82
+ eth_signTypedData_v3: "eth_signTypedData_v3";
83
+ eth_signTypedData_v4: "eth_signTypedData_v4";
84
+ }>>;
85
+ id: Struct<string, null>;
86
+ options: Struct<Record<string, import("@metamask/utils").Json>, null>;
87
+ } & {
88
+ metadata: Struct<{
89
+ name: string;
90
+ importTime: number;
91
+ keyring: {
92
+ type: string;
93
+ };
94
+ nameLastUpdatedAt?: number;
95
+ snap?: {
96
+ id: string;
97
+ name: string;
98
+ enabled: boolean;
99
+ };
100
+ lastSelected?: number;
101
+ }, {
102
+ name: Struct<string, null>;
103
+ nameLastUpdatedAt: Struct<number | import("../superstruct").ExactOptionalTag, null>;
104
+ snap: Struct<import("../superstruct").ExactOptionalTag | {
105
+ id: string;
106
+ name: string;
107
+ enabled: boolean;
108
+ }, {
109
+ id: Struct<string, null>;
110
+ enabled: Struct<boolean, null>;
111
+ name: Struct<string, null>;
112
+ }>;
113
+ lastSelected: Struct<number | import("../superstruct").ExactOptionalTag, null>;
114
+ importTime: Struct<number, null>;
115
+ keyring: Struct<{
116
+ type: string;
117
+ }, {
118
+ type: Struct<string, null>;
119
+ }>;
120
+ }>;
121
+ }>;
122
+ export declare const InternalEthErc4337AccountStruct: Struct<{
123
+ type: "eip155:erc4337";
124
+ id: string;
125
+ address: string;
126
+ options: Record<string, import("@metamask/utils").Json>;
127
+ methods: ("personal_sign" | "eth_sign" | "eth_signTypedData_v1" | "eth_signTypedData_v3" | "eth_signTypedData_v4" | "eth_prepareUserOperation" | "eth_patchUserOperation" | "eth_signUserOperation")[];
128
+ metadata: {
129
+ name: string;
130
+ importTime: number;
131
+ keyring: {
132
+ type: string;
133
+ };
134
+ nameLastUpdatedAt?: number;
135
+ snap?: {
136
+ id: string;
137
+ name: string;
138
+ enabled: boolean;
139
+ };
140
+ lastSelected?: number;
141
+ };
142
+ }, {
143
+ address: Struct<string, null>;
144
+ type: Struct<"eip155:erc4337", "eip155:erc4337">;
145
+ methods: Struct<("personal_sign" | "eth_sign" | "eth_signTypedData_v1" | "eth_signTypedData_v3" | "eth_signTypedData_v4" | "eth_prepareUserOperation" | "eth_patchUserOperation" | "eth_signUserOperation")[], Struct<"personal_sign" | "eth_sign" | "eth_signTypedData_v1" | "eth_signTypedData_v3" | "eth_signTypedData_v4" | "eth_prepareUserOperation" | "eth_patchUserOperation" | "eth_signUserOperation", {
146
+ personal_sign: "personal_sign";
147
+ eth_sign: "eth_sign";
148
+ eth_signTypedData_v1: "eth_signTypedData_v1";
149
+ eth_signTypedData_v3: "eth_signTypedData_v3";
150
+ eth_signTypedData_v4: "eth_signTypedData_v4";
151
+ eth_prepareUserOperation: "eth_prepareUserOperation";
152
+ eth_patchUserOperation: "eth_patchUserOperation";
153
+ eth_signUserOperation: "eth_signUserOperation";
154
+ }>>;
155
+ id: Struct<string, null>;
156
+ options: Struct<Record<string, import("@metamask/utils").Json>, null>;
157
+ } & {
158
+ metadata: Struct<{
159
+ name: string;
160
+ importTime: number;
161
+ keyring: {
162
+ type: string;
163
+ };
164
+ nameLastUpdatedAt?: number;
165
+ snap?: {
166
+ id: string;
167
+ name: string;
168
+ enabled: boolean;
169
+ };
170
+ lastSelected?: number;
171
+ }, {
172
+ name: Struct<string, null>;
173
+ nameLastUpdatedAt: Struct<number | import("../superstruct").ExactOptionalTag, null>;
174
+ snap: Struct<import("../superstruct").ExactOptionalTag | {
175
+ id: string;
176
+ name: string;
177
+ enabled: boolean;
178
+ }, {
179
+ id: Struct<string, null>;
180
+ enabled: Struct<boolean, null>;
181
+ name: Struct<string, null>;
182
+ }>;
183
+ lastSelected: Struct<number | import("../superstruct").ExactOptionalTag, null>;
184
+ importTime: Struct<number, null>;
185
+ keyring: Struct<{
186
+ type: string;
187
+ }, {
188
+ type: Struct<string, null>;
189
+ }>;
190
+ }>;
191
+ }>;
192
+ export declare const InternalBtcP2wpkhAccountStruct: Struct<{
193
+ type: "bip122:p2wpkh";
194
+ id: string;
195
+ address: string;
196
+ options: Record<string, import("@metamask/utils").Json>;
197
+ methods: "btc_sendmany"[];
198
+ metadata: {
199
+ name: string;
200
+ importTime: number;
201
+ keyring: {
202
+ type: string;
203
+ };
204
+ nameLastUpdatedAt?: number;
205
+ snap?: {
206
+ id: string;
207
+ name: string;
208
+ enabled: boolean;
209
+ };
210
+ lastSelected?: number;
211
+ };
212
+ }, {
213
+ address: Struct<string, null>;
214
+ type: Struct<"bip122:p2wpkh", "bip122:p2wpkh">;
215
+ methods: Struct<"btc_sendmany"[], Struct<"btc_sendmany", {
216
+ btc_sendmany: "btc_sendmany";
217
+ }>>;
218
+ id: Struct<string, null>;
219
+ options: Struct<Record<string, import("@metamask/utils").Json>, null>;
220
+ } & {
221
+ metadata: Struct<{
222
+ name: string;
223
+ importTime: number;
224
+ keyring: {
225
+ type: string;
226
+ };
227
+ nameLastUpdatedAt?: number;
228
+ snap?: {
229
+ id: string;
230
+ name: string;
231
+ enabled: boolean;
232
+ };
233
+ lastSelected?: number;
234
+ }, {
235
+ name: Struct<string, null>;
236
+ nameLastUpdatedAt: Struct<number | import("../superstruct").ExactOptionalTag, null>;
237
+ snap: Struct<import("../superstruct").ExactOptionalTag | {
238
+ id: string;
239
+ name: string;
240
+ enabled: boolean;
241
+ }, {
242
+ id: Struct<string, null>;
243
+ enabled: Struct<boolean, null>;
244
+ name: Struct<string, null>;
245
+ }>;
246
+ lastSelected: Struct<number | import("../superstruct").ExactOptionalTag, null>;
247
+ importTime: Struct<number, null>;
248
+ keyring: Struct<{
249
+ type: string;
250
+ }, {
251
+ type: Struct<string, null>;
252
+ }>;
253
+ }>;
254
+ }>;
255
+ export declare type InternalEthEoaAccount = Infer<typeof InternalEthEoaAccountStruct>;
256
+ export declare type InternalEthErc4337Account = Infer<typeof InternalEthErc4337AccountStruct>;
257
+ export declare type InternalBtcP2wpkhAccount = Infer<typeof InternalBtcP2wpkhAccountStruct>;
258
+ export declare const InternalAccountStructs: Record<string, Struct<InternalEthEoaAccount> | Struct<InternalEthErc4337Account> | Struct<InternalBtcP2wpkhAccount>>;
259
+ export declare type InternalAccountTypes = InternalEthEoaAccount | InternalEthErc4337Account | InternalBtcP2wpkhAccount;
260
+ export declare const InternalAccountStruct: Struct<{
261
+ type: "eip155:eoa" | "eip155:erc4337" | "bip122:p2wpkh";
262
+ id: string;
263
+ address: string;
264
+ options: Record<string, import("@metamask/utils").Json>;
265
+ methods: string[];
266
+ metadata: {
267
+ name: string;
268
+ importTime: number;
269
+ keyring: {
270
+ type: string;
271
+ };
272
+ nameLastUpdatedAt?: number;
273
+ snap?: {
274
+ id: string;
275
+ name: string;
276
+ enabled: boolean;
277
+ };
278
+ lastSelected?: number;
279
+ };
280
+ }, {
281
+ metadata: Struct<{
282
+ name: string;
283
+ importTime: number;
284
+ keyring: {
285
+ type: string;
286
+ };
287
+ nameLastUpdatedAt?: number;
288
+ snap?: {
289
+ id: string;
290
+ name: string;
291
+ enabled: boolean;
292
+ };
293
+ lastSelected?: number;
294
+ }, {
295
+ name: Struct<string, null>;
296
+ nameLastUpdatedAt: Struct<number | import("../superstruct").ExactOptionalTag, null>;
297
+ snap: Struct<import("../superstruct").ExactOptionalTag | {
298
+ id: string;
299
+ name: string;
300
+ enabled: boolean;
301
+ }, {
302
+ id: Struct<string, null>;
303
+ enabled: Struct<boolean, null>;
304
+ name: Struct<string, null>;
305
+ }>;
306
+ lastSelected: Struct<number | import("../superstruct").ExactOptionalTag, null>;
307
+ importTime: Struct<number, null>;
308
+ keyring: Struct<{
309
+ type: string;
310
+ }, {
311
+ type: Struct<string, null>;
312
+ }>;
313
+ }>;
314
+ id: Struct<string, null>;
315
+ type: Struct<"eip155:eoa" | "eip155:erc4337" | "bip122:p2wpkh", {
316
+ "eip155:eoa": "eip155:eoa";
317
+ "eip155:erc4337": "eip155:erc4337";
318
+ "bip122:p2wpkh": "bip122:p2wpkh";
319
+ }>;
320
+ address: Struct<string, null>;
321
+ options: Struct<Record<string, import("@metamask/utils").Json>, null>;
322
+ methods: Struct<string[], Struct<string, null>>;
323
+ }>;
324
+ /**
325
+ * Internal account representation.
326
+ *
327
+ * This type is used internally by MetaMask to add additional metadata to the
328
+ * account object. It's should not be used by external applications.
329
+ */
330
+ export declare type InternalAccount = Infer<typeof InternalAccountStruct>;
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InternalAccountStruct = exports.InternalAccountStructs = exports.InternalBtcP2wpkhAccountStruct = exports.InternalEthErc4337AccountStruct = exports.InternalEthEoaAccountStruct = exports.InternalAccountMetadataStruct = void 0;
4
+ const superstruct_1 = require("@metamask/superstruct");
5
+ const api_1 = require("../api");
6
+ const types_1 = require("../btc/types");
7
+ const types_2 = require("../eth/types");
8
+ const superstruct_2 = require("../superstruct");
9
+ exports.InternalAccountMetadataStruct = (0, superstruct_2.object)({
10
+ metadata: (0, superstruct_2.object)({
11
+ name: (0, superstruct_1.string)(),
12
+ nameLastUpdatedAt: (0, superstruct_2.exactOptional)((0, superstruct_1.number)()),
13
+ snap: (0, superstruct_2.exactOptional)((0, superstruct_2.object)({
14
+ id: (0, superstruct_1.string)(),
15
+ enabled: (0, superstruct_1.boolean)(),
16
+ name: (0, superstruct_1.string)(),
17
+ })),
18
+ lastSelected: (0, superstruct_2.exactOptional)((0, superstruct_1.number)()),
19
+ importTime: (0, superstruct_1.number)(),
20
+ keyring: (0, superstruct_2.object)({
21
+ type: (0, superstruct_1.string)(),
22
+ }),
23
+ }),
24
+ });
25
+ /**
26
+ * Creates an `InternalAccount` from an existing account `superstruct` object.
27
+ *
28
+ * @param accountStruct - An account `superstruct` object.
29
+ * @returns The `InternalAccount` associated to `accountStruct`.
30
+ */
31
+ function asInternalAccountStruct(accountStruct) {
32
+ return (0, superstruct_2.object)({
33
+ ...accountStruct.schema,
34
+ ...exports.InternalAccountMetadataStruct.schema,
35
+ });
36
+ }
37
+ exports.InternalEthEoaAccountStruct = asInternalAccountStruct(types_2.EthEoaAccountStruct);
38
+ exports.InternalEthErc4337AccountStruct = asInternalAccountStruct(types_2.EthErc4337AccountStruct);
39
+ exports.InternalBtcP2wpkhAccountStruct = asInternalAccountStruct(types_1.BtcP2wpkhAccountStruct);
40
+ exports.InternalAccountStructs = {
41
+ [`${api_1.EthAccountType.Eoa}`]: exports.InternalEthEoaAccountStruct,
42
+ [`${api_1.EthAccountType.Erc4337}`]: exports.InternalEthErc4337AccountStruct,
43
+ [`${api_1.BtcAccountType.P2wpkh}`]: exports.InternalBtcP2wpkhAccountStruct,
44
+ };
45
+ exports.InternalAccountStruct = (0, superstruct_2.object)({
46
+ ...api_1.KeyringAccountStruct.schema,
47
+ ...exports.InternalAccountMetadataStruct.schema,
48
+ });
49
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/internal/types.ts"],"names":[],"mappings":";;;AACA,uDAAgE;AAEhE,gCAA8E;AAC9E,wCAAsD;AACtD,wCAA4E;AAC5E,gDAAuD;AAI1C,QAAA,6BAA6B,GAAG,IAAA,oBAAM,EAAC;IAClD,QAAQ,EAAE,IAAA,oBAAM,EAAC;QACf,IAAI,EAAE,IAAA,oBAAM,GAAE;QACd,iBAAiB,EAAE,IAAA,2BAAa,EAAC,IAAA,oBAAM,GAAE,CAAC;QAC1C,IAAI,EAAE,IAAA,2BAAa,EACjB,IAAA,oBAAM,EAAC;YACL,EAAE,EAAE,IAAA,oBAAM,GAAE;YACZ,OAAO,EAAE,IAAA,qBAAO,GAAE;YAClB,IAAI,EAAE,IAAA,oBAAM,GAAE;SACf,CAAC,CACH;QACD,YAAY,EAAE,IAAA,2BAAa,EAAC,IAAA,oBAAM,GAAE,CAAC;QACrC,UAAU,EAAE,IAAA,oBAAM,GAAE;QACpB,OAAO,EAAE,IAAA,oBAAM,EAAC;YACd,IAAI,EAAE,IAAA,oBAAM,GAAE;SACf,CAAC;KACH,CAAC;CACH,CAAC,CAAC;AAEH;;;;;GAKG;AACH,SAAS,uBAAuB,CAC9B,aAA6C;IAE7C,OAAO,IAAA,oBAAM,EAAC;QACZ,GAAG,aAAa,CAAC,MAAM;QACvB,GAAG,qCAA6B,CAAC,MAAM;KACxC,CAAC,CAAC;AACL,CAAC;AAEY,QAAA,2BAA2B,GACtC,uBAAuB,CAAC,2BAAmB,CAAC,CAAC;AAElC,QAAA,+BAA+B,GAAG,uBAAuB,CACpE,+BAAuB,CACxB,CAAC;AAEW,QAAA,8BAA8B,GAAG,uBAAuB,CACnE,8BAAsB,CACvB,CAAC;AAYW,QAAA,sBAAsB,GAK/B;IACF,CAAC,GAAG,oBAAc,CAAC,GAAG,EAAE,CAAC,EAAE,mCAA2B;IACtD,CAAC,GAAG,oBAAc,CAAC,OAAO,EAAE,CAAC,EAAE,uCAA+B;IAC9D,CAAC,GAAG,oBAAc,CAAC,MAAM,EAAE,CAAC,EAAE,sCAA8B;CAC7D,CAAC;AAOW,QAAA,qBAAqB,GAAG,IAAA,oBAAM,EAAC;IAC1C,GAAG,0BAAoB,CAAC,MAAM;IAC9B,GAAG,qCAA6B,CAAC,MAAM;CACxC,CAAC,CAAC","sourcesContent":["import type { Infer, Struct } from '@metamask/superstruct';\nimport { boolean, string, number } from '@metamask/superstruct';\n\nimport { BtcAccountType, EthAccountType, KeyringAccountStruct } from '../api';\nimport { BtcP2wpkhAccountStruct } from '../btc/types';\nimport { EthEoaAccountStruct, EthErc4337AccountStruct } from '../eth/types';\nimport { exactOptional, object } from '../superstruct';\n\nexport type InternalAccountType = EthAccountType | BtcAccountType;\n\nexport const InternalAccountMetadataStruct = object({\n metadata: object({\n name: string(),\n nameLastUpdatedAt: exactOptional(number()),\n snap: exactOptional(\n object({\n id: string(),\n enabled: boolean(),\n name: string(),\n }),\n ),\n lastSelected: exactOptional(number()),\n importTime: number(),\n keyring: object({\n type: string(),\n }),\n }),\n});\n\n/**\n * Creates an `InternalAccount` from an existing account `superstruct` object.\n *\n * @param accountStruct - An account `superstruct` object.\n * @returns The `InternalAccount` associated to `accountStruct`.\n */\nfunction asInternalAccountStruct<Account, AccountSchema>(\n accountStruct: Struct<Account, AccountSchema>,\n) {\n return object({\n ...accountStruct.schema,\n ...InternalAccountMetadataStruct.schema,\n });\n}\n\nexport const InternalEthEoaAccountStruct =\n asInternalAccountStruct(EthEoaAccountStruct);\n\nexport const InternalEthErc4337AccountStruct = asInternalAccountStruct(\n EthErc4337AccountStruct,\n);\n\nexport const InternalBtcP2wpkhAccountStruct = asInternalAccountStruct(\n BtcP2wpkhAccountStruct,\n);\n\nexport type InternalEthEoaAccount = Infer<typeof InternalEthEoaAccountStruct>;\n\nexport type InternalEthErc4337Account = Infer<\n typeof InternalEthErc4337AccountStruct\n>;\n\nexport type InternalBtcP2wpkhAccount = Infer<\n typeof InternalBtcP2wpkhAccountStruct\n>;\n\nexport const InternalAccountStructs: Record<\n string,\n | Struct<InternalEthEoaAccount>\n | Struct<InternalEthErc4337Account>\n | Struct<InternalBtcP2wpkhAccount>\n> = {\n [`${EthAccountType.Eoa}`]: InternalEthEoaAccountStruct,\n [`${EthAccountType.Erc4337}`]: InternalEthErc4337AccountStruct,\n [`${BtcAccountType.P2wpkh}`]: InternalBtcP2wpkhAccountStruct,\n};\n\nexport type InternalAccountTypes =\n | InternalEthEoaAccount\n | InternalEthErc4337Account\n | InternalBtcP2wpkhAccount;\n\nexport const InternalAccountStruct = object({\n ...KeyringAccountStruct.schema,\n ...InternalAccountMetadataStruct.schema,\n});\n\n/**\n * Internal account representation.\n *\n * This type is used internally by MetaMask to add additional metadata to the\n * account object. It's should not be used by external applications.\n */\nexport type InternalAccount = Infer<typeof InternalAccountStruct>;\n"]}
@@ -0,0 +1,29 @@
1
+ import type { Json } from '@metamask/utils';
2
+ import type { Keyring } from './api';
3
+ import type { JsonRpcRequest } from './JsonRpcRequest';
4
+ /**
5
+ * Error thrown when a keyring JSON-RPC method is not supported.
6
+ */
7
+ export declare class MethodNotSupportedError extends Error {
8
+ constructor(method: string);
9
+ }
10
+ /**
11
+ * Handles a keyring JSON-RPC request.
12
+ *
13
+ * This function is meant to be used as a handler for Keyring JSON-RPC requests
14
+ * in an Accounts Snap.
15
+ *
16
+ * @param keyring - Keyring instance.
17
+ * @param request - Keyring JSON-RPC request.
18
+ * @returns A promise that resolves to the keyring response.
19
+ * @example
20
+ * ```ts
21
+ * export const onKeyringRequest: OnKeyringRequestHandler = async ({
22
+ * origin,
23
+ * request,
24
+ * }) => {
25
+ * return await handleKeyringRequest(keyring, request);
26
+ * };
27
+ * ```
28
+ */
29
+ export declare function handleKeyringRequest(keyring: Keyring, request: JsonRpcRequest): Promise<Json | void>;
@@ -0,0 +1,136 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.handleKeyringRequest = exports.MethodNotSupportedError = void 0;
4
+ const superstruct_1 = require("@metamask/superstruct");
5
+ const api_1 = require("./internal/api");
6
+ const rpc_1 = require("./internal/rpc");
7
+ const JsonRpcRequest_1 = require("./JsonRpcRequest");
8
+ /**
9
+ * Error thrown when a keyring JSON-RPC method is not supported.
10
+ */
11
+ class MethodNotSupportedError extends Error {
12
+ constructor(method) {
13
+ super(`Method not supported: ${method}`);
14
+ }
15
+ }
16
+ exports.MethodNotSupportedError = MethodNotSupportedError;
17
+ /**
18
+ * Inner function that dispatches JSON-RPC request to the associated Keyring
19
+ * methods.
20
+ *
21
+ * @param keyring - Keyring instance.
22
+ * @param request - Keyring JSON-RPC request.
23
+ * @returns A promise that resolves to the keyring response.
24
+ */
25
+ async function dispatchRequest(keyring, request) {
26
+ // We first have to make sure that the request is a valid JSON-RPC request so
27
+ // we can check its method name.
28
+ (0, superstruct_1.assert)(request, JsonRpcRequest_1.JsonRpcRequestStruct);
29
+ switch (request.method) {
30
+ case rpc_1.KeyringRpcMethod.ListAccounts: {
31
+ (0, superstruct_1.assert)(request, api_1.ListAccountsRequestStruct);
32
+ return keyring.listAccounts();
33
+ }
34
+ case rpc_1.KeyringRpcMethod.GetAccount: {
35
+ (0, superstruct_1.assert)(request, api_1.GetAccountRequestStruct);
36
+ return keyring.getAccount(request.params.id);
37
+ }
38
+ case rpc_1.KeyringRpcMethod.CreateAccount: {
39
+ (0, superstruct_1.assert)(request, api_1.CreateAccountRequestStruct);
40
+ return keyring.createAccount(request.params.options);
41
+ }
42
+ case rpc_1.KeyringRpcMethod.GetAccountBalances: {
43
+ if (keyring.getAccountBalances === undefined) {
44
+ throw new MethodNotSupportedError(request.method);
45
+ }
46
+ (0, superstruct_1.assert)(request, api_1.GetAccountBalancesRequestStruct);
47
+ return keyring.getAccountBalances(request.params.id, request.params.assets);
48
+ }
49
+ case rpc_1.KeyringRpcMethod.FilterAccountChains: {
50
+ (0, superstruct_1.assert)(request, api_1.FilterAccountChainsStruct);
51
+ return keyring.filterAccountChains(request.params.id, request.params.chains);
52
+ }
53
+ case rpc_1.KeyringRpcMethod.UpdateAccount: {
54
+ (0, superstruct_1.assert)(request, api_1.UpdateAccountRequestStruct);
55
+ return keyring.updateAccount(request.params.account);
56
+ }
57
+ case rpc_1.KeyringRpcMethod.DeleteAccount: {
58
+ (0, superstruct_1.assert)(request, api_1.DeleteAccountRequestStruct);
59
+ return keyring.deleteAccount(request.params.id);
60
+ }
61
+ case rpc_1.KeyringRpcMethod.ExportAccount: {
62
+ if (keyring.exportAccount === undefined) {
63
+ throw new MethodNotSupportedError(request.method);
64
+ }
65
+ (0, superstruct_1.assert)(request, api_1.ExportAccountRequestStruct);
66
+ return keyring.exportAccount(request.params.id);
67
+ }
68
+ case rpc_1.KeyringRpcMethod.ListRequests: {
69
+ if (keyring.listRequests === undefined) {
70
+ throw new MethodNotSupportedError(request.method);
71
+ }
72
+ (0, superstruct_1.assert)(request, api_1.ListRequestsRequestStruct);
73
+ return keyring.listRequests();
74
+ }
75
+ case rpc_1.KeyringRpcMethod.GetRequest: {
76
+ if (keyring.getRequest === undefined) {
77
+ throw new MethodNotSupportedError(request.method);
78
+ }
79
+ (0, superstruct_1.assert)(request, api_1.GetRequestRequestStruct);
80
+ return keyring.getRequest(request.params.id);
81
+ }
82
+ case rpc_1.KeyringRpcMethod.SubmitRequest: {
83
+ (0, superstruct_1.assert)(request, api_1.SubmitRequestRequestStruct);
84
+ return keyring.submitRequest(request.params);
85
+ }
86
+ case rpc_1.KeyringRpcMethod.ApproveRequest: {
87
+ if (keyring.approveRequest === undefined) {
88
+ throw new MethodNotSupportedError(request.method);
89
+ }
90
+ (0, superstruct_1.assert)(request, api_1.ApproveRequestRequestStruct);
91
+ return keyring.approveRequest(request.params.id, request.params.data);
92
+ }
93
+ case rpc_1.KeyringRpcMethod.RejectRequest: {
94
+ if (keyring.rejectRequest === undefined) {
95
+ throw new MethodNotSupportedError(request.method);
96
+ }
97
+ (0, superstruct_1.assert)(request, api_1.RejectRequestRequestStruct);
98
+ return keyring.rejectRequest(request.params.id);
99
+ }
100
+ default: {
101
+ throw new MethodNotSupportedError(request.method);
102
+ }
103
+ }
104
+ }
105
+ /**
106
+ * Handles a keyring JSON-RPC request.
107
+ *
108
+ * This function is meant to be used as a handler for Keyring JSON-RPC requests
109
+ * in an Accounts Snap.
110
+ *
111
+ * @param keyring - Keyring instance.
112
+ * @param request - Keyring JSON-RPC request.
113
+ * @returns A promise that resolves to the keyring response.
114
+ * @example
115
+ * ```ts
116
+ * export const onKeyringRequest: OnKeyringRequestHandler = async ({
117
+ * origin,
118
+ * request,
119
+ * }) => {
120
+ * return await handleKeyringRequest(keyring, request);
121
+ * };
122
+ * ```
123
+ */
124
+ async function handleKeyringRequest(keyring, request) {
125
+ try {
126
+ return await dispatchRequest(keyring, request);
127
+ }
128
+ catch (error) {
129
+ const message = error instanceof Error && typeof error.message === 'string'
130
+ ? error.message
131
+ : 'An unknown error occurred while handling the keyring request';
132
+ throw new Error(message);
133
+ }
134
+ }
135
+ exports.handleKeyringRequest = handleKeyringRequest;
136
+ //# sourceMappingURL=rpc-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rpc-handler.js","sourceRoot":"","sources":["../src/rpc-handler.ts"],"names":[],"mappings":"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","sourcesContent":["import { assert } from '@metamask/superstruct';\nimport type { Json } from '@metamask/utils';\n\nimport type { Keyring } from './api';\nimport {\n GetAccountRequestStruct,\n CreateAccountRequestStruct,\n ApproveRequestRequestStruct,\n DeleteAccountRequestStruct,\n ExportAccountRequestStruct,\n GetRequestRequestStruct,\n RejectRequestRequestStruct,\n SubmitRequestRequestStruct,\n UpdateAccountRequestStruct,\n FilterAccountChainsStruct,\n ListAccountsRequestStruct,\n ListRequestsRequestStruct,\n GetAccountBalancesRequestStruct,\n} from './internal/api';\nimport { KeyringRpcMethod } from './internal/rpc';\nimport type { JsonRpcRequest } from './JsonRpcRequest';\nimport { JsonRpcRequestStruct } from './JsonRpcRequest';\n\n/**\n * Error thrown when a keyring JSON-RPC method is not supported.\n */\nexport class MethodNotSupportedError extends Error {\n constructor(method: string) {\n super(`Method not supported: ${method}`);\n }\n}\n\n/**\n * Inner function that dispatches JSON-RPC request to the associated Keyring\n * methods.\n *\n * @param keyring - Keyring instance.\n * @param request - Keyring JSON-RPC request.\n * @returns A promise that resolves to the keyring response.\n */\nasync function dispatchRequest(\n keyring: Keyring,\n request: JsonRpcRequest,\n): Promise<Json | void> {\n // We first have to make sure that the request is a valid JSON-RPC request so\n // we can check its method name.\n assert(request, JsonRpcRequestStruct);\n\n switch (request.method) {\n case KeyringRpcMethod.ListAccounts: {\n assert(request, ListAccountsRequestStruct);\n return keyring.listAccounts();\n }\n\n case KeyringRpcMethod.GetAccount: {\n assert(request, GetAccountRequestStruct);\n return keyring.getAccount(request.params.id);\n }\n\n case KeyringRpcMethod.CreateAccount: {\n assert(request, CreateAccountRequestStruct);\n return keyring.createAccount(request.params.options);\n }\n\n case KeyringRpcMethod.GetAccountBalances: {\n if (keyring.getAccountBalances === undefined) {\n throw new MethodNotSupportedError(request.method);\n }\n assert(request, GetAccountBalancesRequestStruct);\n return keyring.getAccountBalances(\n request.params.id,\n request.params.assets,\n );\n }\n\n case KeyringRpcMethod.FilterAccountChains: {\n assert(request, FilterAccountChainsStruct);\n return keyring.filterAccountChains(\n request.params.id,\n request.params.chains,\n );\n }\n\n case KeyringRpcMethod.UpdateAccount: {\n assert(request, UpdateAccountRequestStruct);\n return keyring.updateAccount(request.params.account);\n }\n\n case KeyringRpcMethod.DeleteAccount: {\n assert(request, DeleteAccountRequestStruct);\n return keyring.deleteAccount(request.params.id);\n }\n\n case KeyringRpcMethod.ExportAccount: {\n if (keyring.exportAccount === undefined) {\n throw new MethodNotSupportedError(request.method);\n }\n assert(request, ExportAccountRequestStruct);\n return keyring.exportAccount(request.params.id);\n }\n\n case KeyringRpcMethod.ListRequests: {\n if (keyring.listRequests === undefined) {\n throw new MethodNotSupportedError(request.method);\n }\n assert(request, ListRequestsRequestStruct);\n return keyring.listRequests();\n }\n\n case KeyringRpcMethod.GetRequest: {\n if (keyring.getRequest === undefined) {\n throw new MethodNotSupportedError(request.method);\n }\n assert(request, GetRequestRequestStruct);\n return keyring.getRequest(request.params.id);\n }\n\n case KeyringRpcMethod.SubmitRequest: {\n assert(request, SubmitRequestRequestStruct);\n return keyring.submitRequest(request.params);\n }\n\n case KeyringRpcMethod.ApproveRequest: {\n if (keyring.approveRequest === undefined) {\n throw new MethodNotSupportedError(request.method);\n }\n assert(request, ApproveRequestRequestStruct);\n return keyring.approveRequest(request.params.id, request.params.data);\n }\n\n case KeyringRpcMethod.RejectRequest: {\n if (keyring.rejectRequest === undefined) {\n throw new MethodNotSupportedError(request.method);\n }\n assert(request, RejectRequestRequestStruct);\n return keyring.rejectRequest(request.params.id);\n }\n\n default: {\n throw new MethodNotSupportedError(request.method);\n }\n }\n}\n\n/**\n * Handles a keyring JSON-RPC request.\n *\n * This function is meant to be used as a handler for Keyring JSON-RPC requests\n * in an Accounts Snap.\n *\n * @param keyring - Keyring instance.\n * @param request - Keyring JSON-RPC request.\n * @returns A promise that resolves to the keyring response.\n * @example\n * ```ts\n * export const onKeyringRequest: OnKeyringRequestHandler = async ({\n * origin,\n * request,\n * }) => {\n * return await handleKeyringRequest(keyring, request);\n * };\n * ```\n */\nexport async function handleKeyringRequest(\n keyring: Keyring,\n request: JsonRpcRequest,\n): Promise<Json | void> {\n try {\n return await dispatchRequest(keyring, request);\n } catch (error) {\n const message =\n error instanceof Error && typeof error.message === 'string'\n ? error.message\n : 'An unknown error occurred while handling the keyring request';\n\n throw new Error(message);\n }\n}\n"]}
@@ -0,0 +1,11 @@
1
+ import type { SnapsProvider } from '@metamask/snaps-sdk';
2
+ import type { Json } from '@metamask/utils';
3
+ import type { KeyringEvent } from './events';
4
+ /**
5
+ * Emit a keyring event from a snap.
6
+ *
7
+ * @param snap - The global snap object.
8
+ * @param event - The event name.
9
+ * @param data - The event data.
10
+ */
11
+ export declare function emitSnapKeyringEvent(snap: SnapsProvider, event: KeyringEvent, data: Record<string, Json>): Promise<void>;
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.emitSnapKeyringEvent = void 0;
4
+ /**
5
+ * Emit a keyring event from a snap.
6
+ *
7
+ * @param snap - The global snap object.
8
+ * @param event - The event name.
9
+ * @param data - The event data.
10
+ */
11
+ async function emitSnapKeyringEvent(snap, event, data) {
12
+ await snap.request({
13
+ method: 'snap_manageAccounts',
14
+ params: {
15
+ method: event,
16
+ params: { ...data },
17
+ },
18
+ });
19
+ }
20
+ exports.emitSnapKeyringEvent = emitSnapKeyringEvent;
21
+ //# sourceMappingURL=snap-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"snap-utils.js","sourceRoot":"","sources":["../src/snap-utils.ts"],"names":[],"mappings":";;;AAKA;;;;;;GAMG;AACI,KAAK,UAAU,oBAAoB,CACxC,IAAmB,EACnB,KAAmB,EACnB,IAA0B;IAE1B,MAAM,IAAI,CAAC,OAAO,CAAC;QACjB,MAAM,EAAE,qBAAqB;QAC7B,MAAM,EAAE;YACN,MAAM,EAAE,KAAK;YACb,MAAM,EAAE,EAAE,GAAG,IAAI,EAAE;SACpB;KACF,CAAC,CAAC;AACL,CAAC;AAZD,oDAYC","sourcesContent":["import type { SnapsProvider } from '@metamask/snaps-sdk';\nimport type { Json } from '@metamask/utils';\n\nimport type { KeyringEvent } from './events';\n\n/**\n * Emit a keyring event from a snap.\n *\n * @param snap - The global snap object.\n * @param event - The event name.\n * @param data - The event data.\n */\nexport async function emitSnapKeyringEvent(\n snap: SnapsProvider,\n event: KeyringEvent,\n data: Record<string, Json>,\n): Promise<void> {\n await snap.request({\n method: 'snap_manageAccounts',\n params: {\n method: event,\n params: { ...data },\n },\n });\n}\n"]}