@metamask/snaps-jest 6.0.1 → 6.0.2
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 +7 -1
- package/dist/{chunk-LHU3EHLI.mjs → chunk-3HU56QS3.mjs} +5 -3
- package/dist/{chunk-LHU3EHLI.mjs.map → chunk-3HU56QS3.mjs.map} +1 -1
- package/dist/{chunk-4SC3HVI5.mjs → chunk-3SNZ4SPY.mjs} +2 -2
- package/dist/{chunk-WFBQPYSV.js → chunk-6HW5NGCB.js} +8 -4
- package/dist/chunk-6HW5NGCB.js.map +1 -0
- package/dist/{chunk-JUNUGLG4.js → chunk-6RXFM4YC.js} +3 -3
- package/dist/{chunk-CCYBLBVL.mjs → chunk-BS24WMRW.mjs} +8 -4
- package/dist/chunk-BS24WMRW.mjs.map +1 -0
- package/dist/{chunk-SQJOQ7AF.js → chunk-C2ONPIIB.js} +7 -5
- package/dist/chunk-C2ONPIIB.js.map +1 -0
- package/dist/environment.js +4 -4
- package/dist/environment.mjs +3 -3
- package/dist/helpers.js +2 -2
- package/dist/helpers.mjs +2 -2
- package/dist/index.js +4 -4
- package/dist/index.mjs +3 -3
- package/dist/internals/index.js +3 -3
- package/dist/internals/index.mjs +2 -2
- package/dist/internals/request.js +2 -2
- package/dist/internals/request.mjs +2 -2
- package/dist/internals/simulation/controllers.js +2 -2
- package/dist/internals/simulation/controllers.mjs +1 -1
- package/dist/internals/simulation/index.js +3 -3
- package/dist/internals/simulation/index.mjs +2 -2
- package/dist/internals/simulation/simulation.js +3 -3
- package/dist/internals/simulation/simulation.mjs +2 -2
- package/dist/matchers.js +2 -2
- package/dist/matchers.mjs +2 -2
- package/dist/setup.js +2 -2
- package/dist/setup.mjs +2 -2
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/types/internals/structs.d.ts +16 -8
- package/package.json +11 -11
- package/dist/chunk-CCYBLBVL.mjs.map +0 -1
- package/dist/chunk-SQJOQ7AF.js.map +0 -1
- package/dist/chunk-WFBQPYSV.js.map +0 -1
- /package/dist/{chunk-4SC3HVI5.mjs.map → chunk-3SNZ4SPY.mjs.map} +0 -0
- /package/dist/{chunk-JUNUGLG4.js.map → chunk-6RXFM4YC.js.map} +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -6,6 +6,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|
|
6
6
|
|
|
7
7
|
## [Unreleased]
|
|
8
8
|
|
|
9
|
+
## [6.0.2]
|
|
10
|
+
### Changed
|
|
11
|
+
- Bump MetaMask dependencies ([#2270](https://github.com/MetaMask/snaps/pull/2270))
|
|
12
|
+
- Bump @metamask/json-rpc-engine from 7.3.2 to 7.3.3 ([#2247](https://github.com/MetaMask/snaps/pull/2247))
|
|
13
|
+
|
|
9
14
|
## [6.0.1]
|
|
10
15
|
### Fixed
|
|
11
16
|
- Fix minor build configuration problems ([#2220](https://github.com/MetaMask/snaps/pull/2220))
|
|
@@ -107,7 +112,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|
|
107
112
|
- The version of the package no longer needs to match the version of all other
|
|
108
113
|
MetaMask Snaps packages.
|
|
109
114
|
|
|
110
|
-
[Unreleased]: https://github.com/MetaMask/snaps/compare/@metamask/snaps-jest@6.0.
|
|
115
|
+
[Unreleased]: https://github.com/MetaMask/snaps/compare/@metamask/snaps-jest@6.0.2...HEAD
|
|
116
|
+
[6.0.2]: https://github.com/MetaMask/snaps/compare/@metamask/snaps-jest@6.0.1...@metamask/snaps-jest@6.0.2
|
|
111
117
|
[6.0.1]: https://github.com/MetaMask/snaps/compare/@metamask/snaps-jest@6.0.0...@metamask/snaps-jest@6.0.1
|
|
112
118
|
[6.0.0]: https://github.com/MetaMask/snaps/compare/@metamask/snaps-jest@5.0.0...@metamask/snaps-jest@6.0.0
|
|
113
119
|
[5.0.0]: https://github.com/MetaMask/snaps/compare/@metamask/snaps-jest@4.0.1...@metamask/snaps-jest@5.0.0
|
|
@@ -7,7 +7,7 @@ import {
|
|
|
7
7
|
import {
|
|
8
8
|
getControllers,
|
|
9
9
|
registerSnap
|
|
10
|
-
} from "./chunk-
|
|
10
|
+
} from "./chunk-BS24WMRW.mjs";
|
|
11
11
|
import {
|
|
12
12
|
getEndowments
|
|
13
13
|
} from "./chunk-HBLJOACO.mjs";
|
|
@@ -66,7 +66,9 @@ async function handleInstallSnap(snapId, {
|
|
|
66
66
|
const service = new ExecutionService({
|
|
67
67
|
...executionServiceOptions,
|
|
68
68
|
messenger: controllerMessenger.getRestricted({
|
|
69
|
-
name: "ExecutionService"
|
|
69
|
+
name: "ExecutionService",
|
|
70
|
+
allowedActions: [],
|
|
71
|
+
allowedEvents: []
|
|
70
72
|
}),
|
|
71
73
|
setupSnapProvider: (_snapId, rpcStream) => {
|
|
72
74
|
const mux = setupMultiplex(rpcStream, "snapStream");
|
|
@@ -134,4 +136,4 @@ export {
|
|
|
134
136
|
getHooks,
|
|
135
137
|
registerActions
|
|
136
138
|
};
|
|
137
|
-
//# sourceMappingURL=chunk-
|
|
139
|
+
//# sourceMappingURL=chunk-3HU56QS3.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/internals/simulation/simulation.ts"],"sourcesContent":["import type {\n ActionConstraint,\n EventConstraint,\n} from '@metamask/base-controller';\nimport { ControllerMessenger } from '@metamask/base-controller';\nimport { createEngineStream } from '@metamask/json-rpc-middleware-stream';\nimport { mnemonicPhraseToBytes } from '@metamask/key-tree';\nimport type { AbstractExecutionService } from '@metamask/snaps-controllers';\nimport {\n fetchSnap,\n detectSnapLocation,\n NodeThreadExecutionService,\n setupMultiplex,\n} from '@metamask/snaps-controllers/node';\nimport { getEncryptionKey } from '@metamask/snaps-rpc-methods';\nimport type {\n SnapId,\n AuxiliaryFileEncoding,\n Component,\n InterfaceState,\n} from '@metamask/snaps-sdk';\nimport type { FetchedSnapFiles } from '@metamask/snaps-utils';\nimport { logError } from '@metamask/snaps-utils';\nimport type { Duplex } from 'readable-stream';\nimport { pipeline } from 'readable-stream';\n\nimport type { RootControllerMessenger } from './controllers';\nimport { getControllers, registerSnap } from './controllers';\nimport { getSnapFile } from './files';\nimport { getEndowments } from './methods';\nimport { createJsonRpcEngine } from './middleware';\nimport type { SimulationOptions, SimulationUserOptions } from './options';\nimport { getOptions } from './options';\nimport type { RunSagaFunction, Store } from './store';\nimport { createStore } from './store';\n\n/**\n * Options for the execution service, without the options that are shared\n * between all execution services.\n *\n * @template Service - The type of the execution service, i.e., the class that\n * creates the execution service.\n */\nexport type ExecutionServiceOptions<\n Service extends new (...args: any[]) => any,\n> = Omit<\n ConstructorParameters<Service>[0],\n keyof ConstructorParameters<typeof AbstractExecutionService<unknown>>[0]\n>;\n\n/**\n * The options for running a Snap in a simulated environment.\n *\n * @property executionService - The execution service to use.\n * @property executionServiceOptions - The options to use when creating the\n * execution service, if any. This should only include options specific to the\n * provided execution service.\n * @property options - The simulation options.\n * @template Service - The type of the execution service.\n */\nexport type InstallSnapOptions<\n Service extends new (...args: any[]) => InstanceType<\n typeof AbstractExecutionService<unknown>\n >,\n> = ExecutionServiceOptions<Service> extends Record<string, never>\n ? {\n executionService: Service;\n executionServiceOptions?: ExecutionServiceOptions<Service>;\n options?: SimulationUserOptions;\n }\n : {\n executionService: Service;\n executionServiceOptions: ExecutionServiceOptions<Service>;\n options?: SimulationUserOptions;\n };\n\nexport type InstalledSnap = {\n snapId: SnapId;\n store: Store;\n executionService: InstanceType<typeof AbstractExecutionService>;\n controllerMessenger: ControllerMessenger<ActionConstraint, EventConstraint>;\n runSaga: RunSagaFunction;\n};\n\nexport type MiddlewareHooks = {\n /**\n * A hook that returns the user's secret recovery phrase.\n *\n * @returns The user's secret recovery phrase.\n */\n getMnemonic: () => Promise<Uint8Array>;\n\n /**\n * A hook that returns the Snap's auxiliary file for the given path.\n *\n * @param path - The path of the auxiliary file to get.\n * @param encoding - The encoding to use when returning the file.\n * @returns The Snap's auxiliary file for the given path.\n */\n getSnapFile: (\n path: string,\n encoding: AuxiliaryFileEncoding,\n ) => Promise<string | null>;\n\n /**\n * A hook that returns whether the client is locked or not.\n *\n * @returns A boolean flag signaling whether the client is locked.\n */\n getIsLocked: () => boolean;\n createInterface: (content: Component) => Promise<string>;\n updateInterface: (id: string, content: Component) => Promise<void>;\n getInterfaceState: (id: string) => InterfaceState;\n};\n\n/**\n * Install a Snap in a simulated environment. This will fetch the Snap files,\n * create a Redux store, set up the controllers and JSON-RPC stack, register the\n * Snap, and run the Snap code in the execution service.\n *\n * @param snapId - The ID of the Snap to install.\n * @param options - The options to use when installing the Snap.\n * @param options.executionService - The execution service to use.\n * @param options.executionServiceOptions - The options to use when creating the\n * execution service, if any. This should only include options specific to the\n * provided execution service.\n * @param options.options - The simulation options.\n * @template Service - The type of the execution service.\n */\nexport async function handleInstallSnap<\n Service extends new (...args: any[]) => InstanceType<\n typeof AbstractExecutionService\n >,\n>(\n snapId: SnapId,\n {\n executionService,\n executionServiceOptions,\n options: rawOptions = {},\n }: Partial<InstallSnapOptions<Service>> = {},\n): Promise<InstalledSnap> {\n const options = getOptions(rawOptions);\n\n // Fetch Snap files.\n const location = detectSnapLocation(snapId, {\n allowLocal: true,\n });\n\n const snapFiles = await fetchSnap(snapId, location);\n\n // Create Redux store.\n const password = await getEncryptionKey({\n mnemonicPhrase: mnemonicPhraseToBytes(options.secretRecoveryPhrase),\n snapId,\n });\n\n const { store, runSaga } = createStore(password, options);\n\n const controllerMessenger = new ControllerMessenger<any, any>();\n\n registerActions(controllerMessenger);\n\n // Set up controllers and JSON-RPC stack.\n const hooks = getHooks(options, snapFiles, snapId, controllerMessenger);\n\n const { subjectMetadataController, permissionController } = getControllers({\n controllerMessenger,\n hooks,\n runSaga,\n options,\n });\n\n const engine = createJsonRpcEngine({\n store,\n hooks,\n permissionMiddleware: permissionController.createPermissionMiddleware({\n origin: snapId,\n }),\n });\n\n // Create execution service.\n const ExecutionService = executionService ?? NodeThreadExecutionService;\n const service = new ExecutionService({\n ...executionServiceOptions,\n messenger: controllerMessenger.getRestricted({\n name: 'ExecutionService',\n }),\n setupSnapProvider: (_snapId: string, rpcStream: Duplex) => {\n const mux = setupMultiplex(rpcStream, 'snapStream');\n const stream = mux.createStream('metamask-provider');\n const providerStream = createEngineStream({ engine });\n\n // Error function is difficult to test, so we ignore it.\n /* istanbul ignore next 2 */\n pipeline(stream, providerStream, stream, (error: unknown) => {\n if (error) {\n logError(`Provider stream failure.`, error);\n }\n });\n },\n });\n\n // Register the Snap. This sets up the Snap's permissions and subject\n // metadata.\n await registerSnap(snapId, snapFiles.manifest.result, {\n permissionController,\n subjectMetadataController,\n });\n\n // Run the Snap code in the execution service.\n await service.executeSnap({\n snapId,\n sourceCode: snapFiles.sourceCode.toString('utf8'),\n endowments: await getEndowments(permissionController, snapId),\n });\n\n return {\n snapId,\n store,\n executionService: service,\n controllerMessenger,\n runSaga,\n };\n}\n\n/**\n * Get the hooks for the simulation.\n *\n * @param options - The simulation options.\n * @param snapFiles - The Snap files.\n * @param snapId - The Snap ID.\n * @param controllerMessenger - The controller messenger.\n * @returns The hooks for the simulation.\n */\nexport function getHooks(\n options: SimulationOptions,\n snapFiles: FetchedSnapFiles,\n snapId: SnapId,\n controllerMessenger: RootControllerMessenger,\n): MiddlewareHooks {\n return {\n getMnemonic: async () =>\n Promise.resolve(mnemonicPhraseToBytes(options.secretRecoveryPhrase)),\n getSnapFile: async (path: string, encoding: AuxiliaryFileEncoding) =>\n await getSnapFile(snapFiles.auxiliaryFiles, path, encoding),\n getIsLocked: () => false,\n createInterface: async (...args) =>\n controllerMessenger.call(\n 'SnapInterfaceController:createInterface',\n snapId,\n ...args,\n ),\n updateInterface: async (...args) =>\n controllerMessenger.call(\n 'SnapInterfaceController:updateInterface',\n snapId,\n ...args,\n ),\n getInterfaceState: (...args) =>\n controllerMessenger.call(\n 'SnapInterfaceController:getInterface',\n snapId,\n ...args,\n ).state,\n };\n}\n\n/**\n * Register mocked action handlers.\n *\n * @param controllerMessenger - The controller messenger.\n */\nexport function registerActions(controllerMessenger: RootControllerMessenger) {\n controllerMessenger.registerActionHandler(\n 'PhishingController:maybeUpdateState',\n async () => Promise.resolve(),\n );\n\n controllerMessenger.registerActionHandler(\n 'PhishingController:testOrigin',\n () => ({ result: false, type: 'all' }),\n );\n}\n"],"mappings":"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","names":[]}
|
|
1
|
+
{"version":3,"sources":["../src/internals/simulation/simulation.ts"],"sourcesContent":["import type {\n ActionConstraint,\n EventConstraint,\n} from '@metamask/base-controller';\nimport { ControllerMessenger } from '@metamask/base-controller';\nimport { createEngineStream } from '@metamask/json-rpc-middleware-stream';\nimport { mnemonicPhraseToBytes } from '@metamask/key-tree';\nimport type { AbstractExecutionService } from '@metamask/snaps-controllers';\nimport {\n fetchSnap,\n detectSnapLocation,\n NodeThreadExecutionService,\n setupMultiplex,\n} from '@metamask/snaps-controllers/node';\nimport { getEncryptionKey } from '@metamask/snaps-rpc-methods';\nimport type {\n SnapId,\n AuxiliaryFileEncoding,\n Component,\n InterfaceState,\n} from '@metamask/snaps-sdk';\nimport type { FetchedSnapFiles } from '@metamask/snaps-utils';\nimport { logError } from '@metamask/snaps-utils';\nimport type { Duplex } from 'readable-stream';\nimport { pipeline } from 'readable-stream';\n\nimport type { RootControllerMessenger } from './controllers';\nimport { getControllers, registerSnap } from './controllers';\nimport { getSnapFile } from './files';\nimport { getEndowments } from './methods';\nimport { createJsonRpcEngine } from './middleware';\nimport type { SimulationOptions, SimulationUserOptions } from './options';\nimport { getOptions } from './options';\nimport type { RunSagaFunction, Store } from './store';\nimport { createStore } from './store';\n\n/**\n * Options for the execution service, without the options that are shared\n * between all execution services.\n *\n * @template Service - The type of the execution service, i.e., the class that\n * creates the execution service.\n */\nexport type ExecutionServiceOptions<\n Service extends new (...args: any[]) => any,\n> = Omit<\n ConstructorParameters<Service>[0],\n keyof ConstructorParameters<typeof AbstractExecutionService<unknown>>[0]\n>;\n\n/**\n * The options for running a Snap in a simulated environment.\n *\n * @property executionService - The execution service to use.\n * @property executionServiceOptions - The options to use when creating the\n * execution service, if any. This should only include options specific to the\n * provided execution service.\n * @property options - The simulation options.\n * @template Service - The type of the execution service.\n */\nexport type InstallSnapOptions<\n Service extends new (...args: any[]) => InstanceType<\n typeof AbstractExecutionService<unknown>\n >,\n> = ExecutionServiceOptions<Service> extends Record<string, never>\n ? {\n executionService: Service;\n executionServiceOptions?: ExecutionServiceOptions<Service>;\n options?: SimulationUserOptions;\n }\n : {\n executionService: Service;\n executionServiceOptions: ExecutionServiceOptions<Service>;\n options?: SimulationUserOptions;\n };\n\nexport type InstalledSnap = {\n snapId: SnapId;\n store: Store;\n executionService: InstanceType<typeof AbstractExecutionService>;\n controllerMessenger: ControllerMessenger<ActionConstraint, EventConstraint>;\n runSaga: RunSagaFunction;\n};\n\nexport type MiddlewareHooks = {\n /**\n * A hook that returns the user's secret recovery phrase.\n *\n * @returns The user's secret recovery phrase.\n */\n getMnemonic: () => Promise<Uint8Array>;\n\n /**\n * A hook that returns the Snap's auxiliary file for the given path.\n *\n * @param path - The path of the auxiliary file to get.\n * @param encoding - The encoding to use when returning the file.\n * @returns The Snap's auxiliary file for the given path.\n */\n getSnapFile: (\n path: string,\n encoding: AuxiliaryFileEncoding,\n ) => Promise<string | null>;\n\n /**\n * A hook that returns whether the client is locked or not.\n *\n * @returns A boolean flag signaling whether the client is locked.\n */\n getIsLocked: () => boolean;\n createInterface: (content: Component) => Promise<string>;\n updateInterface: (id: string, content: Component) => Promise<void>;\n getInterfaceState: (id: string) => InterfaceState;\n};\n\n/**\n * Install a Snap in a simulated environment. This will fetch the Snap files,\n * create a Redux store, set up the controllers and JSON-RPC stack, register the\n * Snap, and run the Snap code in the execution service.\n *\n * @param snapId - The ID of the Snap to install.\n * @param options - The options to use when installing the Snap.\n * @param options.executionService - The execution service to use.\n * @param options.executionServiceOptions - The options to use when creating the\n * execution service, if any. This should only include options specific to the\n * provided execution service.\n * @param options.options - The simulation options.\n * @template Service - The type of the execution service.\n */\nexport async function handleInstallSnap<\n Service extends new (...args: any[]) => InstanceType<\n typeof AbstractExecutionService\n >,\n>(\n snapId: SnapId,\n {\n executionService,\n executionServiceOptions,\n options: rawOptions = {},\n }: Partial<InstallSnapOptions<Service>> = {},\n): Promise<InstalledSnap> {\n const options = getOptions(rawOptions);\n\n // Fetch Snap files.\n const location = detectSnapLocation(snapId, {\n allowLocal: true,\n });\n\n const snapFiles = await fetchSnap(snapId, location);\n\n // Create Redux store.\n const password = await getEncryptionKey({\n mnemonicPhrase: mnemonicPhraseToBytes(options.secretRecoveryPhrase),\n snapId,\n });\n\n const { store, runSaga } = createStore(password, options);\n\n const controllerMessenger = new ControllerMessenger<any, any>();\n\n registerActions(controllerMessenger);\n\n // Set up controllers and JSON-RPC stack.\n const hooks = getHooks(options, snapFiles, snapId, controllerMessenger);\n\n const { subjectMetadataController, permissionController } = getControllers({\n controllerMessenger,\n hooks,\n runSaga,\n options,\n });\n\n const engine = createJsonRpcEngine({\n store,\n hooks,\n permissionMiddleware: permissionController.createPermissionMiddleware({\n origin: snapId,\n }),\n });\n\n // Create execution service.\n const ExecutionService = executionService ?? NodeThreadExecutionService;\n const service = new ExecutionService({\n ...executionServiceOptions,\n messenger: controllerMessenger.getRestricted({\n name: 'ExecutionService',\n allowedActions: [],\n allowedEvents: [],\n }),\n setupSnapProvider: (_snapId: string, rpcStream: Duplex) => {\n const mux = setupMultiplex(rpcStream, 'snapStream');\n const stream = mux.createStream('metamask-provider');\n const providerStream = createEngineStream({ engine });\n\n // Error function is difficult to test, so we ignore it.\n /* istanbul ignore next 2 */\n pipeline(stream, providerStream, stream, (error: unknown) => {\n if (error) {\n logError(`Provider stream failure.`, error);\n }\n });\n },\n });\n\n // Register the Snap. This sets up the Snap's permissions and subject\n // metadata.\n await registerSnap(snapId, snapFiles.manifest.result, {\n permissionController,\n subjectMetadataController,\n });\n\n // Run the Snap code in the execution service.\n await service.executeSnap({\n snapId,\n sourceCode: snapFiles.sourceCode.toString('utf8'),\n endowments: await getEndowments(permissionController, snapId),\n });\n\n return {\n snapId,\n store,\n executionService: service,\n controllerMessenger,\n runSaga,\n };\n}\n\n/**\n * Get the hooks for the simulation.\n *\n * @param options - The simulation options.\n * @param snapFiles - The Snap files.\n * @param snapId - The Snap ID.\n * @param controllerMessenger - The controller messenger.\n * @returns The hooks for the simulation.\n */\nexport function getHooks(\n options: SimulationOptions,\n snapFiles: FetchedSnapFiles,\n snapId: SnapId,\n controllerMessenger: RootControllerMessenger,\n): MiddlewareHooks {\n return {\n getMnemonic: async () =>\n Promise.resolve(mnemonicPhraseToBytes(options.secretRecoveryPhrase)),\n getSnapFile: async (path: string, encoding: AuxiliaryFileEncoding) =>\n await getSnapFile(snapFiles.auxiliaryFiles, path, encoding),\n getIsLocked: () => false,\n createInterface: async (...args) =>\n controllerMessenger.call(\n 'SnapInterfaceController:createInterface',\n snapId,\n ...args,\n ),\n updateInterface: async (...args) =>\n controllerMessenger.call(\n 'SnapInterfaceController:updateInterface',\n snapId,\n ...args,\n ),\n getInterfaceState: (...args) =>\n controllerMessenger.call(\n 'SnapInterfaceController:getInterface',\n snapId,\n ...args,\n ).state,\n };\n}\n\n/**\n * Register mocked action handlers.\n *\n * @param controllerMessenger - The controller messenger.\n */\nexport function registerActions(controllerMessenger: RootControllerMessenger) {\n controllerMessenger.registerActionHandler(\n 'PhishingController:maybeUpdateState',\n async () => Promise.resolve(),\n );\n\n controllerMessenger.registerActionHandler(\n 'PhishingController:testOrigin',\n () => ({ result: false, type: 'all' }),\n );\n}\n"],"mappings":"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","names":[]}
|
|
@@ -3,7 +3,7 @@ import {
|
|
|
3
3
|
} from "./chunk-B73P64TE.mjs";
|
|
4
4
|
import {
|
|
5
5
|
handleInstallSnap
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-3HU56QS3.mjs";
|
|
7
7
|
import {
|
|
8
8
|
startServer
|
|
9
9
|
} from "./chunk-SLU4FNKX.mjs";
|
|
@@ -101,4 +101,4 @@ export {
|
|
|
101
101
|
SnapsEnvironment,
|
|
102
102
|
environment_default
|
|
103
103
|
};
|
|
104
|
-
//# sourceMappingURL=chunk-
|
|
104
|
+
//# sourceMappingURL=chunk-3SNZ4SPY.mjs.map
|
|
@@ -22,7 +22,9 @@ function getControllers(options) {
|
|
|
22
22
|
const { controllerMessenger } = options;
|
|
23
23
|
const subjectMetadataController = new (0, _permissioncontroller.SubjectMetadataController)({
|
|
24
24
|
messenger: controllerMessenger.getRestricted({
|
|
25
|
-
name: "SubjectMetadataController"
|
|
25
|
+
name: "SubjectMetadataController",
|
|
26
|
+
allowedActions: [],
|
|
27
|
+
allowedEvents: []
|
|
26
28
|
}),
|
|
27
29
|
subjectCacheLimit: 100
|
|
28
30
|
});
|
|
@@ -32,7 +34,8 @@ function getControllers(options) {
|
|
|
32
34
|
allowedActions: [
|
|
33
35
|
"PhishingController:maybeUpdateState",
|
|
34
36
|
"PhishingController:testOrigin"
|
|
35
|
-
]
|
|
37
|
+
],
|
|
38
|
+
allowedEvents: []
|
|
36
39
|
})
|
|
37
40
|
});
|
|
38
41
|
const permissionController = getPermissionController(options);
|
|
@@ -56,7 +59,8 @@ function getPermissionController(options) {
|
|
|
56
59
|
`SnapController:getPermitted`,
|
|
57
60
|
`SnapController:install`,
|
|
58
61
|
`SubjectMetadataController:getSubjectMetadata`
|
|
59
|
-
]
|
|
62
|
+
],
|
|
63
|
+
allowedEvents: []
|
|
60
64
|
}),
|
|
61
65
|
caveatSpecifications: {
|
|
62
66
|
..._snapsrpcmethods.caveatSpecifications,
|
|
@@ -88,4 +92,4 @@ async function registerSnap(snapId, manifest, {
|
|
|
88
92
|
|
|
89
93
|
|
|
90
94
|
exports.getControllers = getControllers; exports.registerSnap = registerSnap;
|
|
91
|
-
//# sourceMappingURL=chunk-
|
|
95
|
+
//# sourceMappingURL=chunk-6HW5NGCB.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/internals/simulation/controllers.ts"],"names":[],"mappings":";;;;;;;;AAOA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,+BAA+B;AAMxC;AAAA,EACE,wBAAwB;AAAA,EACxB,iCAAiC;AAAA,EACjC;AAAA,OACK;AAGP,SAAS,mBAAmB;AA0CrB,SAAS,eAAe,SAA6C;AAC1E,QAAM,EAAE,oBAAoB,IAAI;AAChC,QAAM,4BAA4B,IAAI,0BAA0B;AAAA,IAC9D,WAAW,oBAAoB,cAAc;AAAA,MAC3C,MAAM;AAAA,MACN,gBAAgB,CAAC;AAAA,MACjB,eAAe,CAAC;AAAA,IAClB,CAAC;AAAA,IACD,mBAAmB;AAAA,EACrB,CAAC;AAED,QAAM,sBAAsB,IAAI,wBAAwB;AAAA,IACtD,WAAW,oBAAoB,cAAc;AAAA,MAC3C,MAAM;AAAA,MACN,gBAAgB;AAAA,QACd;AAAA,QACA;AAAA,MACF;AAAA,MACA,eAAe,CAAC;AAAA,IAClB,CAAC;AAAA,EACH,CAAC;AAED,QAAM,uBAAuB,wBAAwB,OAAO;AAE5D,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;AAUA,SAAS,wBAAwB,SAAgC;AAC/D,QAAM,EAAE,oBAAoB,IAAI;AAChC,QAAM,2BAA2B,4BAA4B,OAAO;AACpE,SAAO,IAAI,qBAAqB;AAAA,IAC9B,WAAW,oBAAoB,cAAc;AAAA,MAC3C,MAAM;AAAA,MACN,gBAAgB;AAAA,QACd;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,MACA,eAAe,CAAC;AAAA,IAClB,CAAC;AAAA,IACD,sBAAsB;AAAA,MACpB,GAAG;AAAA,MACH,GAAG;AAAA,IACL;AAAA,IACA;AAAA,IACA,qBAAqB;AAAA,EACvB,CAAC;AACH;AAWA,eAAsB,aACpB,QACA,UACA;AAAA,EACE;AAAA,EACA;AACF,GACA;AACA,4BAA0B,mBAAmB;AAAA,IAC3C,QAAQ;AAAA,IACR,aAAa,YAAY;AAAA,EAC3B,CAAC;AAED,QAAM,sBAAsB;AAAA,IAC1B,YAAY,SAAS,kBAAkB;AAAA,EACzC;AAEA,uBAAqB,iBAAiB;AAAA,IACpC;AAAA,IACA,SAAS,EAAE,QAAQ,OAAO;AAAA,IAC1B,6BAA6B;AAAA,EAC/B,CAAC;AACH","sourcesContent":["import type { ControllerMessenger } from '@metamask/base-controller';\nimport type {\n CaveatSpecificationConstraint,\n PermissionSpecificationConstraint,\n PermissionControllerActions,\n SubjectMetadataControllerActions,\n} from '@metamask/permission-controller';\nimport {\n PermissionController,\n SubjectMetadataController,\n SubjectType,\n} from '@metamask/permission-controller';\nimport { SnapInterfaceController } from '@metamask/snaps-controllers';\nimport type {\n ExecutionServiceActions,\n SnapInterfaceControllerActions,\n SnapInterfaceControllerAllowedActions,\n} from '@metamask/snaps-controllers';\nimport {\n caveatSpecifications as snapsCaveatsSpecifications,\n endowmentCaveatSpecifications as snapsEndowmentCaveatSpecifications,\n processSnapPermissions,\n} from '@metamask/snaps-rpc-methods';\nimport type { SnapId } from '@metamask/snaps-sdk';\nimport type { SnapManifest } from '@metamask/snaps-utils';\nimport { getSafeJson } from '@metamask/utils';\n\nimport { getPermissionSpecifications } from './methods';\nimport { UNRESTRICTED_METHODS } from './methods/constants';\nimport type { SimulationOptions } from './options';\nimport type { MiddlewareHooks } from './simulation';\nimport type { RunSagaFunction } from './store';\n\nexport type RootControllerAllowedActions =\n | SnapInterfaceControllerActions\n | SnapInterfaceControllerAllowedActions\n | PermissionControllerActions\n | ExecutionServiceActions\n | SubjectMetadataControllerActions;\n\nexport type RootControllerMessenger = ControllerMessenger<\n RootControllerAllowedActions,\n any\n>;\n\nexport type GetControllersOptions = {\n controllerMessenger: ControllerMessenger<any, any>;\n hooks: MiddlewareHooks;\n runSaga: RunSagaFunction;\n options: SimulationOptions;\n};\n\nexport type Controllers = {\n permissionController: PermissionController<\n PermissionSpecificationConstraint,\n CaveatSpecificationConstraint\n >;\n subjectMetadataController: SubjectMetadataController;\n interfaceController: SnapInterfaceController;\n};\n\n/**\n * Get the controllers for the Snap.\n *\n * @param options - The options.\n * @returns The controllers for the Snap.\n */\nexport function getControllers(options: GetControllersOptions): Controllers {\n const { controllerMessenger } = options;\n const subjectMetadataController = new SubjectMetadataController({\n messenger: controllerMessenger.getRestricted({\n name: 'SubjectMetadataController',\n allowedActions: [],\n allowedEvents: [],\n }),\n subjectCacheLimit: 100,\n });\n\n const interfaceController = new SnapInterfaceController({\n messenger: controllerMessenger.getRestricted({\n name: 'SnapInterfaceController',\n allowedActions: [\n 'PhishingController:maybeUpdateState',\n 'PhishingController:testOrigin',\n ],\n allowedEvents: [],\n }),\n });\n\n const permissionController = getPermissionController(options);\n\n return {\n permissionController,\n subjectMetadataController,\n interfaceController,\n };\n}\n\n/**\n * Get the permission controller for the Snap.\n *\n * @param options - The options.\n * @param options.controllerMessenger - The controller messenger.\n * @param options.options - Miscellaneous options.\n * @returns The permission controller for the Snap.\n */\nfunction getPermissionController(options: GetControllersOptions) {\n const { controllerMessenger } = options;\n const permissionSpecifications = getPermissionSpecifications(options);\n return new PermissionController({\n messenger: controllerMessenger.getRestricted({\n name: 'PermissionController',\n allowedActions: [\n `ApprovalController:addRequest`,\n `ApprovalController:hasRequest`,\n `ApprovalController:acceptRequest`,\n `ApprovalController:rejectRequest`,\n `SnapController:getPermitted`,\n `SnapController:install`,\n `SubjectMetadataController:getSubjectMetadata`,\n ],\n allowedEvents: [],\n }),\n caveatSpecifications: {\n ...snapsCaveatsSpecifications,\n ...snapsEndowmentCaveatSpecifications,\n },\n permissionSpecifications,\n unrestrictedMethods: UNRESTRICTED_METHODS,\n });\n}\n\n/**\n * Register the Snap. This sets up the Snap's permissions and subject metadata.\n *\n * @param snapId - The ID of the Snap to install.\n * @param manifest - The parsed manifest.\n * @param controllers - The controllers for the Snap.\n * @param controllers.permissionController - The permission controller.\n * @param controllers.subjectMetadataController - The subject metadata controller.\n */\nexport async function registerSnap(\n snapId: SnapId,\n manifest: SnapManifest,\n {\n permissionController,\n subjectMetadataController,\n }: Omit<Controllers, 'interfaceController'>,\n) {\n subjectMetadataController.addSubjectMetadata({\n origin: snapId,\n subjectType: SubjectType.Snap,\n });\n\n const approvedPermissions = processSnapPermissions(\n getSafeJson(manifest.initialPermissions),\n );\n\n permissionController.grantPermissions({\n approvedPermissions,\n subject: { origin: snapId },\n preserveExistingPermissions: false,\n });\n}\n"]}
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
var _chunkT2PHS5FYjs = require('./chunk-T2PHS5FY.js');
|
|
4
4
|
|
|
5
5
|
|
|
6
|
-
var
|
|
6
|
+
var _chunkC2ONPIIBjs = require('./chunk-C2ONPIIB.js');
|
|
7
7
|
|
|
8
8
|
|
|
9
9
|
var _chunkN6MAO223js = require('./chunk-N6MAO223.js');
|
|
@@ -72,7 +72,7 @@ var SnapsEnvironment = class extends _jestenvironmentnode2.default {
|
|
|
72
72
|
*/
|
|
73
73
|
async installSnap(snapId = this.snapId, options = {}) {
|
|
74
74
|
await _chunkPHUTP7NBjs.__privateGet.call(void 0, this, _instance)?.executionService.terminateAllSnaps();
|
|
75
|
-
_chunkPHUTP7NBjs.__privateSet.call(void 0, this, _instance, await
|
|
75
|
+
_chunkPHUTP7NBjs.__privateSet.call(void 0, this, _instance, await _chunkC2ONPIIBjs.handleInstallSnap.call(void 0, snapId, options));
|
|
76
76
|
return _chunkPHUTP7NBjs.__privateGet.call(void 0, this, _instance);
|
|
77
77
|
}
|
|
78
78
|
/**
|
|
@@ -101,4 +101,4 @@ var environment_default = SnapsEnvironment;
|
|
|
101
101
|
|
|
102
102
|
|
|
103
103
|
exports.SnapsEnvironment = SnapsEnvironment; exports.environment_default = environment_default;
|
|
104
|
-
//# sourceMappingURL=chunk-
|
|
104
|
+
//# sourceMappingURL=chunk-6RXFM4YC.js.map
|
|
@@ -22,7 +22,9 @@ function getControllers(options) {
|
|
|
22
22
|
const { controllerMessenger } = options;
|
|
23
23
|
const subjectMetadataController = new SubjectMetadataController({
|
|
24
24
|
messenger: controllerMessenger.getRestricted({
|
|
25
|
-
name: "SubjectMetadataController"
|
|
25
|
+
name: "SubjectMetadataController",
|
|
26
|
+
allowedActions: [],
|
|
27
|
+
allowedEvents: []
|
|
26
28
|
}),
|
|
27
29
|
subjectCacheLimit: 100
|
|
28
30
|
});
|
|
@@ -32,7 +34,8 @@ function getControllers(options) {
|
|
|
32
34
|
allowedActions: [
|
|
33
35
|
"PhishingController:maybeUpdateState",
|
|
34
36
|
"PhishingController:testOrigin"
|
|
35
|
-
]
|
|
37
|
+
],
|
|
38
|
+
allowedEvents: []
|
|
36
39
|
})
|
|
37
40
|
});
|
|
38
41
|
const permissionController = getPermissionController(options);
|
|
@@ -56,7 +59,8 @@ function getPermissionController(options) {
|
|
|
56
59
|
`SnapController:getPermitted`,
|
|
57
60
|
`SnapController:install`,
|
|
58
61
|
`SubjectMetadataController:getSubjectMetadata`
|
|
59
|
-
]
|
|
62
|
+
],
|
|
63
|
+
allowedEvents: []
|
|
60
64
|
}),
|
|
61
65
|
caveatSpecifications: {
|
|
62
66
|
...snapsCaveatsSpecifications,
|
|
@@ -88,4 +92,4 @@ export {
|
|
|
88
92
|
getControllers,
|
|
89
93
|
registerSnap
|
|
90
94
|
};
|
|
91
|
-
//# sourceMappingURL=chunk-
|
|
95
|
+
//# sourceMappingURL=chunk-BS24WMRW.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/internals/simulation/controllers.ts"],"sourcesContent":["import type { ControllerMessenger } from '@metamask/base-controller';\nimport type {\n CaveatSpecificationConstraint,\n PermissionSpecificationConstraint,\n PermissionControllerActions,\n SubjectMetadataControllerActions,\n} from '@metamask/permission-controller';\nimport {\n PermissionController,\n SubjectMetadataController,\n SubjectType,\n} from '@metamask/permission-controller';\nimport { SnapInterfaceController } from '@metamask/snaps-controllers';\nimport type {\n ExecutionServiceActions,\n SnapInterfaceControllerActions,\n SnapInterfaceControllerAllowedActions,\n} from '@metamask/snaps-controllers';\nimport {\n caveatSpecifications as snapsCaveatsSpecifications,\n endowmentCaveatSpecifications as snapsEndowmentCaveatSpecifications,\n processSnapPermissions,\n} from '@metamask/snaps-rpc-methods';\nimport type { SnapId } from '@metamask/snaps-sdk';\nimport type { SnapManifest } from '@metamask/snaps-utils';\nimport { getSafeJson } from '@metamask/utils';\n\nimport { getPermissionSpecifications } from './methods';\nimport { UNRESTRICTED_METHODS } from './methods/constants';\nimport type { SimulationOptions } from './options';\nimport type { MiddlewareHooks } from './simulation';\nimport type { RunSagaFunction } from './store';\n\nexport type RootControllerAllowedActions =\n | SnapInterfaceControllerActions\n | SnapInterfaceControllerAllowedActions\n | PermissionControllerActions\n | ExecutionServiceActions\n | SubjectMetadataControllerActions;\n\nexport type RootControllerMessenger = ControllerMessenger<\n RootControllerAllowedActions,\n any\n>;\n\nexport type GetControllersOptions = {\n controllerMessenger: ControllerMessenger<any, any>;\n hooks: MiddlewareHooks;\n runSaga: RunSagaFunction;\n options: SimulationOptions;\n};\n\nexport type Controllers = {\n permissionController: PermissionController<\n PermissionSpecificationConstraint,\n CaveatSpecificationConstraint\n >;\n subjectMetadataController: SubjectMetadataController;\n interfaceController: SnapInterfaceController;\n};\n\n/**\n * Get the controllers for the Snap.\n *\n * @param options - The options.\n * @returns The controllers for the Snap.\n */\nexport function getControllers(options: GetControllersOptions): Controllers {\n const { controllerMessenger } = options;\n const subjectMetadataController = new SubjectMetadataController({\n messenger: controllerMessenger.getRestricted({\n name: 'SubjectMetadataController',\n allowedActions: [],\n allowedEvents: [],\n }),\n subjectCacheLimit: 100,\n });\n\n const interfaceController = new SnapInterfaceController({\n messenger: controllerMessenger.getRestricted({\n name: 'SnapInterfaceController',\n allowedActions: [\n 'PhishingController:maybeUpdateState',\n 'PhishingController:testOrigin',\n ],\n allowedEvents: [],\n }),\n });\n\n const permissionController = getPermissionController(options);\n\n return {\n permissionController,\n subjectMetadataController,\n interfaceController,\n };\n}\n\n/**\n * Get the permission controller for the Snap.\n *\n * @param options - The options.\n * @param options.controllerMessenger - The controller messenger.\n * @param options.options - Miscellaneous options.\n * @returns The permission controller for the Snap.\n */\nfunction getPermissionController(options: GetControllersOptions) {\n const { controllerMessenger } = options;\n const permissionSpecifications = getPermissionSpecifications(options);\n return new PermissionController({\n messenger: controllerMessenger.getRestricted({\n name: 'PermissionController',\n allowedActions: [\n `ApprovalController:addRequest`,\n `ApprovalController:hasRequest`,\n `ApprovalController:acceptRequest`,\n `ApprovalController:rejectRequest`,\n `SnapController:getPermitted`,\n `SnapController:install`,\n `SubjectMetadataController:getSubjectMetadata`,\n ],\n allowedEvents: [],\n }),\n caveatSpecifications: {\n ...snapsCaveatsSpecifications,\n ...snapsEndowmentCaveatSpecifications,\n },\n permissionSpecifications,\n unrestrictedMethods: UNRESTRICTED_METHODS,\n });\n}\n\n/**\n * Register the Snap. This sets up the Snap's permissions and subject metadata.\n *\n * @param snapId - The ID of the Snap to install.\n * @param manifest - The parsed manifest.\n * @param controllers - The controllers for the Snap.\n * @param controllers.permissionController - The permission controller.\n * @param controllers.subjectMetadataController - The subject metadata controller.\n */\nexport async function registerSnap(\n snapId: SnapId,\n manifest: SnapManifest,\n {\n permissionController,\n subjectMetadataController,\n }: Omit<Controllers, 'interfaceController'>,\n) {\n subjectMetadataController.addSubjectMetadata({\n origin: snapId,\n subjectType: SubjectType.Snap,\n });\n\n const approvedPermissions = processSnapPermissions(\n getSafeJson(manifest.initialPermissions),\n );\n\n permissionController.grantPermissions({\n approvedPermissions,\n subject: { origin: snapId },\n preserveExistingPermissions: false,\n });\n}\n"],"mappings":";;;;;;;;AAOA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,+BAA+B;AAMxC;AAAA,EACE,wBAAwB;AAAA,EACxB,iCAAiC;AAAA,EACjC;AAAA,OACK;AAGP,SAAS,mBAAmB;AA0CrB,SAAS,eAAe,SAA6C;AAC1E,QAAM,EAAE,oBAAoB,IAAI;AAChC,QAAM,4BAA4B,IAAI,0BAA0B;AAAA,IAC9D,WAAW,oBAAoB,cAAc;AAAA,MAC3C,MAAM;AAAA,MACN,gBAAgB,CAAC;AAAA,MACjB,eAAe,CAAC;AAAA,IAClB,CAAC;AAAA,IACD,mBAAmB;AAAA,EACrB,CAAC;AAED,QAAM,sBAAsB,IAAI,wBAAwB;AAAA,IACtD,WAAW,oBAAoB,cAAc;AAAA,MAC3C,MAAM;AAAA,MACN,gBAAgB;AAAA,QACd;AAAA,QACA;AAAA,MACF;AAAA,MACA,eAAe,CAAC;AAAA,IAClB,CAAC;AAAA,EACH,CAAC;AAED,QAAM,uBAAuB,wBAAwB,OAAO;AAE5D,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;AAUA,SAAS,wBAAwB,SAAgC;AAC/D,QAAM,EAAE,oBAAoB,IAAI;AAChC,QAAM,2BAA2B,4BAA4B,OAAO;AACpE,SAAO,IAAI,qBAAqB;AAAA,IAC9B,WAAW,oBAAoB,cAAc;AAAA,MAC3C,MAAM;AAAA,MACN,gBAAgB;AAAA,QACd;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,MACA,eAAe,CAAC;AAAA,IAClB,CAAC;AAAA,IACD,sBAAsB;AAAA,MACpB,GAAG;AAAA,MACH,GAAG;AAAA,IACL;AAAA,IACA;AAAA,IACA,qBAAqB;AAAA,EACvB,CAAC;AACH;AAWA,eAAsB,aACpB,QACA,UACA;AAAA,EACE;AAAA,EACA;AACF,GACA;AACA,4BAA0B,mBAAmB;AAAA,IAC3C,QAAQ;AAAA,IACR,aAAa,YAAY;AAAA,EAC3B,CAAC;AAED,QAAM,sBAAsB;AAAA,IAC1B,YAAY,SAAS,kBAAkB;AAAA,EACzC;AAEA,uBAAqB,iBAAiB;AAAA,IACpC;AAAA,IACA,SAAS,EAAE,QAAQ,OAAO;AAAA,IAC1B,6BAA6B;AAAA,EAC/B,CAAC;AACH;","names":[]}
|
|
@@ -7,7 +7,7 @@ var _chunkVXPCUDBIjs = require('./chunk-VXPCUDBI.js');
|
|
|
7
7
|
|
|
8
8
|
|
|
9
9
|
|
|
10
|
-
var
|
|
10
|
+
var _chunk6HW5NGCBjs = require('./chunk-6HW5NGCB.js');
|
|
11
11
|
|
|
12
12
|
|
|
13
13
|
var _chunkLXSNRZV4js = require('./chunk-LXSNRZV4.js');
|
|
@@ -49,7 +49,7 @@ async function handleInstallSnap(snapId, {
|
|
|
49
49
|
const controllerMessenger = new (0, _basecontroller.ControllerMessenger)();
|
|
50
50
|
registerActions(controllerMessenger);
|
|
51
51
|
const hooks = getHooks(options, snapFiles, snapId, controllerMessenger);
|
|
52
|
-
const { subjectMetadataController, permissionController } =
|
|
52
|
+
const { subjectMetadataController, permissionController } = _chunk6HW5NGCBjs.getControllers.call(void 0, {
|
|
53
53
|
controllerMessenger,
|
|
54
54
|
hooks,
|
|
55
55
|
runSaga,
|
|
@@ -66,7 +66,9 @@ async function handleInstallSnap(snapId, {
|
|
|
66
66
|
const service = new ExecutionService({
|
|
67
67
|
...executionServiceOptions,
|
|
68
68
|
messenger: controllerMessenger.getRestricted({
|
|
69
|
-
name: "ExecutionService"
|
|
69
|
+
name: "ExecutionService",
|
|
70
|
+
allowedActions: [],
|
|
71
|
+
allowedEvents: []
|
|
70
72
|
}),
|
|
71
73
|
setupSnapProvider: (_snapId, rpcStream) => {
|
|
72
74
|
const mux = _node.setupMultiplex.call(void 0, rpcStream, "snapStream");
|
|
@@ -79,7 +81,7 @@ async function handleInstallSnap(snapId, {
|
|
|
79
81
|
});
|
|
80
82
|
}
|
|
81
83
|
});
|
|
82
|
-
await
|
|
84
|
+
await _chunk6HW5NGCBjs.registerSnap.call(void 0, snapId, snapFiles.manifest.result, {
|
|
83
85
|
permissionController,
|
|
84
86
|
subjectMetadataController
|
|
85
87
|
});
|
|
@@ -134,4 +136,4 @@ function registerActions(controllerMessenger) {
|
|
|
134
136
|
|
|
135
137
|
|
|
136
138
|
exports.handleInstallSnap = handleInstallSnap; exports.getHooks = getHooks; exports.registerActions = registerActions;
|
|
137
|
-
//# sourceMappingURL=chunk-
|
|
139
|
+
//# sourceMappingURL=chunk-C2ONPIIB.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/internals/simulation/simulation.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n ActionConstraint,\n EventConstraint,\n} from '@metamask/base-controller';\nimport { ControllerMessenger } from '@metamask/base-controller';\nimport { createEngineStream } from '@metamask/json-rpc-middleware-stream';\nimport { mnemonicPhraseToBytes } from '@metamask/key-tree';\nimport type { AbstractExecutionService } from '@metamask/snaps-controllers';\nimport {\n fetchSnap,\n detectSnapLocation,\n NodeThreadExecutionService,\n setupMultiplex,\n} from '@metamask/snaps-controllers/node';\nimport { getEncryptionKey } from '@metamask/snaps-rpc-methods';\nimport type {\n SnapId,\n AuxiliaryFileEncoding,\n Component,\n InterfaceState,\n} from '@metamask/snaps-sdk';\nimport type { FetchedSnapFiles } from '@metamask/snaps-utils';\nimport { logError } from '@metamask/snaps-utils';\nimport type { Duplex } from 'readable-stream';\nimport { pipeline } from 'readable-stream';\n\nimport type { RootControllerMessenger } from './controllers';\nimport { getControllers, registerSnap } from './controllers';\nimport { getSnapFile } from './files';\nimport { getEndowments } from './methods';\nimport { createJsonRpcEngine } from './middleware';\nimport type { SimulationOptions, SimulationUserOptions } from './options';\nimport { getOptions } from './options';\nimport type { RunSagaFunction, Store } from './store';\nimport { createStore } from './store';\n\n/**\n * Options for the execution service, without the options that are shared\n * between all execution services.\n *\n * @template Service - The type of the execution service, i.e., the class that\n * creates the execution service.\n */\nexport type ExecutionServiceOptions<\n Service extends new (...args: any[]) => any,\n> = Omit<\n ConstructorParameters<Service>[0],\n keyof ConstructorParameters<typeof AbstractExecutionService<unknown>>[0]\n>;\n\n/**\n * The options for running a Snap in a simulated environment.\n *\n * @property executionService - The execution service to use.\n * @property executionServiceOptions - The options to use when creating the\n * execution service, if any. This should only include options specific to the\n * provided execution service.\n * @property options - The simulation options.\n * @template Service - The type of the execution service.\n */\nexport type InstallSnapOptions<\n Service extends new (...args: any[]) => InstanceType<\n typeof AbstractExecutionService<unknown>\n >,\n> = ExecutionServiceOptions<Service> extends Record<string, never>\n ? {\n executionService: Service;\n executionServiceOptions?: ExecutionServiceOptions<Service>;\n options?: SimulationUserOptions;\n }\n : {\n executionService: Service;\n executionServiceOptions: ExecutionServiceOptions<Service>;\n options?: SimulationUserOptions;\n };\n\nexport type InstalledSnap = {\n snapId: SnapId;\n store: Store;\n executionService: InstanceType<typeof AbstractExecutionService>;\n controllerMessenger: ControllerMessenger<ActionConstraint, EventConstraint>;\n runSaga: RunSagaFunction;\n};\n\nexport type MiddlewareHooks = {\n /**\n * A hook that returns the user's secret recovery phrase.\n *\n * @returns The user's secret recovery phrase.\n */\n getMnemonic: () => Promise<Uint8Array>;\n\n /**\n * A hook that returns the Snap's auxiliary file for the given path.\n *\n * @param path - The path of the auxiliary file to get.\n * @param encoding - The encoding to use when returning the file.\n * @returns The Snap's auxiliary file for the given path.\n */\n getSnapFile: (\n path: string,\n encoding: AuxiliaryFileEncoding,\n ) => Promise<string | null>;\n\n /**\n * A hook that returns whether the client is locked or not.\n *\n * @returns A boolean flag signaling whether the client is locked.\n */\n getIsLocked: () => boolean;\n createInterface: (content: Component) => Promise<string>;\n updateInterface: (id: string, content: Component) => Promise<void>;\n getInterfaceState: (id: string) => InterfaceState;\n};\n\n/**\n * Install a Snap in a simulated environment. This will fetch the Snap files,\n * create a Redux store, set up the controllers and JSON-RPC stack, register the\n * Snap, and run the Snap code in the execution service.\n *\n * @param snapId - The ID of the Snap to install.\n * @param options - The options to use when installing the Snap.\n * @param options.executionService - The execution service to use.\n * @param options.executionServiceOptions - The options to use when creating the\n * execution service, if any. This should only include options specific to the\n * provided execution service.\n * @param options.options - The simulation options.\n * @template Service - The type of the execution service.\n */\nexport async function handleInstallSnap<\n Service extends new (...args: any[]) => InstanceType<\n typeof AbstractExecutionService\n >,\n>(\n snapId: SnapId,\n {\n executionService,\n executionServiceOptions,\n options: rawOptions = {},\n }: Partial<InstallSnapOptions<Service>> = {},\n): Promise<InstalledSnap> {\n const options = getOptions(rawOptions);\n\n // Fetch Snap files.\n const location = detectSnapLocation(snapId, {\n allowLocal: true,\n });\n\n const snapFiles = await fetchSnap(snapId, location);\n\n // Create Redux store.\n const password = await getEncryptionKey({\n mnemonicPhrase: mnemonicPhraseToBytes(options.secretRecoveryPhrase),\n snapId,\n });\n\n const { store, runSaga } = createStore(password, options);\n\n const controllerMessenger = new ControllerMessenger<any, any>();\n\n registerActions(controllerMessenger);\n\n // Set up controllers and JSON-RPC stack.\n const hooks = getHooks(options, snapFiles, snapId, controllerMessenger);\n\n const { subjectMetadataController, permissionController } = getControllers({\n controllerMessenger,\n hooks,\n runSaga,\n options,\n });\n\n const engine = createJsonRpcEngine({\n store,\n hooks,\n permissionMiddleware: permissionController.createPermissionMiddleware({\n origin: snapId,\n }),\n });\n\n // Create execution service.\n const ExecutionService = executionService ?? NodeThreadExecutionService;\n const service = new ExecutionService({\n ...executionServiceOptions,\n messenger: controllerMessenger.getRestricted({\n name: 'ExecutionService',\n allowedActions: [],\n allowedEvents: [],\n }),\n setupSnapProvider: (_snapId: string, rpcStream: Duplex) => {\n const mux = setupMultiplex(rpcStream, 'snapStream');\n const stream = mux.createStream('metamask-provider');\n const providerStream = createEngineStream({ engine });\n\n // Error function is difficult to test, so we ignore it.\n /* istanbul ignore next 2 */\n pipeline(stream, providerStream, stream, (error: unknown) => {\n if (error) {\n logError(`Provider stream failure.`, error);\n }\n });\n },\n });\n\n // Register the Snap. This sets up the Snap's permissions and subject\n // metadata.\n await registerSnap(snapId, snapFiles.manifest.result, {\n permissionController,\n subjectMetadataController,\n });\n\n // Run the Snap code in the execution service.\n await service.executeSnap({\n snapId,\n sourceCode: snapFiles.sourceCode.toString('utf8'),\n endowments: await getEndowments(permissionController, snapId),\n });\n\n return {\n snapId,\n store,\n executionService: service,\n controllerMessenger,\n runSaga,\n };\n}\n\n/**\n * Get the hooks for the simulation.\n *\n * @param options - The simulation options.\n * @param snapFiles - The Snap files.\n * @param snapId - The Snap ID.\n * @param controllerMessenger - The controller messenger.\n * @returns The hooks for the simulation.\n */\nexport function getHooks(\n options: SimulationOptions,\n snapFiles: FetchedSnapFiles,\n snapId: SnapId,\n controllerMessenger: RootControllerMessenger,\n): MiddlewareHooks {\n return {\n getMnemonic: async () =>\n Promise.resolve(mnemonicPhraseToBytes(options.secretRecoveryPhrase)),\n getSnapFile: async (path: string, encoding: AuxiliaryFileEncoding) =>\n await getSnapFile(snapFiles.auxiliaryFiles, path, encoding),\n getIsLocked: () => false,\n createInterface: async (...args) =>\n controllerMessenger.call(\n 'SnapInterfaceController:createInterface',\n snapId,\n ...args,\n ),\n updateInterface: async (...args) =>\n controllerMessenger.call(\n 'SnapInterfaceController:updateInterface',\n snapId,\n ...args,\n ),\n getInterfaceState: (...args) =>\n controllerMessenger.call(\n 'SnapInterfaceController:getInterface',\n snapId,\n ...args,\n ).state,\n };\n}\n\n/**\n * Register mocked action handlers.\n *\n * @param controllerMessenger - The controller messenger.\n */\nexport function registerActions(controllerMessenger: RootControllerMessenger) {\n controllerMessenger.registerActionHandler(\n 'PhishingController:maybeUpdateState',\n async () => Promise.resolve(),\n );\n\n controllerMessenger.registerActionHandler(\n 'PhishingController:testOrigin',\n () => ({ result: false, type: 'all' }),\n );\n}\n"]}
|
package/dist/environment.js
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
3
|
|
|
4
|
-
var
|
|
4
|
+
var _chunk6RXFM4YCjs = require('./chunk-6RXFM4YC.js');
|
|
5
5
|
require('./chunk-T2PHS5FY.js');
|
|
6
6
|
require('./chunk-HROOL3VI.js');
|
|
7
7
|
require('./chunk-HNH5UAKZ.js');
|
|
8
8
|
require('./chunk-GECE47HW.js');
|
|
9
9
|
require('./chunk-ZAQZRYPW.js');
|
|
10
|
-
require('./chunk-
|
|
10
|
+
require('./chunk-C2ONPIIB.js');
|
|
11
11
|
require('./chunk-ZTX624YO.js');
|
|
12
12
|
require('./chunk-XWGECIXI.js');
|
|
13
13
|
require('./chunk-WHGYMK5B.js');
|
|
@@ -20,7 +20,7 @@ require('./chunk-N6MAO223.js');
|
|
|
20
20
|
require('./chunk-TZB4LBT7.js');
|
|
21
21
|
require('./chunk-T2BE4O5H.js');
|
|
22
22
|
require('./chunk-XKJHFUHE.js');
|
|
23
|
-
require('./chunk-
|
|
23
|
+
require('./chunk-6HW5NGCB.js');
|
|
24
24
|
require('./chunk-DR6Y7IVX.js');
|
|
25
25
|
require('./chunk-LXSNRZV4.js');
|
|
26
26
|
require('./chunk-U5BLLHIU.js');
|
|
@@ -43,5 +43,5 @@ require('./chunk-PHUTP7NB.js');
|
|
|
43
43
|
|
|
44
44
|
|
|
45
45
|
|
|
46
|
-
exports.SnapsEnvironment =
|
|
46
|
+
exports.SnapsEnvironment = _chunk6RXFM4YCjs.SnapsEnvironment; exports.default = _chunk6RXFM4YCjs.environment_default;
|
|
47
47
|
//# sourceMappingURL=environment.js.map
|
package/dist/environment.mjs
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import {
|
|
2
2
|
SnapsEnvironment,
|
|
3
3
|
environment_default
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-3SNZ4SPY.mjs";
|
|
5
5
|
import "./chunk-B73P64TE.mjs";
|
|
6
6
|
import "./chunk-MF43OG3Z.mjs";
|
|
7
7
|
import "./chunk-LYK6EGZU.mjs";
|
|
8
8
|
import "./chunk-5ZFHFICZ.mjs";
|
|
9
9
|
import "./chunk-6MVV44M5.mjs";
|
|
10
|
-
import "./chunk-
|
|
10
|
+
import "./chunk-3HU56QS3.mjs";
|
|
11
11
|
import "./chunk-ZG33OGC3.mjs";
|
|
12
12
|
import "./chunk-KNJNL723.mjs";
|
|
13
13
|
import "./chunk-6HHV6YFQ.mjs";
|
|
@@ -20,7 +20,7 @@ import "./chunk-SLU4FNKX.mjs";
|
|
|
20
20
|
import "./chunk-J4ZPUCLX.mjs";
|
|
21
21
|
import "./chunk-7J34R6YW.mjs";
|
|
22
22
|
import "./chunk-6KXCBUNZ.mjs";
|
|
23
|
-
import "./chunk-
|
|
23
|
+
import "./chunk-BS24WMRW.mjs";
|
|
24
24
|
import "./chunk-NTOY6Y4Q.mjs";
|
|
25
25
|
import "./chunk-HBLJOACO.mjs";
|
|
26
26
|
import "./chunk-V6LFAN3U.mjs";
|
package/dist/helpers.js
CHANGED
|
@@ -5,7 +5,7 @@ require('./chunk-HROOL3VI.js');
|
|
|
5
5
|
require('./chunk-HNH5UAKZ.js');
|
|
6
6
|
require('./chunk-GECE47HW.js');
|
|
7
7
|
require('./chunk-ZAQZRYPW.js');
|
|
8
|
-
require('./chunk-
|
|
8
|
+
require('./chunk-C2ONPIIB.js');
|
|
9
9
|
require('./chunk-ZTX624YO.js');
|
|
10
10
|
require('./chunk-XWGECIXI.js');
|
|
11
11
|
require('./chunk-WHGYMK5B.js');
|
|
@@ -18,7 +18,7 @@ require('./chunk-N6MAO223.js');
|
|
|
18
18
|
require('./chunk-TZB4LBT7.js');
|
|
19
19
|
require('./chunk-T2BE4O5H.js');
|
|
20
20
|
require('./chunk-XKJHFUHE.js');
|
|
21
|
-
require('./chunk-
|
|
21
|
+
require('./chunk-6HW5NGCB.js');
|
|
22
22
|
require('./chunk-DR6Y7IVX.js');
|
|
23
23
|
require('./chunk-LXSNRZV4.js');
|
|
24
24
|
require('./chunk-U5BLLHIU.js');
|
package/dist/helpers.mjs
CHANGED
|
@@ -5,7 +5,7 @@ import "./chunk-MF43OG3Z.mjs";
|
|
|
5
5
|
import "./chunk-LYK6EGZU.mjs";
|
|
6
6
|
import "./chunk-5ZFHFICZ.mjs";
|
|
7
7
|
import "./chunk-6MVV44M5.mjs";
|
|
8
|
-
import "./chunk-
|
|
8
|
+
import "./chunk-3HU56QS3.mjs";
|
|
9
9
|
import "./chunk-ZG33OGC3.mjs";
|
|
10
10
|
import "./chunk-KNJNL723.mjs";
|
|
11
11
|
import "./chunk-6HHV6YFQ.mjs";
|
|
@@ -18,7 +18,7 @@ import "./chunk-SLU4FNKX.mjs";
|
|
|
18
18
|
import "./chunk-J4ZPUCLX.mjs";
|
|
19
19
|
import "./chunk-7J34R6YW.mjs";
|
|
20
20
|
import "./chunk-6KXCBUNZ.mjs";
|
|
21
|
-
import "./chunk-
|
|
21
|
+
import "./chunk-BS24WMRW.mjs";
|
|
22
22
|
import "./chunk-NTOY6Y4Q.mjs";
|
|
23
23
|
import "./chunk-HBLJOACO.mjs";
|
|
24
24
|
import "./chunk-V6LFAN3U.mjs";
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunk6RXFM4YCjs = require('./chunk-6RXFM4YC.js');
|
|
4
4
|
|
|
5
5
|
|
|
6
6
|
var _chunk5PLDD7ZCjs = require('./chunk-5PLDD7ZC.js');
|
|
@@ -11,7 +11,7 @@ require('./chunk-HROOL3VI.js');
|
|
|
11
11
|
require('./chunk-HNH5UAKZ.js');
|
|
12
12
|
require('./chunk-GECE47HW.js');
|
|
13
13
|
require('./chunk-ZAQZRYPW.js');
|
|
14
|
-
require('./chunk-
|
|
14
|
+
require('./chunk-C2ONPIIB.js');
|
|
15
15
|
require('./chunk-ZTX624YO.js');
|
|
16
16
|
require('./chunk-XWGECIXI.js');
|
|
17
17
|
require('./chunk-WHGYMK5B.js');
|
|
@@ -24,7 +24,7 @@ require('./chunk-N6MAO223.js');
|
|
|
24
24
|
require('./chunk-TZB4LBT7.js');
|
|
25
25
|
require('./chunk-T2BE4O5H.js');
|
|
26
26
|
require('./chunk-XKJHFUHE.js');
|
|
27
|
-
require('./chunk-
|
|
27
|
+
require('./chunk-6HW5NGCB.js');
|
|
28
28
|
require('./chunk-DR6Y7IVX.js');
|
|
29
29
|
require('./chunk-LXSNRZV4.js');
|
|
30
30
|
require('./chunk-U5BLLHIU.js');
|
|
@@ -50,5 +50,5 @@ require('./chunk-PHUTP7NB.js');
|
|
|
50
50
|
|
|
51
51
|
|
|
52
52
|
|
|
53
|
-
exports.TestEnvironment =
|
|
53
|
+
exports.TestEnvironment = _chunk6RXFM4YCjs.environment_default; exports.default = _chunk6RXFM4YCjs.environment_default; exports.getOptions = _chunkT2PHS5FYjs.getOptions; exports.installSnap = _chunk5PLDD7ZCjs.installSnap;
|
|
54
54
|
//# sourceMappingURL=index.js.map
|
package/dist/index.mjs
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
environment_default
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-3SNZ4SPY.mjs";
|
|
4
4
|
import {
|
|
5
5
|
installSnap
|
|
6
6
|
} from "./chunk-WIFOID2P.mjs";
|
|
@@ -11,7 +11,7 @@ import "./chunk-MF43OG3Z.mjs";
|
|
|
11
11
|
import "./chunk-LYK6EGZU.mjs";
|
|
12
12
|
import "./chunk-5ZFHFICZ.mjs";
|
|
13
13
|
import "./chunk-6MVV44M5.mjs";
|
|
14
|
-
import "./chunk-
|
|
14
|
+
import "./chunk-3HU56QS3.mjs";
|
|
15
15
|
import "./chunk-ZG33OGC3.mjs";
|
|
16
16
|
import "./chunk-KNJNL723.mjs";
|
|
17
17
|
import "./chunk-6HHV6YFQ.mjs";
|
|
@@ -24,7 +24,7 @@ import "./chunk-SLU4FNKX.mjs";
|
|
|
24
24
|
import "./chunk-J4ZPUCLX.mjs";
|
|
25
25
|
import "./chunk-7J34R6YW.mjs";
|
|
26
26
|
import "./chunk-6KXCBUNZ.mjs";
|
|
27
|
-
import "./chunk-
|
|
27
|
+
import "./chunk-BS24WMRW.mjs";
|
|
28
28
|
import "./chunk-NTOY6Y4Q.mjs";
|
|
29
29
|
import "./chunk-HBLJOACO.mjs";
|
|
30
30
|
import "./chunk-V6LFAN3U.mjs";
|
package/dist/internals/index.js
CHANGED
|
@@ -12,7 +12,7 @@ var _chunkZAQZRYPWjs = require('../chunk-ZAQZRYPW.js');
|
|
|
12
12
|
|
|
13
13
|
|
|
14
14
|
|
|
15
|
-
var
|
|
15
|
+
var _chunkC2ONPIIBjs = require('../chunk-C2ONPIIB.js');
|
|
16
16
|
require('../chunk-ZTX624YO.js');
|
|
17
17
|
require('../chunk-XWGECIXI.js');
|
|
18
18
|
require('../chunk-WHGYMK5B.js');
|
|
@@ -42,7 +42,7 @@ var _chunkT2BE4O5Hjs = require('../chunk-T2BE4O5H.js');
|
|
|
42
42
|
|
|
43
43
|
|
|
44
44
|
var _chunkXKJHFUHEjs = require('../chunk-XKJHFUHE.js');
|
|
45
|
-
require('../chunk-
|
|
45
|
+
require('../chunk-6HW5NGCB.js');
|
|
46
46
|
require('../chunk-DR6Y7IVX.js');
|
|
47
47
|
require('../chunk-LXSNRZV4.js');
|
|
48
48
|
require('../chunk-U5BLLHIU.js');
|
|
@@ -119,5 +119,5 @@ require('../chunk-PHUTP7NB.js');
|
|
|
119
119
|
|
|
120
120
|
|
|
121
121
|
|
|
122
|
-
exports.DEFAULT_JSON_RPC_ENDPOINT = _chunkXKJHFUHEjs.DEFAULT_JSON_RPC_ENDPOINT; exports.DEFAULT_LOCALE = _chunkXKJHFUHEjs.DEFAULT_LOCALE; exports.DEFAULT_SRP = _chunkXKJHFUHEjs.DEFAULT_SRP; exports.InterfaceStruct = _chunkT2BE4O5Hjs.InterfaceStruct; exports.JsonRpcMockOptionsStruct = _chunkT2BE4O5Hjs.JsonRpcMockOptionsStruct; exports.SignatureOptionsStruct = _chunkT2BE4O5Hjs.SignatureOptionsStruct; exports.SnapOptionsStruct = _chunkT2BE4O5Hjs.SnapOptionsStruct; exports.SnapResponseStruct = _chunkT2BE4O5Hjs.SnapResponseStruct; exports.TransactionOptionsStruct = _chunkT2BE4O5Hjs.TransactionOptionsStruct; exports.addNotification = _chunk2YE2P5BZjs.addNotification; exports.clearNotifications = _chunk2YE2P5BZjs.clearNotifications; exports.clearState = _chunkLBC2OGSNjs.clearState; exports.closeInterface = _chunkPZDTZGSIjs.closeInterface; exports.createStore = _chunkTO46ICOZjs.createStore; exports.getContentFromResult = _chunkHNH5UAKZjs.getContentFromResult; exports.getCurrentInterface = _chunkPZDTZGSIjs.getCurrentInterface; exports.getEnvironment = _chunk2JTGBHPRjs.getEnvironment; exports.getHooks =
|
|
122
|
+
exports.DEFAULT_JSON_RPC_ENDPOINT = _chunkXKJHFUHEjs.DEFAULT_JSON_RPC_ENDPOINT; exports.DEFAULT_LOCALE = _chunkXKJHFUHEjs.DEFAULT_LOCALE; exports.DEFAULT_SRP = _chunkXKJHFUHEjs.DEFAULT_SRP; exports.InterfaceStruct = _chunkT2BE4O5Hjs.InterfaceStruct; exports.JsonRpcMockOptionsStruct = _chunkT2BE4O5Hjs.JsonRpcMockOptionsStruct; exports.SignatureOptionsStruct = _chunkT2BE4O5Hjs.SignatureOptionsStruct; exports.SnapOptionsStruct = _chunkT2BE4O5Hjs.SnapOptionsStruct; exports.SnapResponseStruct = _chunkT2BE4O5Hjs.SnapResponseStruct; exports.TransactionOptionsStruct = _chunkT2BE4O5Hjs.TransactionOptionsStruct; exports.addNotification = _chunk2YE2P5BZjs.addNotification; exports.clearNotifications = _chunk2YE2P5BZjs.clearNotifications; exports.clearState = _chunkLBC2OGSNjs.clearState; exports.closeInterface = _chunkPZDTZGSIjs.closeInterface; exports.createStore = _chunkTO46ICOZjs.createStore; exports.getContentFromResult = _chunkHNH5UAKZjs.getContentFromResult; exports.getCurrentInterface = _chunkPZDTZGSIjs.getCurrentInterface; exports.getEnvironment = _chunk2JTGBHPRjs.getEnvironment; exports.getHooks = _chunkC2ONPIIBjs.getHooks; exports.getInterface = _chunkZAQZRYPWjs.getInterface; exports.getInterfaceResponse = _chunkZAQZRYPWjs.getInterfaceResponse; exports.getNotifications = _chunk2YE2P5BZjs.getNotifications; exports.getOptions = _chunkVXPCUDBIjs.getOptions; exports.getState = _chunkLBC2OGSNjs.getState; exports.handleInstallSnap = _chunkC2ONPIIBjs.handleInstallSnap; exports.handleRequest = _chunkHNH5UAKZjs.handleRequest; exports.notificationsSlice = _chunk2YE2P5BZjs.notificationsSlice; exports.registerActions = _chunkC2ONPIIBjs.registerActions; exports.removeNotification = _chunk2YE2P5BZjs.removeNotification; exports.resolveInterface = _chunkPZDTZGSIjs.resolveInterface; exports.rootLogger = _chunkTZB4LBT7js.rootLogger; exports.setInterface = _chunkPZDTZGSIjs.setInterface; exports.setState = _chunkLBC2OGSNjs.setState; exports.startServer = _chunkN6MAO223js.startServer; exports.stateSlice = _chunkLBC2OGSNjs.stateSlice; exports.uiSlice = _chunkPZDTZGSIjs.uiSlice;
|
|
123
123
|
//# sourceMappingURL=index.js.map
|
package/dist/internals/index.mjs
CHANGED
|
@@ -12,7 +12,7 @@ import {
|
|
|
12
12
|
getHooks,
|
|
13
13
|
handleInstallSnap,
|
|
14
14
|
registerActions
|
|
15
|
-
} from "../chunk-
|
|
15
|
+
} from "../chunk-3HU56QS3.mjs";
|
|
16
16
|
import "../chunk-ZG33OGC3.mjs";
|
|
17
17
|
import "../chunk-KNJNL723.mjs";
|
|
18
18
|
import "../chunk-6HHV6YFQ.mjs";
|
|
@@ -42,7 +42,7 @@ import {
|
|
|
42
42
|
DEFAULT_LOCALE,
|
|
43
43
|
DEFAULT_SRP
|
|
44
44
|
} from "../chunk-6KXCBUNZ.mjs";
|
|
45
|
-
import "../chunk-
|
|
45
|
+
import "../chunk-BS24WMRW.mjs";
|
|
46
46
|
import "../chunk-NTOY6Y4Q.mjs";
|
|
47
47
|
import "../chunk-HBLJOACO.mjs";
|
|
48
48
|
import "../chunk-V6LFAN3U.mjs";
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
var _chunkHNH5UAKZjs = require('../chunk-HNH5UAKZ.js');
|
|
5
5
|
require('../chunk-GECE47HW.js');
|
|
6
6
|
require('../chunk-ZAQZRYPW.js');
|
|
7
|
-
require('../chunk-
|
|
7
|
+
require('../chunk-C2ONPIIB.js');
|
|
8
8
|
require('../chunk-ZTX624YO.js');
|
|
9
9
|
require('../chunk-XWGECIXI.js');
|
|
10
10
|
require('../chunk-WHGYMK5B.js');
|
|
@@ -14,7 +14,7 @@ require('../chunk-3FNLFVV2.js');
|
|
|
14
14
|
require('../chunk-EMTW3H54.js');
|
|
15
15
|
require('../chunk-VXPCUDBI.js');
|
|
16
16
|
require('../chunk-XKJHFUHE.js');
|
|
17
|
-
require('../chunk-
|
|
17
|
+
require('../chunk-6HW5NGCB.js');
|
|
18
18
|
require('../chunk-DR6Y7IVX.js');
|
|
19
19
|
require('../chunk-LXSNRZV4.js');
|
|
20
20
|
require('../chunk-U5BLLHIU.js');
|
|
@@ -4,7 +4,7 @@ import {
|
|
|
4
4
|
} from "../chunk-LYK6EGZU.mjs";
|
|
5
5
|
import "../chunk-5ZFHFICZ.mjs";
|
|
6
6
|
import "../chunk-6MVV44M5.mjs";
|
|
7
|
-
import "../chunk-
|
|
7
|
+
import "../chunk-3HU56QS3.mjs";
|
|
8
8
|
import "../chunk-ZG33OGC3.mjs";
|
|
9
9
|
import "../chunk-KNJNL723.mjs";
|
|
10
10
|
import "../chunk-6HHV6YFQ.mjs";
|
|
@@ -14,7 +14,7 @@ import "../chunk-IXKO6X55.mjs";
|
|
|
14
14
|
import "../chunk-FP4H3ADT.mjs";
|
|
15
15
|
import "../chunk-IH7UNS5A.mjs";
|
|
16
16
|
import "../chunk-6KXCBUNZ.mjs";
|
|
17
|
-
import "../chunk-
|
|
17
|
+
import "../chunk-BS24WMRW.mjs";
|
|
18
18
|
import "../chunk-NTOY6Y4Q.mjs";
|
|
19
19
|
import "../chunk-HBLJOACO.mjs";
|
|
20
20
|
import "../chunk-V6LFAN3U.mjs";
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
3
|
|
|
4
|
-
var
|
|
4
|
+
var _chunk6HW5NGCBjs = require('../../chunk-6HW5NGCB.js');
|
|
5
5
|
require('../../chunk-DR6Y7IVX.js');
|
|
6
6
|
require('../../chunk-LXSNRZV4.js');
|
|
7
7
|
require('../../chunk-U5BLLHIU.js');
|
|
@@ -22,5 +22,5 @@ require('../../chunk-PHUTP7NB.js');
|
|
|
22
22
|
|
|
23
23
|
|
|
24
24
|
|
|
25
|
-
exports.getControllers =
|
|
25
|
+
exports.getControllers = _chunk6HW5NGCBjs.getControllers; exports.registerSnap = _chunk6HW5NGCBjs.registerSnap;
|
|
26
26
|
//# sourceMappingURL=controllers.js.map
|
|
@@ -7,7 +7,7 @@ var _chunkZAQZRYPWjs = require('../../chunk-ZAQZRYPW.js');
|
|
|
7
7
|
|
|
8
8
|
|
|
9
9
|
|
|
10
|
-
var
|
|
10
|
+
var _chunkC2ONPIIBjs = require('../../chunk-C2ONPIIB.js');
|
|
11
11
|
require('../../chunk-ZTX624YO.js');
|
|
12
12
|
require('../../chunk-XWGECIXI.js');
|
|
13
13
|
require('../../chunk-WHGYMK5B.js');
|
|
@@ -23,7 +23,7 @@ var _chunkVXPCUDBIjs = require('../../chunk-VXPCUDBI.js');
|
|
|
23
23
|
|
|
24
24
|
|
|
25
25
|
var _chunkXKJHFUHEjs = require('../../chunk-XKJHFUHE.js');
|
|
26
|
-
require('../../chunk-
|
|
26
|
+
require('../../chunk-6HW5NGCB.js');
|
|
27
27
|
require('../../chunk-DR6Y7IVX.js');
|
|
28
28
|
require('../../chunk-LXSNRZV4.js');
|
|
29
29
|
require('../../chunk-U5BLLHIU.js');
|
|
@@ -86,5 +86,5 @@ require('../../chunk-PHUTP7NB.js');
|
|
|
86
86
|
|
|
87
87
|
|
|
88
88
|
|
|
89
|
-
exports.DEFAULT_JSON_RPC_ENDPOINT = _chunkXKJHFUHEjs.DEFAULT_JSON_RPC_ENDPOINT; exports.DEFAULT_LOCALE = _chunkXKJHFUHEjs.DEFAULT_LOCALE; exports.DEFAULT_SRP = _chunkXKJHFUHEjs.DEFAULT_SRP; exports.addNotification = _chunk2YE2P5BZjs.addNotification; exports.clearNotifications = _chunk2YE2P5BZjs.clearNotifications; exports.clearState = _chunkLBC2OGSNjs.clearState; exports.closeInterface = _chunkPZDTZGSIjs.closeInterface; exports.createStore = _chunkTO46ICOZjs.createStore; exports.getCurrentInterface = _chunkPZDTZGSIjs.getCurrentInterface; exports.getHooks =
|
|
89
|
+
exports.DEFAULT_JSON_RPC_ENDPOINT = _chunkXKJHFUHEjs.DEFAULT_JSON_RPC_ENDPOINT; exports.DEFAULT_LOCALE = _chunkXKJHFUHEjs.DEFAULT_LOCALE; exports.DEFAULT_SRP = _chunkXKJHFUHEjs.DEFAULT_SRP; exports.addNotification = _chunk2YE2P5BZjs.addNotification; exports.clearNotifications = _chunk2YE2P5BZjs.clearNotifications; exports.clearState = _chunkLBC2OGSNjs.clearState; exports.closeInterface = _chunkPZDTZGSIjs.closeInterface; exports.createStore = _chunkTO46ICOZjs.createStore; exports.getCurrentInterface = _chunkPZDTZGSIjs.getCurrentInterface; exports.getHooks = _chunkC2ONPIIBjs.getHooks; exports.getInterface = _chunkZAQZRYPWjs.getInterface; exports.getInterfaceResponse = _chunkZAQZRYPWjs.getInterfaceResponse; exports.getNotifications = _chunk2YE2P5BZjs.getNotifications; exports.getOptions = _chunkVXPCUDBIjs.getOptions; exports.getState = _chunkLBC2OGSNjs.getState; exports.handleInstallSnap = _chunkC2ONPIIBjs.handleInstallSnap; exports.notificationsSlice = _chunk2YE2P5BZjs.notificationsSlice; exports.registerActions = _chunkC2ONPIIBjs.registerActions; exports.removeNotification = _chunk2YE2P5BZjs.removeNotification; exports.resolveInterface = _chunkPZDTZGSIjs.resolveInterface; exports.setInterface = _chunkPZDTZGSIjs.setInterface; exports.setState = _chunkLBC2OGSNjs.setState; exports.stateSlice = _chunkLBC2OGSNjs.stateSlice; exports.uiSlice = _chunkPZDTZGSIjs.uiSlice;
|
|
90
90
|
//# sourceMappingURL=index.js.map
|