@xyo-network/node-view 2.106.0 → 2.107.1
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/dist/browser/ViewNode.d.cts +0 -1
- package/dist/browser/ViewNode.d.cts.map +1 -1
- package/dist/browser/ViewNode.d.mts +0 -1
- package/dist/browser/ViewNode.d.mts.map +1 -1
- package/dist/browser/ViewNode.d.ts +0 -1
- package/dist/browser/ViewNode.d.ts.map +1 -1
- package/dist/browser/index.cjs +1 -145
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +1 -124
- package/dist/browser/index.js.map +1 -1
- package/dist/neutral/ViewNode.d.cts +0 -1
- package/dist/neutral/ViewNode.d.cts.map +1 -1
- package/dist/neutral/ViewNode.d.mts +0 -1
- package/dist/neutral/ViewNode.d.mts.map +1 -1
- package/dist/neutral/ViewNode.d.ts +0 -1
- package/dist/neutral/ViewNode.d.ts.map +1 -1
- package/dist/neutral/index.cjs +1 -145
- package/dist/neutral/index.cjs.map +1 -1
- package/dist/neutral/index.js +1 -124
- package/dist/neutral/index.js.map +1 -1
- package/dist/node/ViewNode.d.cts +0 -1
- package/dist/node/ViewNode.d.cts.map +1 -1
- package/dist/node/ViewNode.d.mts +0 -1
- package/dist/node/ViewNode.d.mts.map +1 -1
- package/dist/node/ViewNode.d.ts +0 -1
- package/dist/node/ViewNode.d.ts.map +1 -1
- package/dist/node/index.cjs +1 -154
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +1 -128
- package/dist/node/index.js.map +1 -1
- package/package.json +10 -10
package/dist/neutral/index.cjs
CHANGED
|
@@ -1,146 +1,2 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
7
|
-
var __export = (target, all) => {
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
11
|
-
var __copyProps = (to, from, except, desc) => {
|
|
12
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
-
for (let key of __getOwnPropNames(from))
|
|
14
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
19
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
20
|
-
|
|
21
|
-
// src/index.ts
|
|
22
|
-
var src_exports = {};
|
|
23
|
-
__export(src_exports, {
|
|
24
|
-
ViewNode: () => ViewNode,
|
|
25
|
-
ViewNodeConfigSchema: () => ViewNodeConfigSchema
|
|
26
|
-
});
|
|
27
|
-
module.exports = __toCommonJS(src_exports);
|
|
28
|
-
|
|
29
|
-
// src/ViewNode.ts
|
|
30
|
-
var import_assert = require("@xylabs/assert");
|
|
31
|
-
var import_exists = require("@xylabs/exists");
|
|
32
|
-
var import_module_model = require("@xyo-network/module-model");
|
|
33
|
-
var import_module_resolver = require("@xyo-network/module-resolver");
|
|
34
|
-
var import_node_memory = require("@xyo-network/node-memory");
|
|
35
|
-
var import_node_model = require("@xyo-network/node-model");
|
|
36
|
-
var import_async_mutex = require("async-mutex");
|
|
37
|
-
var ViewNodeConfigSchema = "network.xyo.node.view.config";
|
|
38
|
-
var ViewNode = class extends import_node_memory.MemoryNode {
|
|
39
|
-
static {
|
|
40
|
-
__name(this, "ViewNode");
|
|
41
|
-
}
|
|
42
|
-
static configSchemas = [
|
|
43
|
-
...super.configSchemas,
|
|
44
|
-
ViewNodeConfigSchema
|
|
45
|
-
];
|
|
46
|
-
static defaultConfigSchema = ViewNodeConfigSchema;
|
|
47
|
-
static labels = {
|
|
48
|
-
...import_module_model.ModuleLimitationViewLabel
|
|
49
|
-
};
|
|
50
|
-
_buildMutex = new import_async_mutex.Mutex();
|
|
51
|
-
_built = false;
|
|
52
|
-
_limitedResolver = new import_module_resolver.SimpleModuleResolver({
|
|
53
|
-
root: this
|
|
54
|
-
});
|
|
55
|
-
get ids() {
|
|
56
|
-
return this.config.ids;
|
|
57
|
-
}
|
|
58
|
-
get queries() {
|
|
59
|
-
const disallowedQueries = /* @__PURE__ */ new Set([
|
|
60
|
-
import_node_model.NodeAttachQuerySchema,
|
|
61
|
-
import_node_model.NodeDetachQuerySchema,
|
|
62
|
-
import_node_model.NodeRegisteredQuerySchema
|
|
63
|
-
]);
|
|
64
|
-
const queries = [
|
|
65
|
-
...super.queries
|
|
66
|
-
];
|
|
67
|
-
return queries.filter((query) => !disallowedQueries.has(query));
|
|
68
|
-
}
|
|
69
|
-
get source() {
|
|
70
|
-
return this.config.source;
|
|
71
|
-
}
|
|
72
|
-
async build() {
|
|
73
|
-
return await this._buildMutex.runExclusive(async () => {
|
|
74
|
-
const source = (0, import_node_model.asNodeInstance)(await super.resolve(this.source));
|
|
75
|
-
if (source) {
|
|
76
|
-
await Promise.all(this.ids.map(async (id) => {
|
|
77
|
-
await import_node_memory.NodeHelper.attachToExistingNode(source, id, this);
|
|
78
|
-
}));
|
|
79
|
-
this._built = true;
|
|
80
|
-
}
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
async resolve(idOrFilter = "*", options = {}) {
|
|
84
|
-
if (!this._built) {
|
|
85
|
-
await this.build();
|
|
86
|
-
}
|
|
87
|
-
const mods = await this._limitedResolver.resolve("*");
|
|
88
|
-
if (idOrFilter === "*") {
|
|
89
|
-
return mods;
|
|
90
|
-
}
|
|
91
|
-
switch (typeof idOrFilter) {
|
|
92
|
-
case "string": {
|
|
93
|
-
const mod = mods.find((mod2) => mod2.modName === idOrFilter || mod2.address === idOrFilter);
|
|
94
|
-
return mod;
|
|
95
|
-
}
|
|
96
|
-
case "object": {
|
|
97
|
-
if ((0, import_module_model.isAddressModuleFilter)(idOrFilter)) {
|
|
98
|
-
return (await Promise.all(idOrFilter.address.map(async (address) => await this.resolve(address, options)))).filter(import_exists.exists);
|
|
99
|
-
} else if ((0, import_module_model.isNameModuleFilter)(idOrFilter)) {
|
|
100
|
-
return (await Promise.all(idOrFilter.name.map(async (name) => await this.resolve(name, options)))).filter(import_exists.exists);
|
|
101
|
-
}
|
|
102
|
-
return [];
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
async attachUsingAddress(address) {
|
|
107
|
-
const attached = await this.attached();
|
|
108
|
-
const mods = this.registeredModules().filter((mod) => attached.includes(mod.address));
|
|
109
|
-
const existingModule = mods.find((mod) => mod.address === address);
|
|
110
|
-
(0, import_assert.assertEx)(!existingModule, () => `Module [${existingModule?.modName ?? existingModule?.address}] already attached at address [${address}]`);
|
|
111
|
-
const module2 = this.registeredModuleMap[address];
|
|
112
|
-
if (!module2) {
|
|
113
|
-
return;
|
|
114
|
-
}
|
|
115
|
-
module2.addParent(this);
|
|
116
|
-
const args = {
|
|
117
|
-
module: module2,
|
|
118
|
-
name: module2.modName
|
|
119
|
-
};
|
|
120
|
-
await this.emit("moduleAttached", args);
|
|
121
|
-
this._limitedResolver.add(module2);
|
|
122
|
-
if ((0, import_node_model.isNodeModule)(module2)) {
|
|
123
|
-
const attachedListener = /* @__PURE__ */ __name(async (args2) => await this.emit("moduleAttached", args2), "attachedListener");
|
|
124
|
-
const detachedListener = /* @__PURE__ */ __name(async (args2) => await this.emit("moduleDetached", args2), "detachedListener");
|
|
125
|
-
module2.on("moduleAttached", attachedListener);
|
|
126
|
-
module2.on("moduleDetached", detachedListener);
|
|
127
|
-
}
|
|
128
|
-
return address;
|
|
129
|
-
}
|
|
130
|
-
async attachedPublicModules() {
|
|
131
|
-
return (await this._limitedResolver.resolve("*")).filter((module2) => module2.address !== this.address);
|
|
132
|
-
}
|
|
133
|
-
async detachUsingAddress(address) {
|
|
134
|
-
const module2 = await this.downResolver.resolve(address);
|
|
135
|
-
if (module2) {
|
|
136
|
-
this._limitedResolver.remove(address);
|
|
137
|
-
return address;
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
async startHandler() {
|
|
141
|
-
await super.startHandler();
|
|
142
|
-
await this.build();
|
|
143
|
-
return true;
|
|
144
|
-
}
|
|
145
|
-
};
|
|
1
|
+
"use strict";var c=Object.defineProperty;var x=Object.getOwnPropertyDescriptor;var b=Object.getOwnPropertyNames;var N=Object.prototype.hasOwnProperty;var l=(a,e)=>c(a,"name",{value:e,configurable:!0});var _=(a,e)=>{for(var s in e)c(a,s,{get:e[s],enumerable:!0})},S=(a,e,s,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of b(e))!N.call(a,t)&&t!==s&&c(a,t,{get:()=>e[t],enumerable:!(r=x(e,t))||r.enumerable});return a};var R=a=>S(c({},"__esModule",{value:!0}),a);var A={};_(A,{ViewNode:()=>w,ViewNodeConfigSchema:()=>f});module.exports=R(A);var p=require("@xylabs/assert"),h=require("@xylabs/exists"),d=require("@xyo-network/module-model"),g=require("@xyo-network/module-resolver"),u=require("@xyo-network/node-memory"),o=require("@xyo-network/node-model"),y=require("async-mutex");var f="network.xyo.node.view.config",w=class extends u.MemoryNode{static{l(this,"ViewNode")}static configSchemas=[...super.configSchemas,f];static defaultConfigSchema=f;static labels={...d.ModuleLimitationViewLabel};_buildMutex=new y.Mutex;_built=!1;_limitedResolver=new g.SimpleModuleResolver({root:this});get ids(){return this.config.ids}get queries(){let e=new Set([o.NodeAttachQuerySchema,o.NodeDetachQuerySchema,o.NodeRegisteredQuerySchema]);return[...super.queries].filter(r=>!e.has(r))}get source(){return this.config.source}async build(){return await this._buildMutex.runExclusive(async()=>{let e=(0,o.asNodeInstance)(await super.resolve(this.source));e&&(await Promise.all(this.ids.map(async s=>{await u.NodeHelper.attachToExistingNode(e,s,this)})),this._built=!0)})}async resolve(e="*",s={}){this._built||await this.build();let r=await this._limitedResolver.resolve("*");if(e==="*")return r;switch(typeof e){case"string":return r.find(i=>i.modName===e||i.address===e);case"object":return(0,d.isAddressModuleFilter)(e)?(await Promise.all(e.address.map(async t=>await this.resolve(t,s)))).filter(h.exists):(0,d.isNameModuleFilter)(e)?(await Promise.all(e.name.map(async t=>await this.resolve(t,s)))).filter(h.exists):[]}}async attachUsingAddress(e){let s=await this.attached(),t=this.registeredModules().filter(n=>s.includes(n.address)).find(n=>n.address===e);(0,p.assertEx)(!t,()=>`Module [${t?.modName??t?.address}] already attached at address [${e}]`);let i=this.registeredModuleMap[e];if(!i)return;i.addParent(this);let v={module:i,name:i.modName};if(await this.emit("moduleAttached",v),this._limitedResolver.add(i),(0,o.isNodeModule)(i)){let n=l(async m=>await this.emit("moduleAttached",m),"attachedListener"),M=l(async m=>await this.emit("moduleDetached",m),"detachedListener");i.on("moduleAttached",n),i.on("moduleDetached",M)}return e}async attachedPublicModules(){return(await this._limitedResolver.resolve("*")).filter(e=>e.address!==this.address)}async detachUsingAddress(e){if(await this.downResolver.resolve(e))return this._limitedResolver.remove(e),e}async startHandler(){return await super.startHandler(),await this.build(),!0}};
|
|
146
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/ViewNode.ts"],"sourcesContent":["export * from './ViewNode'\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\nimport { EventListener } from '@xyo-network/module-events'\nimport {\n AnyConfigSchema,\n isAddressModuleFilter,\n isNameModuleFilter,\n ModuleFilter,\n ModuleFilterOptions,\n ModuleIdentifier,\n ModuleInstance,\n ModuleLimitationViewLabel,\n} from '@xyo-network/module-model'\nimport { SimpleModuleResolver } from '@xyo-network/module-resolver'\nimport { MemoryNode, NodeHelper } from '@xyo-network/node-memory'\nimport {\n asNodeInstance,\n AttachableNodeInstance,\n isNodeModule,\n NodeAttachQuerySchema,\n NodeConfig,\n NodeDetachQuerySchema,\n NodeModuleEventData,\n NodeParams,\n NodeRegisteredQuerySchema,\n} from '@xyo-network/node-model'\nimport { Schema } from '@xyo-network/payload-model'\nimport { Mutex } from 'async-mutex'\n\nexport const ViewNodeConfigSchema = 'network.xyo.node.view.config' as const\nexport type ViewNodeConfigSchema = typeof ViewNodeConfigSchema\n\nexport type ViewNodeConfig = NodeConfig<\n {\n ids: ModuleIdentifier[]\n source: ModuleIdentifier\n },\n ViewNodeConfigSchema\n>\n\nexport type ViewNodeParams = NodeParams<AnyConfigSchema<ViewNodeConfig>>\n\nexport class ViewNode<TParams extends ViewNodeParams = ViewNodeParams, TEventData extends NodeModuleEventData = NodeModuleEventData>\n extends MemoryNode<TParams, TEventData>\n implements AttachableNodeInstance\n{\n static override readonly configSchemas: Schema[] = [...super.configSchemas, ViewNodeConfigSchema]\n static override readonly defaultConfigSchema: Schema = ViewNodeConfigSchema\n static override readonly labels = { ...ModuleLimitationViewLabel }\n\n private _buildMutex = new Mutex()\n private _built = false\n private _limitedResolver = new SimpleModuleResolver({ root: this })\n\n get ids() {\n return this.config.ids\n }\n\n override get queries(): Schema[] {\n const disallowedQueries = new Set<Schema>([NodeAttachQuerySchema, NodeDetachQuerySchema, NodeRegisteredQuerySchema])\n const queries: Schema[] = [...super.queries]\n return queries.filter((query) => !disallowedQueries.has(query))\n }\n\n get source() {\n return this.config.source\n }\n\n async build() {\n return await this._buildMutex.runExclusive(async () => {\n const source = asNodeInstance(await super.resolve(this.source))\n if (source) {\n await Promise.all(\n this.ids.map(async (id) => {\n await NodeHelper.attachToExistingNode(source, id, this)\n }),\n )\n this._built = true\n }\n })\n }\n\n /** @deprecated do not pass undefined. If trying to get all, pass '*' */\n override async resolve(): Promise<ModuleInstance[]>\n override async resolve<T extends ModuleInstance = ModuleInstance>(all: '*', options?: ModuleFilterOptions<T>): Promise<T[]>\n override async resolve<T extends ModuleInstance = ModuleInstance>(filter: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n override async resolve<T extends ModuleInstance = ModuleInstance>(id: ModuleIdentifier, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n override async resolve<T extends ModuleInstance = ModuleInstance>(\n idOrFilter: ModuleFilter<T> | ModuleIdentifier = '*',\n options: ModuleFilterOptions<T> = {},\n ): Promise<T | T[] | undefined> {\n if (!this._built) {\n await this.build()\n }\n const mods = await this._limitedResolver.resolve('*')\n if (idOrFilter === '*') {\n return mods as unknown as T[]\n }\n switch (typeof idOrFilter) {\n case 'string': {\n const mod = mods.find((mod) => mod.modName === idOrFilter || mod.address === idOrFilter)\n return mod as unknown as T\n }\n case 'object': {\n if (isAddressModuleFilter(idOrFilter)) {\n return (await Promise.all(idOrFilter.address.map(async (address) => await this.resolve(address, options)))).filter(exists)\n } else if (isNameModuleFilter(idOrFilter)) {\n return (await Promise.all(idOrFilter.name.map(async (name) => await this.resolve(name, options)))).filter(exists)\n }\n return []\n }\n }\n }\n\n protected override async attachUsingAddress(address: Address) {\n const attached = await this.attached()\n const mods = this.registeredModules().filter((mod) => attached.includes(mod.address))\n const existingModule = mods.find((mod) => mod.address === address)\n assertEx(!existingModule, () => `Module [${existingModule?.modName ?? existingModule?.address}] already attached at address [${address}]`)\n const module = this.registeredModuleMap[address]\n\n if (!module) {\n return\n }\n\n module.addParent(this)\n\n const args = { module, name: module.modName }\n await this.emit('moduleAttached', args)\n\n this._limitedResolver.add(module)\n\n if (isNodeModule(module)) {\n const attachedListener: EventListener<TEventData['moduleAttached']> = async (args: TEventData['moduleAttached']) =>\n await this.emit('moduleAttached', args)\n\n const detachedListener: EventListener<TEventData['moduleDetached']> = async (args: TEventData['moduleDetached']) =>\n await this.emit('moduleDetached', args)\n\n module.on('moduleAttached', attachedListener)\n module.on('moduleDetached', detachedListener)\n }\n\n return address\n }\n\n protected override async attachedPublicModules(): Promise<ModuleInstance[]> {\n return (await this._limitedResolver.resolve('*')).filter((module) => module.address !== this.address)\n }\n\n protected override async detachUsingAddress(address: Address) {\n const module = await this.downResolver.resolve(address)\n if (module) {\n this._limitedResolver.remove(address)\n return address\n }\n }\n\n protected override async startHandler(): Promise<boolean> {\n await super.startHandler()\n await this.build()\n return true\n }\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/ViewNode.ts"],"sourcesContent":["export * from './ViewNode'\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\nimport { EventListener } from '@xyo-network/module-events'\nimport {\n AnyConfigSchema,\n isAddressModuleFilter,\n isNameModuleFilter,\n ModuleFilter,\n ModuleFilterOptions,\n ModuleIdentifier,\n ModuleInstance,\n ModuleLimitationViewLabel,\n} from '@xyo-network/module-model'\nimport { SimpleModuleResolver } from '@xyo-network/module-resolver'\nimport { MemoryNode, NodeHelper } from '@xyo-network/node-memory'\nimport {\n asNodeInstance,\n AttachableNodeInstance,\n isNodeModule,\n NodeAttachQuerySchema,\n NodeConfig,\n NodeDetachQuerySchema,\n NodeModuleEventData,\n NodeParams,\n NodeRegisteredQuerySchema,\n} from '@xyo-network/node-model'\nimport { Schema } from '@xyo-network/payload-model'\nimport { Mutex } from 'async-mutex'\n\nexport const ViewNodeConfigSchema = 'network.xyo.node.view.config' as const\nexport type ViewNodeConfigSchema = typeof ViewNodeConfigSchema\n\nexport type ViewNodeConfig = NodeConfig<\n {\n ids: ModuleIdentifier[]\n source: ModuleIdentifier\n },\n ViewNodeConfigSchema\n>\n\nexport type ViewNodeParams = NodeParams<AnyConfigSchema<ViewNodeConfig>>\n\nexport class ViewNode<TParams extends ViewNodeParams = ViewNodeParams, TEventData extends NodeModuleEventData = NodeModuleEventData>\n extends MemoryNode<TParams, TEventData>\n implements AttachableNodeInstance\n{\n static override readonly configSchemas: Schema[] = [...super.configSchemas, ViewNodeConfigSchema]\n static override readonly defaultConfigSchema: Schema = ViewNodeConfigSchema\n static override readonly labels = { ...ModuleLimitationViewLabel }\n\n private _buildMutex = new Mutex()\n private _built = false\n private _limitedResolver = new SimpleModuleResolver({ root: this })\n\n get ids() {\n return this.config.ids\n }\n\n override get queries(): Schema[] {\n const disallowedQueries = new Set<Schema>([NodeAttachQuerySchema, NodeDetachQuerySchema, NodeRegisteredQuerySchema])\n const queries: Schema[] = [...super.queries]\n return queries.filter((query) => !disallowedQueries.has(query))\n }\n\n get source() {\n return this.config.source\n }\n\n async build() {\n return await this._buildMutex.runExclusive(async () => {\n const source = asNodeInstance(await super.resolve(this.source))\n if (source) {\n await Promise.all(\n this.ids.map(async (id) => {\n await NodeHelper.attachToExistingNode(source, id, this)\n }),\n )\n this._built = true\n }\n })\n }\n\n /** @deprecated do not pass undefined. If trying to get all, pass '*' */\n override async resolve(): Promise<ModuleInstance[]>\n override async resolve<T extends ModuleInstance = ModuleInstance>(all: '*', options?: ModuleFilterOptions<T>): Promise<T[]>\n override async resolve<T extends ModuleInstance = ModuleInstance>(filter: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n override async resolve<T extends ModuleInstance = ModuleInstance>(id: ModuleIdentifier, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n override async resolve<T extends ModuleInstance = ModuleInstance>(\n idOrFilter: ModuleFilter<T> | ModuleIdentifier = '*',\n options: ModuleFilterOptions<T> = {},\n ): Promise<T | T[] | undefined> {\n if (!this._built) {\n await this.build()\n }\n const mods = await this._limitedResolver.resolve('*')\n if (idOrFilter === '*') {\n return mods as unknown as T[]\n }\n switch (typeof idOrFilter) {\n case 'string': {\n const mod = mods.find((mod) => mod.modName === idOrFilter || mod.address === idOrFilter)\n return mod as unknown as T\n }\n case 'object': {\n if (isAddressModuleFilter(idOrFilter)) {\n return (await Promise.all(idOrFilter.address.map(async (address) => await this.resolve(address, options)))).filter(exists)\n } else if (isNameModuleFilter(idOrFilter)) {\n return (await Promise.all(idOrFilter.name.map(async (name) => await this.resolve(name, options)))).filter(exists)\n }\n return []\n }\n }\n }\n\n protected override async attachUsingAddress(address: Address) {\n const attached = await this.attached()\n const mods = this.registeredModules().filter((mod) => attached.includes(mod.address))\n const existingModule = mods.find((mod) => mod.address === address)\n assertEx(!existingModule, () => `Module [${existingModule?.modName ?? existingModule?.address}] already attached at address [${address}]`)\n const module = this.registeredModuleMap[address]\n\n if (!module) {\n return\n }\n\n module.addParent(this)\n\n const args = { module, name: module.modName }\n await this.emit('moduleAttached', args)\n\n this._limitedResolver.add(module)\n\n if (isNodeModule(module)) {\n const attachedListener: EventListener<TEventData['moduleAttached']> = async (args: TEventData['moduleAttached']) =>\n await this.emit('moduleAttached', args)\n\n const detachedListener: EventListener<TEventData['moduleDetached']> = async (args: TEventData['moduleDetached']) =>\n await this.emit('moduleDetached', args)\n\n module.on('moduleAttached', attachedListener)\n module.on('moduleDetached', detachedListener)\n }\n\n return address\n }\n\n protected override async attachedPublicModules(): Promise<ModuleInstance[]> {\n return (await this._limitedResolver.resolve('*')).filter((module) => module.address !== this.address)\n }\n\n protected override async detachUsingAddress(address: Address) {\n const module = await this.downResolver.resolve(address)\n if (module) {\n this._limitedResolver.remove(address)\n return address\n }\n }\n\n protected override async startHandler(): Promise<boolean> {\n await super.startHandler()\n await this.build()\n return true\n }\n}\n"],"mappings":"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","names":["src_exports","__export","ViewNode","ViewNodeConfigSchema","__toCommonJS","import_assert","import_exists","import_module_model","import_module_resolver","import_node_memory","import_node_model","import_async_mutex","ViewNodeConfigSchema","ViewNode","MemoryNode","configSchemas","defaultConfigSchema","labels","ModuleLimitationViewLabel","_buildMutex","Mutex","_built","_limitedResolver","SimpleModuleResolver","root","ids","config","queries","disallowedQueries","Set","NodeAttachQuerySchema","NodeDetachQuerySchema","NodeRegisteredQuerySchema","filter","query","has","source","build","runExclusive","asNodeInstance","resolve","Promise","all","map","id","NodeHelper","attachToExistingNode","idOrFilter","options","mods","find","mod","modName","address","isAddressModuleFilter","exists","isNameModuleFilter","name","attachUsingAddress","attached","existingModule","registeredModules","includes","assertEx","module","registeredModuleMap","addParent","args","emit","add","isNodeModule","attachedListener","__name","detachedListener","on","attachedPublicModules","detachUsingAddress","downResolver","remove","startHandler"]}
|
package/dist/neutral/index.js
CHANGED
|
@@ -1,125 +1,2 @@
|
|
|
1
|
-
var
|
|
2
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
-
|
|
4
|
-
// src/ViewNode.ts
|
|
5
|
-
import { assertEx } from "@xylabs/assert";
|
|
6
|
-
import { exists } from "@xylabs/exists";
|
|
7
|
-
import { isAddressModuleFilter, isNameModuleFilter, ModuleLimitationViewLabel } from "@xyo-network/module-model";
|
|
8
|
-
import { SimpleModuleResolver } from "@xyo-network/module-resolver";
|
|
9
|
-
import { MemoryNode, NodeHelper } from "@xyo-network/node-memory";
|
|
10
|
-
import { asNodeInstance, isNodeModule, NodeAttachQuerySchema, NodeDetachQuerySchema, NodeRegisteredQuerySchema } from "@xyo-network/node-model";
|
|
11
|
-
import { Mutex } from "async-mutex";
|
|
12
|
-
var ViewNodeConfigSchema = "network.xyo.node.view.config";
|
|
13
|
-
var ViewNode = class extends MemoryNode {
|
|
14
|
-
static {
|
|
15
|
-
__name(this, "ViewNode");
|
|
16
|
-
}
|
|
17
|
-
static configSchemas = [
|
|
18
|
-
...super.configSchemas,
|
|
19
|
-
ViewNodeConfigSchema
|
|
20
|
-
];
|
|
21
|
-
static defaultConfigSchema = ViewNodeConfigSchema;
|
|
22
|
-
static labels = {
|
|
23
|
-
...ModuleLimitationViewLabel
|
|
24
|
-
};
|
|
25
|
-
_buildMutex = new Mutex();
|
|
26
|
-
_built = false;
|
|
27
|
-
_limitedResolver = new SimpleModuleResolver({
|
|
28
|
-
root: this
|
|
29
|
-
});
|
|
30
|
-
get ids() {
|
|
31
|
-
return this.config.ids;
|
|
32
|
-
}
|
|
33
|
-
get queries() {
|
|
34
|
-
const disallowedQueries = /* @__PURE__ */ new Set([
|
|
35
|
-
NodeAttachQuerySchema,
|
|
36
|
-
NodeDetachQuerySchema,
|
|
37
|
-
NodeRegisteredQuerySchema
|
|
38
|
-
]);
|
|
39
|
-
const queries = [
|
|
40
|
-
...super.queries
|
|
41
|
-
];
|
|
42
|
-
return queries.filter((query) => !disallowedQueries.has(query));
|
|
43
|
-
}
|
|
44
|
-
get source() {
|
|
45
|
-
return this.config.source;
|
|
46
|
-
}
|
|
47
|
-
async build() {
|
|
48
|
-
return await this._buildMutex.runExclusive(async () => {
|
|
49
|
-
const source = asNodeInstance(await super.resolve(this.source));
|
|
50
|
-
if (source) {
|
|
51
|
-
await Promise.all(this.ids.map(async (id) => {
|
|
52
|
-
await NodeHelper.attachToExistingNode(source, id, this);
|
|
53
|
-
}));
|
|
54
|
-
this._built = true;
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
async resolve(idOrFilter = "*", options = {}) {
|
|
59
|
-
if (!this._built) {
|
|
60
|
-
await this.build();
|
|
61
|
-
}
|
|
62
|
-
const mods = await this._limitedResolver.resolve("*");
|
|
63
|
-
if (idOrFilter === "*") {
|
|
64
|
-
return mods;
|
|
65
|
-
}
|
|
66
|
-
switch (typeof idOrFilter) {
|
|
67
|
-
case "string": {
|
|
68
|
-
const mod = mods.find((mod2) => mod2.modName === idOrFilter || mod2.address === idOrFilter);
|
|
69
|
-
return mod;
|
|
70
|
-
}
|
|
71
|
-
case "object": {
|
|
72
|
-
if (isAddressModuleFilter(idOrFilter)) {
|
|
73
|
-
return (await Promise.all(idOrFilter.address.map(async (address) => await this.resolve(address, options)))).filter(exists);
|
|
74
|
-
} else if (isNameModuleFilter(idOrFilter)) {
|
|
75
|
-
return (await Promise.all(idOrFilter.name.map(async (name) => await this.resolve(name, options)))).filter(exists);
|
|
76
|
-
}
|
|
77
|
-
return [];
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
async attachUsingAddress(address) {
|
|
82
|
-
const attached = await this.attached();
|
|
83
|
-
const mods = this.registeredModules().filter((mod) => attached.includes(mod.address));
|
|
84
|
-
const existingModule = mods.find((mod) => mod.address === address);
|
|
85
|
-
assertEx(!existingModule, () => `Module [${existingModule?.modName ?? existingModule?.address}] already attached at address [${address}]`);
|
|
86
|
-
const module = this.registeredModuleMap[address];
|
|
87
|
-
if (!module) {
|
|
88
|
-
return;
|
|
89
|
-
}
|
|
90
|
-
module.addParent(this);
|
|
91
|
-
const args = {
|
|
92
|
-
module,
|
|
93
|
-
name: module.modName
|
|
94
|
-
};
|
|
95
|
-
await this.emit("moduleAttached", args);
|
|
96
|
-
this._limitedResolver.add(module);
|
|
97
|
-
if (isNodeModule(module)) {
|
|
98
|
-
const attachedListener = /* @__PURE__ */ __name(async (args2) => await this.emit("moduleAttached", args2), "attachedListener");
|
|
99
|
-
const detachedListener = /* @__PURE__ */ __name(async (args2) => await this.emit("moduleDetached", args2), "detachedListener");
|
|
100
|
-
module.on("moduleAttached", attachedListener);
|
|
101
|
-
module.on("moduleDetached", detachedListener);
|
|
102
|
-
}
|
|
103
|
-
return address;
|
|
104
|
-
}
|
|
105
|
-
async attachedPublicModules() {
|
|
106
|
-
return (await this._limitedResolver.resolve("*")).filter((module) => module.address !== this.address);
|
|
107
|
-
}
|
|
108
|
-
async detachUsingAddress(address) {
|
|
109
|
-
const module = await this.downResolver.resolve(address);
|
|
110
|
-
if (module) {
|
|
111
|
-
this._limitedResolver.remove(address);
|
|
112
|
-
return address;
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
async startHandler() {
|
|
116
|
-
await super.startHandler();
|
|
117
|
-
await this.build();
|
|
118
|
-
return true;
|
|
119
|
-
}
|
|
120
|
-
};
|
|
121
|
-
export {
|
|
122
|
-
ViewNode,
|
|
123
|
-
ViewNodeConfigSchema
|
|
124
|
-
};
|
|
1
|
+
var f=Object.defineProperty;var r=(n,e)=>f(n,"name",{value:e,configurable:!0});import{assertEx as w}from"@xylabs/assert";import{exists as c}from"@xylabs/exists";import{isAddressModuleFilter as p,isNameModuleFilter as g,ModuleLimitationViewLabel as y}from"@xyo-network/module-model";import{SimpleModuleResolver as v}from"@xyo-network/module-resolver";import{MemoryNode as M,NodeHelper as x}from"@xyo-network/node-memory";import{asNodeInstance as b,isNodeModule as N,NodeAttachQuerySchema as _,NodeDetachQuerySchema as S,NodeRegisteredQuerySchema as R}from"@xyo-network/node-model";import{Mutex as A}from"async-mutex";var l="network.xyo.node.view.config",u=class extends M{static{r(this,"ViewNode")}static configSchemas=[...super.configSchemas,l];static defaultConfigSchema=l;static labels={...y};_buildMutex=new A;_built=!1;_limitedResolver=new v({root:this});get ids(){return this.config.ids}get queries(){let e=new Set([_,S,R]);return[...super.queries].filter(a=>!e.has(a))}get source(){return this.config.source}async build(){return await this._buildMutex.runExclusive(async()=>{let e=b(await super.resolve(this.source));e&&(await Promise.all(this.ids.map(async s=>{await x.attachToExistingNode(e,s,this)})),this._built=!0)})}async resolve(e="*",s={}){this._built||await this.build();let a=await this._limitedResolver.resolve("*");if(e==="*")return a;switch(typeof e){case"string":return a.find(t=>t.modName===e||t.address===e);case"object":return p(e)?(await Promise.all(e.address.map(async i=>await this.resolve(i,s)))).filter(c):g(e)?(await Promise.all(e.name.map(async i=>await this.resolve(i,s)))).filter(c):[]}}async attachUsingAddress(e){let s=await this.attached(),i=this.registeredModules().filter(o=>s.includes(o.address)).find(o=>o.address===e);w(!i,()=>`Module [${i?.modName??i?.address}] already attached at address [${e}]`);let t=this.registeredModuleMap[e];if(!t)return;t.addParent(this);let m={module:t,name:t.modName};if(await this.emit("moduleAttached",m),this._limitedResolver.add(t),N(t)){let o=r(async d=>await this.emit("moduleAttached",d),"attachedListener"),h=r(async d=>await this.emit("moduleDetached",d),"detachedListener");t.on("moduleAttached",o),t.on("moduleDetached",h)}return e}async attachedPublicModules(){return(await this._limitedResolver.resolve("*")).filter(e=>e.address!==this.address)}async detachUsingAddress(e){if(await this.downResolver.resolve(e))return this._limitedResolver.remove(e),e}async startHandler(){return await super.startHandler(),await this.build(),!0}};export{u as ViewNode,l as ViewNodeConfigSchema};
|
|
125
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/ViewNode.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\nimport { EventListener } from '@xyo-network/module-events'\nimport {\n AnyConfigSchema,\n isAddressModuleFilter,\n isNameModuleFilter,\n ModuleFilter,\n ModuleFilterOptions,\n ModuleIdentifier,\n ModuleInstance,\n ModuleLimitationViewLabel,\n} from '@xyo-network/module-model'\nimport { SimpleModuleResolver } from '@xyo-network/module-resolver'\nimport { MemoryNode, NodeHelper } from '@xyo-network/node-memory'\nimport {\n asNodeInstance,\n AttachableNodeInstance,\n isNodeModule,\n NodeAttachQuerySchema,\n NodeConfig,\n NodeDetachQuerySchema,\n NodeModuleEventData,\n NodeParams,\n NodeRegisteredQuerySchema,\n} from '@xyo-network/node-model'\nimport { Schema } from '@xyo-network/payload-model'\nimport { Mutex } from 'async-mutex'\n\nexport const ViewNodeConfigSchema = 'network.xyo.node.view.config' as const\nexport type ViewNodeConfigSchema = typeof ViewNodeConfigSchema\n\nexport type ViewNodeConfig = NodeConfig<\n {\n ids: ModuleIdentifier[]\n source: ModuleIdentifier\n },\n ViewNodeConfigSchema\n>\n\nexport type ViewNodeParams = NodeParams<AnyConfigSchema<ViewNodeConfig>>\n\nexport class ViewNode<TParams extends ViewNodeParams = ViewNodeParams, TEventData extends NodeModuleEventData = NodeModuleEventData>\n extends MemoryNode<TParams, TEventData>\n implements AttachableNodeInstance\n{\n static override readonly configSchemas: Schema[] = [...super.configSchemas, ViewNodeConfigSchema]\n static override readonly defaultConfigSchema: Schema = ViewNodeConfigSchema\n static override readonly labels = { ...ModuleLimitationViewLabel }\n\n private _buildMutex = new Mutex()\n private _built = false\n private _limitedResolver = new SimpleModuleResolver({ root: this })\n\n get ids() {\n return this.config.ids\n }\n\n override get queries(): Schema[] {\n const disallowedQueries = new Set<Schema>([NodeAttachQuerySchema, NodeDetachQuerySchema, NodeRegisteredQuerySchema])\n const queries: Schema[] = [...super.queries]\n return queries.filter((query) => !disallowedQueries.has(query))\n }\n\n get source() {\n return this.config.source\n }\n\n async build() {\n return await this._buildMutex.runExclusive(async () => {\n const source = asNodeInstance(await super.resolve(this.source))\n if (source) {\n await Promise.all(\n this.ids.map(async (id) => {\n await NodeHelper.attachToExistingNode(source, id, this)\n }),\n )\n this._built = true\n }\n })\n }\n\n /** @deprecated do not pass undefined. If trying to get all, pass '*' */\n override async resolve(): Promise<ModuleInstance[]>\n override async resolve<T extends ModuleInstance = ModuleInstance>(all: '*', options?: ModuleFilterOptions<T>): Promise<T[]>\n override async resolve<T extends ModuleInstance = ModuleInstance>(filter: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n override async resolve<T extends ModuleInstance = ModuleInstance>(id: ModuleIdentifier, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n override async resolve<T extends ModuleInstance = ModuleInstance>(\n idOrFilter: ModuleFilter<T> | ModuleIdentifier = '*',\n options: ModuleFilterOptions<T> = {},\n ): Promise<T | T[] | undefined> {\n if (!this._built) {\n await this.build()\n }\n const mods = await this._limitedResolver.resolve('*')\n if (idOrFilter === '*') {\n return mods as unknown as T[]\n }\n switch (typeof idOrFilter) {\n case 'string': {\n const mod = mods.find((mod) => mod.modName === idOrFilter || mod.address === idOrFilter)\n return mod as unknown as T\n }\n case 'object': {\n if (isAddressModuleFilter(idOrFilter)) {\n return (await Promise.all(idOrFilter.address.map(async (address) => await this.resolve(address, options)))).filter(exists)\n } else if (isNameModuleFilter(idOrFilter)) {\n return (await Promise.all(idOrFilter.name.map(async (name) => await this.resolve(name, options)))).filter(exists)\n }\n return []\n }\n }\n }\n\n protected override async attachUsingAddress(address: Address) {\n const attached = await this.attached()\n const mods = this.registeredModules().filter((mod) => attached.includes(mod.address))\n const existingModule = mods.find((mod) => mod.address === address)\n assertEx(!existingModule, () => `Module [${existingModule?.modName ?? existingModule?.address}] already attached at address [${address}]`)\n const module = this.registeredModuleMap[address]\n\n if (!module) {\n return\n }\n\n module.addParent(this)\n\n const args = { module, name: module.modName }\n await this.emit('moduleAttached', args)\n\n this._limitedResolver.add(module)\n\n if (isNodeModule(module)) {\n const attachedListener: EventListener<TEventData['moduleAttached']> = async (args: TEventData['moduleAttached']) =>\n await this.emit('moduleAttached', args)\n\n const detachedListener: EventListener<TEventData['moduleDetached']> = async (args: TEventData['moduleDetached']) =>\n await this.emit('moduleDetached', args)\n\n module.on('moduleAttached', attachedListener)\n module.on('moduleDetached', detachedListener)\n }\n\n return address\n }\n\n protected override async attachedPublicModules(): Promise<ModuleInstance[]> {\n return (await this._limitedResolver.resolve('*')).filter((module) => module.address !== this.address)\n }\n\n protected override async detachUsingAddress(address: Address) {\n const module = await this.downResolver.resolve(address)\n if (module) {\n this._limitedResolver.remove(address)\n return address\n }\n }\n\n protected override async startHandler(): Promise<boolean> {\n await super.startHandler()\n await this.build()\n return true\n }\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/ViewNode.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\nimport { EventListener } from '@xyo-network/module-events'\nimport {\n AnyConfigSchema,\n isAddressModuleFilter,\n isNameModuleFilter,\n ModuleFilter,\n ModuleFilterOptions,\n ModuleIdentifier,\n ModuleInstance,\n ModuleLimitationViewLabel,\n} from '@xyo-network/module-model'\nimport { SimpleModuleResolver } from '@xyo-network/module-resolver'\nimport { MemoryNode, NodeHelper } from '@xyo-network/node-memory'\nimport {\n asNodeInstance,\n AttachableNodeInstance,\n isNodeModule,\n NodeAttachQuerySchema,\n NodeConfig,\n NodeDetachQuerySchema,\n NodeModuleEventData,\n NodeParams,\n NodeRegisteredQuerySchema,\n} from '@xyo-network/node-model'\nimport { Schema } from '@xyo-network/payload-model'\nimport { Mutex } from 'async-mutex'\n\nexport const ViewNodeConfigSchema = 'network.xyo.node.view.config' as const\nexport type ViewNodeConfigSchema = typeof ViewNodeConfigSchema\n\nexport type ViewNodeConfig = NodeConfig<\n {\n ids: ModuleIdentifier[]\n source: ModuleIdentifier\n },\n ViewNodeConfigSchema\n>\n\nexport type ViewNodeParams = NodeParams<AnyConfigSchema<ViewNodeConfig>>\n\nexport class ViewNode<TParams extends ViewNodeParams = ViewNodeParams, TEventData extends NodeModuleEventData = NodeModuleEventData>\n extends MemoryNode<TParams, TEventData>\n implements AttachableNodeInstance\n{\n static override readonly configSchemas: Schema[] = [...super.configSchemas, ViewNodeConfigSchema]\n static override readonly defaultConfigSchema: Schema = ViewNodeConfigSchema\n static override readonly labels = { ...ModuleLimitationViewLabel }\n\n private _buildMutex = new Mutex()\n private _built = false\n private _limitedResolver = new SimpleModuleResolver({ root: this })\n\n get ids() {\n return this.config.ids\n }\n\n override get queries(): Schema[] {\n const disallowedQueries = new Set<Schema>([NodeAttachQuerySchema, NodeDetachQuerySchema, NodeRegisteredQuerySchema])\n const queries: Schema[] = [...super.queries]\n return queries.filter((query) => !disallowedQueries.has(query))\n }\n\n get source() {\n return this.config.source\n }\n\n async build() {\n return await this._buildMutex.runExclusive(async () => {\n const source = asNodeInstance(await super.resolve(this.source))\n if (source) {\n await Promise.all(\n this.ids.map(async (id) => {\n await NodeHelper.attachToExistingNode(source, id, this)\n }),\n )\n this._built = true\n }\n })\n }\n\n /** @deprecated do not pass undefined. If trying to get all, pass '*' */\n override async resolve(): Promise<ModuleInstance[]>\n override async resolve<T extends ModuleInstance = ModuleInstance>(all: '*', options?: ModuleFilterOptions<T>): Promise<T[]>\n override async resolve<T extends ModuleInstance = ModuleInstance>(filter: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n override async resolve<T extends ModuleInstance = ModuleInstance>(id: ModuleIdentifier, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n override async resolve<T extends ModuleInstance = ModuleInstance>(\n idOrFilter: ModuleFilter<T> | ModuleIdentifier = '*',\n options: ModuleFilterOptions<T> = {},\n ): Promise<T | T[] | undefined> {\n if (!this._built) {\n await this.build()\n }\n const mods = await this._limitedResolver.resolve('*')\n if (idOrFilter === '*') {\n return mods as unknown as T[]\n }\n switch (typeof idOrFilter) {\n case 'string': {\n const mod = mods.find((mod) => mod.modName === idOrFilter || mod.address === idOrFilter)\n return mod as unknown as T\n }\n case 'object': {\n if (isAddressModuleFilter(idOrFilter)) {\n return (await Promise.all(idOrFilter.address.map(async (address) => await this.resolve(address, options)))).filter(exists)\n } else if (isNameModuleFilter(idOrFilter)) {\n return (await Promise.all(idOrFilter.name.map(async (name) => await this.resolve(name, options)))).filter(exists)\n }\n return []\n }\n }\n }\n\n protected override async attachUsingAddress(address: Address) {\n const attached = await this.attached()\n const mods = this.registeredModules().filter((mod) => attached.includes(mod.address))\n const existingModule = mods.find((mod) => mod.address === address)\n assertEx(!existingModule, () => `Module [${existingModule?.modName ?? existingModule?.address}] already attached at address [${address}]`)\n const module = this.registeredModuleMap[address]\n\n if (!module) {\n return\n }\n\n module.addParent(this)\n\n const args = { module, name: module.modName }\n await this.emit('moduleAttached', args)\n\n this._limitedResolver.add(module)\n\n if (isNodeModule(module)) {\n const attachedListener: EventListener<TEventData['moduleAttached']> = async (args: TEventData['moduleAttached']) =>\n await this.emit('moduleAttached', args)\n\n const detachedListener: EventListener<TEventData['moduleDetached']> = async (args: TEventData['moduleDetached']) =>\n await this.emit('moduleDetached', args)\n\n module.on('moduleAttached', attachedListener)\n module.on('moduleDetached', detachedListener)\n }\n\n return address\n }\n\n protected override async attachedPublicModules(): Promise<ModuleInstance[]> {\n return (await this._limitedResolver.resolve('*')).filter((module) => module.address !== this.address)\n }\n\n protected override async detachUsingAddress(address: Address) {\n const module = await this.downResolver.resolve(address)\n if (module) {\n this._limitedResolver.remove(address)\n return address\n }\n }\n\n protected override async startHandler(): Promise<boolean> {\n await super.startHandler()\n await this.build()\n return true\n }\n}\n"],"mappings":"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","names":["assertEx","exists","isAddressModuleFilter","isNameModuleFilter","ModuleLimitationViewLabel","SimpleModuleResolver","MemoryNode","NodeHelper","asNodeInstance","isNodeModule","NodeAttachQuerySchema","NodeDetachQuerySchema","NodeRegisteredQuerySchema","Mutex","ViewNodeConfigSchema","ViewNode","MemoryNode","configSchemas","defaultConfigSchema","labels","ModuleLimitationViewLabel","_buildMutex","Mutex","_built","_limitedResolver","SimpleModuleResolver","root","ids","config","queries","disallowedQueries","Set","NodeAttachQuerySchema","NodeDetachQuerySchema","NodeRegisteredQuerySchema","filter","query","has","source","build","runExclusive","asNodeInstance","resolve","Promise","all","map","id","NodeHelper","attachToExistingNode","idOrFilter","options","mods","find","mod","modName","address","isAddressModuleFilter","exists","isNameModuleFilter","name","attachUsingAddress","attached","existingModule","registeredModules","includes","assertEx","module","registeredModuleMap","addParent","args","emit","add","isNodeModule","attachedListener","__name","detachedListener","on","attachedPublicModules","detachUsingAddress","downResolver","remove","startHandler"]}
|
package/dist/node/ViewNode.d.cts
CHANGED
|
@@ -23,7 +23,6 @@ export declare class ViewNode<TParams extends ViewNodeParams = ViewNodeParams, T
|
|
|
23
23
|
get queries(): Schema[];
|
|
24
24
|
get source(): string;
|
|
25
25
|
build(): Promise<void>;
|
|
26
|
-
/** @deprecated do not pass undefined. If trying to get all, pass '*' */
|
|
27
26
|
resolve(): Promise<ModuleInstance[]>;
|
|
28
27
|
resolve<T extends ModuleInstance = ModuleInstance>(all: '*', options?: ModuleFilterOptions<T>): Promise<T[]>;
|
|
29
28
|
resolve<T extends ModuleInstance = ModuleInstance>(filter: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ViewNode.d.ts","sourceRoot":"","sources":["../../src/ViewNode.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC,OAAO,EACL,eAAe,EAGf,YAAY,EACZ,mBAAmB,EACnB,gBAAgB,EAChB,cAAc,EAEf,MAAM,2BAA2B,CAAA;AAElC,OAAO,EAAE,UAAU,EAAc,MAAM,0BAA0B,CAAA;AACjE,OAAO,EAEL,sBAAsB,EAGtB,UAAU,EAEV,mBAAmB,EACnB,UAAU,EAEX,MAAM,yBAAyB,CAAA;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAGnD,eAAO,MAAM,oBAAoB,gCAA0C,CAAA;AAC3E,MAAM,MAAM,oBAAoB,GAAG,OAAO,oBAAoB,CAAA;AAE9D,MAAM,MAAM,cAAc,GAAG,UAAU,CACrC;IACE,GAAG,EAAE,gBAAgB,EAAE,CAAA;IACvB,MAAM,EAAE,gBAAgB,CAAA;CACzB,EACD,oBAAoB,CACrB,CAAA;AAED,MAAM,MAAM,cAAc,GAAG,UAAU,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC,CAAA;AAExE,qBAAa,QAAQ,CAAC,OAAO,SAAS,cAAc,GAAG,cAAc,EAAE,UAAU,SAAS,mBAAmB,GAAG,mBAAmB,CACjI,SAAQ,UAAU,CAAC,OAAO,EAAE,UAAU,CACtC,YAAW,sBAAsB;IAEjC,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAiD;IACjG,gBAAyB,mBAAmB,EAAE,MAAM,CAAuB;IAC3E,gBAAyB,MAAM;;MAAmC;IAElE,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,MAAM,CAAQ;IACtB,OAAO,CAAC,gBAAgB,CAA2C;IAEnE,IAAI,GAAG,aAEN;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAI/B;IAED,IAAI,MAAM,WAET;IAEK,KAAK;
|
|
1
|
+
{"version":3,"file":"ViewNode.d.ts","sourceRoot":"","sources":["../../src/ViewNode.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC,OAAO,EACL,eAAe,EAGf,YAAY,EACZ,mBAAmB,EACnB,gBAAgB,EAChB,cAAc,EAEf,MAAM,2BAA2B,CAAA;AAElC,OAAO,EAAE,UAAU,EAAc,MAAM,0BAA0B,CAAA;AACjE,OAAO,EAEL,sBAAsB,EAGtB,UAAU,EAEV,mBAAmB,EACnB,UAAU,EAEX,MAAM,yBAAyB,CAAA;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAGnD,eAAO,MAAM,oBAAoB,gCAA0C,CAAA;AAC3E,MAAM,MAAM,oBAAoB,GAAG,OAAO,oBAAoB,CAAA;AAE9D,MAAM,MAAM,cAAc,GAAG,UAAU,CACrC;IACE,GAAG,EAAE,gBAAgB,EAAE,CAAA;IACvB,MAAM,EAAE,gBAAgB,CAAA;CACzB,EACD,oBAAoB,CACrB,CAAA;AAED,MAAM,MAAM,cAAc,GAAG,UAAU,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC,CAAA;AAExE,qBAAa,QAAQ,CAAC,OAAO,SAAS,cAAc,GAAG,cAAc,EAAE,UAAU,SAAS,mBAAmB,GAAG,mBAAmB,CACjI,SAAQ,UAAU,CAAC,OAAO,EAAE,UAAU,CACtC,YAAW,sBAAsB;IAEjC,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAiD;IACjG,gBAAyB,mBAAmB,EAAE,MAAM,CAAuB;IAC3E,gBAAyB,MAAM;;MAAmC;IAElE,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,MAAM,CAAQ;IACtB,OAAO,CAAC,gBAAgB,CAA2C;IAEnE,IAAI,GAAG,aAEN;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAI/B;IAED,IAAI,MAAM,WAET;IAEK,KAAK;IAeI,OAAO,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;IACpC,OAAO,CAAC,CAAC,SAAS,cAAc,GAAG,cAAc,EAAE,GAAG,EAAE,GAAG,EAAE,OAAO,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAC5G,OAAO,CAAC,CAAC,SAAS,cAAc,GAAG,cAAc,EAAE,MAAM,EAAE,YAAY,EAAE,OAAO,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IACxH,OAAO,CAAC,CAAC,SAAS,cAAc,GAAG,cAAc,EAAE,EAAE,EAAE,gBAAgB,EAAE,OAAO,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAAC;cA4BxH,kBAAkB,CAAC,OAAO,EAAE,OAAO;cAgCnC,qBAAqB,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;cAIlD,kBAAkB,CAAC,OAAO,EAAE,OAAO;cAQnC,YAAY,IAAI,OAAO,CAAC,OAAO,CAAC;CAK1D"}
|
package/dist/node/ViewNode.d.mts
CHANGED
|
@@ -23,7 +23,6 @@ export declare class ViewNode<TParams extends ViewNodeParams = ViewNodeParams, T
|
|
|
23
23
|
get queries(): Schema[];
|
|
24
24
|
get source(): string;
|
|
25
25
|
build(): Promise<void>;
|
|
26
|
-
/** @deprecated do not pass undefined. If trying to get all, pass '*' */
|
|
27
26
|
resolve(): Promise<ModuleInstance[]>;
|
|
28
27
|
resolve<T extends ModuleInstance = ModuleInstance>(all: '*', options?: ModuleFilterOptions<T>): Promise<T[]>;
|
|
29
28
|
resolve<T extends ModuleInstance = ModuleInstance>(filter: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ViewNode.d.ts","sourceRoot":"","sources":["../../src/ViewNode.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC,OAAO,EACL,eAAe,EAGf,YAAY,EACZ,mBAAmB,EACnB,gBAAgB,EAChB,cAAc,EAEf,MAAM,2BAA2B,CAAA;AAElC,OAAO,EAAE,UAAU,EAAc,MAAM,0BAA0B,CAAA;AACjE,OAAO,EAEL,sBAAsB,EAGtB,UAAU,EAEV,mBAAmB,EACnB,UAAU,EAEX,MAAM,yBAAyB,CAAA;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAGnD,eAAO,MAAM,oBAAoB,gCAA0C,CAAA;AAC3E,MAAM,MAAM,oBAAoB,GAAG,OAAO,oBAAoB,CAAA;AAE9D,MAAM,MAAM,cAAc,GAAG,UAAU,CACrC;IACE,GAAG,EAAE,gBAAgB,EAAE,CAAA;IACvB,MAAM,EAAE,gBAAgB,CAAA;CACzB,EACD,oBAAoB,CACrB,CAAA;AAED,MAAM,MAAM,cAAc,GAAG,UAAU,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC,CAAA;AAExE,qBAAa,QAAQ,CAAC,OAAO,SAAS,cAAc,GAAG,cAAc,EAAE,UAAU,SAAS,mBAAmB,GAAG,mBAAmB,CACjI,SAAQ,UAAU,CAAC,OAAO,EAAE,UAAU,CACtC,YAAW,sBAAsB;IAEjC,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAiD;IACjG,gBAAyB,mBAAmB,EAAE,MAAM,CAAuB;IAC3E,gBAAyB,MAAM;;MAAmC;IAElE,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,MAAM,CAAQ;IACtB,OAAO,CAAC,gBAAgB,CAA2C;IAEnE,IAAI,GAAG,aAEN;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAI/B;IAED,IAAI,MAAM,WAET;IAEK,KAAK;
|
|
1
|
+
{"version":3,"file":"ViewNode.d.ts","sourceRoot":"","sources":["../../src/ViewNode.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC,OAAO,EACL,eAAe,EAGf,YAAY,EACZ,mBAAmB,EACnB,gBAAgB,EAChB,cAAc,EAEf,MAAM,2BAA2B,CAAA;AAElC,OAAO,EAAE,UAAU,EAAc,MAAM,0BAA0B,CAAA;AACjE,OAAO,EAEL,sBAAsB,EAGtB,UAAU,EAEV,mBAAmB,EACnB,UAAU,EAEX,MAAM,yBAAyB,CAAA;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAGnD,eAAO,MAAM,oBAAoB,gCAA0C,CAAA;AAC3E,MAAM,MAAM,oBAAoB,GAAG,OAAO,oBAAoB,CAAA;AAE9D,MAAM,MAAM,cAAc,GAAG,UAAU,CACrC;IACE,GAAG,EAAE,gBAAgB,EAAE,CAAA;IACvB,MAAM,EAAE,gBAAgB,CAAA;CACzB,EACD,oBAAoB,CACrB,CAAA;AAED,MAAM,MAAM,cAAc,GAAG,UAAU,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC,CAAA;AAExE,qBAAa,QAAQ,CAAC,OAAO,SAAS,cAAc,GAAG,cAAc,EAAE,UAAU,SAAS,mBAAmB,GAAG,mBAAmB,CACjI,SAAQ,UAAU,CAAC,OAAO,EAAE,UAAU,CACtC,YAAW,sBAAsB;IAEjC,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAiD;IACjG,gBAAyB,mBAAmB,EAAE,MAAM,CAAuB;IAC3E,gBAAyB,MAAM;;MAAmC;IAElE,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,MAAM,CAAQ;IACtB,OAAO,CAAC,gBAAgB,CAA2C;IAEnE,IAAI,GAAG,aAEN;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAI/B;IAED,IAAI,MAAM,WAET;IAEK,KAAK;IAeI,OAAO,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;IACpC,OAAO,CAAC,CAAC,SAAS,cAAc,GAAG,cAAc,EAAE,GAAG,EAAE,GAAG,EAAE,OAAO,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAC5G,OAAO,CAAC,CAAC,SAAS,cAAc,GAAG,cAAc,EAAE,MAAM,EAAE,YAAY,EAAE,OAAO,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IACxH,OAAO,CAAC,CAAC,SAAS,cAAc,GAAG,cAAc,EAAE,EAAE,EAAE,gBAAgB,EAAE,OAAO,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAAC;cA4BxH,kBAAkB,CAAC,OAAO,EAAE,OAAO;cAgCnC,qBAAqB,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;cAIlD,kBAAkB,CAAC,OAAO,EAAE,OAAO;cAQnC,YAAY,IAAI,OAAO,CAAC,OAAO,CAAC;CAK1D"}
|
package/dist/node/ViewNode.d.ts
CHANGED
|
@@ -23,7 +23,6 @@ export declare class ViewNode<TParams extends ViewNodeParams = ViewNodeParams, T
|
|
|
23
23
|
get queries(): Schema[];
|
|
24
24
|
get source(): string;
|
|
25
25
|
build(): Promise<void>;
|
|
26
|
-
/** @deprecated do not pass undefined. If trying to get all, pass '*' */
|
|
27
26
|
resolve(): Promise<ModuleInstance[]>;
|
|
28
27
|
resolve<T extends ModuleInstance = ModuleInstance>(all: '*', options?: ModuleFilterOptions<T>): Promise<T[]>;
|
|
29
28
|
resolve<T extends ModuleInstance = ModuleInstance>(filter: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ViewNode.d.ts","sourceRoot":"","sources":["../../src/ViewNode.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC,OAAO,EACL,eAAe,EAGf,YAAY,EACZ,mBAAmB,EACnB,gBAAgB,EAChB,cAAc,EAEf,MAAM,2BAA2B,CAAA;AAElC,OAAO,EAAE,UAAU,EAAc,MAAM,0BAA0B,CAAA;AACjE,OAAO,EAEL,sBAAsB,EAGtB,UAAU,EAEV,mBAAmB,EACnB,UAAU,EAEX,MAAM,yBAAyB,CAAA;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAGnD,eAAO,MAAM,oBAAoB,gCAA0C,CAAA;AAC3E,MAAM,MAAM,oBAAoB,GAAG,OAAO,oBAAoB,CAAA;AAE9D,MAAM,MAAM,cAAc,GAAG,UAAU,CACrC;IACE,GAAG,EAAE,gBAAgB,EAAE,CAAA;IACvB,MAAM,EAAE,gBAAgB,CAAA;CACzB,EACD,oBAAoB,CACrB,CAAA;AAED,MAAM,MAAM,cAAc,GAAG,UAAU,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC,CAAA;AAExE,qBAAa,QAAQ,CAAC,OAAO,SAAS,cAAc,GAAG,cAAc,EAAE,UAAU,SAAS,mBAAmB,GAAG,mBAAmB,CACjI,SAAQ,UAAU,CAAC,OAAO,EAAE,UAAU,CACtC,YAAW,sBAAsB;IAEjC,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAiD;IACjG,gBAAyB,mBAAmB,EAAE,MAAM,CAAuB;IAC3E,gBAAyB,MAAM;;MAAmC;IAElE,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,MAAM,CAAQ;IACtB,OAAO,CAAC,gBAAgB,CAA2C;IAEnE,IAAI,GAAG,aAEN;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAI/B;IAED,IAAI,MAAM,WAET;IAEK,KAAK;
|
|
1
|
+
{"version":3,"file":"ViewNode.d.ts","sourceRoot":"","sources":["../../src/ViewNode.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC,OAAO,EACL,eAAe,EAGf,YAAY,EACZ,mBAAmB,EACnB,gBAAgB,EAChB,cAAc,EAEf,MAAM,2BAA2B,CAAA;AAElC,OAAO,EAAE,UAAU,EAAc,MAAM,0BAA0B,CAAA;AACjE,OAAO,EAEL,sBAAsB,EAGtB,UAAU,EAEV,mBAAmB,EACnB,UAAU,EAEX,MAAM,yBAAyB,CAAA;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAGnD,eAAO,MAAM,oBAAoB,gCAA0C,CAAA;AAC3E,MAAM,MAAM,oBAAoB,GAAG,OAAO,oBAAoB,CAAA;AAE9D,MAAM,MAAM,cAAc,GAAG,UAAU,CACrC;IACE,GAAG,EAAE,gBAAgB,EAAE,CAAA;IACvB,MAAM,EAAE,gBAAgB,CAAA;CACzB,EACD,oBAAoB,CACrB,CAAA;AAED,MAAM,MAAM,cAAc,GAAG,UAAU,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC,CAAA;AAExE,qBAAa,QAAQ,CAAC,OAAO,SAAS,cAAc,GAAG,cAAc,EAAE,UAAU,SAAS,mBAAmB,GAAG,mBAAmB,CACjI,SAAQ,UAAU,CAAC,OAAO,EAAE,UAAU,CACtC,YAAW,sBAAsB;IAEjC,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAiD;IACjG,gBAAyB,mBAAmB,EAAE,MAAM,CAAuB;IAC3E,gBAAyB,MAAM;;MAAmC;IAElE,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,MAAM,CAAQ;IACtB,OAAO,CAAC,gBAAgB,CAA2C;IAEnE,IAAI,GAAG,aAEN;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAI/B;IAED,IAAI,MAAM,WAET;IAEK,KAAK;IAeI,OAAO,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;IACpC,OAAO,CAAC,CAAC,SAAS,cAAc,GAAG,cAAc,EAAE,GAAG,EAAE,GAAG,EAAE,OAAO,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAC5G,OAAO,CAAC,CAAC,SAAS,cAAc,GAAG,cAAc,EAAE,MAAM,EAAE,YAAY,EAAE,OAAO,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IACxH,OAAO,CAAC,CAAC,SAAS,cAAc,GAAG,cAAc,EAAE,EAAE,EAAE,gBAAgB,EAAE,OAAO,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAAC;cA4BxH,kBAAkB,CAAC,OAAO,EAAE,OAAO;cAgCnC,qBAAqB,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;cAIlD,kBAAkB,CAAC,OAAO,EAAE,OAAO;cAQnC,YAAY,IAAI,OAAO,CAAC,OAAO,CAAC;CAK1D"}
|
package/dist/node/index.cjs
CHANGED
|
@@ -1,155 +1,2 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
-
var __reflectGet = Reflect.get;
|
|
8
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
9
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
10
|
-
var __export = (target, all) => {
|
|
11
|
-
for (var name in all)
|
|
12
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
13
|
-
};
|
|
14
|
-
var __copyProps = (to, from, except, desc) => {
|
|
15
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
16
|
-
for (let key of __getOwnPropNames(from))
|
|
17
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
18
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
19
|
-
}
|
|
20
|
-
return to;
|
|
21
|
-
};
|
|
22
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
23
|
-
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
24
|
-
var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
|
|
25
|
-
|
|
26
|
-
// src/index.ts
|
|
27
|
-
var src_exports = {};
|
|
28
|
-
__export(src_exports, {
|
|
29
|
-
ViewNode: () => ViewNode,
|
|
30
|
-
ViewNodeConfigSchema: () => ViewNodeConfigSchema
|
|
31
|
-
});
|
|
32
|
-
module.exports = __toCommonJS(src_exports);
|
|
33
|
-
|
|
34
|
-
// src/ViewNode.ts
|
|
35
|
-
var import_assert = require("@xylabs/assert");
|
|
36
|
-
var import_exists = require("@xylabs/exists");
|
|
37
|
-
var import_module_model = require("@xyo-network/module-model");
|
|
38
|
-
var import_module_resolver = require("@xyo-network/module-resolver");
|
|
39
|
-
var import_node_memory = require("@xyo-network/node-memory");
|
|
40
|
-
var import_node_model = require("@xyo-network/node-model");
|
|
41
|
-
var import_async_mutex = require("async-mutex");
|
|
42
|
-
var ViewNodeConfigSchema = "network.xyo.node.view.config";
|
|
43
|
-
var _ViewNode = class _ViewNode extends import_node_memory.MemoryNode {
|
|
44
|
-
_buildMutex = new import_async_mutex.Mutex();
|
|
45
|
-
_built = false;
|
|
46
|
-
_limitedResolver = new import_module_resolver.SimpleModuleResolver({
|
|
47
|
-
root: this
|
|
48
|
-
});
|
|
49
|
-
get ids() {
|
|
50
|
-
return this.config.ids;
|
|
51
|
-
}
|
|
52
|
-
get queries() {
|
|
53
|
-
const disallowedQueries = /* @__PURE__ */ new Set([
|
|
54
|
-
import_node_model.NodeAttachQuerySchema,
|
|
55
|
-
import_node_model.NodeDetachQuerySchema,
|
|
56
|
-
import_node_model.NodeRegisteredQuerySchema
|
|
57
|
-
]);
|
|
58
|
-
const queries = [
|
|
59
|
-
...super.queries
|
|
60
|
-
];
|
|
61
|
-
return queries.filter((query) => !disallowedQueries.has(query));
|
|
62
|
-
}
|
|
63
|
-
get source() {
|
|
64
|
-
return this.config.source;
|
|
65
|
-
}
|
|
66
|
-
async build() {
|
|
67
|
-
return await this._buildMutex.runExclusive(async () => {
|
|
68
|
-
const source = (0, import_node_model.asNodeInstance)(await super.resolve(this.source));
|
|
69
|
-
if (source) {
|
|
70
|
-
await Promise.all(this.ids.map(async (id) => {
|
|
71
|
-
await import_node_memory.NodeHelper.attachToExistingNode(source, id, this);
|
|
72
|
-
}));
|
|
73
|
-
this._built = true;
|
|
74
|
-
}
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
async resolve(idOrFilter = "*", options = {}) {
|
|
78
|
-
if (!this._built) {
|
|
79
|
-
await this.build();
|
|
80
|
-
}
|
|
81
|
-
const mods = await this._limitedResolver.resolve("*");
|
|
82
|
-
if (idOrFilter === "*") {
|
|
83
|
-
return mods;
|
|
84
|
-
}
|
|
85
|
-
switch (typeof idOrFilter) {
|
|
86
|
-
case "string": {
|
|
87
|
-
const mod = mods.find((mod2) => mod2.modName === idOrFilter || mod2.address === idOrFilter);
|
|
88
|
-
return mod;
|
|
89
|
-
}
|
|
90
|
-
case "object": {
|
|
91
|
-
if ((0, import_module_model.isAddressModuleFilter)(idOrFilter)) {
|
|
92
|
-
return (await Promise.all(idOrFilter.address.map(async (address) => await this.resolve(address, options)))).filter(import_exists.exists);
|
|
93
|
-
} else if ((0, import_module_model.isNameModuleFilter)(idOrFilter)) {
|
|
94
|
-
return (await Promise.all(idOrFilter.name.map(async (name) => await this.resolve(name, options)))).filter(import_exists.exists);
|
|
95
|
-
}
|
|
96
|
-
return [];
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
async attachUsingAddress(address) {
|
|
101
|
-
const attached = await this.attached();
|
|
102
|
-
const mods = this.registeredModules().filter((mod) => attached.includes(mod.address));
|
|
103
|
-
const existingModule = mods.find((mod) => mod.address === address);
|
|
104
|
-
(0, import_assert.assertEx)(!existingModule, () => `Module [${(existingModule == null ? void 0 : existingModule.modName) ?? (existingModule == null ? void 0 : existingModule.address)}] already attached at address [${address}]`);
|
|
105
|
-
const module2 = this.registeredModuleMap[address];
|
|
106
|
-
if (!module2) {
|
|
107
|
-
return;
|
|
108
|
-
}
|
|
109
|
-
module2.addParent(this);
|
|
110
|
-
const args = {
|
|
111
|
-
module: module2,
|
|
112
|
-
name: module2.modName
|
|
113
|
-
};
|
|
114
|
-
await this.emit("moduleAttached", args);
|
|
115
|
-
this._limitedResolver.add(module2);
|
|
116
|
-
if ((0, import_node_model.isNodeModule)(module2)) {
|
|
117
|
-
const attachedListener = /* @__PURE__ */ __name(async (args2) => await this.emit("moduleAttached", args2), "attachedListener");
|
|
118
|
-
const detachedListener = /* @__PURE__ */ __name(async (args2) => await this.emit("moduleDetached", args2), "detachedListener");
|
|
119
|
-
module2.on("moduleAttached", attachedListener);
|
|
120
|
-
module2.on("moduleDetached", detachedListener);
|
|
121
|
-
}
|
|
122
|
-
return address;
|
|
123
|
-
}
|
|
124
|
-
async attachedPublicModules() {
|
|
125
|
-
return (await this._limitedResolver.resolve("*")).filter((module2) => module2.address !== this.address);
|
|
126
|
-
}
|
|
127
|
-
async detachUsingAddress(address) {
|
|
128
|
-
const module2 = await this.downResolver.resolve(address);
|
|
129
|
-
if (module2) {
|
|
130
|
-
this._limitedResolver.remove(address);
|
|
131
|
-
return address;
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
async startHandler() {
|
|
135
|
-
await super.startHandler();
|
|
136
|
-
await this.build();
|
|
137
|
-
return true;
|
|
138
|
-
}
|
|
139
|
-
};
|
|
140
|
-
__name(_ViewNode, "ViewNode");
|
|
141
|
-
__publicField(_ViewNode, "configSchemas", [
|
|
142
|
-
...__superGet(_ViewNode, _ViewNode, "configSchemas"),
|
|
143
|
-
ViewNodeConfigSchema
|
|
144
|
-
]);
|
|
145
|
-
__publicField(_ViewNode, "defaultConfigSchema", ViewNodeConfigSchema);
|
|
146
|
-
__publicField(_ViewNode, "labels", {
|
|
147
|
-
...import_module_model.ModuleLimitationViewLabel
|
|
148
|
-
});
|
|
149
|
-
var ViewNode = _ViewNode;
|
|
150
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
151
|
-
0 && (module.exports = {
|
|
152
|
-
ViewNode,
|
|
153
|
-
ViewNodeConfigSchema
|
|
154
|
-
});
|
|
1
|
+
"use strict";var l=Object.defineProperty;var R=Object.getOwnPropertyDescriptor;var A=Object.getOwnPropertyNames;var N=Object.getPrototypeOf,P=Object.prototype.hasOwnProperty;var q=Reflect.get;var L=(a,e,t)=>e in a?l(a,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):a[e]=t;var u=(a,e)=>l(a,"name",{value:e,configurable:!0});var Q=(a,e)=>{for(var t in e)l(a,t,{get:e[t],enumerable:!0})},_=(a,e,t,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of A(e))!P.call(a,s)&&s!==t&&l(a,s,{get:()=>e[s],enumerable:!(o=R(e,s))||o.enumerable});return a};var D=a=>_(l({},"__esModule",{value:!0}),a);var m=(a,e,t)=>L(a,typeof e!="symbol"?e+"":e,t);var v=(a,e,t)=>q(N(a),t,e);var E={};Q(E,{ViewNode:()=>y,ViewNodeConfigSchema:()=>p});module.exports=D(E);var g=require("@xylabs/assert"),w=require("@xylabs/exists"),c=require("@xyo-network/module-model"),b=require("@xyo-network/module-resolver"),h=require("@xyo-network/node-memory"),r=require("@xyo-network/node-model"),M=require("async-mutex");var p="network.xyo.node.view.config",d=class d extends h.MemoryNode{_buildMutex=new M.Mutex;_built=!1;_limitedResolver=new b.SimpleModuleResolver({root:this});get ids(){return this.config.ids}get queries(){let e=new Set([r.NodeAttachQuerySchema,r.NodeDetachQuerySchema,r.NodeRegisteredQuerySchema]);return[...super.queries].filter(o=>!e.has(o))}get source(){return this.config.source}async build(){return await this._buildMutex.runExclusive(async()=>{let e=(0,r.asNodeInstance)(await super.resolve(this.source));e&&(await Promise.all(this.ids.map(async t=>{await h.NodeHelper.attachToExistingNode(e,t,this)})),this._built=!0)})}async resolve(e="*",t={}){this._built||await this.build();let o=await this._limitedResolver.resolve("*");if(e==="*")return o;switch(typeof e){case"string":return o.find(i=>i.modName===e||i.address===e);case"object":return(0,c.isAddressModuleFilter)(e)?(await Promise.all(e.address.map(async s=>await this.resolve(s,t)))).filter(w.exists):(0,c.isNameModuleFilter)(e)?(await Promise.all(e.name.map(async s=>await this.resolve(s,t)))).filter(w.exists):[]}}async attachUsingAddress(e){let t=await this.attached(),s=this.registeredModules().filter(n=>t.includes(n.address)).find(n=>n.address===e);(0,g.assertEx)(!s,()=>`Module [${(s==null?void 0:s.modName)??(s==null?void 0:s.address)}] already attached at address [${e}]`);let i=this.registeredModuleMap[e];if(!i)return;i.addParent(this);let x={module:i,name:i.modName};if(await this.emit("moduleAttached",x),this._limitedResolver.add(i),(0,r.isNodeModule)(i)){let n=u(async f=>await this.emit("moduleAttached",f),"attachedListener"),S=u(async f=>await this.emit("moduleDetached",f),"detachedListener");i.on("moduleAttached",n),i.on("moduleDetached",S)}return e}async attachedPublicModules(){return(await this._limitedResolver.resolve("*")).filter(e=>e.address!==this.address)}async detachUsingAddress(e){if(await this.downResolver.resolve(e))return this._limitedResolver.remove(e),e}async startHandler(){return await super.startHandler(),await this.build(),!0}};u(d,"ViewNode"),m(d,"configSchemas",[...v(d,d,"configSchemas"),p]),m(d,"defaultConfigSchema",p),m(d,"labels",{...c.ModuleLimitationViewLabel});var y=d;0&&(module.exports={ViewNode,ViewNodeConfigSchema});
|
|
155
2
|
//# sourceMappingURL=index.cjs.map
|