@metamask/selected-network-controller 8.0.0 → 10.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (32) hide show
  1. package/CHANGELOG.md +30 -2
  2. package/dist/SelectedNetworkController.js +14 -140
  3. package/dist/SelectedNetworkController.js.map +1 -1
  4. package/dist/SelectedNetworkController.mjs +15 -0
  5. package/dist/SelectedNetworkController.mjs.map +1 -0
  6. package/dist/SelectedNetworkMiddleware.js +7 -15
  7. package/dist/SelectedNetworkMiddleware.js.map +1 -1
  8. package/dist/SelectedNetworkMiddleware.mjs +8 -0
  9. package/dist/SelectedNetworkMiddleware.mjs.map +1 -0
  10. package/dist/chunk-DZKNOQNE.mjs +222 -0
  11. package/dist/chunk-DZKNOQNE.mjs.map +1 -0
  12. package/dist/chunk-MRZPOKCN.js +23 -0
  13. package/dist/chunk-MRZPOKCN.js.map +1 -0
  14. package/dist/chunk-PPX4FXXU.mjs +23 -0
  15. package/dist/chunk-PPX4FXXU.mjs.map +1 -0
  16. package/dist/chunk-WK7GHGRD.js +222 -0
  17. package/dist/chunk-WK7GHGRD.js.map +1 -0
  18. package/dist/index.js +16 -10
  19. package/dist/index.js.map +1 -1
  20. package/dist/index.mjs +17 -0
  21. package/dist/index.mjs.map +1 -0
  22. package/dist/tsconfig.build.tsbuildinfo +1 -0
  23. package/dist/{SelectedNetworkController.d.ts → types/SelectedNetworkController.d.ts} +7 -14
  24. package/dist/types/SelectedNetworkController.d.ts.map +1 -0
  25. package/dist/types/SelectedNetworkMiddleware.d.ts.map +1 -0
  26. package/dist/types/index.d.ts.map +1 -0
  27. package/package.json +17 -5
  28. package/dist/SelectedNetworkController.d.ts.map +0 -1
  29. package/dist/SelectedNetworkMiddleware.d.ts.map +0 -1
  30. package/dist/index.d.ts.map +0 -1
  31. /package/dist/{SelectedNetworkMiddleware.d.ts → types/SelectedNetworkMiddleware.d.ts} +0 -0
  32. /package/dist/{index.d.ts → types/index.d.ts} +0 -0
package/CHANGELOG.md CHANGED
@@ -7,6 +7,32 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
7
7
 
8
8
  ## [Unreleased]
9
9
 
10
+ ## [10.0.0]
11
+
12
+ ### Added
13
+
14
+ - **BREAKING**: Add ESM build ([#3998](https://github.com/MetaMask/core/pull/3998))
15
+ - It's no longer possible to import files from `./dist` directly.
16
+
17
+ ### Changed
18
+
19
+ - **BREAKING:** Bump `@metamask/base-controller` to `^5.0.0` ([#4039](https://github.com/MetaMask/core/pull/4039))
20
+ - This version has a number of breaking changes. See the changelog for more.
21
+ - **BREAKING:** Bump dependency and peer dependency on `@metamask/network-controller` to `^18.0.0` ([#4007](https://github.com/MetaMask/core/pull/4007))
22
+ - **BREAKING:** Bump dependency and peer dependency on `@metamask/permission-controller` to `^9.0.0` ([#4007](https://github.com/MetaMask/core/pull/4007))
23
+ - Bump `@metamask/json-rpc-engine` to `^8.0.0` ([#4007](https://github.com/MetaMask/core/pull/4007))
24
+
25
+ ## [9.0.0]
26
+
27
+ ### Added
28
+
29
+ - Listen to permissions changes and add/remove `domains` ([#3969](https://github.com/MetaMask/core/pull/3969))
30
+
31
+ ### Changed
32
+
33
+ - **BREAKING** remove `perDomainNetwork` from state ([#3989](https://github.com/MetaMask/core/pull/3989))
34
+ - **BREAKING** Add dependency and peer dependency on `@metamask/permission-controller` ^8.0.1 ([#4000](https://github.com/MetaMask/core/pull/4000))
35
+
10
36
  ## [8.0.0]
11
37
 
12
38
  ### Changed
@@ -30,7 +56,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
30
56
 
31
57
  ### Changed
32
58
 
33
- - Selected network controller should update all domains when perDomainNetwork feature flag is off ([#3834](https://github.com/MetaMask/controllers/pull/3834))
59
+ - Selected network controller should update all domains when perDomainNetwork feature flag is off ([#3834](https://github.com/MetaMask/core/pull/3834))
34
60
 
35
61
  ## [7.0.0]
36
62
 
@@ -125,7 +151,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
125
151
 
126
152
  - Initial Release ([#1643](https://github.com/MetaMask/core/pull/1643))
127
153
 
128
- [Unreleased]: https://github.com/MetaMask/core/compare/@metamask/selected-network-controller@8.0.0...HEAD
154
+ [Unreleased]: https://github.com/MetaMask/core/compare/@metamask/selected-network-controller@10.0.0...HEAD
155
+ [10.0.0]: https://github.com/MetaMask/core/compare/@metamask/selected-network-controller@9.0.0...@metamask/selected-network-controller@10.0.0
156
+ [9.0.0]: https://github.com/MetaMask/core/compare/@metamask/selected-network-controller@8.0.0...@metamask/selected-network-controller@9.0.0
129
157
  [8.0.0]: https://github.com/MetaMask/core/compare/@metamask/selected-network-controller@7.0.1...@metamask/selected-network-controller@8.0.0
130
158
  [7.0.1]: https://github.com/MetaMask/core/compare/@metamask/selected-network-controller@7.0.0...@metamask/selected-network-controller@7.0.1
131
159
  [7.0.0]: https://github.com/MetaMask/core/compare/@metamask/selected-network-controller@6.0.0...@metamask/selected-network-controller@7.0.0
@@ -1,141 +1,15 @@
1
- "use strict";
2
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
3
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
4
- 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");
5
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
6
- };
7
- var _SelectedNetworkController_instances, _SelectedNetworkController_proxies, _SelectedNetworkController_registerMessageHandlers, _SelectedNetworkController_setNetworkClientIdForDomain, _SelectedNetworkController_domainHasPermissions;
8
- Object.defineProperty(exports, "__esModule", { value: true });
9
- exports.SelectedNetworkController = exports.SelectedNetworkControllerEventTypes = exports.SelectedNetworkControllerActionTypes = exports.METAMASK_DOMAIN = exports.controllerName = void 0;
10
- const base_controller_1 = require("@metamask/base-controller");
11
- const swappable_obj_proxy_1 = require("@metamask/swappable-obj-proxy");
12
- exports.controllerName = 'SelectedNetworkController';
13
- const stateMetadata = {
14
- domains: { persist: true, anonymous: false },
15
- perDomainNetwork: { persist: true, anonymous: false },
16
- };
17
- const getDefaultState = () => ({
18
- domains: {},
19
- perDomainNetwork: false,
20
- });
21
- exports.METAMASK_DOMAIN = 'metamask';
22
- exports.SelectedNetworkControllerActionTypes = {
23
- getState: `${exports.controllerName}:getState`,
24
- getNetworkClientIdForDomain: `${exports.controllerName}:getNetworkClientIdForDomain`,
25
- setNetworkClientIdForDomain: `${exports.controllerName}:setNetworkClientIdForDomain`,
26
- };
27
- exports.SelectedNetworkControllerEventTypes = {
28
- stateChange: `${exports.controllerName}:stateChange`,
29
- };
30
- /**
31
- * Controller for getting and setting the network for a particular domain.
32
- */
33
- class SelectedNetworkController extends base_controller_1.BaseController {
34
- /**
35
- * Construct a SelectedNetworkController controller.
36
- *
37
- * @param options - The controller options.
38
- * @param options.messenger - The restricted controller messenger for the EncryptionPublicKey controller.
39
- * @param options.state - The controllers initial state.
40
- */
41
- constructor({ messenger, state = getDefaultState(), }) {
42
- super({
43
- name: exports.controllerName,
44
- metadata: stateMetadata,
45
- messenger,
46
- state,
47
- });
48
- _SelectedNetworkController_instances.add(this);
49
- _SelectedNetworkController_proxies.set(this, new Map());
50
- __classPrivateFieldGet(this, _SelectedNetworkController_instances, "m", _SelectedNetworkController_registerMessageHandlers).call(this);
51
- this.messagingSystem.subscribe('NetworkController:stateChange', ({ selectedNetworkClientId }, patches) => {
52
- patches.forEach(({ op, path }) => {
53
- // if a network is removed, update the networkClientId for all domains that were using it to the selected network
54
- if (op === 'remove' && path[0] === 'networkConfigurations') {
55
- const removedNetworkClientId = path[1];
56
- Object.entries(this.state.domains).forEach(([domain, networkClientIdForDomain]) => {
57
- if (networkClientIdForDomain === removedNetworkClientId) {
58
- this.setNetworkClientIdForDomain(domain, selectedNetworkClientId);
59
- }
60
- });
61
- }
62
- });
63
- });
64
- }
65
- setNetworkClientIdForDomain(domain, networkClientId) {
66
- if (domain === exports.METAMASK_DOMAIN) {
67
- throw new Error(`NetworkClientId for domain "${exports.METAMASK_DOMAIN}" cannot be set on the SelectedNetworkController`);
68
- }
69
- if (!__classPrivateFieldGet(this, _SelectedNetworkController_instances, "m", _SelectedNetworkController_domainHasPermissions).call(this, domain)) {
70
- throw new Error('NetworkClientId for domain cannot be called with a domain that has not yet been granted permissions');
71
- }
72
- __classPrivateFieldGet(this, _SelectedNetworkController_instances, "m", _SelectedNetworkController_setNetworkClientIdForDomain).call(this, domain, networkClientId);
73
- }
74
- getNetworkClientIdForDomain(domain) {
75
- var _a;
76
- const { selectedNetworkClientId: metamaskSelectedNetworkClientId } = this.messagingSystem.call('NetworkController:getState');
77
- if (!this.state.perDomainNetwork) {
78
- return metamaskSelectedNetworkClientId;
79
- }
80
- return (_a = this.state.domains[domain]) !== null && _a !== void 0 ? _a : metamaskSelectedNetworkClientId;
81
- }
82
- /**
83
- * Accesses the provider and block tracker for the currently selected network.
84
- *
85
- * @param domain - the domain for the provider
86
- * @returns The proxy and block tracker proxies.
87
- */
88
- getProviderAndBlockTracker(domain) {
89
- if (!this.state.perDomainNetwork) {
90
- throw new Error('Provider and BlockTracker should be fetched from NetworkController when perDomainNetwork is false');
91
- }
92
- const networkClientId = this.state.domains[domain];
93
- if (!networkClientId) {
94
- throw new Error('NetworkClientId has not been set for the requested domain');
95
- }
96
- let networkProxy = __classPrivateFieldGet(this, _SelectedNetworkController_proxies, "f").get(domain);
97
- if (networkProxy === undefined) {
98
- const networkClient = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId);
99
- networkProxy = {
100
- provider: (0, swappable_obj_proxy_1.createEventEmitterProxy)(networkClient.provider),
101
- blockTracker: (0, swappable_obj_proxy_1.createEventEmitterProxy)(networkClient.blockTracker, {
102
- eventFilter: 'skipInternal',
103
- }),
104
- };
105
- __classPrivateFieldGet(this, _SelectedNetworkController_proxies, "f").set(domain, networkProxy);
106
- }
107
- return networkProxy;
108
- }
109
- setPerDomainNetwork(enabled) {
110
- this.update((state) => {
111
- state.perDomainNetwork = enabled;
112
- return state;
113
- });
114
- }
115
- }
116
- exports.SelectedNetworkController = SelectedNetworkController;
117
- _SelectedNetworkController_proxies = new WeakMap(), _SelectedNetworkController_instances = new WeakSet(), _SelectedNetworkController_registerMessageHandlers = function _SelectedNetworkController_registerMessageHandlers() {
118
- this.messagingSystem.registerActionHandler(exports.SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain, this.getNetworkClientIdForDomain.bind(this));
119
- this.messagingSystem.registerActionHandler(exports.SelectedNetworkControllerActionTypes.setNetworkClientIdForDomain, this.setNetworkClientIdForDomain.bind(this));
120
- }, _SelectedNetworkController_setNetworkClientIdForDomain = function _SelectedNetworkController_setNetworkClientIdForDomain(domain, networkClientId) {
121
- const networkClient = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId);
122
- const networkProxy = __classPrivateFieldGet(this, _SelectedNetworkController_proxies, "f").get(domain);
123
- if (networkProxy === undefined) {
124
- __classPrivateFieldGet(this, _SelectedNetworkController_proxies, "f").set(domain, {
125
- provider: (0, swappable_obj_proxy_1.createEventEmitterProxy)(networkClient.provider),
126
- blockTracker: (0, swappable_obj_proxy_1.createEventEmitterProxy)(networkClient.blockTracker, {
127
- eventFilter: 'skipInternal',
128
- }),
129
- });
130
- }
131
- else {
132
- networkProxy.provider.setTarget(networkClient.provider);
133
- networkProxy.blockTracker.setTarget(networkClient.blockTracker);
134
- }
135
- this.update((state) => {
136
- state.domains[domain] = networkClientId;
137
- });
138
- }, _SelectedNetworkController_domainHasPermissions = function _SelectedNetworkController_domainHasPermissions(domain) {
139
- return this.messagingSystem.call('PermissionController:hasPermissions', domain);
140
- };
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
+
3
+
4
+
5
+
6
+
7
+ var _chunkWK7GHGRDjs = require('./chunk-WK7GHGRD.js');
8
+
9
+
10
+
11
+
12
+
13
+
14
+ exports.METAMASK_DOMAIN = _chunkWK7GHGRDjs.METAMASK_DOMAIN; exports.SelectedNetworkController = _chunkWK7GHGRDjs.SelectedNetworkController; exports.SelectedNetworkControllerActionTypes = _chunkWK7GHGRDjs.SelectedNetworkControllerActionTypes; exports.SelectedNetworkControllerEventTypes = _chunkWK7GHGRDjs.SelectedNetworkControllerEventTypes; exports.controllerName = _chunkWK7GHGRDjs.controllerName;
141
15
  //# sourceMappingURL=SelectedNetworkController.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SelectedNetworkController.js","sourceRoot":"","sources":["../src/SelectedNetworkController.ts"],"names":[],"mappings":"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","sourcesContent":["import type { RestrictedControllerMessenger } from '@metamask/base-controller';\nimport { BaseController } from '@metamask/base-controller';\nimport type {\n BlockTrackerProxy,\n NetworkClientId,\n NetworkControllerGetNetworkClientByIdAction,\n NetworkControllerGetStateAction,\n NetworkControllerStateChangeEvent,\n ProviderProxy,\n} from '@metamask/network-controller';\nimport { createEventEmitterProxy } from '@metamask/swappable-obj-proxy';\nimport type { Patch } from 'immer';\n\nexport const controllerName = 'SelectedNetworkController';\n\nconst stateMetadata = {\n domains: { persist: true, anonymous: false },\n perDomainNetwork: { persist: true, anonymous: false },\n};\n\nconst getDefaultState = () => ({\n domains: {},\n perDomainNetwork: false,\n});\n\ntype Domain = string;\n\nexport const METAMASK_DOMAIN = 'metamask' as const;\n\nexport const SelectedNetworkControllerActionTypes = {\n getState: `${controllerName}:getState` as const,\n getNetworkClientIdForDomain:\n `${controllerName}:getNetworkClientIdForDomain` as const,\n setNetworkClientIdForDomain:\n `${controllerName}:setNetworkClientIdForDomain` as const,\n};\n\nexport const SelectedNetworkControllerEventTypes = {\n stateChange: `${controllerName}:stateChange` as const,\n};\n\nexport type SelectedNetworkControllerState = {\n domains: Record<Domain, NetworkClientId>;\n /**\n * Feature flag to start returning networkClientId based on the domain.\n * when the flag is false, the 'metamask' domain will always be used.\n * defaults to false\n */\n perDomainNetwork: boolean;\n};\n\nexport type SelectedNetworkControllerStateChangeEvent = {\n type: typeof SelectedNetworkControllerEventTypes.stateChange;\n payload: [SelectedNetworkControllerState, Patch[]];\n};\n\nexport type SelectedNetworkControllerGetSelectedNetworkStateAction = {\n type: typeof SelectedNetworkControllerActionTypes.getState;\n handler: () => SelectedNetworkControllerState;\n};\n\nexport type SelectedNetworkControllerGetNetworkClientIdForDomainAction = {\n type: typeof SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain;\n handler: SelectedNetworkController['getNetworkClientIdForDomain'];\n};\n\nexport type SelectedNetworkControllerSetNetworkClientIdForDomainAction = {\n type: typeof SelectedNetworkControllerActionTypes.setNetworkClientIdForDomain;\n handler: SelectedNetworkController['setNetworkClientIdForDomain'];\n};\n\ntype PermissionControllerHasPermissions = {\n type: `PermissionController:hasPermissions`;\n handler: (domain: string) => boolean;\n};\n\nexport type SelectedNetworkControllerActions =\n | SelectedNetworkControllerGetSelectedNetworkStateAction\n | SelectedNetworkControllerGetNetworkClientIdForDomainAction\n | SelectedNetworkControllerSetNetworkClientIdForDomainAction;\n\nexport type AllowedActions =\n | NetworkControllerGetNetworkClientByIdAction\n | NetworkControllerGetStateAction\n | PermissionControllerHasPermissions;\n\nexport type SelectedNetworkControllerEvents =\n SelectedNetworkControllerStateChangeEvent;\n\nexport type AllowedEvents = NetworkControllerStateChangeEvent;\n\nexport type SelectedNetworkControllerMessenger = RestrictedControllerMessenger<\n typeof controllerName,\n SelectedNetworkControllerActions | AllowedActions,\n SelectedNetworkControllerEvents | AllowedEvents,\n AllowedActions['type'],\n AllowedEvents['type']\n>;\n\nexport type SelectedNetworkControllerOptions = {\n state?: SelectedNetworkControllerState;\n messenger: SelectedNetworkControllerMessenger;\n};\n\nexport type NetworkProxy = {\n provider: ProviderProxy;\n blockTracker: BlockTrackerProxy;\n};\n\n/**\n * Controller for getting and setting the network for a particular domain.\n */\nexport class SelectedNetworkController extends BaseController<\n typeof controllerName,\n SelectedNetworkControllerState,\n SelectedNetworkControllerMessenger\n> {\n #proxies = new Map<Domain, NetworkProxy>();\n\n /**\n * Construct a SelectedNetworkController controller.\n *\n * @param options - The controller options.\n * @param options.messenger - The restricted controller messenger for the EncryptionPublicKey controller.\n * @param options.state - The controllers initial state.\n */\n constructor({\n messenger,\n state = getDefaultState(),\n }: SelectedNetworkControllerOptions) {\n super({\n name: controllerName,\n metadata: stateMetadata,\n messenger,\n state,\n });\n this.#registerMessageHandlers();\n\n this.messagingSystem.subscribe(\n 'NetworkController:stateChange',\n ({ selectedNetworkClientId }, patches) => {\n patches.forEach(({ op, path }) => {\n // if a network is removed, update the networkClientId for all domains that were using it to the selected network\n if (op === 'remove' && path[0] === 'networkConfigurations') {\n const removedNetworkClientId = path[1] as NetworkClientId;\n Object.entries(this.state.domains).forEach(\n ([domain, networkClientIdForDomain]) => {\n if (networkClientIdForDomain === removedNetworkClientId) {\n this.setNetworkClientIdForDomain(\n domain,\n selectedNetworkClientId,\n );\n }\n },\n );\n }\n });\n },\n );\n }\n\n #registerMessageHandlers(): void {\n this.messagingSystem.registerActionHandler(\n SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain,\n this.getNetworkClientIdForDomain.bind(this),\n );\n this.messagingSystem.registerActionHandler(\n SelectedNetworkControllerActionTypes.setNetworkClientIdForDomain,\n this.setNetworkClientIdForDomain.bind(this),\n );\n }\n\n #setNetworkClientIdForDomain(\n domain: Domain,\n networkClientId: NetworkClientId,\n ) {\n const networkClient = this.messagingSystem.call(\n 'NetworkController:getNetworkClientById',\n networkClientId,\n );\n const networkProxy = this.#proxies.get(domain);\n if (networkProxy === undefined) {\n this.#proxies.set(domain, {\n provider: createEventEmitterProxy(networkClient.provider),\n blockTracker: createEventEmitterProxy(networkClient.blockTracker, {\n eventFilter: 'skipInternal',\n }),\n });\n } else {\n networkProxy.provider.setTarget(networkClient.provider);\n networkProxy.blockTracker.setTarget(networkClient.blockTracker);\n }\n\n this.update((state) => {\n state.domains[domain] = networkClientId;\n });\n }\n\n #domainHasPermissions(domain: Domain): boolean {\n return this.messagingSystem.call(\n 'PermissionController:hasPermissions',\n domain,\n );\n }\n\n setNetworkClientIdForDomain(\n domain: Domain,\n networkClientId: NetworkClientId,\n ) {\n if (domain === METAMASK_DOMAIN) {\n throw new Error(\n `NetworkClientId for domain \"${METAMASK_DOMAIN}\" cannot be set on the SelectedNetworkController`,\n );\n }\n\n if (!this.#domainHasPermissions(domain)) {\n throw new Error(\n 'NetworkClientId for domain cannot be called with a domain that has not yet been granted permissions',\n );\n }\n\n this.#setNetworkClientIdForDomain(domain, networkClientId);\n }\n\n getNetworkClientIdForDomain(domain: Domain): NetworkClientId {\n const { selectedNetworkClientId: metamaskSelectedNetworkClientId } =\n this.messagingSystem.call('NetworkController:getState');\n if (!this.state.perDomainNetwork) {\n return metamaskSelectedNetworkClientId;\n }\n return this.state.domains[domain] ?? metamaskSelectedNetworkClientId;\n }\n\n /**\n * Accesses the provider and block tracker for the currently selected network.\n *\n * @param domain - the domain for the provider\n * @returns The proxy and block tracker proxies.\n */\n getProviderAndBlockTracker(domain: Domain): NetworkProxy {\n if (!this.state.perDomainNetwork) {\n throw new Error(\n 'Provider and BlockTracker should be fetched from NetworkController when perDomainNetwork is false',\n );\n }\n const networkClientId = this.state.domains[domain];\n if (!networkClientId) {\n throw new Error(\n 'NetworkClientId has not been set for the requested domain',\n );\n }\n let networkProxy = this.#proxies.get(domain);\n if (networkProxy === undefined) {\n const networkClient = this.messagingSystem.call(\n 'NetworkController:getNetworkClientById',\n networkClientId,\n );\n networkProxy = {\n provider: createEventEmitterProxy(networkClient.provider),\n blockTracker: createEventEmitterProxy(networkClient.blockTracker, {\n eventFilter: 'skipInternal',\n }),\n };\n this.#proxies.set(domain, networkProxy);\n }\n\n return networkProxy;\n }\n\n setPerDomainNetwork(enabled: boolean) {\n this.update((state) => {\n state.perDomainNetwork = enabled;\n return state;\n });\n }\n}\n"]}
1
+ {"version":3,"sources":[],"names":[],"mappings":""}
@@ -0,0 +1,15 @@
1
+ import {
2
+ METAMASK_DOMAIN,
3
+ SelectedNetworkController,
4
+ SelectedNetworkControllerActionTypes,
5
+ SelectedNetworkControllerEventTypes,
6
+ controllerName
7
+ } from "./chunk-DZKNOQNE.mjs";
8
+ export {
9
+ METAMASK_DOMAIN,
10
+ SelectedNetworkController,
11
+ SelectedNetworkControllerActionTypes,
12
+ SelectedNetworkControllerEventTypes,
13
+ controllerName
14
+ };
15
+ //# sourceMappingURL=SelectedNetworkController.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -1,16 +1,8 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createSelectedNetworkMiddleware = void 0;
4
- const SelectedNetworkController_1 = require("./SelectedNetworkController");
5
- const createSelectedNetworkMiddleware = (messenger) => {
6
- const getNetworkClientIdForDomain = (origin) => messenger.call(SelectedNetworkController_1.SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain, origin);
7
- return (req, _, next) => {
8
- if (!req.origin) {
9
- throw new Error("Request object is lacking an 'origin'");
10
- }
11
- req.networkClientId = getNetworkClientIdForDomain(req.origin);
12
- return next();
13
- };
14
- };
15
- exports.createSelectedNetworkMiddleware = createSelectedNetworkMiddleware;
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
+
3
+ var _chunkMRZPOKCNjs = require('./chunk-MRZPOKCN.js');
4
+ require('./chunk-WK7GHGRD.js');
5
+
6
+
7
+ exports.createSelectedNetworkMiddleware = _chunkMRZPOKCNjs.createSelectedNetworkMiddleware;
16
8
  //# sourceMappingURL=SelectedNetworkMiddleware.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SelectedNetworkMiddleware.js","sourceRoot":"","sources":["../src/SelectedNetworkMiddleware.ts"],"names":[],"mappings":";;;AAKA,2EAAmF;AAO5E,MAAM,+BAA+B,GAAG,CAC7C,SAA6C,EACL,EAAE;IAC1C,MAAM,2BAA2B,GAAG,CAAC,MAAc,EAAE,EAAE,CACrD,SAAS,CAAC,IAAI,CACZ,gEAAoC,CAAC,2BAA2B,EAChE,MAAM,CACP,CAAC;IAEJ,OAAO,CAAC,GAA4C,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;QAC/D,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE;YACf,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;SAC1D;QAED,GAAG,CAAC,eAAe,GAAG,2BAA2B,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAC9D,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC,CAAC;AACJ,CAAC,CAAC;AAjBW,QAAA,+BAA+B,mCAiB1C","sourcesContent":["import type { JsonRpcMiddleware } from '@metamask/json-rpc-engine';\nimport type { NetworkClientId } from '@metamask/network-controller';\nimport type { Json, JsonRpcParams, JsonRpcRequest } from '@metamask/utils';\n\nimport type { SelectedNetworkControllerMessenger } from './SelectedNetworkController';\nimport { SelectedNetworkControllerActionTypes } from './SelectedNetworkController';\n\nexport type SelectedNetworkMiddlewareJsonRpcRequest = JsonRpcRequest & {\n networkClientId?: NetworkClientId;\n origin?: string;\n};\n\nexport const createSelectedNetworkMiddleware = (\n messenger: SelectedNetworkControllerMessenger,\n): JsonRpcMiddleware<JsonRpcParams, Json> => {\n const getNetworkClientIdForDomain = (origin: string) =>\n messenger.call(\n SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain,\n origin,\n );\n\n return (req: SelectedNetworkMiddlewareJsonRpcRequest, _, next) => {\n if (!req.origin) {\n throw new Error(\"Request object is lacking an 'origin'\");\n }\n\n req.networkClientId = getNetworkClientIdForDomain(req.origin);\n return next();\n };\n};\n"]}
1
+ {"version":3,"sources":[],"names":[],"mappings":""}
@@ -0,0 +1,8 @@
1
+ import {
2
+ createSelectedNetworkMiddleware
3
+ } from "./chunk-PPX4FXXU.mjs";
4
+ import "./chunk-DZKNOQNE.mjs";
5
+ export {
6
+ createSelectedNetworkMiddleware
7
+ };
8
+ //# sourceMappingURL=SelectedNetworkMiddleware.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,222 @@
1
+ var __accessCheck = (obj, member, msg) => {
2
+ if (!member.has(obj))
3
+ throw TypeError("Cannot " + msg);
4
+ };
5
+ var __privateGet = (obj, member, getter) => {
6
+ __accessCheck(obj, member, "read from private field");
7
+ return getter ? getter.call(obj) : member.get(obj);
8
+ };
9
+ var __privateAdd = (obj, member, value) => {
10
+ if (member.has(obj))
11
+ throw TypeError("Cannot add the same private member more than once");
12
+ member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
13
+ };
14
+ var __privateSet = (obj, member, value, setter) => {
15
+ __accessCheck(obj, member, "write to private field");
16
+ setter ? setter.call(obj, value) : member.set(obj, value);
17
+ return value;
18
+ };
19
+ var __privateMethod = (obj, member, method) => {
20
+ __accessCheck(obj, member, "access private method");
21
+ return method;
22
+ };
23
+
24
+ // src/SelectedNetworkController.ts
25
+ import { BaseController } from "@metamask/base-controller";
26
+ import { createEventEmitterProxy } from "@metamask/swappable-obj-proxy";
27
+ var controllerName = "SelectedNetworkController";
28
+ var stateMetadata = {
29
+ domains: { persist: true, anonymous: false }
30
+ };
31
+ var getDefaultState = () => ({ domains: {} });
32
+ var METAMASK_DOMAIN = "metamask";
33
+ var SelectedNetworkControllerActionTypes = {
34
+ getState: `${controllerName}:getState`,
35
+ getNetworkClientIdForDomain: `${controllerName}:getNetworkClientIdForDomain`,
36
+ setNetworkClientIdForDomain: `${controllerName}:setNetworkClientIdForDomain`
37
+ };
38
+ var SelectedNetworkControllerEventTypes = {
39
+ stateChange: `${controllerName}:stateChange`
40
+ };
41
+ var _proxies, _getUseRequestQueue, _registerMessageHandlers, registerMessageHandlers_fn, _setNetworkClientIdForDomain, setNetworkClientIdForDomain_fn, _domainHasPermissions, domainHasPermissions_fn;
42
+ var SelectedNetworkController = class extends BaseController {
43
+ /**
44
+ * Construct a SelectedNetworkController controller.
45
+ *
46
+ * @param options - The controller options.
47
+ * @param options.messenger - The restricted controller messenger for the EncryptionPublicKey controller.
48
+ * @param options.state - The controllers initial state.
49
+ * @param options.getUseRequestQueue - feature flag for perDappNetwork & request queueing features
50
+ */
51
+ constructor({
52
+ messenger,
53
+ state = getDefaultState(),
54
+ getUseRequestQueue
55
+ }) {
56
+ super({
57
+ name: controllerName,
58
+ metadata: stateMetadata,
59
+ messenger,
60
+ state
61
+ });
62
+ __privateAdd(this, _registerMessageHandlers);
63
+ __privateAdd(this, _setNetworkClientIdForDomain);
64
+ __privateAdd(this, _domainHasPermissions);
65
+ __privateAdd(this, _proxies, /* @__PURE__ */ new Map());
66
+ __privateAdd(this, _getUseRequestQueue, void 0);
67
+ __privateSet(this, _getUseRequestQueue, getUseRequestQueue);
68
+ __privateMethod(this, _registerMessageHandlers, registerMessageHandlers_fn).call(this);
69
+ this.messagingSystem.call("PermissionController:getSubjectNames").filter((domain) => this.state.domains[domain] === void 0).forEach(
70
+ (domain) => this.setNetworkClientIdForDomain(
71
+ domain,
72
+ this.messagingSystem.call("NetworkController:getState").selectedNetworkClientId
73
+ )
74
+ );
75
+ this.messagingSystem.subscribe(
76
+ "PermissionController:stateChange",
77
+ (_, patches) => {
78
+ patches.forEach(({ op, path }) => {
79
+ const isChangingSubject = path[0] === "subjects" && path[1] !== void 0;
80
+ if (isChangingSubject && typeof path[1] === "string") {
81
+ const domain = path[1];
82
+ if (op === "add" && this.state.domains[domain] === void 0) {
83
+ this.setNetworkClientIdForDomain(
84
+ domain,
85
+ this.messagingSystem.call("NetworkController:getState").selectedNetworkClientId
86
+ );
87
+ } else if (op === "remove" && this.state.domains[domain] !== void 0) {
88
+ this.update(({ domains }) => {
89
+ delete domains[domain];
90
+ });
91
+ }
92
+ }
93
+ });
94
+ }
95
+ );
96
+ this.messagingSystem.subscribe(
97
+ "NetworkController:stateChange",
98
+ ({ selectedNetworkClientId }, patches) => {
99
+ patches.forEach(({ op, path }) => {
100
+ if (op === "remove" && path[0] === "networkConfigurations") {
101
+ const removedNetworkClientId = path[1];
102
+ Object.entries(this.state.domains).forEach(
103
+ ([domain, networkClientIdForDomain]) => {
104
+ if (networkClientIdForDomain === removedNetworkClientId) {
105
+ this.setNetworkClientIdForDomain(
106
+ domain,
107
+ selectedNetworkClientId
108
+ );
109
+ }
110
+ }
111
+ );
112
+ }
113
+ });
114
+ }
115
+ );
116
+ }
117
+ setNetworkClientIdForDomain(domain, networkClientId) {
118
+ if (domain === METAMASK_DOMAIN) {
119
+ throw new Error(
120
+ `NetworkClientId for domain "${METAMASK_DOMAIN}" cannot be set on the SelectedNetworkController`
121
+ );
122
+ }
123
+ if (!__privateMethod(this, _domainHasPermissions, domainHasPermissions_fn).call(this, domain)) {
124
+ throw new Error(
125
+ "NetworkClientId for domain cannot be called with a domain that has not yet been granted permissions"
126
+ );
127
+ }
128
+ __privateMethod(this, _setNetworkClientIdForDomain, setNetworkClientIdForDomain_fn).call(this, domain, networkClientId);
129
+ }
130
+ getNetworkClientIdForDomain(domain) {
131
+ const { selectedNetworkClientId: metamaskSelectedNetworkClientId } = this.messagingSystem.call("NetworkController:getState");
132
+ if (!__privateGet(this, _getUseRequestQueue).call(this)) {
133
+ return metamaskSelectedNetworkClientId;
134
+ }
135
+ return this.state.domains[domain] ?? metamaskSelectedNetworkClientId;
136
+ }
137
+ /**
138
+ * Accesses the provider and block tracker for the currently selected network.
139
+ *
140
+ * @param domain - the domain for the provider
141
+ * @returns The proxy and block tracker proxies.
142
+ */
143
+ getProviderAndBlockTracker(domain) {
144
+ if (!__privateGet(this, _getUseRequestQueue).call(this)) {
145
+ throw new Error(
146
+ "Provider and BlockTracker should be fetched from NetworkController when useRequestQueue is false"
147
+ );
148
+ }
149
+ const networkClientId = this.state.domains[domain];
150
+ if (!networkClientId) {
151
+ throw new Error(
152
+ "NetworkClientId has not been set for the requested domain"
153
+ );
154
+ }
155
+ let networkProxy = __privateGet(this, _proxies).get(domain);
156
+ if (networkProxy === void 0) {
157
+ const networkClient = this.messagingSystem.call(
158
+ "NetworkController:getNetworkClientById",
159
+ networkClientId
160
+ );
161
+ networkProxy = {
162
+ provider: createEventEmitterProxy(networkClient.provider),
163
+ blockTracker: createEventEmitterProxy(networkClient.blockTracker, {
164
+ eventFilter: "skipInternal"
165
+ })
166
+ };
167
+ __privateGet(this, _proxies).set(domain, networkProxy);
168
+ }
169
+ return networkProxy;
170
+ }
171
+ };
172
+ _proxies = new WeakMap();
173
+ _getUseRequestQueue = new WeakMap();
174
+ _registerMessageHandlers = new WeakSet();
175
+ registerMessageHandlers_fn = function() {
176
+ this.messagingSystem.registerActionHandler(
177
+ SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain,
178
+ this.getNetworkClientIdForDomain.bind(this)
179
+ );
180
+ this.messagingSystem.registerActionHandler(
181
+ SelectedNetworkControllerActionTypes.setNetworkClientIdForDomain,
182
+ this.setNetworkClientIdForDomain.bind(this)
183
+ );
184
+ };
185
+ _setNetworkClientIdForDomain = new WeakSet();
186
+ setNetworkClientIdForDomain_fn = function(domain, networkClientId) {
187
+ const networkClient = this.messagingSystem.call(
188
+ "NetworkController:getNetworkClientById",
189
+ networkClientId
190
+ );
191
+ const networkProxy = __privateGet(this, _proxies).get(domain);
192
+ if (networkProxy === void 0) {
193
+ __privateGet(this, _proxies).set(domain, {
194
+ provider: createEventEmitterProxy(networkClient.provider),
195
+ blockTracker: createEventEmitterProxy(networkClient.blockTracker, {
196
+ eventFilter: "skipInternal"
197
+ })
198
+ });
199
+ } else {
200
+ networkProxy.provider.setTarget(networkClient.provider);
201
+ networkProxy.blockTracker.setTarget(networkClient.blockTracker);
202
+ }
203
+ this.update((state) => {
204
+ state.domains[domain] = networkClientId;
205
+ });
206
+ };
207
+ _domainHasPermissions = new WeakSet();
208
+ domainHasPermissions_fn = function(domain) {
209
+ return this.messagingSystem.call(
210
+ "PermissionController:hasPermissions",
211
+ domain
212
+ );
213
+ };
214
+
215
+ export {
216
+ controllerName,
217
+ METAMASK_DOMAIN,
218
+ SelectedNetworkControllerActionTypes,
219
+ SelectedNetworkControllerEventTypes,
220
+ SelectedNetworkController
221
+ };
222
+ //# sourceMappingURL=chunk-DZKNOQNE.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/SelectedNetworkController.ts"],"sourcesContent":["import type { RestrictedControllerMessenger } from '@metamask/base-controller';\nimport { BaseController } from '@metamask/base-controller';\nimport type {\n BlockTrackerProxy,\n NetworkClientId,\n NetworkControllerGetNetworkClientByIdAction,\n NetworkControllerGetStateAction,\n NetworkControllerStateChangeEvent,\n ProviderProxy,\n} from '@metamask/network-controller';\nimport type {\n PermissionControllerStateChange,\n GetSubjects as PermissionControllerGetSubjectsAction,\n HasPermissions as PermissionControllerHasPermissions,\n} from '@metamask/permission-controller';\nimport { createEventEmitterProxy } from '@metamask/swappable-obj-proxy';\nimport type { Patch } from 'immer';\n\nexport const controllerName = 'SelectedNetworkController';\n\nconst stateMetadata = {\n domains: { persist: true, anonymous: false },\n};\n\nconst getDefaultState = () => ({ domains: {} });\n\ntype Domain = string;\n\nexport const METAMASK_DOMAIN = 'metamask' as const;\n\nexport const SelectedNetworkControllerActionTypes = {\n getState: `${controllerName}:getState` as const,\n getNetworkClientIdForDomain:\n `${controllerName}:getNetworkClientIdForDomain` as const,\n setNetworkClientIdForDomain:\n `${controllerName}:setNetworkClientIdForDomain` as const,\n};\n\nexport const SelectedNetworkControllerEventTypes = {\n stateChange: `${controllerName}:stateChange` as const,\n};\n\nexport type SelectedNetworkControllerState = {\n domains: Record<Domain, NetworkClientId>;\n};\n\nexport type SelectedNetworkControllerStateChangeEvent = {\n type: typeof SelectedNetworkControllerEventTypes.stateChange;\n payload: [SelectedNetworkControllerState, Patch[]];\n};\n\nexport type SelectedNetworkControllerGetSelectedNetworkStateAction = {\n type: typeof SelectedNetworkControllerActionTypes.getState;\n handler: () => SelectedNetworkControllerState;\n};\n\nexport type SelectedNetworkControllerGetNetworkClientIdForDomainAction = {\n type: typeof SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain;\n handler: SelectedNetworkController['getNetworkClientIdForDomain'];\n};\n\nexport type SelectedNetworkControllerSetNetworkClientIdForDomainAction = {\n type: typeof SelectedNetworkControllerActionTypes.setNetworkClientIdForDomain;\n handler: SelectedNetworkController['setNetworkClientIdForDomain'];\n};\n\nexport type SelectedNetworkControllerActions =\n | SelectedNetworkControllerGetSelectedNetworkStateAction\n | SelectedNetworkControllerGetNetworkClientIdForDomainAction\n | SelectedNetworkControllerSetNetworkClientIdForDomainAction;\n\nexport type AllowedActions =\n | NetworkControllerGetNetworkClientByIdAction\n | NetworkControllerGetStateAction\n | PermissionControllerHasPermissions\n | PermissionControllerGetSubjectsAction;\n\nexport type SelectedNetworkControllerEvents =\n SelectedNetworkControllerStateChangeEvent;\n\nexport type AllowedEvents =\n | NetworkControllerStateChangeEvent\n | PermissionControllerStateChange;\n\nexport type SelectedNetworkControllerMessenger = RestrictedControllerMessenger<\n typeof controllerName,\n SelectedNetworkControllerActions | AllowedActions,\n SelectedNetworkControllerEvents | AllowedEvents,\n AllowedActions['type'],\n AllowedEvents['type']\n>;\n\nexport type GetUseRequestQueue = () => boolean;\n\nexport type SelectedNetworkControllerOptions = {\n state?: SelectedNetworkControllerState;\n messenger: SelectedNetworkControllerMessenger;\n getUseRequestQueue: GetUseRequestQueue;\n};\n\nexport type NetworkProxy = {\n provider: ProviderProxy;\n blockTracker: BlockTrackerProxy;\n};\n\n/**\n * Controller for getting and setting the network for a particular domain.\n */\nexport class SelectedNetworkController extends BaseController<\n typeof controllerName,\n SelectedNetworkControllerState,\n SelectedNetworkControllerMessenger\n> {\n #proxies = new Map<Domain, NetworkProxy>();\n\n #getUseRequestQueue: GetUseRequestQueue;\n\n /**\n * Construct a SelectedNetworkController controller.\n *\n * @param options - The controller options.\n * @param options.messenger - The restricted controller messenger for the EncryptionPublicKey controller.\n * @param options.state - The controllers initial state.\n * @param options.getUseRequestQueue - feature flag for perDappNetwork & request queueing features\n */\n constructor({\n messenger,\n state = getDefaultState(),\n getUseRequestQueue,\n }: SelectedNetworkControllerOptions) {\n super({\n name: controllerName,\n metadata: stateMetadata,\n messenger,\n state,\n });\n this.#getUseRequestQueue = getUseRequestQueue;\n this.#registerMessageHandlers();\n\n // this is fetching all the dapp permissions from the PermissionsController and looking for any domains that are not in domains state in this controller. Then we take any missing domains and add them to state here, setting it with the globally selected networkClientId (fetched from the NetworkController)\n this.messagingSystem\n .call('PermissionController:getSubjectNames')\n .filter((domain) => this.state.domains[domain] === undefined)\n .forEach((domain) =>\n this.setNetworkClientIdForDomain(\n domain,\n this.messagingSystem.call('NetworkController:getState')\n .selectedNetworkClientId,\n ),\n );\n\n this.messagingSystem.subscribe(\n 'PermissionController:stateChange',\n (_, patches) => {\n patches.forEach(({ op, path }) => {\n const isChangingSubject =\n path[0] === 'subjects' && path[1] !== undefined;\n if (isChangingSubject && typeof path[1] === 'string') {\n const domain = path[1];\n if (op === 'add' && this.state.domains[domain] === undefined) {\n this.setNetworkClientIdForDomain(\n domain,\n this.messagingSystem.call('NetworkController:getState')\n .selectedNetworkClientId,\n );\n } else if (\n op === 'remove' &&\n this.state.domains[domain] !== undefined\n ) {\n this.update(({ domains }) => {\n delete domains[domain];\n });\n }\n }\n });\n },\n );\n\n this.messagingSystem.subscribe(\n 'NetworkController:stateChange',\n ({ selectedNetworkClientId }, patches) => {\n patches.forEach(({ op, path }) => {\n // if a network is removed, update the networkClientId for all domains that were using it to the selected network\n if (op === 'remove' && path[0] === 'networkConfigurations') {\n const removedNetworkClientId = path[1] as NetworkClientId;\n Object.entries(this.state.domains).forEach(\n ([domain, networkClientIdForDomain]) => {\n if (networkClientIdForDomain === removedNetworkClientId) {\n this.setNetworkClientIdForDomain(\n domain,\n selectedNetworkClientId,\n );\n }\n },\n );\n }\n });\n },\n );\n }\n\n #registerMessageHandlers(): void {\n this.messagingSystem.registerActionHandler(\n SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain,\n this.getNetworkClientIdForDomain.bind(this),\n );\n this.messagingSystem.registerActionHandler(\n SelectedNetworkControllerActionTypes.setNetworkClientIdForDomain,\n this.setNetworkClientIdForDomain.bind(this),\n );\n }\n\n #setNetworkClientIdForDomain(\n domain: Domain,\n networkClientId: NetworkClientId,\n ) {\n const networkClient = this.messagingSystem.call(\n 'NetworkController:getNetworkClientById',\n networkClientId,\n );\n const networkProxy = this.#proxies.get(domain);\n if (networkProxy === undefined) {\n this.#proxies.set(domain, {\n provider: createEventEmitterProxy(networkClient.provider),\n blockTracker: createEventEmitterProxy(networkClient.blockTracker, {\n eventFilter: 'skipInternal',\n }),\n });\n } else {\n networkProxy.provider.setTarget(networkClient.provider);\n networkProxy.blockTracker.setTarget(networkClient.blockTracker);\n }\n\n this.update((state) => {\n state.domains[domain] = networkClientId;\n });\n }\n\n #domainHasPermissions(domain: Domain): boolean {\n return this.messagingSystem.call(\n 'PermissionController:hasPermissions',\n domain,\n );\n }\n\n setNetworkClientIdForDomain(\n domain: Domain,\n networkClientId: NetworkClientId,\n ) {\n if (domain === METAMASK_DOMAIN) {\n throw new Error(\n `NetworkClientId for domain \"${METAMASK_DOMAIN}\" cannot be set on the SelectedNetworkController`,\n );\n }\n\n if (!this.#domainHasPermissions(domain)) {\n throw new Error(\n 'NetworkClientId for domain cannot be called with a domain that has not yet been granted permissions',\n );\n }\n\n this.#setNetworkClientIdForDomain(domain, networkClientId);\n }\n\n getNetworkClientIdForDomain(domain: Domain): NetworkClientId {\n const { selectedNetworkClientId: metamaskSelectedNetworkClientId } =\n this.messagingSystem.call('NetworkController:getState');\n if (!this.#getUseRequestQueue()) {\n return metamaskSelectedNetworkClientId;\n }\n return this.state.domains[domain] ?? metamaskSelectedNetworkClientId;\n }\n\n /**\n * Accesses the provider and block tracker for the currently selected network.\n *\n * @param domain - the domain for the provider\n * @returns The proxy and block tracker proxies.\n */\n getProviderAndBlockTracker(domain: Domain): NetworkProxy {\n if (!this.#getUseRequestQueue()) {\n throw new Error(\n 'Provider and BlockTracker should be fetched from NetworkController when useRequestQueue is false',\n );\n }\n const networkClientId = this.state.domains[domain];\n if (!networkClientId) {\n throw new Error(\n 'NetworkClientId has not been set for the requested domain',\n );\n }\n let networkProxy = this.#proxies.get(domain);\n if (networkProxy === undefined) {\n const networkClient = this.messagingSystem.call(\n 'NetworkController:getNetworkClientById',\n networkClientId,\n );\n networkProxy = {\n provider: createEventEmitterProxy(networkClient.provider),\n blockTracker: createEventEmitterProxy(networkClient.blockTracker, {\n eventFilter: 'skipInternal',\n }),\n };\n this.#proxies.set(domain, networkProxy);\n }\n\n return networkProxy;\n }\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,23 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
+
3
+ var _chunkWK7GHGRDjs = require('./chunk-WK7GHGRD.js');
4
+
5
+ // src/SelectedNetworkMiddleware.ts
6
+ var createSelectedNetworkMiddleware = (messenger) => {
7
+ const getNetworkClientIdForDomain = (origin) => messenger.call(
8
+ _chunkWK7GHGRDjs.SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain,
9
+ origin
10
+ );
11
+ return (req, _, next) => {
12
+ if (!req.origin) {
13
+ throw new Error("Request object is lacking an 'origin'");
14
+ }
15
+ req.networkClientId = getNetworkClientIdForDomain(req.origin);
16
+ return next();
17
+ };
18
+ };
19
+
20
+
21
+
22
+ exports.createSelectedNetworkMiddleware = createSelectedNetworkMiddleware;
23
+ //# sourceMappingURL=chunk-MRZPOKCN.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/SelectedNetworkMiddleware.ts"],"names":[],"mappings":";;;;;AAYO,IAAM,kCAAkC,CAC7C,cAC2C;AAC3C,QAAM,8BAA8B,CAAC,WACnC,UAAU;AAAA,IACR,qCAAqC;AAAA,IACrC;AAAA,EACF;AAEF,SAAO,CAAC,KAA8C,GAAG,SAAS;AAChE,QAAI,CAAC,IAAI,QAAQ;AACf,YAAM,IAAI,MAAM,uCAAuC;AAAA,IACzD;AAEA,QAAI,kBAAkB,4BAA4B,IAAI,MAAM;AAC5D,WAAO,KAAK;AAAA,EACd;AACF","sourcesContent":["import type { JsonRpcMiddleware } from '@metamask/json-rpc-engine';\nimport type { NetworkClientId } from '@metamask/network-controller';\nimport type { Json, JsonRpcParams, JsonRpcRequest } from '@metamask/utils';\n\nimport type { SelectedNetworkControllerMessenger } from './SelectedNetworkController';\nimport { SelectedNetworkControllerActionTypes } from './SelectedNetworkController';\n\nexport type SelectedNetworkMiddlewareJsonRpcRequest = JsonRpcRequest & {\n networkClientId?: NetworkClientId;\n origin?: string;\n};\n\nexport const createSelectedNetworkMiddleware = (\n messenger: SelectedNetworkControllerMessenger,\n): JsonRpcMiddleware<JsonRpcParams, Json> => {\n const getNetworkClientIdForDomain = (origin: string) =>\n messenger.call(\n SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain,\n origin,\n );\n\n return (req: SelectedNetworkMiddlewareJsonRpcRequest, _, next) => {\n if (!req.origin) {\n throw new Error(\"Request object is lacking an 'origin'\");\n }\n\n req.networkClientId = getNetworkClientIdForDomain(req.origin);\n return next();\n };\n};\n"]}
@@ -0,0 +1,23 @@
1
+ import {
2
+ SelectedNetworkControllerActionTypes
3
+ } from "./chunk-DZKNOQNE.mjs";
4
+
5
+ // src/SelectedNetworkMiddleware.ts
6
+ var createSelectedNetworkMiddleware = (messenger) => {
7
+ const getNetworkClientIdForDomain = (origin) => messenger.call(
8
+ SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain,
9
+ origin
10
+ );
11
+ return (req, _, next) => {
12
+ if (!req.origin) {
13
+ throw new Error("Request object is lacking an 'origin'");
14
+ }
15
+ req.networkClientId = getNetworkClientIdForDomain(req.origin);
16
+ return next();
17
+ };
18
+ };
19
+
20
+ export {
21
+ createSelectedNetworkMiddleware
22
+ };
23
+ //# sourceMappingURL=chunk-PPX4FXXU.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/SelectedNetworkMiddleware.ts"],"sourcesContent":["import type { JsonRpcMiddleware } from '@metamask/json-rpc-engine';\nimport type { NetworkClientId } from '@metamask/network-controller';\nimport type { Json, JsonRpcParams, JsonRpcRequest } from '@metamask/utils';\n\nimport type { SelectedNetworkControllerMessenger } from './SelectedNetworkController';\nimport { SelectedNetworkControllerActionTypes } from './SelectedNetworkController';\n\nexport type SelectedNetworkMiddlewareJsonRpcRequest = JsonRpcRequest & {\n networkClientId?: NetworkClientId;\n origin?: string;\n};\n\nexport const createSelectedNetworkMiddleware = (\n messenger: SelectedNetworkControllerMessenger,\n): JsonRpcMiddleware<JsonRpcParams, Json> => {\n const getNetworkClientIdForDomain = (origin: string) =>\n messenger.call(\n SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain,\n origin,\n );\n\n return (req: SelectedNetworkMiddlewareJsonRpcRequest, _, next) => {\n if (!req.origin) {\n throw new Error(\"Request object is lacking an 'origin'\");\n }\n\n req.networkClientId = getNetworkClientIdForDomain(req.origin);\n return next();\n };\n};\n"],"mappings":";;;;;AAYO,IAAM,kCAAkC,CAC7C,cAC2C;AAC3C,QAAM,8BAA8B,CAAC,WACnC,UAAU;AAAA,IACR,qCAAqC;AAAA,IACrC;AAAA,EACF;AAEF,SAAO,CAAC,KAA8C,GAAG,SAAS;AAChE,QAAI,CAAC,IAAI,QAAQ;AACf,YAAM,IAAI,MAAM,uCAAuC;AAAA,IACzD;AAEA,QAAI,kBAAkB,4BAA4B,IAAI,MAAM;AAC5D,WAAO,KAAK;AAAA,EACd;AACF;","names":[]}