@metamask-previews/selected-network-controller 18.0.0-preview-cf09c0a → 18.0.0-preview-09a2ffd5

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 (44) hide show
  1. package/dist/SelectedNetworkController.js +15 -0
  2. package/dist/SelectedNetworkController.js.map +1 -0
  3. package/dist/SelectedNetworkController.mjs +13 -226
  4. package/dist/SelectedNetworkController.mjs.map +1 -1
  5. package/dist/SelectedNetworkMiddleware.js +8 -0
  6. package/dist/SelectedNetworkMiddleware.js.map +1 -0
  7. package/dist/SelectedNetworkMiddleware.mjs +6 -10
  8. package/dist/SelectedNetworkMiddleware.mjs.map +1 -1
  9. package/dist/chunk-D745I7P5.mjs +281 -0
  10. package/dist/chunk-D745I7P5.mjs.map +1 -0
  11. package/dist/chunk-H6ZVCOKD.js +23 -0
  12. package/dist/chunk-H6ZVCOKD.js.map +1 -0
  13. package/dist/chunk-JFYFZWUW.mjs +23 -0
  14. package/dist/chunk-JFYFZWUW.mjs.map +1 -0
  15. package/dist/chunk-ZFFMRFO4.js +281 -0
  16. package/dist/chunk-ZFFMRFO4.js.map +1 -0
  17. package/dist/index.js +17 -0
  18. package/dist/index.js.map +1 -0
  19. package/dist/index.mjs +16 -2
  20. package/dist/index.mjs.map +1 -1
  21. package/dist/tsconfig.build.tsbuildinfo +1 -0
  22. package/dist/{SelectedNetworkController.d.mts → types/SelectedNetworkController.d.ts} +6 -6
  23. package/dist/types/SelectedNetworkController.d.ts.map +1 -0
  24. package/dist/types/SelectedNetworkMiddleware.d.ts +10 -0
  25. package/dist/types/SelectedNetworkMiddleware.d.ts.map +1 -0
  26. package/dist/{index.d.cts → types/index.d.ts} +5 -5
  27. package/dist/types/index.d.ts.map +1 -0
  28. package/package.json +7 -12
  29. package/dist/SelectedNetworkController.cjs +0 -231
  30. package/dist/SelectedNetworkController.cjs.map +0 -1
  31. package/dist/SelectedNetworkController.d.cts +0 -80
  32. package/dist/SelectedNetworkController.d.cts.map +0 -1
  33. package/dist/SelectedNetworkController.d.mts.map +0 -1
  34. package/dist/SelectedNetworkMiddleware.cjs +0 -16
  35. package/dist/SelectedNetworkMiddleware.cjs.map +0 -1
  36. package/dist/SelectedNetworkMiddleware.d.cts +0 -10
  37. package/dist/SelectedNetworkMiddleware.d.cts.map +0 -1
  38. package/dist/SelectedNetworkMiddleware.d.mts +0 -10
  39. package/dist/SelectedNetworkMiddleware.d.mts.map +0 -1
  40. package/dist/index.cjs +0 -11
  41. package/dist/index.cjs.map +0 -1
  42. package/dist/index.d.cts.map +0 -1
  43. package/dist/index.d.mts +0 -5
  44. package/dist/index.d.mts.map +0 -1
@@ -0,0 +1,15 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
+
3
+
4
+
5
+
6
+
7
+ var _chunkZFFMRFO4js = require('./chunk-ZFFMRFO4.js');
8
+
9
+
10
+
11
+
12
+
13
+
14
+ exports.METAMASK_DOMAIN = _chunkZFFMRFO4js.METAMASK_DOMAIN; exports.SelectedNetworkController = _chunkZFFMRFO4js.SelectedNetworkController; exports.SelectedNetworkControllerActionTypes = _chunkZFFMRFO4js.SelectedNetworkControllerActionTypes; exports.SelectedNetworkControllerEventTypes = _chunkZFFMRFO4js.SelectedNetworkControllerEventTypes; exports.controllerName = _chunkZFFMRFO4js.controllerName;
15
+ //# sourceMappingURL=SelectedNetworkController.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":""}
@@ -1,228 +1,15 @@
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 _SelectedNetworkController_instances, _SelectedNetworkController_domainProxyMap, _SelectedNetworkController_useRequestQueuePreference, _SelectedNetworkController_registerMessageHandlers, _SelectedNetworkController_setNetworkClientIdForDomain, _SelectedNetworkController_unsetNetworkClientIdForDomain, _SelectedNetworkController_domainHasPermissions, _SelectedNetworkController_resetAllPermissionedDomains;
13
- import { BaseController } from "@metamask/base-controller";
14
- import $metamaskswappableobjproxy from "@metamask/swappable-obj-proxy";
15
- const { createEventEmitterProxy } = $metamaskswappableobjproxy;
16
- export const controllerName = 'SelectedNetworkController';
17
- const stateMetadata = {
18
- domains: { persist: true, anonymous: false },
19
- };
20
- const getDefaultState = () => ({ domains: {} });
21
- // npm and local are currently the only valid prefixes for snap domains
22
- // TODO: eventually we maybe want to pull this in from snaps-utils to ensure it stays in sync
23
- // For now it seems like overkill to add a dependency for this one constant
24
- // https://github.com/MetaMask/snaps/blob/2beee7803bfe9e540788a3558b546b9f55dc3cb4/packages/snaps-utils/src/types.ts#L120
25
- const snapsPrefixes = ['npm:', 'local:'];
26
- export const METAMASK_DOMAIN = 'metamask';
27
- export const SelectedNetworkControllerActionTypes = {
28
- getState: `${controllerName}:getState`,
29
- getNetworkClientIdForDomain: `${controllerName}:getNetworkClientIdForDomain`,
30
- setNetworkClientIdForDomain: `${controllerName}:setNetworkClientIdForDomain`,
31
- };
32
- export const SelectedNetworkControllerEventTypes = {
33
- stateChange: `${controllerName}:stateChange`,
34
- };
35
- /**
36
- * Controller for getting and setting the network for a particular domain.
37
- */
38
- export class SelectedNetworkController extends BaseController {
39
- /**
40
- * Construct a SelectedNetworkController controller.
41
- *
42
- * @param options - The controller options.
43
- * @param options.messenger - The restricted controller messenger for the EncryptionPublicKey controller.
44
- * @param options.state - The controllers initial state.
45
- * @param options.useRequestQueuePreference - A boolean indicating whether to use the request queue preference.
46
- * @param options.onPreferencesStateChange - A callback that is called when the preference state changes.
47
- * @param options.domainProxyMap - A map for storing domain-specific proxies that are held in memory only during use.
48
- */
49
- constructor({ messenger, state = getDefaultState(), useRequestQueuePreference, onPreferencesStateChange, domainProxyMap, }) {
50
- super({
51
- name: controllerName,
52
- metadata: stateMetadata,
53
- messenger,
54
- state,
55
- });
56
- _SelectedNetworkController_instances.add(this);
57
- _SelectedNetworkController_domainProxyMap.set(this, void 0);
58
- _SelectedNetworkController_useRequestQueuePreference.set(this, void 0);
59
- __classPrivateFieldSet(this, _SelectedNetworkController_useRequestQueuePreference, useRequestQueuePreference, "f");
60
- __classPrivateFieldSet(this, _SelectedNetworkController_domainProxyMap, domainProxyMap, "f");
61
- __classPrivateFieldGet(this, _SelectedNetworkController_instances, "m", _SelectedNetworkController_registerMessageHandlers).call(this);
62
- // 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)
63
- this.messagingSystem
64
- .call('PermissionController:getSubjectNames')
65
- .filter((domain) => this.state.domains[domain] === undefined)
66
- .forEach((domain) => this.setNetworkClientIdForDomain(domain, this.messagingSystem.call('NetworkController:getState')
67
- .selectedNetworkClientId));
68
- this.messagingSystem.subscribe('PermissionController:stateChange', (_, patches) => {
69
- patches.forEach(({ op, path }) => {
70
- const isChangingSubject = path[0] === 'subjects' && path[1] !== undefined;
71
- if (isChangingSubject && typeof path[1] === 'string') {
72
- const domain = path[1];
73
- if (op === 'add' && this.state.domains[domain] === undefined) {
74
- this.setNetworkClientIdForDomain(domain, this.messagingSystem.call('NetworkController:getState')
75
- .selectedNetworkClientId);
76
- }
77
- else if (op === 'remove' &&
78
- this.state.domains[domain] !== undefined) {
79
- __classPrivateFieldGet(this, _SelectedNetworkController_instances, "m", _SelectedNetworkController_unsetNetworkClientIdForDomain).call(this, domain);
80
- }
81
- }
82
- });
83
- });
84
- this.messagingSystem.subscribe('NetworkController:stateChange', ({ selectedNetworkClientId, networkConfigurationsByChainId }, patches) => {
85
- const patch = patches.find(({ op, path }) => (op === 'replace' || op === 'remove') &&
86
- path[0] === 'networkConfigurationsByChainId');
87
- if (patch) {
88
- const networkClientIdToChainId = Object.values(networkConfigurationsByChainId).reduce((acc, network) => {
89
- network.rpcEndpoints.forEach(({ networkClientId }) => (acc[networkClientId] = network.chainId));
90
- return acc;
91
- }, {});
92
- Object.entries(this.state.domains).forEach(([domain, networkClientIdForDomain]) => {
93
- const chainIdForDomain = networkClientIdToChainId[networkClientIdForDomain];
94
- if (patch.op === 'remove' && !chainIdForDomain) {
95
- // If the network was removed, fall back to the globally selected network
96
- this.setNetworkClientIdForDomain(domain, selectedNetworkClientId);
97
- }
98
- else if (patch.op === 'replace') {
99
- // If the network was updated, redirect to the network's default endpoint
100
- const updatedChainId = patch.path[1];
101
- if (!chainIdForDomain || chainIdForDomain === updatedChainId) {
102
- const network = networkConfigurationsByChainId[updatedChainId];
103
- const { networkClientId: defaultNetworkClientId } = network.rpcEndpoints[network.defaultRpcEndpointIndex];
104
- if (networkClientIdForDomain !== defaultNetworkClientId) {
105
- this.setNetworkClientIdForDomain(domain, defaultNetworkClientId);
106
- }
107
- }
108
- }
109
- });
110
- }
111
- });
112
- onPreferencesStateChange(({ useRequestQueue }) => {
113
- if (__classPrivateFieldGet(this, _SelectedNetworkController_useRequestQueuePreference, "f") !== useRequestQueue) {
114
- if (!useRequestQueue) {
115
- // Loop through all domains and points each domain's proxy
116
- // to the NetworkController's own proxy of the globally selected networkClient
117
- Object.keys(this.state.domains).forEach((domain) => {
118
- __classPrivateFieldGet(this, _SelectedNetworkController_instances, "m", _SelectedNetworkController_unsetNetworkClientIdForDomain).call(this, domain);
119
- });
120
- }
121
- else {
122
- __classPrivateFieldGet(this, _SelectedNetworkController_instances, "m", _SelectedNetworkController_resetAllPermissionedDomains).call(this);
123
- }
124
- __classPrivateFieldSet(this, _SelectedNetworkController_useRequestQueuePreference, useRequestQueue, "f");
125
- }
126
- });
127
- }
128
- setNetworkClientIdForDomain(domain, networkClientId) {
129
- if (!__classPrivateFieldGet(this, _SelectedNetworkController_useRequestQueuePreference, "f")) {
130
- return;
131
- }
132
- if (domain === METAMASK_DOMAIN) {
133
- throw new Error(`NetworkClientId for domain "${METAMASK_DOMAIN}" cannot be set on the SelectedNetworkController`);
134
- }
135
- if (snapsPrefixes.some((prefix) => domain.startsWith(prefix))) {
136
- return;
137
- }
138
- if (!__classPrivateFieldGet(this, _SelectedNetworkController_instances, "m", _SelectedNetworkController_domainHasPermissions).call(this, domain)) {
139
- throw new Error('NetworkClientId for domain cannot be called with a domain that has not yet been granted permissions');
140
- }
141
- __classPrivateFieldGet(this, _SelectedNetworkController_instances, "m", _SelectedNetworkController_setNetworkClientIdForDomain).call(this, domain, networkClientId);
142
- }
143
- getNetworkClientIdForDomain(domain) {
144
- const { selectedNetworkClientId: metamaskSelectedNetworkClientId } = this.messagingSystem.call('NetworkController:getState');
145
- if (!__classPrivateFieldGet(this, _SelectedNetworkController_useRequestQueuePreference, "f")) {
146
- return metamaskSelectedNetworkClientId;
147
- }
148
- return this.state.domains[domain] ?? metamaskSelectedNetworkClientId;
149
- }
150
- /**
151
- * Accesses the provider and block tracker for the currently selected network.
152
- *
153
- * @param domain - the domain for the provider
154
- * @returns The proxy and block tracker proxies.
155
- */
156
- getProviderAndBlockTracker(domain) {
157
- // If the domain is 'metamask' or a snap, return the NetworkController's globally selected network client proxy
158
- if (domain === METAMASK_DOMAIN ||
159
- snapsPrefixes.some((prefix) => domain.startsWith(prefix))) {
160
- const networkClient = this.messagingSystem.call('NetworkController:getSelectedNetworkClient');
161
- if (networkClient === undefined) {
162
- throw new Error('Selected network not initialized');
163
- }
164
- return networkClient;
165
- }
166
- let networkProxy = __classPrivateFieldGet(this, _SelectedNetworkController_domainProxyMap, "f").get(domain);
167
- if (networkProxy === undefined) {
168
- let networkClient;
169
- if (__classPrivateFieldGet(this, _SelectedNetworkController_useRequestQueuePreference, "f") &&
170
- __classPrivateFieldGet(this, _SelectedNetworkController_instances, "m", _SelectedNetworkController_domainHasPermissions).call(this, domain)) {
171
- const networkClientId = this.getNetworkClientIdForDomain(domain);
172
- networkClient = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId);
173
- }
174
- else {
175
- networkClient = this.messagingSystem.call('NetworkController:getSelectedNetworkClient');
176
- if (networkClient === undefined) {
177
- throw new Error('Selected network not initialized');
178
- }
179
- }
180
- networkProxy = {
181
- provider: createEventEmitterProxy(networkClient.provider),
182
- blockTracker: createEventEmitterProxy(networkClient.blockTracker, {
183
- eventFilter: 'skipInternal',
184
- }),
185
- };
186
- __classPrivateFieldGet(this, _SelectedNetworkController_domainProxyMap, "f").set(domain, networkProxy);
187
- }
188
- return networkProxy;
189
- }
190
- }
191
- _SelectedNetworkController_domainProxyMap = new WeakMap(), _SelectedNetworkController_useRequestQueuePreference = new WeakMap(), _SelectedNetworkController_instances = new WeakSet(), _SelectedNetworkController_registerMessageHandlers = function _SelectedNetworkController_registerMessageHandlers() {
192
- this.messagingSystem.registerActionHandler(SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain, this.getNetworkClientIdForDomain.bind(this));
193
- this.messagingSystem.registerActionHandler(SelectedNetworkControllerActionTypes.setNetworkClientIdForDomain, this.setNetworkClientIdForDomain.bind(this));
194
- }, _SelectedNetworkController_setNetworkClientIdForDomain = function _SelectedNetworkController_setNetworkClientIdForDomain(domain, networkClientId) {
195
- const networkClient = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId);
196
- const networkProxy = this.getProviderAndBlockTracker(domain);
197
- networkProxy.provider.setTarget(networkClient.provider);
198
- networkProxy.blockTracker.setTarget(networkClient.blockTracker);
199
- this.update((state) => {
200
- state.domains[domain] = networkClientId;
201
- });
202
- }, _SelectedNetworkController_unsetNetworkClientIdForDomain = function _SelectedNetworkController_unsetNetworkClientIdForDomain(domain) {
203
- const globallySelectedNetworkClient = this.messagingSystem.call('NetworkController:getSelectedNetworkClient');
204
- const networkProxy = __classPrivateFieldGet(this, _SelectedNetworkController_domainProxyMap, "f").get(domain);
205
- if (networkProxy && globallySelectedNetworkClient) {
206
- networkProxy.provider.setTarget(globallySelectedNetworkClient.provider);
207
- networkProxy.blockTracker.setTarget(globallySelectedNetworkClient.blockTracker);
208
- }
209
- else if (networkProxy) {
210
- __classPrivateFieldGet(this, _SelectedNetworkController_domainProxyMap, "f").delete(domain);
211
- }
212
- this.update((state) => {
213
- delete state.domains[domain];
214
- });
215
- }, _SelectedNetworkController_domainHasPermissions = function _SelectedNetworkController_domainHasPermissions(domain) {
216
- return this.messagingSystem.call('PermissionController:hasPermissions', domain);
217
- }, _SelectedNetworkController_resetAllPermissionedDomains = function _SelectedNetworkController_resetAllPermissionedDomains() {
218
- __classPrivateFieldGet(this, _SelectedNetworkController_domainProxyMap, "f").forEach((_, domain) => {
219
- const { selectedNetworkClientId } = this.messagingSystem.call('NetworkController:getState');
220
- // can't use public setNetworkClientIdForDomain because it will throw an error
221
- // rather than simply skip if the domain doesn't have permissions which can happen
222
- // in this case since proxies are added for each site the user visits
223
- if (__classPrivateFieldGet(this, _SelectedNetworkController_instances, "m", _SelectedNetworkController_domainHasPermissions).call(this, domain)) {
224
- __classPrivateFieldGet(this, _SelectedNetworkController_instances, "m", _SelectedNetworkController_setNetworkClientIdForDomain).call(this, domain, selectedNetworkClientId);
225
- }
226
- });
1
+ import {
2
+ METAMASK_DOMAIN,
3
+ SelectedNetworkController,
4
+ SelectedNetworkControllerActionTypes,
5
+ SelectedNetworkControllerEventTypes,
6
+ controllerName
7
+ } from "./chunk-D745I7P5.mjs";
8
+ export {
9
+ METAMASK_DOMAIN,
10
+ SelectedNetworkController,
11
+ SelectedNetworkControllerActionTypes,
12
+ SelectedNetworkControllerEventTypes,
13
+ controllerName
227
14
  };
228
15
  //# sourceMappingURL=SelectedNetworkController.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"SelectedNetworkController.mjs","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 NetworkControllerGetSelectedNetworkClientAction,\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 { Hex } from '@metamask/utils';\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\n// npm and local are currently the only valid prefixes for snap domains\n// TODO: eventually we maybe want to pull this in from snaps-utils to ensure it stays in sync\n// For now it seems like overkill to add a dependency for this one constant\n// https://github.com/MetaMask/snaps/blob/2beee7803bfe9e540788a3558b546b9f55dc3cb4/packages/snaps-utils/src/types.ts#L120\nconst snapsPrefixes = ['npm:', 'local:'] as const;\n\nexport type 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 | NetworkControllerGetSelectedNetworkClientAction\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 SelectedNetworkControllerOptions = {\n state?: SelectedNetworkControllerState;\n messenger: SelectedNetworkControllerMessenger;\n useRequestQueuePreference: boolean;\n onPreferencesStateChange: (\n listener: (preferencesState: { useRequestQueue: boolean }) => void,\n ) => void;\n domainProxyMap: Map<Domain, NetworkProxy>;\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 #domainProxyMap: Map<Domain, NetworkProxy>;\n\n #useRequestQueuePreference: boolean;\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.useRequestQueuePreference - A boolean indicating whether to use the request queue preference.\n * @param options.onPreferencesStateChange - A callback that is called when the preference state changes.\n * @param options.domainProxyMap - A map for storing domain-specific proxies that are held in memory only during use.\n */\n constructor({\n messenger,\n state = getDefaultState(),\n useRequestQueuePreference,\n onPreferencesStateChange,\n domainProxyMap,\n }: SelectedNetworkControllerOptions) {\n super({\n name: controllerName,\n metadata: stateMetadata,\n messenger,\n state,\n });\n this.#useRequestQueuePreference = useRequestQueuePreference;\n this.#domainProxyMap = domainProxyMap;\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.#unsetNetworkClientIdForDomain(domain);\n }\n }\n });\n },\n );\n\n this.messagingSystem.subscribe(\n 'NetworkController:stateChange',\n (\n { selectedNetworkClientId, networkConfigurationsByChainId },\n patches,\n ) => {\n const patch = patches.find(\n ({ op, path }) =>\n (op === 'replace' || op === 'remove') &&\n path[0] === 'networkConfigurationsByChainId',\n );\n\n if (patch) {\n const networkClientIdToChainId = Object.values(\n networkConfigurationsByChainId,\n ).reduce((acc, network) => {\n network.rpcEndpoints.forEach(\n ({ networkClientId }) => (acc[networkClientId] = network.chainId),\n );\n return acc;\n }, {} as Record<string, Hex>);\n\n Object.entries(this.state.domains).forEach(\n ([domain, networkClientIdForDomain]) => {\n const chainIdForDomain =\n networkClientIdToChainId[networkClientIdForDomain];\n\n if (patch.op === 'remove' && !chainIdForDomain) {\n // If the network was removed, fall back to the globally selected network\n this.setNetworkClientIdForDomain(\n domain,\n selectedNetworkClientId,\n );\n } else if (patch.op === 'replace') {\n // If the network was updated, redirect to the network's default endpoint\n\n const updatedChainId = patch.path[1] as Hex;\n if (!chainIdForDomain || chainIdForDomain === updatedChainId) {\n const network =\n networkConfigurationsByChainId[updatedChainId];\n\n const { networkClientId: defaultNetworkClientId } =\n network.rpcEndpoints[network.defaultRpcEndpointIndex];\n\n if (networkClientIdForDomain !== defaultNetworkClientId) {\n this.setNetworkClientIdForDomain(\n domain,\n defaultNetworkClientId,\n );\n }\n }\n }\n },\n );\n }\n },\n );\n\n onPreferencesStateChange(({ useRequestQueue }) => {\n if (this.#useRequestQueuePreference !== useRequestQueue) {\n if (!useRequestQueue) {\n // Loop through all domains and points each domain's proxy\n // to the NetworkController's own proxy of the globally selected networkClient\n Object.keys(this.state.domains).forEach((domain) => {\n this.#unsetNetworkClientIdForDomain(domain);\n });\n } else {\n this.#resetAllPermissionedDomains();\n }\n this.#useRequestQueuePreference = useRequestQueue;\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.getProviderAndBlockTracker(domain);\n networkProxy.provider.setTarget(networkClient.provider);\n networkProxy.blockTracker.setTarget(networkClient.blockTracker);\n\n this.update((state) => {\n state.domains[domain] = networkClientId;\n });\n }\n\n /**\n * This method is used when a domain is removed from the PermissionsController.\n * It will remove re-point the network proxy to the globally selected network in the domainProxyMap or, if no globally selected network client is available, delete the proxy.\n *\n * @param domain - The domain for which to unset the network client ID.\n */\n #unsetNetworkClientIdForDomain(domain: Domain) {\n const globallySelectedNetworkClient = this.messagingSystem.call(\n 'NetworkController:getSelectedNetworkClient',\n );\n const networkProxy = this.#domainProxyMap.get(domain);\n if (networkProxy && globallySelectedNetworkClient) {\n networkProxy.provider.setTarget(globallySelectedNetworkClient.provider);\n networkProxy.blockTracker.setTarget(\n globallySelectedNetworkClient.blockTracker,\n );\n } else if (networkProxy) {\n this.#domainProxyMap.delete(domain);\n }\n this.update((state) => {\n delete state.domains[domain];\n });\n }\n\n #domainHasPermissions(domain: Domain): boolean {\n return this.messagingSystem.call(\n 'PermissionController:hasPermissions',\n domain,\n );\n }\n\n // Loop through all domains and for those with permissions it points that domain's proxy\n // to an unproxied instance of the globally selected network client.\n // NOT the NetworkController's proxy of the globally selected networkClient\n #resetAllPermissionedDomains() {\n this.#domainProxyMap.forEach((_: NetworkProxy, domain: string) => {\n const { selectedNetworkClientId } = this.messagingSystem.call(\n 'NetworkController:getState',\n );\n // can't use public setNetworkClientIdForDomain because it will throw an error\n // rather than simply skip if the domain doesn't have permissions which can happen\n // in this case since proxies are added for each site the user visits\n if (this.#domainHasPermissions(domain)) {\n this.#setNetworkClientIdForDomain(domain, selectedNetworkClientId);\n }\n });\n }\n\n setNetworkClientIdForDomain(\n domain: Domain,\n networkClientId: NetworkClientId,\n ) {\n if (!this.#useRequestQueuePreference) {\n return;\n }\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 (snapsPrefixes.some((prefix) => domain.startsWith(prefix))) {\n return;\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.#useRequestQueuePreference) {\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 the domain is 'metamask' or a snap, return the NetworkController's globally selected network client proxy\n if (\n domain === METAMASK_DOMAIN ||\n snapsPrefixes.some((prefix) => domain.startsWith(prefix))\n ) {\n const networkClient = this.messagingSystem.call(\n 'NetworkController:getSelectedNetworkClient',\n );\n if (networkClient === undefined) {\n throw new Error('Selected network not initialized');\n }\n return networkClient;\n }\n\n let networkProxy = this.#domainProxyMap.get(domain);\n if (networkProxy === undefined) {\n let networkClient;\n if (\n this.#useRequestQueuePreference &&\n this.#domainHasPermissions(domain)\n ) {\n const networkClientId = this.getNetworkClientIdForDomain(domain);\n networkClient = this.messagingSystem.call(\n 'NetworkController:getNetworkClientById',\n networkClientId,\n );\n } else {\n networkClient = this.messagingSystem.call(\n 'NetworkController:getSelectedNetworkClient',\n );\n if (networkClient === undefined) {\n throw new Error('Selected network not initialized');\n }\n }\n networkProxy = {\n provider: createEventEmitterProxy(networkClient.provider),\n blockTracker: createEventEmitterProxy(networkClient.blockTracker, {\n eventFilter: 'skipInternal',\n }),\n };\n this.#domainProxyMap.set(domain, networkProxy);\n }\n return networkProxy;\n }\n}\n"]}
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,8 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
+
3
+ var _chunkH6ZVCOKDjs = require('./chunk-H6ZVCOKD.js');
4
+ require('./chunk-ZFFMRFO4.js');
5
+
6
+
7
+ exports.createSelectedNetworkMiddleware = _chunkH6ZVCOKDjs.createSelectedNetworkMiddleware;
8
+ //# sourceMappingURL=SelectedNetworkMiddleware.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":""}
@@ -1,12 +1,8 @@
1
- import { SelectedNetworkControllerActionTypes } from "./SelectedNetworkController.mjs";
2
- export const createSelectedNetworkMiddleware = (messenger) => {
3
- const getNetworkClientIdForDomain = (origin) => messenger.call(SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain, origin);
4
- return (req, _, next) => {
5
- if (!req.origin) {
6
- throw new Error("Request object is lacking an 'origin'");
7
- }
8
- req.networkClientId = getNetworkClientIdForDomain(req.origin);
9
- return next();
10
- };
1
+ import {
2
+ createSelectedNetworkMiddleware
3
+ } from "./chunk-JFYFZWUW.mjs";
4
+ import "./chunk-D745I7P5.mjs";
5
+ export {
6
+ createSelectedNetworkMiddleware
11
7
  };
12
8
  //# sourceMappingURL=SelectedNetworkMiddleware.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"SelectedNetworkMiddleware.mjs","sourceRoot":"","sources":["../src/SelectedNetworkMiddleware.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,oCAAoC,EAAE,wCAAoC;AAOnF,MAAM,CAAC,MAAM,+BAA+B,GAAG,CAC7C,SAA6C,EACL,EAAE;IAC1C,MAAM,2BAA2B,GAAG,CAAC,MAAc,EAAE,EAAE,CACrD,SAAS,CAAC,IAAI,CACZ,oCAAoC,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","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":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,281 @@
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 { selectAvailableNetworkClientIds } from "@metamask/network-controller";
27
+ import { createEventEmitterProxy } from "@metamask/swappable-obj-proxy";
28
+ var controllerName = "SelectedNetworkController";
29
+ var stateMetadata = {
30
+ domains: { persist: true, anonymous: false }
31
+ };
32
+ var getDefaultState = () => ({ domains: {} });
33
+ var snapsPrefixes = ["npm:", "local:"];
34
+ var METAMASK_DOMAIN = "metamask";
35
+ var SelectedNetworkControllerActionTypes = {
36
+ getState: `${controllerName}:getState`,
37
+ getNetworkClientIdForDomain: `${controllerName}:getNetworkClientIdForDomain`,
38
+ setNetworkClientIdForDomain: `${controllerName}:setNetworkClientIdForDomain`
39
+ };
40
+ var SelectedNetworkControllerEventTypes = {
41
+ stateChange: `${controllerName}:stateChange`
42
+ };
43
+ var _domainProxyMap, _useRequestQueuePreference, _registerMessageHandlers, registerMessageHandlers_fn, _setNetworkClientIdForDomain, setNetworkClientIdForDomain_fn, _unsetNetworkClientIdForDomain, unsetNetworkClientIdForDomain_fn, _domainHasPermissions, domainHasPermissions_fn, _resetAllPermissionedDomains, resetAllPermissionedDomains_fn;
44
+ var SelectedNetworkController = class extends BaseController {
45
+ /**
46
+ * Construct a SelectedNetworkController controller.
47
+ *
48
+ * @param options - The controller options.
49
+ * @param options.messenger - The restricted controller messenger for the EncryptionPublicKey controller.
50
+ * @param options.state - The controllers initial state.
51
+ * @param options.useRequestQueuePreference - A boolean indicating whether to use the request queue preference.
52
+ * @param options.onPreferencesStateChange - A callback that is called when the preference state changes.
53
+ * @param options.domainProxyMap - A map for storing domain-specific proxies that are held in memory only during use.
54
+ */
55
+ constructor({
56
+ messenger,
57
+ state = getDefaultState(),
58
+ useRequestQueuePreference,
59
+ onPreferencesStateChange,
60
+ domainProxyMap
61
+ }) {
62
+ super({
63
+ name: controllerName,
64
+ metadata: stateMetadata,
65
+ messenger,
66
+ state
67
+ });
68
+ __privateAdd(this, _registerMessageHandlers);
69
+ __privateAdd(this, _setNetworkClientIdForDomain);
70
+ /**
71
+ * This method is used when a domain is removed from the PermissionsController.
72
+ * It will remove re-point the network proxy to the globally selected network in the domainProxyMap or, if no globally selected network client is available, delete the proxy.
73
+ *
74
+ * @param domain - The domain for which to unset the network client ID.
75
+ */
76
+ __privateAdd(this, _unsetNetworkClientIdForDomain);
77
+ __privateAdd(this, _domainHasPermissions);
78
+ // Loop through all domains and for those with permissions it points that domain's proxy
79
+ // to an unproxied instance of the globally selected network client.
80
+ // NOT the NetworkController's proxy of the globally selected networkClient
81
+ __privateAdd(this, _resetAllPermissionedDomains);
82
+ __privateAdd(this, _domainProxyMap, void 0);
83
+ __privateAdd(this, _useRequestQueuePreference, void 0);
84
+ __privateSet(this, _useRequestQueuePreference, useRequestQueuePreference);
85
+ __privateSet(this, _domainProxyMap, domainProxyMap);
86
+ __privateMethod(this, _registerMessageHandlers, registerMessageHandlers_fn).call(this);
87
+ this.messagingSystem.call("PermissionController:getSubjectNames").filter((domain) => this.state.domains[domain] === void 0).forEach(
88
+ (domain) => this.setNetworkClientIdForDomain(
89
+ domain,
90
+ this.messagingSystem.call("NetworkController:getState").selectedNetworkClientId
91
+ )
92
+ );
93
+ this.messagingSystem.subscribe(
94
+ "PermissionController:stateChange",
95
+ (_, patches) => {
96
+ patches.forEach(({ op, path }) => {
97
+ const isChangingSubject = path[0] === "subjects" && path[1] !== void 0;
98
+ if (isChangingSubject && typeof path[1] === "string") {
99
+ const domain = path[1];
100
+ if (op === "add" && this.state.domains[domain] === void 0) {
101
+ this.setNetworkClientIdForDomain(
102
+ domain,
103
+ this.messagingSystem.call("NetworkController:getState").selectedNetworkClientId
104
+ );
105
+ } else if (op === "remove" && this.state.domains[domain] !== void 0) {
106
+ __privateMethod(this, _unsetNetworkClientIdForDomain, unsetNetworkClientIdForDomain_fn).call(this, domain);
107
+ }
108
+ }
109
+ });
110
+ }
111
+ );
112
+ this.messagingSystem.subscribe(
113
+ "NetworkController:stateChange",
114
+ (availableNetworkClientIds) => {
115
+ const { selectedNetworkClientId } = this.messagingSystem.call(
116
+ "NetworkController:getState"
117
+ );
118
+ Object.entries(this.state.domains).forEach(
119
+ ([domain, networkClientIdForDomain]) => {
120
+ if (!availableNetworkClientIds.includes(networkClientIdForDomain)) {
121
+ this.setNetworkClientIdForDomain(domain, selectedNetworkClientId);
122
+ }
123
+ }
124
+ );
125
+ },
126
+ selectAvailableNetworkClientIds
127
+ );
128
+ onPreferencesStateChange(({ useRequestQueue }) => {
129
+ if (__privateGet(this, _useRequestQueuePreference) !== useRequestQueue) {
130
+ if (!useRequestQueue) {
131
+ Object.keys(this.state.domains).forEach((domain) => {
132
+ __privateMethod(this, _unsetNetworkClientIdForDomain, unsetNetworkClientIdForDomain_fn).call(this, domain);
133
+ });
134
+ } else {
135
+ __privateMethod(this, _resetAllPermissionedDomains, resetAllPermissionedDomains_fn).call(this);
136
+ }
137
+ __privateSet(this, _useRequestQueuePreference, useRequestQueue);
138
+ }
139
+ });
140
+ }
141
+ setNetworkClientIdForDomain(domain, networkClientId) {
142
+ if (!__privateGet(this, _useRequestQueuePreference)) {
143
+ return;
144
+ }
145
+ if (domain === METAMASK_DOMAIN) {
146
+ throw new Error(
147
+ `NetworkClientId for domain "${METAMASK_DOMAIN}" cannot be set on the SelectedNetworkController`
148
+ );
149
+ }
150
+ if (snapsPrefixes.some((prefix) => domain.startsWith(prefix))) {
151
+ return;
152
+ }
153
+ if (!__privateMethod(this, _domainHasPermissions, domainHasPermissions_fn).call(this, domain)) {
154
+ throw new Error(
155
+ "NetworkClientId for domain cannot be called with a domain that has not yet been granted permissions"
156
+ );
157
+ }
158
+ __privateMethod(this, _setNetworkClientIdForDomain, setNetworkClientIdForDomain_fn).call(this, domain, networkClientId);
159
+ }
160
+ getNetworkClientIdForDomain(domain) {
161
+ const { selectedNetworkClientId: metamaskSelectedNetworkClientId } = this.messagingSystem.call("NetworkController:getState");
162
+ if (!__privateGet(this, _useRequestQueuePreference)) {
163
+ return metamaskSelectedNetworkClientId;
164
+ }
165
+ return this.state.domains[domain] ?? metamaskSelectedNetworkClientId;
166
+ }
167
+ /**
168
+ * Accesses the provider and block tracker for the currently selected network.
169
+ *
170
+ * @param domain - the domain for the provider
171
+ * @returns The proxy and block tracker proxies.
172
+ */
173
+ getProviderAndBlockTracker(domain) {
174
+ if (domain === METAMASK_DOMAIN || snapsPrefixes.some((prefix) => domain.startsWith(prefix))) {
175
+ const networkClient = this.messagingSystem.call(
176
+ "NetworkController:getSelectedNetworkClient"
177
+ );
178
+ if (networkClient === void 0) {
179
+ throw new Error("Selected network not initialized");
180
+ }
181
+ return networkClient;
182
+ }
183
+ let networkProxy = __privateGet(this, _domainProxyMap).get(domain);
184
+ if (networkProxy === void 0) {
185
+ let networkClient;
186
+ if (__privateGet(this, _useRequestQueuePreference) && __privateMethod(this, _domainHasPermissions, domainHasPermissions_fn).call(this, domain)) {
187
+ const networkClientId = this.getNetworkClientIdForDomain(domain);
188
+ networkClient = this.messagingSystem.call(
189
+ "NetworkController:getNetworkClientById",
190
+ networkClientId
191
+ );
192
+ } else {
193
+ networkClient = this.messagingSystem.call(
194
+ "NetworkController:getSelectedNetworkClient"
195
+ );
196
+ if (networkClient === void 0) {
197
+ throw new Error("Selected network not initialized");
198
+ }
199
+ }
200
+ networkProxy = {
201
+ provider: createEventEmitterProxy(networkClient.provider),
202
+ blockTracker: createEventEmitterProxy(networkClient.blockTracker, {
203
+ eventFilter: "skipInternal"
204
+ })
205
+ };
206
+ __privateGet(this, _domainProxyMap).set(domain, networkProxy);
207
+ }
208
+ return networkProxy;
209
+ }
210
+ };
211
+ _domainProxyMap = new WeakMap();
212
+ _useRequestQueuePreference = new WeakMap();
213
+ _registerMessageHandlers = new WeakSet();
214
+ registerMessageHandlers_fn = function() {
215
+ this.messagingSystem.registerActionHandler(
216
+ SelectedNetworkControllerActionTypes.getNetworkClientIdForDomain,
217
+ this.getNetworkClientIdForDomain.bind(this)
218
+ );
219
+ this.messagingSystem.registerActionHandler(
220
+ SelectedNetworkControllerActionTypes.setNetworkClientIdForDomain,
221
+ this.setNetworkClientIdForDomain.bind(this)
222
+ );
223
+ };
224
+ _setNetworkClientIdForDomain = new WeakSet();
225
+ setNetworkClientIdForDomain_fn = function(domain, networkClientId) {
226
+ const networkClient = this.messagingSystem.call(
227
+ "NetworkController:getNetworkClientById",
228
+ networkClientId
229
+ );
230
+ const networkProxy = this.getProviderAndBlockTracker(domain);
231
+ networkProxy.provider.setTarget(networkClient.provider);
232
+ networkProxy.blockTracker.setTarget(networkClient.blockTracker);
233
+ this.update((state) => {
234
+ state.domains[domain] = networkClientId;
235
+ });
236
+ };
237
+ _unsetNetworkClientIdForDomain = new WeakSet();
238
+ unsetNetworkClientIdForDomain_fn = function(domain) {
239
+ const globallySelectedNetworkClient = this.messagingSystem.call(
240
+ "NetworkController:getSelectedNetworkClient"
241
+ );
242
+ const networkProxy = __privateGet(this, _domainProxyMap).get(domain);
243
+ if (networkProxy && globallySelectedNetworkClient) {
244
+ networkProxy.provider.setTarget(globallySelectedNetworkClient.provider);
245
+ networkProxy.blockTracker.setTarget(
246
+ globallySelectedNetworkClient.blockTracker
247
+ );
248
+ } else if (networkProxy) {
249
+ __privateGet(this, _domainProxyMap).delete(domain);
250
+ }
251
+ this.update((state) => {
252
+ delete state.domains[domain];
253
+ });
254
+ };
255
+ _domainHasPermissions = new WeakSet();
256
+ domainHasPermissions_fn = function(domain) {
257
+ return this.messagingSystem.call(
258
+ "PermissionController:hasPermissions",
259
+ domain
260
+ );
261
+ };
262
+ _resetAllPermissionedDomains = new WeakSet();
263
+ resetAllPermissionedDomains_fn = function() {
264
+ __privateGet(this, _domainProxyMap).forEach((_, domain) => {
265
+ const { selectedNetworkClientId } = this.messagingSystem.call(
266
+ "NetworkController:getState"
267
+ );
268
+ if (__privateMethod(this, _domainHasPermissions, domainHasPermissions_fn).call(this, domain)) {
269
+ __privateMethod(this, _setNetworkClientIdForDomain, setNetworkClientIdForDomain_fn).call(this, domain, selectedNetworkClientId);
270
+ }
271
+ });
272
+ };
273
+
274
+ export {
275
+ controllerName,
276
+ METAMASK_DOMAIN,
277
+ SelectedNetworkControllerActionTypes,
278
+ SelectedNetworkControllerEventTypes,
279
+ SelectedNetworkController
280
+ };
281
+ //# sourceMappingURL=chunk-D745I7P5.mjs.map