@metamask-previews/keyring-internal-snap-client 2.0.0-a527719 → 3.0.0-7ba2de1

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 CHANGED
@@ -7,6 +7,18 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
7
7
 
8
8
  ## [Unreleased]
9
9
 
10
+ ## [3.0.0]
11
+
12
+ ### Added
13
+
14
+ - Add `listAccountAssets` keyring method ([#148](https://github.com/MetaMask/accounts/pull/148))
15
+ - This is inherited from the `KeyringClient` changes.
16
+
17
+ ### Changed
18
+
19
+ - **BREAKING:** Bump `@metamask/keyring-api` from `^13.0.0` to `^14.0.0` ([#155](https://github.com/MetaMask/accounts/pull/155))
20
+ - The `CaipAssetType` is now more restrictive which affects the existing `getAccountBalances` method.
21
+
10
22
  ## [2.0.0]
11
23
 
12
24
  ### Changed
@@ -33,7 +45,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
33
45
  - This new version fixes a bug with CJS re-exports.
34
46
  - Initial release ([#24](https://github.com/MetaMask/accounts/pull/24))
35
47
 
36
- [Unreleased]: https://github.com/MetaMask/accounts/compare/@metamask/keyring-internal-snap-client@2.0.0...HEAD
48
+ [Unreleased]: https://github.com/MetaMask/accounts/compare/@metamask/keyring-internal-snap-client@3.0.0...HEAD
49
+ [3.0.0]: https://github.com/MetaMask/accounts/compare/@metamask/keyring-internal-snap-client@2.0.0...@metamask/keyring-internal-snap-client@3.0.0
37
50
  [2.0.0]: https://github.com/MetaMask/accounts/compare/@metamask/keyring-internal-snap-client@1.1.0...@metamask/keyring-internal-snap-client@2.0.0
38
51
  [1.1.0]: https://github.com/MetaMask/accounts/compare/@metamask/keyring-internal-snap-client@1.0.0...@metamask/keyring-internal-snap-client@1.1.0
39
52
  [1.0.0]: https://github.com/MetaMask/accounts/releases/tag/@metamask/keyring-internal-snap-client@1.0.0
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
3
+ if (kind === "m") throw new TypeError("Private method is not writable");
4
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
5
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
6
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
7
+ };
8
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
9
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
10
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
11
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
12
+ };
13
+ var _SnapControllerMessengerSender_snapId, _SnapControllerMessengerSender_origin, _SnapControllerMessengerSender_messenger, _SnapControllerMessengerSender_handler, _KeyringInternalSnapClient_messenger;
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.KeyringInternalSnapClient = void 0;
16
+ const keyring_snap_client_1 = require("@metamask/keyring-snap-client");
17
+ /**
18
+ * Implementation of the `Sender` interface that can be used to send requests
19
+ * to a Snap through a `Messenger`.
20
+ */
21
+ class SnapControllerMessengerSender {
22
+ /**
23
+ * Create a new instance of `SnapControllerSender`.
24
+ *
25
+ * @param messenger - The `Messenger` instance used when dispatching controllers actions.
26
+ * @param snapId - The ID of the Snap to use.
27
+ * @param origin - The sender's origin.
28
+ * @param handler - The handler type.
29
+ */
30
+ constructor(messenger, snapId, origin, handler) {
31
+ _SnapControllerMessengerSender_snapId.set(this, void 0);
32
+ _SnapControllerMessengerSender_origin.set(this, void 0);
33
+ _SnapControllerMessengerSender_messenger.set(this, void 0);
34
+ _SnapControllerMessengerSender_handler.set(this, void 0);
35
+ __classPrivateFieldSet(this, _SnapControllerMessengerSender_messenger, messenger, "f");
36
+ __classPrivateFieldSet(this, _SnapControllerMessengerSender_snapId, snapId, "f");
37
+ __classPrivateFieldSet(this, _SnapControllerMessengerSender_origin, origin, "f");
38
+ __classPrivateFieldSet(this, _SnapControllerMessengerSender_handler, handler, "f");
39
+ }
40
+ /**
41
+ * Send a request to the Snap and return the response.
42
+ *
43
+ * @param request - JSON-RPC request to send to the Snap.
44
+ * @returns A promise that resolves to the response of the request.
45
+ */
46
+ async send(request) {
47
+ return __classPrivateFieldGet(this, _SnapControllerMessengerSender_messenger, "f").call('SnapController:handleRequest', {
48
+ snapId: __classPrivateFieldGet(this, _SnapControllerMessengerSender_snapId, "f"),
49
+ origin: __classPrivateFieldGet(this, _SnapControllerMessengerSender_origin, "f"),
50
+ handler: __classPrivateFieldGet(this, _SnapControllerMessengerSender_handler, "f"),
51
+ request,
52
+ });
53
+ }
54
+ }
55
+ _SnapControllerMessengerSender_snapId = new WeakMap(), _SnapControllerMessengerSender_origin = new WeakMap(), _SnapControllerMessengerSender_messenger = new WeakMap(), _SnapControllerMessengerSender_handler = new WeakMap();
56
+ /**
57
+ * A `KeyringClient` that allows the communication with a Snap through a
58
+ * `Messenger`.
59
+ */
60
+ class KeyringInternalSnapClient extends keyring_snap_client_1.KeyringClient {
61
+ /**
62
+ * Create a new instance of `KeyringInternalSnapClient`.
63
+ *
64
+ * The `handlerType` argument has a hard-coded default `string` value instead
65
+ * of a `HandlerType` value to prevent the `@metamask/snaps-utils` module
66
+ * from being required at runtime.
67
+ *
68
+ * @param args - Constructor arguments.
69
+ * @param args.messenger - The `KeyringInternalSnapClientMessenger` instance to use.
70
+ * @param args.snapId - The ID of the Snap to use (default: `'undefined'`).
71
+ * @param args.origin - The sender's origin (default: `'metamask'`).
72
+ * @param args.handler - The handler type (default: `'onKeyringRequest'`).
73
+ */
74
+ constructor({ messenger, snapId = 'undefined', origin = 'metamask', handler = 'onKeyringRequest', }) {
75
+ super(new SnapControllerMessengerSender(messenger, snapId, origin, handler));
76
+ _KeyringInternalSnapClient_messenger.set(this, void 0);
77
+ __classPrivateFieldSet(this, _KeyringInternalSnapClient_messenger, messenger, "f");
78
+ }
79
+ /**
80
+ * Create a new instance of `KeyringInternalSnapClient` with the specified
81
+ * `snapId`.
82
+ *
83
+ * @param snapId - The ID of the Snap to use in the new instance.
84
+ * @returns A new instance of `KeyringInternalSnapClient` with the
85
+ * specified Snap ID.
86
+ */
87
+ withSnapId(snapId) {
88
+ return new KeyringInternalSnapClient({
89
+ messenger: __classPrivateFieldGet(this, _KeyringInternalSnapClient_messenger, "f"),
90
+ snapId,
91
+ });
92
+ }
93
+ }
94
+ exports.KeyringInternalSnapClient = KeyringInternalSnapClient;
95
+ _KeyringInternalSnapClient_messenger = new WeakMap();
96
+ //# sourceMappingURL=KeyringInternalSnapClient.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"KeyringInternalSnapClient.cjs","sourceRoot":"","sources":["../src/KeyringInternalSnapClient.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,uEAA2E;AAsB3E;;;GAGG;AACH,MAAM,6BAA6B;IASjC;;;;;;;OAOG;IACH,YACE,SAA6C,EAC7C,MAAc,EACd,MAAc,EACd,OAAoB;QApBb,wDAAgB;QAEhB,wDAAgB;QAEhB,2DAA+C;QAE/C,yDAAsB;QAgB7B,uBAAA,IAAI,4CAAc,SAAS,MAAA,CAAC;QAC5B,uBAAA,IAAI,yCAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,yCAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,0CAAY,OAAO,MAAA,CAAC;IAC1B,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,IAAI,CAAC,OAAuB;QAChC,OAAO,uBAAA,IAAI,gDAAW,CAAC,IAAI,CAAC,8BAA8B,EAAE;YAC1D,MAAM,EAAE,uBAAA,IAAI,6CAAQ;YACpB,MAAM,EAAE,uBAAA,IAAI,6CAAQ;YACpB,OAAO,EAAE,uBAAA,IAAI,8CAAS;YACtB,OAAO;SACR,CAAkB,CAAC;IACtB,CAAC;CACF;;AAED;;;GAGG;AACH,MAAa,yBAA0B,SAAQ,mCAAa;IAG1D;;;;;;;;;;;;OAYG;IACH,YAAY,EACV,SAAS,EACT,MAAM,GAAG,WAAqB,EAC9B,MAAM,GAAG,UAAU,EACnB,OAAO,GAAG,kBAAiC,GAM5C;QACC,KAAK,CACH,IAAI,6BAA6B,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CACtE,CAAC;QA5BK,uDAA+C;QA6BtD,uBAAA,IAAI,wCAAc,SAAS,MAAA,CAAC;IAC9B,CAAC;IAED;;;;;;;OAOG;IACH,UAAU,CAAC,MAAc;QACvB,OAAO,IAAI,yBAAyB,CAAC;YACnC,SAAS,EAAE,uBAAA,IAAI,4CAAW;YAC1B,MAAM;SACP,CAAC,CAAC;IACL,CAAC;CACF;AA/CD,8DA+CC","sourcesContent":["import type { RestrictedControllerMessenger } from '@metamask/base-controller';\nimport { KeyringClient, type Sender } from '@metamask/keyring-snap-client';\nimport type { JsonRpcRequest } from '@metamask/keyring-utils';\nimport type { HandleSnapRequest } from '@metamask/snaps-controllers';\nimport type { SnapId } from '@metamask/snaps-sdk';\nimport type { HandlerType } from '@metamask/snaps-utils';\nimport type { Json } from '@metamask/utils';\n\n// We only need to dispatch Snap request to the Snaps controller for now.\ntype AllowedActions = HandleSnapRequest;\n\n/**\n * A restricted-`Messenger` used by `KeyringInternalSnapClient` to dispatch\n * internal Snap requests.\n */\nexport type KeyringInternalSnapClientMessenger = RestrictedControllerMessenger<\n 'KeyringInternalSnapClient',\n AllowedActions,\n never,\n AllowedActions['type'],\n never\n>;\n\n/**\n * Implementation of the `Sender` interface that can be used to send requests\n * to a Snap through a `Messenger`.\n */\nclass SnapControllerMessengerSender implements Sender {\n readonly #snapId: SnapId;\n\n readonly #origin: string;\n\n readonly #messenger: KeyringInternalSnapClientMessenger;\n\n readonly #handler: HandlerType;\n\n /**\n * Create a new instance of `SnapControllerSender`.\n *\n * @param messenger - The `Messenger` instance used when dispatching controllers actions.\n * @param snapId - The ID of the Snap to use.\n * @param origin - The sender's origin.\n * @param handler - The handler type.\n */\n constructor(\n messenger: KeyringInternalSnapClientMessenger,\n snapId: SnapId,\n origin: string,\n handler: HandlerType,\n ) {\n this.#messenger = messenger;\n this.#snapId = snapId;\n this.#origin = origin;\n this.#handler = handler;\n }\n\n /**\n * Send a request to the Snap and return the response.\n *\n * @param request - JSON-RPC request to send to the Snap.\n * @returns A promise that resolves to the response of the request.\n */\n async send(request: JsonRpcRequest): Promise<Json> {\n return this.#messenger.call('SnapController:handleRequest', {\n snapId: this.#snapId,\n origin: this.#origin,\n handler: this.#handler,\n request,\n }) as Promise<Json>;\n }\n}\n\n/**\n * A `KeyringClient` that allows the communication with a Snap through a\n * `Messenger`.\n */\nexport class KeyringInternalSnapClient extends KeyringClient {\n readonly #messenger: KeyringInternalSnapClientMessenger;\n\n /**\n * Create a new instance of `KeyringInternalSnapClient`.\n *\n * The `handlerType` argument has a hard-coded default `string` value instead\n * of a `HandlerType` value to prevent the `@metamask/snaps-utils` module\n * from being required at runtime.\n *\n * @param args - Constructor arguments.\n * @param args.messenger - The `KeyringInternalSnapClientMessenger` instance to use.\n * @param args.snapId - The ID of the Snap to use (default: `'undefined'`).\n * @param args.origin - The sender's origin (default: `'metamask'`).\n * @param args.handler - The handler type (default: `'onKeyringRequest'`).\n */\n constructor({\n messenger,\n snapId = 'undefined' as SnapId,\n origin = 'metamask',\n handler = 'onKeyringRequest' as HandlerType,\n }: {\n messenger: KeyringInternalSnapClientMessenger;\n snapId?: SnapId;\n origin?: string;\n handler?: HandlerType;\n }) {\n super(\n new SnapControllerMessengerSender(messenger, snapId, origin, handler),\n );\n this.#messenger = messenger;\n }\n\n /**\n * Create a new instance of `KeyringInternalSnapClient` with the specified\n * `snapId`.\n *\n * @param snapId - The ID of the Snap to use in the new instance.\n * @returns A new instance of `KeyringInternalSnapClient` with the\n * specified Snap ID.\n */\n withSnapId(snapId: SnapId): KeyringInternalSnapClient {\n return new KeyringInternalSnapClient({\n messenger: this.#messenger,\n snapId,\n });\n }\n}\n"]}
@@ -0,0 +1,48 @@
1
+ import type { RestrictedControllerMessenger } from "@metamask/base-controller";
2
+ import { KeyringClient } from "@metamask/keyring-snap-client";
3
+ import type { HandleSnapRequest } from "@metamask/snaps-controllers";
4
+ import type { SnapId } from "@metamask/snaps-sdk";
5
+ import type { HandlerType } from "@metamask/snaps-utils";
6
+ type AllowedActions = HandleSnapRequest;
7
+ /**
8
+ * A restricted-`Messenger` used by `KeyringInternalSnapClient` to dispatch
9
+ * internal Snap requests.
10
+ */
11
+ export type KeyringInternalSnapClientMessenger = RestrictedControllerMessenger<'KeyringInternalSnapClient', AllowedActions, never, AllowedActions['type'], never>;
12
+ /**
13
+ * A `KeyringClient` that allows the communication with a Snap through a
14
+ * `Messenger`.
15
+ */
16
+ export declare class KeyringInternalSnapClient extends KeyringClient {
17
+ #private;
18
+ /**
19
+ * Create a new instance of `KeyringInternalSnapClient`.
20
+ *
21
+ * The `handlerType` argument has a hard-coded default `string` value instead
22
+ * of a `HandlerType` value to prevent the `@metamask/snaps-utils` module
23
+ * from being required at runtime.
24
+ *
25
+ * @param args - Constructor arguments.
26
+ * @param args.messenger - The `KeyringInternalSnapClientMessenger` instance to use.
27
+ * @param args.snapId - The ID of the Snap to use (default: `'undefined'`).
28
+ * @param args.origin - The sender's origin (default: `'metamask'`).
29
+ * @param args.handler - The handler type (default: `'onKeyringRequest'`).
30
+ */
31
+ constructor({ messenger, snapId, origin, handler, }: {
32
+ messenger: KeyringInternalSnapClientMessenger;
33
+ snapId?: SnapId;
34
+ origin?: string;
35
+ handler?: HandlerType;
36
+ });
37
+ /**
38
+ * Create a new instance of `KeyringInternalSnapClient` with the specified
39
+ * `snapId`.
40
+ *
41
+ * @param snapId - The ID of the Snap to use in the new instance.
42
+ * @returns A new instance of `KeyringInternalSnapClient` with the
43
+ * specified Snap ID.
44
+ */
45
+ withSnapId(snapId: SnapId): KeyringInternalSnapClient;
46
+ }
47
+ export {};
48
+ //# sourceMappingURL=KeyringInternalSnapClient.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"KeyringInternalSnapClient.d.cts","sourceRoot":"","sources":["../src/KeyringInternalSnapClient.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,6BAA6B,EAAE,kCAAkC;AAC/E,OAAO,EAAE,aAAa,EAAe,sCAAsC;AAE3E,OAAO,KAAK,EAAE,iBAAiB,EAAE,oCAAoC;AACrE,OAAO,KAAK,EAAE,MAAM,EAAE,4BAA4B;AAClD,OAAO,KAAK,EAAE,WAAW,EAAE,8BAA8B;AAIzD,KAAK,cAAc,GAAG,iBAAiB,CAAC;AAExC;;;GAGG;AACH,MAAM,MAAM,kCAAkC,GAAG,6BAA6B,CAC5E,2BAA2B,EAC3B,cAAc,EACd,KAAK,EACL,cAAc,CAAC,MAAM,CAAC,EACtB,KAAK,CACN,CAAC;AAmDF;;;GAGG;AACH,qBAAa,yBAA0B,SAAQ,aAAa;;IAG1D;;;;;;;;;;;;OAYG;gBACS,EACV,SAAS,EACT,MAA8B,EAC9B,MAAmB,EACnB,OAA2C,GAC5C,EAAE;QACD,SAAS,EAAE,kCAAkC,CAAC;QAC9C,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,OAAO,CAAC,EAAE,WAAW,CAAC;KACvB;IAOD;;;;;;;OAOG;IACH,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,yBAAyB;CAMtD"}
@@ -0,0 +1,48 @@
1
+ import type { RestrictedControllerMessenger } from "@metamask/base-controller";
2
+ import { KeyringClient } from "@metamask/keyring-snap-client";
3
+ import type { HandleSnapRequest } from "@metamask/snaps-controllers";
4
+ import type { SnapId } from "@metamask/snaps-sdk";
5
+ import type { HandlerType } from "@metamask/snaps-utils";
6
+ type AllowedActions = HandleSnapRequest;
7
+ /**
8
+ * A restricted-`Messenger` used by `KeyringInternalSnapClient` to dispatch
9
+ * internal Snap requests.
10
+ */
11
+ export type KeyringInternalSnapClientMessenger = RestrictedControllerMessenger<'KeyringInternalSnapClient', AllowedActions, never, AllowedActions['type'], never>;
12
+ /**
13
+ * A `KeyringClient` that allows the communication with a Snap through a
14
+ * `Messenger`.
15
+ */
16
+ export declare class KeyringInternalSnapClient extends KeyringClient {
17
+ #private;
18
+ /**
19
+ * Create a new instance of `KeyringInternalSnapClient`.
20
+ *
21
+ * The `handlerType` argument has a hard-coded default `string` value instead
22
+ * of a `HandlerType` value to prevent the `@metamask/snaps-utils` module
23
+ * from being required at runtime.
24
+ *
25
+ * @param args - Constructor arguments.
26
+ * @param args.messenger - The `KeyringInternalSnapClientMessenger` instance to use.
27
+ * @param args.snapId - The ID of the Snap to use (default: `'undefined'`).
28
+ * @param args.origin - The sender's origin (default: `'metamask'`).
29
+ * @param args.handler - The handler type (default: `'onKeyringRequest'`).
30
+ */
31
+ constructor({ messenger, snapId, origin, handler, }: {
32
+ messenger: KeyringInternalSnapClientMessenger;
33
+ snapId?: SnapId;
34
+ origin?: string;
35
+ handler?: HandlerType;
36
+ });
37
+ /**
38
+ * Create a new instance of `KeyringInternalSnapClient` with the specified
39
+ * `snapId`.
40
+ *
41
+ * @param snapId - The ID of the Snap to use in the new instance.
42
+ * @returns A new instance of `KeyringInternalSnapClient` with the
43
+ * specified Snap ID.
44
+ */
45
+ withSnapId(snapId: SnapId): KeyringInternalSnapClient;
46
+ }
47
+ export {};
48
+ //# sourceMappingURL=KeyringInternalSnapClient.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"KeyringInternalSnapClient.d.mts","sourceRoot":"","sources":["../src/KeyringInternalSnapClient.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,6BAA6B,EAAE,kCAAkC;AAC/E,OAAO,EAAE,aAAa,EAAe,sCAAsC;AAE3E,OAAO,KAAK,EAAE,iBAAiB,EAAE,oCAAoC;AACrE,OAAO,KAAK,EAAE,MAAM,EAAE,4BAA4B;AAClD,OAAO,KAAK,EAAE,WAAW,EAAE,8BAA8B;AAIzD,KAAK,cAAc,GAAG,iBAAiB,CAAC;AAExC;;;GAGG;AACH,MAAM,MAAM,kCAAkC,GAAG,6BAA6B,CAC5E,2BAA2B,EAC3B,cAAc,EACd,KAAK,EACL,cAAc,CAAC,MAAM,CAAC,EACtB,KAAK,CACN,CAAC;AAmDF;;;GAGG;AACH,qBAAa,yBAA0B,SAAQ,aAAa;;IAG1D;;;;;;;;;;;;OAYG;gBACS,EACV,SAAS,EACT,MAA8B,EAC9B,MAAmB,EACnB,OAA2C,GAC5C,EAAE;QACD,SAAS,EAAE,kCAAkC,CAAC;QAC9C,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,OAAO,CAAC,EAAE,WAAW,CAAC;KACvB;IAOD;;;;;;;OAOG;IACH,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,yBAAyB;CAMtD"}
@@ -0,0 +1,92 @@
1
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
2
+ if (kind === "m") throw new TypeError("Private method is not writable");
3
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
4
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
5
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
6
+ };
7
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
8
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
9
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
10
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
11
+ };
12
+ var _SnapControllerMessengerSender_snapId, _SnapControllerMessengerSender_origin, _SnapControllerMessengerSender_messenger, _SnapControllerMessengerSender_handler, _KeyringInternalSnapClient_messenger;
13
+ import { KeyringClient } from "@metamask/keyring-snap-client";
14
+ /**
15
+ * Implementation of the `Sender` interface that can be used to send requests
16
+ * to a Snap through a `Messenger`.
17
+ */
18
+ class SnapControllerMessengerSender {
19
+ /**
20
+ * Create a new instance of `SnapControllerSender`.
21
+ *
22
+ * @param messenger - The `Messenger` instance used when dispatching controllers actions.
23
+ * @param snapId - The ID of the Snap to use.
24
+ * @param origin - The sender's origin.
25
+ * @param handler - The handler type.
26
+ */
27
+ constructor(messenger, snapId, origin, handler) {
28
+ _SnapControllerMessengerSender_snapId.set(this, void 0);
29
+ _SnapControllerMessengerSender_origin.set(this, void 0);
30
+ _SnapControllerMessengerSender_messenger.set(this, void 0);
31
+ _SnapControllerMessengerSender_handler.set(this, void 0);
32
+ __classPrivateFieldSet(this, _SnapControllerMessengerSender_messenger, messenger, "f");
33
+ __classPrivateFieldSet(this, _SnapControllerMessengerSender_snapId, snapId, "f");
34
+ __classPrivateFieldSet(this, _SnapControllerMessengerSender_origin, origin, "f");
35
+ __classPrivateFieldSet(this, _SnapControllerMessengerSender_handler, handler, "f");
36
+ }
37
+ /**
38
+ * Send a request to the Snap and return the response.
39
+ *
40
+ * @param request - JSON-RPC request to send to the Snap.
41
+ * @returns A promise that resolves to the response of the request.
42
+ */
43
+ async send(request) {
44
+ return __classPrivateFieldGet(this, _SnapControllerMessengerSender_messenger, "f").call('SnapController:handleRequest', {
45
+ snapId: __classPrivateFieldGet(this, _SnapControllerMessengerSender_snapId, "f"),
46
+ origin: __classPrivateFieldGet(this, _SnapControllerMessengerSender_origin, "f"),
47
+ handler: __classPrivateFieldGet(this, _SnapControllerMessengerSender_handler, "f"),
48
+ request,
49
+ });
50
+ }
51
+ }
52
+ _SnapControllerMessengerSender_snapId = new WeakMap(), _SnapControllerMessengerSender_origin = new WeakMap(), _SnapControllerMessengerSender_messenger = new WeakMap(), _SnapControllerMessengerSender_handler = new WeakMap();
53
+ /**
54
+ * A `KeyringClient` that allows the communication with a Snap through a
55
+ * `Messenger`.
56
+ */
57
+ export class KeyringInternalSnapClient extends KeyringClient {
58
+ /**
59
+ * Create a new instance of `KeyringInternalSnapClient`.
60
+ *
61
+ * The `handlerType` argument has a hard-coded default `string` value instead
62
+ * of a `HandlerType` value to prevent the `@metamask/snaps-utils` module
63
+ * from being required at runtime.
64
+ *
65
+ * @param args - Constructor arguments.
66
+ * @param args.messenger - The `KeyringInternalSnapClientMessenger` instance to use.
67
+ * @param args.snapId - The ID of the Snap to use (default: `'undefined'`).
68
+ * @param args.origin - The sender's origin (default: `'metamask'`).
69
+ * @param args.handler - The handler type (default: `'onKeyringRequest'`).
70
+ */
71
+ constructor({ messenger, snapId = 'undefined', origin = 'metamask', handler = 'onKeyringRequest', }) {
72
+ super(new SnapControllerMessengerSender(messenger, snapId, origin, handler));
73
+ _KeyringInternalSnapClient_messenger.set(this, void 0);
74
+ __classPrivateFieldSet(this, _KeyringInternalSnapClient_messenger, messenger, "f");
75
+ }
76
+ /**
77
+ * Create a new instance of `KeyringInternalSnapClient` with the specified
78
+ * `snapId`.
79
+ *
80
+ * @param snapId - The ID of the Snap to use in the new instance.
81
+ * @returns A new instance of `KeyringInternalSnapClient` with the
82
+ * specified Snap ID.
83
+ */
84
+ withSnapId(snapId) {
85
+ return new KeyringInternalSnapClient({
86
+ messenger: __classPrivateFieldGet(this, _KeyringInternalSnapClient_messenger, "f"),
87
+ snapId,
88
+ });
89
+ }
90
+ }
91
+ _KeyringInternalSnapClient_messenger = new WeakMap();
92
+ //# sourceMappingURL=KeyringInternalSnapClient.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"KeyringInternalSnapClient.mjs","sourceRoot":"","sources":["../src/KeyringInternalSnapClient.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,OAAO,EAAE,aAAa,EAAe,sCAAsC;AAsB3E;;;GAGG;AACH,MAAM,6BAA6B;IASjC;;;;;;;OAOG;IACH,YACE,SAA6C,EAC7C,MAAc,EACd,MAAc,EACd,OAAoB;QApBb,wDAAgB;QAEhB,wDAAgB;QAEhB,2DAA+C;QAE/C,yDAAsB;QAgB7B,uBAAA,IAAI,4CAAc,SAAS,MAAA,CAAC;QAC5B,uBAAA,IAAI,yCAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,yCAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,0CAAY,OAAO,MAAA,CAAC;IAC1B,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,IAAI,CAAC,OAAuB;QAChC,OAAO,uBAAA,IAAI,gDAAW,CAAC,IAAI,CAAC,8BAA8B,EAAE;YAC1D,MAAM,EAAE,uBAAA,IAAI,6CAAQ;YACpB,MAAM,EAAE,uBAAA,IAAI,6CAAQ;YACpB,OAAO,EAAE,uBAAA,IAAI,8CAAS;YACtB,OAAO;SACR,CAAkB,CAAC;IACtB,CAAC;CACF;;AAED;;;GAGG;AACH,MAAM,OAAO,yBAA0B,SAAQ,aAAa;IAG1D;;;;;;;;;;;;OAYG;IACH,YAAY,EACV,SAAS,EACT,MAAM,GAAG,WAAqB,EAC9B,MAAM,GAAG,UAAU,EACnB,OAAO,GAAG,kBAAiC,GAM5C;QACC,KAAK,CACH,IAAI,6BAA6B,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CACtE,CAAC;QA5BK,uDAA+C;QA6BtD,uBAAA,IAAI,wCAAc,SAAS,MAAA,CAAC;IAC9B,CAAC;IAED;;;;;;;OAOG;IACH,UAAU,CAAC,MAAc;QACvB,OAAO,IAAI,yBAAyB,CAAC;YACnC,SAAS,EAAE,uBAAA,IAAI,4CAAW;YAC1B,MAAM;SACP,CAAC,CAAC;IACL,CAAC;CACF","sourcesContent":["import type { RestrictedControllerMessenger } from '@metamask/base-controller';\nimport { KeyringClient, type Sender } from '@metamask/keyring-snap-client';\nimport type { JsonRpcRequest } from '@metamask/keyring-utils';\nimport type { HandleSnapRequest } from '@metamask/snaps-controllers';\nimport type { SnapId } from '@metamask/snaps-sdk';\nimport type { HandlerType } from '@metamask/snaps-utils';\nimport type { Json } from '@metamask/utils';\n\n// We only need to dispatch Snap request to the Snaps controller for now.\ntype AllowedActions = HandleSnapRequest;\n\n/**\n * A restricted-`Messenger` used by `KeyringInternalSnapClient` to dispatch\n * internal Snap requests.\n */\nexport type KeyringInternalSnapClientMessenger = RestrictedControllerMessenger<\n 'KeyringInternalSnapClient',\n AllowedActions,\n never,\n AllowedActions['type'],\n never\n>;\n\n/**\n * Implementation of the `Sender` interface that can be used to send requests\n * to a Snap through a `Messenger`.\n */\nclass SnapControllerMessengerSender implements Sender {\n readonly #snapId: SnapId;\n\n readonly #origin: string;\n\n readonly #messenger: KeyringInternalSnapClientMessenger;\n\n readonly #handler: HandlerType;\n\n /**\n * Create a new instance of `SnapControllerSender`.\n *\n * @param messenger - The `Messenger` instance used when dispatching controllers actions.\n * @param snapId - The ID of the Snap to use.\n * @param origin - The sender's origin.\n * @param handler - The handler type.\n */\n constructor(\n messenger: KeyringInternalSnapClientMessenger,\n snapId: SnapId,\n origin: string,\n handler: HandlerType,\n ) {\n this.#messenger = messenger;\n this.#snapId = snapId;\n this.#origin = origin;\n this.#handler = handler;\n }\n\n /**\n * Send a request to the Snap and return the response.\n *\n * @param request - JSON-RPC request to send to the Snap.\n * @returns A promise that resolves to the response of the request.\n */\n async send(request: JsonRpcRequest): Promise<Json> {\n return this.#messenger.call('SnapController:handleRequest', {\n snapId: this.#snapId,\n origin: this.#origin,\n handler: this.#handler,\n request,\n }) as Promise<Json>;\n }\n}\n\n/**\n * A `KeyringClient` that allows the communication with a Snap through a\n * `Messenger`.\n */\nexport class KeyringInternalSnapClient extends KeyringClient {\n readonly #messenger: KeyringInternalSnapClientMessenger;\n\n /**\n * Create a new instance of `KeyringInternalSnapClient`.\n *\n * The `handlerType` argument has a hard-coded default `string` value instead\n * of a `HandlerType` value to prevent the `@metamask/snaps-utils` module\n * from being required at runtime.\n *\n * @param args - Constructor arguments.\n * @param args.messenger - The `KeyringInternalSnapClientMessenger` instance to use.\n * @param args.snapId - The ID of the Snap to use (default: `'undefined'`).\n * @param args.origin - The sender's origin (default: `'metamask'`).\n * @param args.handler - The handler type (default: `'onKeyringRequest'`).\n */\n constructor({\n messenger,\n snapId = 'undefined' as SnapId,\n origin = 'metamask',\n handler = 'onKeyringRequest' as HandlerType,\n }: {\n messenger: KeyringInternalSnapClientMessenger;\n snapId?: SnapId;\n origin?: string;\n handler?: HandlerType;\n }) {\n super(\n new SnapControllerMessengerSender(messenger, snapId, origin, handler),\n );\n this.#messenger = messenger;\n }\n\n /**\n * Create a new instance of `KeyringInternalSnapClient` with the specified\n * `snapId`.\n *\n * @param snapId - The ID of the Snap to use in the new instance.\n * @returns A new instance of `KeyringInternalSnapClient` with the\n * specified Snap ID.\n */\n withSnapId(snapId: SnapId): KeyringInternalSnapClient {\n return new KeyringInternalSnapClient({\n messenger: this.#messenger,\n snapId,\n });\n }\n}\n"]}
package/dist/index.cjs CHANGED
@@ -14,5 +14,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./KeyringSnapControllerClient.cjs"), exports);
17
+ __exportStar(require("./KeyringInternalSnapClient.cjs"), exports);
18
18
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oEAA8C","sourcesContent":["export * from './KeyringSnapControllerClient';\n"]}
1
+ {"version":3,"file":"index.cjs","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kEAA4C","sourcesContent":["export * from './KeyringInternalSnapClient';\n"]}
package/dist/index.d.cts CHANGED
@@ -1,2 +1,2 @@
1
- export * from "./KeyringSnapControllerClient.cjs";
1
+ export * from "./KeyringInternalSnapClient.cjs";
2
2
  //# sourceMappingURL=index.d.cts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.cts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,kDAA8C"}
1
+ {"version":3,"file":"index.d.cts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,gDAA4C"}
package/dist/index.d.mts CHANGED
@@ -1,2 +1,2 @@
1
- export * from "./KeyringSnapControllerClient.mjs";
1
+ export * from "./KeyringInternalSnapClient.mjs";
2
2
  //# sourceMappingURL=index.d.mts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.mts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,kDAA8C"}
1
+ {"version":3,"file":"index.d.mts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,gDAA4C"}
package/dist/index.mjs CHANGED
@@ -1,2 +1,2 @@
1
- export * from "./KeyringSnapControllerClient.mjs";
1
+ export * from "./KeyringInternalSnapClient.mjs";
2
2
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,kDAA8C","sourcesContent":["export * from './KeyringSnapControllerClient';\n"]}
1
+ {"version":3,"file":"index.mjs","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,gDAA4C","sourcesContent":["export * from './KeyringInternalSnapClient';\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@metamask-previews/keyring-internal-snap-client",
3
- "version": "2.0.0-a527719",
3
+ "version": "3.0.0-7ba2de1",
4
4
  "description": "MetaMask Keyring Snap internal clients",
5
5
  "keywords": [
6
6
  "metamask",
@@ -45,19 +45,18 @@
45
45
  "test:watch": "jest --watch"
46
46
  },
47
47
  "dependencies": {
48
- "@metamask/keyring-api": "13.0.0",
49
- "@metamask/keyring-snap-client": "2.0.0",
50
- "@metamask/keyring-utils": "1.1.0",
51
- "@metamask/snaps-controllers": "^9.10.0",
52
- "@metamask/snaps-sdk": "^6.7.0",
53
- "@metamask/snaps-utils": "^8.3.0",
54
- "webextension-polyfill": "^0.12.0"
48
+ "@metamask/base-controller": "^7.1.1",
49
+ "@metamask/keyring-api": "14.0.0",
50
+ "@metamask/keyring-snap-client": "3.0.0",
51
+ "@metamask/keyring-utils": "1.2.0"
55
52
  },
56
53
  "devDependencies": {
57
54
  "@lavamoat/allow-scripts": "^3.2.1",
58
55
  "@lavamoat/preinstall-always-fail": "^2.1.0",
59
56
  "@metamask/auto-changelog": "^3.4.4",
60
- "@metamask/providers": "^18.3.1",
57
+ "@metamask/snaps-controllers": "^9.10.0",
58
+ "@metamask/snaps-sdk": "^6.7.0",
59
+ "@metamask/snaps-utils": "^8.3.0",
61
60
  "@metamask/utils": "^11.0.1",
62
61
  "@ts-bridge/cli": "^0.6.1",
63
62
  "@types/jest": "^29.5.12",
@@ -73,9 +72,6 @@
73
72
  "typedoc": "^0.25.13",
74
73
  "typescript": "~5.6.3"
75
74
  },
76
- "peerDependencies": {
77
- "@metamask/providers": "^18.3.1"
78
- },
79
75
  "engines": {
80
76
  "node": "^18.18 || >=20"
81
77
  },
@@ -1,104 +0,0 @@
1
- "use strict";
2
- var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
3
- if (kind === "m") throw new TypeError("Private method is not writable");
4
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
5
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
6
- return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
7
- };
8
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
9
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
10
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
11
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
12
- };
13
- var _SnapControllerSender_snapId, _SnapControllerSender_origin, _SnapControllerSender_controller, _SnapControllerSender_handler, _KeyringSnapControllerClient_controller;
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.KeyringSnapControllerClient = void 0;
16
- const keyring_snap_client_1 = require("@metamask/keyring-snap-client");
17
- /**
18
- * Implementation of the `Sender` interface that can be used to send requests
19
- * to a snap through a `SnapController`.
20
- */
21
- class SnapControllerSender {
22
- /**
23
- * Create a new instance of `SnapControllerSender`.
24
- *
25
- * @param controller - The `SnapController` instance to send requests to.
26
- * @param snapId - The ID of the snap to use.
27
- * @param origin - The sender's origin.
28
- * @param handler - The handler type.
29
- */
30
- constructor(controller, snapId, origin, handler) {
31
- _SnapControllerSender_snapId.set(this, void 0);
32
- _SnapControllerSender_origin.set(this, void 0);
33
- _SnapControllerSender_controller.set(this, void 0);
34
- _SnapControllerSender_handler.set(this, void 0);
35
- __classPrivateFieldSet(this, _SnapControllerSender_controller, controller, "f");
36
- __classPrivateFieldSet(this, _SnapControllerSender_snapId, snapId, "f");
37
- __classPrivateFieldSet(this, _SnapControllerSender_origin, origin, "f");
38
- __classPrivateFieldSet(this, _SnapControllerSender_handler, handler, "f");
39
- }
40
- /**
41
- * Send a request to the snap and return the response.
42
- *
43
- * @param request - JSON-RPC request to send to the snap.
44
- * @returns A promise that resolves to the response of the request.
45
- */
46
- async send(request) {
47
- return __classPrivateFieldGet(this, _SnapControllerSender_controller, "f").handleRequest({
48
- snapId: __classPrivateFieldGet(this, _SnapControllerSender_snapId, "f"),
49
- origin: __classPrivateFieldGet(this, _SnapControllerSender_origin, "f"),
50
- handler: __classPrivateFieldGet(this, _SnapControllerSender_handler, "f"),
51
- request,
52
- });
53
- }
54
- }
55
- _SnapControllerSender_snapId = new WeakMap(), _SnapControllerSender_origin = new WeakMap(), _SnapControllerSender_controller = new WeakMap(), _SnapControllerSender_handler = new WeakMap();
56
- /**
57
- * A `KeyringClient` that allows the communication with a snap through the
58
- * `SnapController`.
59
- */
60
- class KeyringSnapControllerClient extends keyring_snap_client_1.KeyringClient {
61
- /**
62
- * Create a new instance of `KeyringSnapControllerClient`.
63
- *
64
- * The `handlerType` argument has a hard-coded default `string` value instead
65
- * of a `HandlerType` value to prevent the `@metamask/snaps-utils` module
66
- * from being required at runtime.
67
- *
68
- * @param args - Constructor arguments.
69
- * @param args.controller - The `SnapController` instance to use.
70
- * @param args.snapId - The ID of the snap to use (default: `'undefined'`).
71
- * @param args.origin - The sender's origin (default: `'metamask'`).
72
- * @param args.handler - The handler type (default: `'onKeyringRequest'`).
73
- */
74
- constructor({ controller, snapId = 'undefined', origin = 'metamask', handler = 'onKeyringRequest', }) {
75
- super(new SnapControllerSender(controller, snapId, origin, handler));
76
- _KeyringSnapControllerClient_controller.set(this, void 0);
77
- __classPrivateFieldSet(this, _KeyringSnapControllerClient_controller, controller, "f");
78
- }
79
- /**
80
- * Create a new instance of `KeyringSnapControllerClient` with the specified
81
- * `snapId`.
82
- *
83
- * @param snapId - The ID of the snap to use in the new instance.
84
- * @returns A new instance of `KeyringSnapControllerClient` with the
85
- * specified snap ID.
86
- */
87
- withSnapId(snapId) {
88
- return new KeyringSnapControllerClient({
89
- controller: __classPrivateFieldGet(this, _KeyringSnapControllerClient_controller, "f"),
90
- snapId,
91
- });
92
- }
93
- /**
94
- * Get the `SnapController` instance used by this client.
95
- *
96
- * @returns The `SnapController` instance used by this client.
97
- */
98
- getController() {
99
- return __classPrivateFieldGet(this, _KeyringSnapControllerClient_controller, "f");
100
- }
101
- }
102
- exports.KeyringSnapControllerClient = KeyringSnapControllerClient;
103
- _KeyringSnapControllerClient_controller = new WeakMap();
104
- //# sourceMappingURL=KeyringSnapControllerClient.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"KeyringSnapControllerClient.cjs","sourceRoot":"","sources":["../src/KeyringSnapControllerClient.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,uEAA2E;AAO3E;;;GAGG;AACH,MAAM,oBAAoB;IASxB;;;;;;;OAOG;IACH,YACE,UAA0B,EAC1B,MAAc,EACd,MAAc,EACd,OAAoB;QApBb,+CAAgB;QAEhB,+CAAgB;QAEhB,mDAA4B;QAE5B,gDAAsB;QAgB7B,uBAAA,IAAI,oCAAe,UAAU,MAAA,CAAC;QAC9B,uBAAA,IAAI,gCAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,gCAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,iCAAY,OAAO,MAAA,CAAC;IAC1B,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,IAAI,CAAC,OAAuB;QAChC,OAAO,uBAAA,IAAI,wCAAY,CAAC,aAAa,CAAC;YACpC,MAAM,EAAE,uBAAA,IAAI,oCAAQ;YACpB,MAAM,EAAE,uBAAA,IAAI,oCAAQ;YACpB,OAAO,EAAE,uBAAA,IAAI,qCAAS;YACtB,OAAO;SACR,CAAkB,CAAC;IACtB,CAAC;CACF;;AAED;;;GAGG;AACH,MAAa,2BAA4B,SAAQ,mCAAa;IAG5D;;;;;;;;;;;;OAYG;IACH,YAAY,EACV,UAAU,EACV,MAAM,GAAG,WAAqB,EAC9B,MAAM,GAAG,UAAU,EACnB,OAAO,GAAG,kBAAiC,GAM5C;QACC,KAAK,CAAC,IAAI,oBAAoB,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;QA1B9D,0DAA4B;QA2BnC,uBAAA,IAAI,2CAAe,UAAU,MAAA,CAAC;IAChC,CAAC;IAED;;;;;;;OAOG;IACH,UAAU,CAAC,MAAc;QACvB,OAAO,IAAI,2BAA2B,CAAC;YACrC,UAAU,EAAE,uBAAA,IAAI,+CAAY;YAC5B,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACH,aAAa;QACX,OAAO,uBAAA,IAAI,+CAAY,CAAC;IAC1B,CAAC;CACF;AAtDD,kEAsDC","sourcesContent":["import { KeyringClient, type Sender } from '@metamask/keyring-snap-client';\nimport type { JsonRpcRequest } from '@metamask/keyring-utils';\nimport type { SnapController } from '@metamask/snaps-controllers';\nimport type { SnapId } from '@metamask/snaps-sdk';\nimport type { HandlerType } from '@metamask/snaps-utils';\nimport type { Json } from '@metamask/utils';\n\n/**\n * Implementation of the `Sender` interface that can be used to send requests\n * to a snap through a `SnapController`.\n */\nclass SnapControllerSender implements Sender {\n readonly #snapId: SnapId;\n\n readonly #origin: string;\n\n readonly #controller: SnapController;\n\n readonly #handler: HandlerType;\n\n /**\n * Create a new instance of `SnapControllerSender`.\n *\n * @param controller - The `SnapController` instance to send requests to.\n * @param snapId - The ID of the snap to use.\n * @param origin - The sender's origin.\n * @param handler - The handler type.\n */\n constructor(\n controller: SnapController,\n snapId: SnapId,\n origin: string,\n handler: HandlerType,\n ) {\n this.#controller = controller;\n this.#snapId = snapId;\n this.#origin = origin;\n this.#handler = handler;\n }\n\n /**\n * Send a request to the snap and return the response.\n *\n * @param request - JSON-RPC request to send to the snap.\n * @returns A promise that resolves to the response of the request.\n */\n async send(request: JsonRpcRequest): Promise<Json> {\n return this.#controller.handleRequest({\n snapId: this.#snapId,\n origin: this.#origin,\n handler: this.#handler,\n request,\n }) as Promise<Json>;\n }\n}\n\n/**\n * A `KeyringClient` that allows the communication with a snap through the\n * `SnapController`.\n */\nexport class KeyringSnapControllerClient extends KeyringClient {\n readonly #controller: SnapController;\n\n /**\n * Create a new instance of `KeyringSnapControllerClient`.\n *\n * The `handlerType` argument has a hard-coded default `string` value instead\n * of a `HandlerType` value to prevent the `@metamask/snaps-utils` module\n * from being required at runtime.\n *\n * @param args - Constructor arguments.\n * @param args.controller - The `SnapController` instance to use.\n * @param args.snapId - The ID of the snap to use (default: `'undefined'`).\n * @param args.origin - The sender's origin (default: `'metamask'`).\n * @param args.handler - The handler type (default: `'onKeyringRequest'`).\n */\n constructor({\n controller,\n snapId = 'undefined' as SnapId,\n origin = 'metamask',\n handler = 'onKeyringRequest' as HandlerType,\n }: {\n controller: SnapController;\n snapId?: SnapId;\n origin?: string;\n handler?: HandlerType;\n }) {\n super(new SnapControllerSender(controller, snapId, origin, handler));\n this.#controller = controller;\n }\n\n /**\n * Create a new instance of `KeyringSnapControllerClient` with the specified\n * `snapId`.\n *\n * @param snapId - The ID of the snap to use in the new instance.\n * @returns A new instance of `KeyringSnapControllerClient` with the\n * specified snap ID.\n */\n withSnapId(snapId: SnapId): KeyringSnapControllerClient {\n return new KeyringSnapControllerClient({\n controller: this.#controller,\n snapId,\n });\n }\n\n /**\n * Get the `SnapController` instance used by this client.\n *\n * @returns The `SnapController` instance used by this client.\n */\n getController(): SnapController {\n return this.#controller;\n }\n}\n"]}
@@ -1,46 +0,0 @@
1
- import { KeyringClient } from "@metamask/keyring-snap-client";
2
- import type { SnapController } from "@metamask/snaps-controllers";
3
- import type { SnapId } from "@metamask/snaps-sdk";
4
- import type { HandlerType } from "@metamask/snaps-utils";
5
- /**
6
- * A `KeyringClient` that allows the communication with a snap through the
7
- * `SnapController`.
8
- */
9
- export declare class KeyringSnapControllerClient extends KeyringClient {
10
- #private;
11
- /**
12
- * Create a new instance of `KeyringSnapControllerClient`.
13
- *
14
- * The `handlerType` argument has a hard-coded default `string` value instead
15
- * of a `HandlerType` value to prevent the `@metamask/snaps-utils` module
16
- * from being required at runtime.
17
- *
18
- * @param args - Constructor arguments.
19
- * @param args.controller - The `SnapController` instance to use.
20
- * @param args.snapId - The ID of the snap to use (default: `'undefined'`).
21
- * @param args.origin - The sender's origin (default: `'metamask'`).
22
- * @param args.handler - The handler type (default: `'onKeyringRequest'`).
23
- */
24
- constructor({ controller, snapId, origin, handler, }: {
25
- controller: SnapController;
26
- snapId?: SnapId;
27
- origin?: string;
28
- handler?: HandlerType;
29
- });
30
- /**
31
- * Create a new instance of `KeyringSnapControllerClient` with the specified
32
- * `snapId`.
33
- *
34
- * @param snapId - The ID of the snap to use in the new instance.
35
- * @returns A new instance of `KeyringSnapControllerClient` with the
36
- * specified snap ID.
37
- */
38
- withSnapId(snapId: SnapId): KeyringSnapControllerClient;
39
- /**
40
- * Get the `SnapController` instance used by this client.
41
- *
42
- * @returns The `SnapController` instance used by this client.
43
- */
44
- getController(): SnapController;
45
- }
46
- //# sourceMappingURL=KeyringSnapControllerClient.d.cts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"KeyringSnapControllerClient.d.cts","sourceRoot":"","sources":["../src/KeyringSnapControllerClient.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAe,sCAAsC;AAE3E,OAAO,KAAK,EAAE,cAAc,EAAE,oCAAoC;AAClE,OAAO,KAAK,EAAE,MAAM,EAAE,4BAA4B;AAClD,OAAO,KAAK,EAAE,WAAW,EAAE,8BAA8B;AAoDzD;;;GAGG;AACH,qBAAa,2BAA4B,SAAQ,aAAa;;IAG5D;;;;;;;;;;;;OAYG;gBACS,EACV,UAAU,EACV,MAA8B,EAC9B,MAAmB,EACnB,OAA2C,GAC5C,EAAE;QACD,UAAU,EAAE,cAAc,CAAC;QAC3B,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,OAAO,CAAC,EAAE,WAAW,CAAC;KACvB;IAKD;;;;;;;OAOG;IACH,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,2BAA2B;IAOvD;;;;OAIG;IACH,aAAa,IAAI,cAAc;CAGhC"}
@@ -1,46 +0,0 @@
1
- import { KeyringClient } from "@metamask/keyring-snap-client";
2
- import type { SnapController } from "@metamask/snaps-controllers";
3
- import type { SnapId } from "@metamask/snaps-sdk";
4
- import type { HandlerType } from "@metamask/snaps-utils";
5
- /**
6
- * A `KeyringClient` that allows the communication with a snap through the
7
- * `SnapController`.
8
- */
9
- export declare class KeyringSnapControllerClient extends KeyringClient {
10
- #private;
11
- /**
12
- * Create a new instance of `KeyringSnapControllerClient`.
13
- *
14
- * The `handlerType` argument has a hard-coded default `string` value instead
15
- * of a `HandlerType` value to prevent the `@metamask/snaps-utils` module
16
- * from being required at runtime.
17
- *
18
- * @param args - Constructor arguments.
19
- * @param args.controller - The `SnapController` instance to use.
20
- * @param args.snapId - The ID of the snap to use (default: `'undefined'`).
21
- * @param args.origin - The sender's origin (default: `'metamask'`).
22
- * @param args.handler - The handler type (default: `'onKeyringRequest'`).
23
- */
24
- constructor({ controller, snapId, origin, handler, }: {
25
- controller: SnapController;
26
- snapId?: SnapId;
27
- origin?: string;
28
- handler?: HandlerType;
29
- });
30
- /**
31
- * Create a new instance of `KeyringSnapControllerClient` with the specified
32
- * `snapId`.
33
- *
34
- * @param snapId - The ID of the snap to use in the new instance.
35
- * @returns A new instance of `KeyringSnapControllerClient` with the
36
- * specified snap ID.
37
- */
38
- withSnapId(snapId: SnapId): KeyringSnapControllerClient;
39
- /**
40
- * Get the `SnapController` instance used by this client.
41
- *
42
- * @returns The `SnapController` instance used by this client.
43
- */
44
- getController(): SnapController;
45
- }
46
- //# sourceMappingURL=KeyringSnapControllerClient.d.mts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"KeyringSnapControllerClient.d.mts","sourceRoot":"","sources":["../src/KeyringSnapControllerClient.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAe,sCAAsC;AAE3E,OAAO,KAAK,EAAE,cAAc,EAAE,oCAAoC;AAClE,OAAO,KAAK,EAAE,MAAM,EAAE,4BAA4B;AAClD,OAAO,KAAK,EAAE,WAAW,EAAE,8BAA8B;AAoDzD;;;GAGG;AACH,qBAAa,2BAA4B,SAAQ,aAAa;;IAG5D;;;;;;;;;;;;OAYG;gBACS,EACV,UAAU,EACV,MAA8B,EAC9B,MAAmB,EACnB,OAA2C,GAC5C,EAAE;QACD,UAAU,EAAE,cAAc,CAAC;QAC3B,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,OAAO,CAAC,EAAE,WAAW,CAAC;KACvB;IAKD;;;;;;;OAOG;IACH,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,2BAA2B;IAOvD;;;;OAIG;IACH,aAAa,IAAI,cAAc;CAGhC"}
@@ -1,100 +0,0 @@
1
- var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
2
- if (kind === "m") throw new TypeError("Private method is not writable");
3
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
4
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
5
- return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
6
- };
7
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
8
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
9
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
10
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
11
- };
12
- var _SnapControllerSender_snapId, _SnapControllerSender_origin, _SnapControllerSender_controller, _SnapControllerSender_handler, _KeyringSnapControllerClient_controller;
13
- import { KeyringClient } from "@metamask/keyring-snap-client";
14
- /**
15
- * Implementation of the `Sender` interface that can be used to send requests
16
- * to a snap through a `SnapController`.
17
- */
18
- class SnapControllerSender {
19
- /**
20
- * Create a new instance of `SnapControllerSender`.
21
- *
22
- * @param controller - The `SnapController` instance to send requests to.
23
- * @param snapId - The ID of the snap to use.
24
- * @param origin - The sender's origin.
25
- * @param handler - The handler type.
26
- */
27
- constructor(controller, snapId, origin, handler) {
28
- _SnapControllerSender_snapId.set(this, void 0);
29
- _SnapControllerSender_origin.set(this, void 0);
30
- _SnapControllerSender_controller.set(this, void 0);
31
- _SnapControllerSender_handler.set(this, void 0);
32
- __classPrivateFieldSet(this, _SnapControllerSender_controller, controller, "f");
33
- __classPrivateFieldSet(this, _SnapControllerSender_snapId, snapId, "f");
34
- __classPrivateFieldSet(this, _SnapControllerSender_origin, origin, "f");
35
- __classPrivateFieldSet(this, _SnapControllerSender_handler, handler, "f");
36
- }
37
- /**
38
- * Send a request to the snap and return the response.
39
- *
40
- * @param request - JSON-RPC request to send to the snap.
41
- * @returns A promise that resolves to the response of the request.
42
- */
43
- async send(request) {
44
- return __classPrivateFieldGet(this, _SnapControllerSender_controller, "f").handleRequest({
45
- snapId: __classPrivateFieldGet(this, _SnapControllerSender_snapId, "f"),
46
- origin: __classPrivateFieldGet(this, _SnapControllerSender_origin, "f"),
47
- handler: __classPrivateFieldGet(this, _SnapControllerSender_handler, "f"),
48
- request,
49
- });
50
- }
51
- }
52
- _SnapControllerSender_snapId = new WeakMap(), _SnapControllerSender_origin = new WeakMap(), _SnapControllerSender_controller = new WeakMap(), _SnapControllerSender_handler = new WeakMap();
53
- /**
54
- * A `KeyringClient` that allows the communication with a snap through the
55
- * `SnapController`.
56
- */
57
- export class KeyringSnapControllerClient extends KeyringClient {
58
- /**
59
- * Create a new instance of `KeyringSnapControllerClient`.
60
- *
61
- * The `handlerType` argument has a hard-coded default `string` value instead
62
- * of a `HandlerType` value to prevent the `@metamask/snaps-utils` module
63
- * from being required at runtime.
64
- *
65
- * @param args - Constructor arguments.
66
- * @param args.controller - The `SnapController` instance to use.
67
- * @param args.snapId - The ID of the snap to use (default: `'undefined'`).
68
- * @param args.origin - The sender's origin (default: `'metamask'`).
69
- * @param args.handler - The handler type (default: `'onKeyringRequest'`).
70
- */
71
- constructor({ controller, snapId = 'undefined', origin = 'metamask', handler = 'onKeyringRequest', }) {
72
- super(new SnapControllerSender(controller, snapId, origin, handler));
73
- _KeyringSnapControllerClient_controller.set(this, void 0);
74
- __classPrivateFieldSet(this, _KeyringSnapControllerClient_controller, controller, "f");
75
- }
76
- /**
77
- * Create a new instance of `KeyringSnapControllerClient` with the specified
78
- * `snapId`.
79
- *
80
- * @param snapId - The ID of the snap to use in the new instance.
81
- * @returns A new instance of `KeyringSnapControllerClient` with the
82
- * specified snap ID.
83
- */
84
- withSnapId(snapId) {
85
- return new KeyringSnapControllerClient({
86
- controller: __classPrivateFieldGet(this, _KeyringSnapControllerClient_controller, "f"),
87
- snapId,
88
- });
89
- }
90
- /**
91
- * Get the `SnapController` instance used by this client.
92
- *
93
- * @returns The `SnapController` instance used by this client.
94
- */
95
- getController() {
96
- return __classPrivateFieldGet(this, _KeyringSnapControllerClient_controller, "f");
97
- }
98
- }
99
- _KeyringSnapControllerClient_controller = new WeakMap();
100
- //# sourceMappingURL=KeyringSnapControllerClient.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"KeyringSnapControllerClient.mjs","sourceRoot":"","sources":["../src/KeyringSnapControllerClient.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,OAAO,EAAE,aAAa,EAAe,sCAAsC;AAO3E;;;GAGG;AACH,MAAM,oBAAoB;IASxB;;;;;;;OAOG;IACH,YACE,UAA0B,EAC1B,MAAc,EACd,MAAc,EACd,OAAoB;QApBb,+CAAgB;QAEhB,+CAAgB;QAEhB,mDAA4B;QAE5B,gDAAsB;QAgB7B,uBAAA,IAAI,oCAAe,UAAU,MAAA,CAAC;QAC9B,uBAAA,IAAI,gCAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,gCAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,iCAAY,OAAO,MAAA,CAAC;IAC1B,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,IAAI,CAAC,OAAuB;QAChC,OAAO,uBAAA,IAAI,wCAAY,CAAC,aAAa,CAAC;YACpC,MAAM,EAAE,uBAAA,IAAI,oCAAQ;YACpB,MAAM,EAAE,uBAAA,IAAI,oCAAQ;YACpB,OAAO,EAAE,uBAAA,IAAI,qCAAS;YACtB,OAAO;SACR,CAAkB,CAAC;IACtB,CAAC;CACF;;AAED;;;GAGG;AACH,MAAM,OAAO,2BAA4B,SAAQ,aAAa;IAG5D;;;;;;;;;;;;OAYG;IACH,YAAY,EACV,UAAU,EACV,MAAM,GAAG,WAAqB,EAC9B,MAAM,GAAG,UAAU,EACnB,OAAO,GAAG,kBAAiC,GAM5C;QACC,KAAK,CAAC,IAAI,oBAAoB,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;QA1B9D,0DAA4B;QA2BnC,uBAAA,IAAI,2CAAe,UAAU,MAAA,CAAC;IAChC,CAAC;IAED;;;;;;;OAOG;IACH,UAAU,CAAC,MAAc;QACvB,OAAO,IAAI,2BAA2B,CAAC;YACrC,UAAU,EAAE,uBAAA,IAAI,+CAAY;YAC5B,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACH,aAAa;QACX,OAAO,uBAAA,IAAI,+CAAY,CAAC;IAC1B,CAAC;CACF","sourcesContent":["import { KeyringClient, type Sender } from '@metamask/keyring-snap-client';\nimport type { JsonRpcRequest } from '@metamask/keyring-utils';\nimport type { SnapController } from '@metamask/snaps-controllers';\nimport type { SnapId } from '@metamask/snaps-sdk';\nimport type { HandlerType } from '@metamask/snaps-utils';\nimport type { Json } from '@metamask/utils';\n\n/**\n * Implementation of the `Sender` interface that can be used to send requests\n * to a snap through a `SnapController`.\n */\nclass SnapControllerSender implements Sender {\n readonly #snapId: SnapId;\n\n readonly #origin: string;\n\n readonly #controller: SnapController;\n\n readonly #handler: HandlerType;\n\n /**\n * Create a new instance of `SnapControllerSender`.\n *\n * @param controller - The `SnapController` instance to send requests to.\n * @param snapId - The ID of the snap to use.\n * @param origin - The sender's origin.\n * @param handler - The handler type.\n */\n constructor(\n controller: SnapController,\n snapId: SnapId,\n origin: string,\n handler: HandlerType,\n ) {\n this.#controller = controller;\n this.#snapId = snapId;\n this.#origin = origin;\n this.#handler = handler;\n }\n\n /**\n * Send a request to the snap and return the response.\n *\n * @param request - JSON-RPC request to send to the snap.\n * @returns A promise that resolves to the response of the request.\n */\n async send(request: JsonRpcRequest): Promise<Json> {\n return this.#controller.handleRequest({\n snapId: this.#snapId,\n origin: this.#origin,\n handler: this.#handler,\n request,\n }) as Promise<Json>;\n }\n}\n\n/**\n * A `KeyringClient` that allows the communication with a snap through the\n * `SnapController`.\n */\nexport class KeyringSnapControllerClient extends KeyringClient {\n readonly #controller: SnapController;\n\n /**\n * Create a new instance of `KeyringSnapControllerClient`.\n *\n * The `handlerType` argument has a hard-coded default `string` value instead\n * of a `HandlerType` value to prevent the `@metamask/snaps-utils` module\n * from being required at runtime.\n *\n * @param args - Constructor arguments.\n * @param args.controller - The `SnapController` instance to use.\n * @param args.snapId - The ID of the snap to use (default: `'undefined'`).\n * @param args.origin - The sender's origin (default: `'metamask'`).\n * @param args.handler - The handler type (default: `'onKeyringRequest'`).\n */\n constructor({\n controller,\n snapId = 'undefined' as SnapId,\n origin = 'metamask',\n handler = 'onKeyringRequest' as HandlerType,\n }: {\n controller: SnapController;\n snapId?: SnapId;\n origin?: string;\n handler?: HandlerType;\n }) {\n super(new SnapControllerSender(controller, snapId, origin, handler));\n this.#controller = controller;\n }\n\n /**\n * Create a new instance of `KeyringSnapControllerClient` with the specified\n * `snapId`.\n *\n * @param snapId - The ID of the snap to use in the new instance.\n * @returns A new instance of `KeyringSnapControllerClient` with the\n * specified snap ID.\n */\n withSnapId(snapId: SnapId): KeyringSnapControllerClient {\n return new KeyringSnapControllerClient({\n controller: this.#controller,\n snapId,\n });\n }\n\n /**\n * Get the `SnapController` instance used by this client.\n *\n * @returns The `SnapController` instance used by this client.\n */\n getController(): SnapController {\n return this.#controller;\n }\n}\n"]}