@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.
- package/CHANGELOG.md +30 -2
- package/dist/SelectedNetworkController.js +14 -140
- package/dist/SelectedNetworkController.js.map +1 -1
- package/dist/SelectedNetworkController.mjs +15 -0
- package/dist/SelectedNetworkController.mjs.map +1 -0
- package/dist/SelectedNetworkMiddleware.js +7 -15
- package/dist/SelectedNetworkMiddleware.js.map +1 -1
- package/dist/SelectedNetworkMiddleware.mjs +8 -0
- package/dist/SelectedNetworkMiddleware.mjs.map +1 -0
- package/dist/chunk-DZKNOQNE.mjs +222 -0
- package/dist/chunk-DZKNOQNE.mjs.map +1 -0
- package/dist/chunk-MRZPOKCN.js +23 -0
- package/dist/chunk-MRZPOKCN.js.map +1 -0
- package/dist/chunk-PPX4FXXU.mjs +23 -0
- package/dist/chunk-PPX4FXXU.mjs.map +1 -0
- package/dist/chunk-WK7GHGRD.js +222 -0
- package/dist/chunk-WK7GHGRD.js.map +1 -0
- package/dist/index.js +16 -10
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +17 -0
- package/dist/index.mjs.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/dist/{SelectedNetworkController.d.ts → types/SelectedNetworkController.d.ts} +7 -14
- package/dist/types/SelectedNetworkController.d.ts.map +1 -0
- package/dist/types/SelectedNetworkMiddleware.d.ts.map +1 -0
- package/dist/types/index.d.ts.map +1 -0
- package/package.json +17 -5
- package/dist/SelectedNetworkController.d.ts.map +0 -1
- package/dist/SelectedNetworkMiddleware.d.ts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- /package/dist/{SelectedNetworkMiddleware.d.ts → types/SelectedNetworkMiddleware.d.ts} +0 -0
- /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/
|
|
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@
|
|
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
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
var
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
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
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
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,"
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":""}
|
|
@@ -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":[]}
|