@xyo-network/bridge-worker 2.102.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +165 -0
- package/README.md +13 -0
- package/dist/browser/WorkerBridge.d.cts +63 -0
- package/dist/browser/WorkerBridge.d.cts.map +1 -0
- package/dist/browser/WorkerBridge.d.mts +63 -0
- package/dist/browser/WorkerBridge.d.mts.map +1 -0
- package/dist/browser/WorkerBridge.d.ts +63 -0
- package/dist/browser/WorkerBridge.d.ts.map +1 -0
- package/dist/browser/WorkerBridgeConfig.d.cts +6 -0
- package/dist/browser/WorkerBridgeConfig.d.cts.map +1 -0
- package/dist/browser/WorkerBridgeConfig.d.mts +6 -0
- package/dist/browser/WorkerBridgeConfig.d.mts.map +1 -0
- package/dist/browser/WorkerBridgeConfig.d.ts +6 -0
- package/dist/browser/WorkerBridgeConfig.d.ts.map +1 -0
- package/dist/browser/defaultNodeManifest.d.cts +3 -0
- package/dist/browser/defaultNodeManifest.d.cts.map +1 -0
- package/dist/browser/defaultNodeManifest.d.mts +3 -0
- package/dist/browser/defaultNodeManifest.d.mts.map +1 -0
- package/dist/browser/defaultNodeManifest.d.ts +3 -0
- package/dist/browser/defaultNodeManifest.d.ts.map +1 -0
- package/dist/browser/docsEntry.d.cts +4 -0
- package/dist/browser/docsEntry.d.cts.map +1 -0
- package/dist/browser/docsEntry.d.mts +4 -0
- package/dist/browser/docsEntry.d.mts.map +1 -0
- package/dist/browser/docsEntry.d.ts +4 -0
- package/dist/browser/docsEntry.d.ts.map +1 -0
- package/dist/browser/index.cjs +261 -0
- package/dist/browser/index.cjs.map +1 -0
- package/dist/browser/index.d.cts +5 -0
- package/dist/browser/index.d.cts.map +1 -0
- package/dist/browser/index.d.mts +5 -0
- package/dist/browser/index.d.mts.map +1 -0
- package/dist/browser/index.d.ts +5 -0
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/browser/index.js +239 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/browser/worker/Worker.d.cts +2 -0
- package/dist/browser/worker/Worker.d.cts.map +1 -0
- package/dist/browser/worker/Worker.d.mts +2 -0
- package/dist/browser/worker/Worker.d.mts.map +1 -0
- package/dist/browser/worker/Worker.d.ts +2 -0
- package/dist/browser/worker/Worker.d.ts.map +1 -0
- package/dist/browser/worker/WorkerNodeHost.d.cts +22 -0
- package/dist/browser/worker/WorkerNodeHost.d.cts.map +1 -0
- package/dist/browser/worker/WorkerNodeHost.d.mts +22 -0
- package/dist/browser/worker/WorkerNodeHost.d.mts.map +1 -0
- package/dist/browser/worker/WorkerNodeHost.d.ts +22 -0
- package/dist/browser/worker/WorkerNodeHost.d.ts.map +1 -0
- package/dist/browser/worker/index.d.cts +2 -0
- package/dist/browser/worker/index.d.cts.map +1 -0
- package/dist/browser/worker/index.d.mts +2 -0
- package/dist/browser/worker/index.d.mts.map +1 -0
- package/dist/browser/worker/index.d.ts +2 -0
- package/dist/browser/worker/index.d.ts.map +1 -0
- package/dist/neutral/WorkerBridge.d.cts +63 -0
- package/dist/neutral/WorkerBridge.d.cts.map +1 -0
- package/dist/neutral/WorkerBridge.d.mts +63 -0
- package/dist/neutral/WorkerBridge.d.mts.map +1 -0
- package/dist/neutral/WorkerBridge.d.ts +63 -0
- package/dist/neutral/WorkerBridge.d.ts.map +1 -0
- package/dist/neutral/WorkerBridgeConfig.d.cts +6 -0
- package/dist/neutral/WorkerBridgeConfig.d.cts.map +1 -0
- package/dist/neutral/WorkerBridgeConfig.d.mts +6 -0
- package/dist/neutral/WorkerBridgeConfig.d.mts.map +1 -0
- package/dist/neutral/WorkerBridgeConfig.d.ts +6 -0
- package/dist/neutral/WorkerBridgeConfig.d.ts.map +1 -0
- package/dist/neutral/defaultNodeManifest.d.cts +3 -0
- package/dist/neutral/defaultNodeManifest.d.cts.map +1 -0
- package/dist/neutral/defaultNodeManifest.d.mts +3 -0
- package/dist/neutral/defaultNodeManifest.d.mts.map +1 -0
- package/dist/neutral/defaultNodeManifest.d.ts +3 -0
- package/dist/neutral/defaultNodeManifest.d.ts.map +1 -0
- package/dist/neutral/docsEntry.d.cts +4 -0
- package/dist/neutral/docsEntry.d.cts.map +1 -0
- package/dist/neutral/docsEntry.d.mts +4 -0
- package/dist/neutral/docsEntry.d.mts.map +1 -0
- package/dist/neutral/docsEntry.d.ts +4 -0
- package/dist/neutral/docsEntry.d.ts.map +1 -0
- package/dist/neutral/index.cjs +261 -0
- package/dist/neutral/index.cjs.map +1 -0
- package/dist/neutral/index.d.cts +5 -0
- package/dist/neutral/index.d.cts.map +1 -0
- package/dist/neutral/index.d.mts +5 -0
- package/dist/neutral/index.d.mts.map +1 -0
- package/dist/neutral/index.d.ts +5 -0
- package/dist/neutral/index.d.ts.map +1 -0
- package/dist/neutral/index.js +239 -0
- package/dist/neutral/index.js.map +1 -0
- package/dist/neutral/worker/Worker.d.cts +2 -0
- package/dist/neutral/worker/Worker.d.cts.map +1 -0
- package/dist/neutral/worker/Worker.d.mts +2 -0
- package/dist/neutral/worker/Worker.d.mts.map +1 -0
- package/dist/neutral/worker/Worker.d.ts +2 -0
- package/dist/neutral/worker/Worker.d.ts.map +1 -0
- package/dist/neutral/worker/WorkerNodeHost.d.cts +22 -0
- package/dist/neutral/worker/WorkerNodeHost.d.cts.map +1 -0
- package/dist/neutral/worker/WorkerNodeHost.d.mts +22 -0
- package/dist/neutral/worker/WorkerNodeHost.d.mts.map +1 -0
- package/dist/neutral/worker/WorkerNodeHost.d.ts +22 -0
- package/dist/neutral/worker/WorkerNodeHost.d.ts.map +1 -0
- package/dist/neutral/worker/index.d.cts +2 -0
- package/dist/neutral/worker/index.d.cts.map +1 -0
- package/dist/neutral/worker/index.d.mts +2 -0
- package/dist/neutral/worker/index.d.mts.map +1 -0
- package/dist/neutral/worker/index.d.ts +2 -0
- package/dist/neutral/worker/index.d.ts.map +1 -0
- package/dist/node/WorkerBridge.d.cts +63 -0
- package/dist/node/WorkerBridge.d.cts.map +1 -0
- package/dist/node/WorkerBridge.d.mts +63 -0
- package/dist/node/WorkerBridge.d.mts.map +1 -0
- package/dist/node/WorkerBridge.d.ts +63 -0
- package/dist/node/WorkerBridge.d.ts.map +1 -0
- package/dist/node/WorkerBridgeConfig.d.cts +6 -0
- package/dist/node/WorkerBridgeConfig.d.cts.map +1 -0
- package/dist/node/WorkerBridgeConfig.d.mts +6 -0
- package/dist/node/WorkerBridgeConfig.d.mts.map +1 -0
- package/dist/node/WorkerBridgeConfig.d.ts +6 -0
- package/dist/node/WorkerBridgeConfig.d.ts.map +1 -0
- package/dist/node/defaultNodeManifest.d.cts +3 -0
- package/dist/node/defaultNodeManifest.d.cts.map +1 -0
- package/dist/node/defaultNodeManifest.d.mts +3 -0
- package/dist/node/defaultNodeManifest.d.mts.map +1 -0
- package/dist/node/defaultNodeManifest.d.ts +3 -0
- package/dist/node/defaultNodeManifest.d.ts.map +1 -0
- package/dist/node/docsEntry.d.cts +4 -0
- package/dist/node/docsEntry.d.cts.map +1 -0
- package/dist/node/docsEntry.d.mts +4 -0
- package/dist/node/docsEntry.d.mts.map +1 -0
- package/dist/node/docsEntry.d.ts +4 -0
- package/dist/node/docsEntry.d.ts.map +1 -0
- package/dist/node/index.cjs +275 -0
- package/dist/node/index.cjs.map +1 -0
- package/dist/node/index.d.cts +5 -0
- package/dist/node/index.d.cts.map +1 -0
- package/dist/node/index.d.mts +5 -0
- package/dist/node/index.d.mts.map +1 -0
- package/dist/node/index.d.ts +5 -0
- package/dist/node/index.d.ts.map +1 -0
- package/dist/node/index.js +247 -0
- package/dist/node/index.js.map +1 -0
- package/dist/node/worker/Worker.d.cts +2 -0
- package/dist/node/worker/Worker.d.cts.map +1 -0
- package/dist/node/worker/Worker.d.mts +2 -0
- package/dist/node/worker/Worker.d.mts.map +1 -0
- package/dist/node/worker/Worker.d.ts +2 -0
- package/dist/node/worker/Worker.d.ts.map +1 -0
- package/dist/node/worker/WorkerNodeHost.d.cts +22 -0
- package/dist/node/worker/WorkerNodeHost.d.cts.map +1 -0
- package/dist/node/worker/WorkerNodeHost.d.mts +22 -0
- package/dist/node/worker/WorkerNodeHost.d.mts.map +1 -0
- package/dist/node/worker/WorkerNodeHost.d.ts +22 -0
- package/dist/node/worker/WorkerNodeHost.d.ts.map +1 -0
- package/dist/node/worker/index.d.cts +2 -0
- package/dist/node/worker/index.d.cts.map +1 -0
- package/dist/node/worker/index.d.mts +2 -0
- package/dist/node/worker/index.d.mts.map +1 -0
- package/dist/node/worker/index.d.ts +2 -0
- package/dist/node/worker/index.d.ts.map +1 -0
- package/package.json +70 -0
- package/src/WorkerBridge.ts +119 -0
- package/src/WorkerBridgeConfig.ts +7 -0
- package/src/defaultNodeManifest.ts +40 -0
- package/src/docsEntry.ts +4 -0
- package/src/index.ts +4 -0
- package/src/worker/Worker.ts +3 -0
- package/src/worker/WorkerNodeHost.ts +90 -0
- package/src/worker/index.ts +1 -0
- package/typedoc.json +5 -0
|
@@ -0,0 +1,247 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
3
|
+
var __reflectGet = Reflect.get;
|
|
4
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
5
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
|
+
var __publicField = (obj, key, value) => {
|
|
7
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
8
|
+
return value;
|
|
9
|
+
};
|
|
10
|
+
var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
|
|
11
|
+
|
|
12
|
+
// src/defaultNodeManifest.ts
|
|
13
|
+
import { ArchivistConfigSchema } from "@xyo-network/archivist-model";
|
|
14
|
+
import { PackageManifestPayloadSchema } from "@xyo-network/manifest-model";
|
|
15
|
+
import { NodeConfigSchema } from "@xyo-network/node-model";
|
|
16
|
+
import { SentinelConfigSchema } from "@xyo-network/sentinel-model";
|
|
17
|
+
var defaultPackageManifest = {
|
|
18
|
+
nodes: [
|
|
19
|
+
{
|
|
20
|
+
config: {
|
|
21
|
+
name: "SimpleMemoryDapp",
|
|
22
|
+
schema: NodeConfigSchema
|
|
23
|
+
},
|
|
24
|
+
modules: {
|
|
25
|
+
private: [
|
|
26
|
+
{
|
|
27
|
+
config: {
|
|
28
|
+
name: "ScratchArchivist",
|
|
29
|
+
schema: ArchivistConfigSchema
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
],
|
|
33
|
+
public: [
|
|
34
|
+
{
|
|
35
|
+
config: {
|
|
36
|
+
name: "SimpleArchivist",
|
|
37
|
+
schema: ArchivistConfigSchema
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
config: {
|
|
42
|
+
name: "SimpleSentinel",
|
|
43
|
+
schema: SentinelConfigSchema
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
]
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
],
|
|
50
|
+
schema: PackageManifestPayloadSchema
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
// src/worker/WorkerNodeHost.ts
|
|
54
|
+
import { generateMnemonic } from "@scure/bip39";
|
|
55
|
+
import { wordlist } from "@scure/bip39/wordlists/english";
|
|
56
|
+
import { forget } from "@xylabs/forget";
|
|
57
|
+
import { HDWallet } from "@xyo-network/account";
|
|
58
|
+
import { ManifestWrapper } from "@xyo-network/manifest";
|
|
59
|
+
var _WorkerNodeHost = class _WorkerNodeHost {
|
|
60
|
+
node;
|
|
61
|
+
logger;
|
|
62
|
+
constructor(node, logger) {
|
|
63
|
+
this.node = node;
|
|
64
|
+
this.logger = logger;
|
|
65
|
+
}
|
|
66
|
+
static async create(config) {
|
|
67
|
+
const mnemonic = generateMnemonic(wordlist, 256);
|
|
68
|
+
const manifest = new ManifestWrapper(config, await HDWallet.fromPhrase(mnemonic));
|
|
69
|
+
const [node] = await manifest.loadNodes();
|
|
70
|
+
const worker = new this(node);
|
|
71
|
+
worker.attachNode(node);
|
|
72
|
+
return worker;
|
|
73
|
+
}
|
|
74
|
+
static start(logger) {
|
|
75
|
+
const listener = /* @__PURE__ */ __name(async (event) => {
|
|
76
|
+
switch (event.data.type) {
|
|
77
|
+
case "createNode": {
|
|
78
|
+
const message = event.data;
|
|
79
|
+
const worker = await this.create(message.manifest);
|
|
80
|
+
logger == null ? void 0 : logger.log(`createNode: ${worker.node.address}`);
|
|
81
|
+
const response = {
|
|
82
|
+
address: worker.node.address,
|
|
83
|
+
type: "nodeCreated"
|
|
84
|
+
};
|
|
85
|
+
postMessage(response);
|
|
86
|
+
break;
|
|
87
|
+
}
|
|
88
|
+
default: {
|
|
89
|
+
const message = event.data;
|
|
90
|
+
logger == null ? void 0 : logger.debug(`Unknown Event (Static) [${JSON.stringify(event)}]: ${JSON.stringify(message, null, 2)}`);
|
|
91
|
+
break;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}, "listener");
|
|
95
|
+
self.addEventListener("message", (event) => {
|
|
96
|
+
forget(listener(event));
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
attachNode(node) {
|
|
100
|
+
const listener = /* @__PURE__ */ __name(async (event) => {
|
|
101
|
+
var _a;
|
|
102
|
+
const message = event.data;
|
|
103
|
+
switch (message.type) {
|
|
104
|
+
case "xyoQuery": {
|
|
105
|
+
const message2 = event.data;
|
|
106
|
+
const { address, msgId, query, payloads } = message2;
|
|
107
|
+
const module = address ? await node.resolve(address, {
|
|
108
|
+
direction: "down"
|
|
109
|
+
}) : node;
|
|
110
|
+
if (module) {
|
|
111
|
+
const result = {
|
|
112
|
+
address,
|
|
113
|
+
msgId,
|
|
114
|
+
result: await module.query(query, payloads)
|
|
115
|
+
};
|
|
116
|
+
self.postMessage(result);
|
|
117
|
+
}
|
|
118
|
+
break;
|
|
119
|
+
}
|
|
120
|
+
default: {
|
|
121
|
+
const message2 = event.data;
|
|
122
|
+
(_a = this.logger) == null ? void 0 : _a.debug(`Unknown Event [${JSON.stringify(event)}]: ${JSON.stringify(message2, null, 2)}`);
|
|
123
|
+
break;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}, "listener");
|
|
127
|
+
self.addEventListener("message", (event) => {
|
|
128
|
+
forget(listener(event));
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
};
|
|
132
|
+
__name(_WorkerNodeHost, "WorkerNodeHost");
|
|
133
|
+
var WorkerNodeHost = _WorkerNodeHost;
|
|
134
|
+
|
|
135
|
+
// src/WorkerBridge.ts
|
|
136
|
+
import { assertEx } from "@xylabs/assert";
|
|
137
|
+
import { AbstractBridge } from "@xyo-network/abstract-bridge";
|
|
138
|
+
import { creatableModule } from "@xyo-network/module-model";
|
|
139
|
+
import { LRUCache } from "lru-cache";
|
|
140
|
+
|
|
141
|
+
// src/WorkerBridgeConfig.ts
|
|
142
|
+
var WorkerBridgeConfigSchema = "network.xyo.bridge.worker.config";
|
|
143
|
+
|
|
144
|
+
// src/WorkerBridge.ts
|
|
145
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
146
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
147
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
|
|
148
|
+
r = Reflect.decorate(decorators, target, key, desc);
|
|
149
|
+
else
|
|
150
|
+
for (var i = decorators.length - 1; i >= 0; i--)
|
|
151
|
+
if (d = decorators[i])
|
|
152
|
+
r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
153
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
154
|
+
}
|
|
155
|
+
__name(_ts_decorate, "_ts_decorate");
|
|
156
|
+
var _WorkerBridge = class _WorkerBridge extends AbstractBridge {
|
|
157
|
+
_discoverCache;
|
|
158
|
+
_targetConfigs = {};
|
|
159
|
+
_targetQueries = {};
|
|
160
|
+
get discoverCache() {
|
|
161
|
+
const config = this.discoverCacheConfig;
|
|
162
|
+
this._discoverCache = this._discoverCache ?? new LRUCache({
|
|
163
|
+
ttlAutopurge: true,
|
|
164
|
+
...config
|
|
165
|
+
});
|
|
166
|
+
return this._discoverCache;
|
|
167
|
+
}
|
|
168
|
+
get discoverCacheConfig() {
|
|
169
|
+
const discoverCacheConfig = {};
|
|
170
|
+
return {
|
|
171
|
+
max: 100,
|
|
172
|
+
ttl: 1e3 * 60 * 5,
|
|
173
|
+
...discoverCacheConfig
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
get worker() {
|
|
177
|
+
return assertEx(this.params.worker);
|
|
178
|
+
}
|
|
179
|
+
static async createWorkerNode(manifest = defaultPackageManifest) {
|
|
180
|
+
var _a;
|
|
181
|
+
const worker = new Worker(new URL("worker/Worker.ts", ((_a = import.meta) == null ? void 0 : _a.url) ?? __filename));
|
|
182
|
+
worker.postMessage({
|
|
183
|
+
manifest,
|
|
184
|
+
type: "createNode"
|
|
185
|
+
});
|
|
186
|
+
await new Promise((resolve, reject) => {
|
|
187
|
+
const eventFunc = /* @__PURE__ */ __name((event) => {
|
|
188
|
+
const timeout = setTimeout(() => {
|
|
189
|
+
console.log("Node creation timeout");
|
|
190
|
+
worker.removeEventListener("message", eventFunc);
|
|
191
|
+
reject("Timeout");
|
|
192
|
+
}, 1e3);
|
|
193
|
+
switch (event.data.type) {
|
|
194
|
+
case "nodeCreated": {
|
|
195
|
+
clearTimeout(timeout);
|
|
196
|
+
worker.removeEventListener("message", eventFunc);
|
|
197
|
+
resolve(true);
|
|
198
|
+
break;
|
|
199
|
+
}
|
|
200
|
+
default: {
|
|
201
|
+
const message = event.data;
|
|
202
|
+
console.log(`Unknown Event (nodeCreated listener) [${JSON.stringify(event)}]: ${JSON.stringify(message, null, 2)}`);
|
|
203
|
+
break;
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}, "eventFunc");
|
|
207
|
+
worker.addEventListener("message", eventFunc);
|
|
208
|
+
});
|
|
209
|
+
const bridge = await _WorkerBridge.create({
|
|
210
|
+
config: {
|
|
211
|
+
schema: WorkerBridgeConfigSchema
|
|
212
|
+
},
|
|
213
|
+
worker
|
|
214
|
+
});
|
|
215
|
+
await bridge.start();
|
|
216
|
+
return bridge;
|
|
217
|
+
}
|
|
218
|
+
exposeHandler(_id, _options) {
|
|
219
|
+
return [];
|
|
220
|
+
}
|
|
221
|
+
exposedHandler() {
|
|
222
|
+
return [];
|
|
223
|
+
}
|
|
224
|
+
getRoots(_force) {
|
|
225
|
+
return Promise.resolve([]);
|
|
226
|
+
}
|
|
227
|
+
unexposeHandler(_id, _options) {
|
|
228
|
+
return [];
|
|
229
|
+
}
|
|
230
|
+
};
|
|
231
|
+
__name(_WorkerBridge, "WorkerBridge");
|
|
232
|
+
__publicField(_WorkerBridge, "configSchemas", [
|
|
233
|
+
...__superGet(_WorkerBridge, _WorkerBridge, "configSchemas"),
|
|
234
|
+
WorkerBridgeConfigSchema
|
|
235
|
+
]);
|
|
236
|
+
__publicField(_WorkerBridge, "defaultConfigSchema", WorkerBridgeConfigSchema);
|
|
237
|
+
var WorkerBridge = _WorkerBridge;
|
|
238
|
+
WorkerBridge = _ts_decorate([
|
|
239
|
+
creatableModule()
|
|
240
|
+
], WorkerBridge);
|
|
241
|
+
export {
|
|
242
|
+
WorkerBridge,
|
|
243
|
+
WorkerBridgeConfigSchema,
|
|
244
|
+
WorkerNodeHost,
|
|
245
|
+
defaultPackageManifest
|
|
246
|
+
};
|
|
247
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/defaultNodeManifest.ts","../../src/worker/WorkerNodeHost.ts","../../src/WorkerBridge.ts","../../src/WorkerBridgeConfig.ts"],"sourcesContent":["import { ArchivistConfigSchema } from '@xyo-network/archivist-model'\nimport { PackageManifestPayload, PackageManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport { NodeConfigSchema } from '@xyo-network/node-model'\nimport { SentinelConfigSchema } from '@xyo-network/sentinel-model'\n\nexport const defaultPackageManifest: PackageManifestPayload = {\n nodes: [\n {\n config: {\n name: 'SimpleMemoryDapp',\n schema: NodeConfigSchema,\n },\n modules: {\n private: [\n {\n config: {\n name: 'ScratchArchivist',\n schema: ArchivistConfigSchema,\n },\n },\n ],\n public: [\n {\n config: {\n name: 'SimpleArchivist',\n schema: ArchivistConfigSchema,\n },\n },\n {\n config: {\n name: 'SimpleSentinel',\n schema: SentinelConfigSchema,\n },\n },\n ],\n },\n },\n ],\n schema: PackageManifestPayloadSchema,\n}\n","import { generateMnemonic } from '@scure/bip39'\n// eslint-disable-next-line import/no-internal-modules\nimport { wordlist } from '@scure/bip39/wordlists/english'\nimport { forget } from '@xylabs/forget'\nimport { Address } from '@xylabs/hex'\nimport { Logger } from '@xylabs/logger'\nimport { HDWallet } from '@xyo-network/account'\nimport { ManifestWrapper, PackageManifestPayload } from '@xyo-network/manifest'\nimport { NodeInstance } from '@xyo-network/node-model'\n\nimport { Message, QueryMessage, QueryResultMessage } from '../WorkerBridge'\n\nexport type QueryEvent = MessageEvent<QueryMessage>\n\nexport interface CreateNodeMessage extends Message<'createNode'> {\n manifest: PackageManifestPayload\n}\n\nexport type CreateNodeEvent = MessageEvent<CreateNodeMessage>\n\nexport interface NodeCreatedMessage extends Message<'nodeCreated'> {\n address: Address\n}\n\nexport class WorkerNodeHost {\n constructor(\n protected node: NodeInstance,\n protected logger?: Logger,\n ) {}\n\n static async create(config: PackageManifestPayload) {\n const mnemonic = generateMnemonic(wordlist, 256)\n const manifest = new ManifestWrapper(config, await HDWallet.fromPhrase(mnemonic))\n const [node] = await manifest.loadNodes()\n const worker = new this(node)\n worker.attachNode(node)\n return worker\n }\n\n static start(logger?: Logger) {\n const listener = async (event: MessageEvent) => {\n switch (event.data.type) {\n case 'createNode': {\n const message: CreateNodeMessage = event.data\n const worker = await this.create(message.manifest)\n logger?.log(`createNode: ${worker.node.address}`)\n const response: NodeCreatedMessage = { address: worker.node.address, type: 'nodeCreated' }\n postMessage(response)\n break\n }\n default: {\n const message: Message = event.data\n logger?.debug(`Unknown Event (Static) [${JSON.stringify(event)}]: ${JSON.stringify(message, null, 2)}`)\n break\n }\n }\n }\n\n self.addEventListener('message', (event: MessageEvent) => {\n forget(listener(event))\n })\n }\n\n private attachNode(node: NodeInstance) {\n const listener = async (event: MessageEvent) => {\n const message = event.data as Message\n switch (message.type) {\n case 'xyoQuery': {\n const message: QueryMessage = event.data\n const { address, msgId, query, payloads } = message\n const module = address ? await node.resolve(address, { direction: 'down' }) : node\n if (module) {\n const result: QueryResultMessage = { address, msgId, result: await module.query(query, payloads) }\n self.postMessage(result)\n }\n break\n }\n default: {\n const message: Message = event.data\n this.logger?.debug(`Unknown Event [${JSON.stringify(event)}]: ${JSON.stringify(message, null, 2)}`)\n break\n }\n }\n }\n\n self.addEventListener('message', (event: MessageEvent) => {\n forget(listener(event))\n })\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Address } from '@xylabs/hex'\nimport { Promisable } from '@xylabs/promise'\nimport { AbstractBridge } from '@xyo-network/abstract-bridge'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { BridgeExposeOptions, BridgeModule, BridgeUnexposeOptions } from '@xyo-network/bridge-model'\nimport { PackageManifestPayload } from '@xyo-network/manifest-model'\nimport {\n AnyConfigSchema,\n CacheConfig,\n creatableModule,\n ModuleConfig,\n ModuleInstance,\n ModuleParams,\n ModuleQueryResult,\n} from '@xyo-network/module-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\nimport { LRUCache } from 'lru-cache'\n\nimport { defaultPackageManifest } from './defaultNodeManifest'\nimport { WorkerBridgeConfig, WorkerBridgeConfigSchema } from './WorkerBridgeConfig'\n\nexport type WorkerBridgeParams<TConfig extends AnyConfigSchema<WorkerBridgeConfig> = AnyConfigSchema<WorkerBridgeConfig>> = ModuleParams<\n TConfig,\n {\n worker?: Worker\n }\n>\n\nexport interface Message<T extends string = string> {\n type: T\n}\n\nexport interface QueryMessage extends Message<'xyoQuery'> {\n address: Address\n msgId?: string\n payloads?: Payload[]\n query: QueryBoundWitness\n}\n\nexport interface QueryResultMessage {\n address: Address\n msgId?: string\n result: ModuleQueryResult\n}\n\n@creatableModule()\nexport class WorkerBridge<TParams extends WorkerBridgeParams = WorkerBridgeParams> extends AbstractBridge<TParams> implements BridgeModule<TParams> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, WorkerBridgeConfigSchema]\n static override readonly defaultConfigSchema: Schema = WorkerBridgeConfigSchema\n\n private _discoverCache?: LRUCache<string, Payload[]>\n private _targetConfigs: Record<string, ModuleConfig> = {}\n private _targetQueries: Record<string, string[]> = {}\n\n get discoverCache() {\n const config = this.discoverCacheConfig\n this._discoverCache = this._discoverCache ?? new LRUCache<string, Payload[]>({ ttlAutopurge: true, ...config })\n return this._discoverCache\n }\n\n get discoverCacheConfig(): LRUCache.Options<string, Payload[], unknown> {\n const discoverCacheConfig: CacheConfig | undefined = {}\n return { max: 100, ttl: 1000 * 60 * 5, ...discoverCacheConfig }\n }\n\n get worker(): Worker {\n return assertEx(this.params.worker)\n }\n\n static async createWorkerNode(manifest: PackageManifestPayload = defaultPackageManifest as PackageManifestPayload) {\n const worker = new Worker(new URL('worker/Worker.ts', import.meta?.url ?? __filename))\n worker.postMessage({ manifest, type: 'createNode' })\n\n await new Promise((resolve, reject) => {\n const eventFunc = (event: MessageEvent) => {\n const timeout = setTimeout(() => {\n console.log('Node creation timeout')\n worker.removeEventListener('message', eventFunc)\n reject('Timeout')\n }, 1000)\n switch (event.data.type) {\n case 'nodeCreated': {\n clearTimeout(timeout)\n worker.removeEventListener('message', eventFunc)\n resolve(true)\n break\n }\n default: {\n const message: Message = event.data\n console.log(`Unknown Event (nodeCreated listener) [${JSON.stringify(event)}]: ${JSON.stringify(message, null, 2)}`)\n break\n }\n }\n }\n worker.addEventListener('message', eventFunc)\n })\n\n const bridge = await WorkerBridge.create({ config: { schema: WorkerBridgeConfigSchema }, worker })\n await bridge.start()\n return bridge\n }\n\n override exposeHandler(_id: string, _options?: BridgeExposeOptions | undefined): Promisable<ModuleInstance[]> {\n return []\n }\n\n override exposedHandler(): Promisable<Address[]> {\n return []\n }\n\n override getRoots(_force?: boolean | undefined): Promise<ModuleInstance[]> {\n return Promise.resolve([])\n }\n\n override unexposeHandler(_id: string, _options?: BridgeUnexposeOptions | undefined): Promisable<ModuleInstance[]> {\n return []\n }\n}\n","import { EmptyObject } from '@xylabs/object'\nimport { BridgeConfig } from '@xyo-network/bridge-model'\n\nexport type WorkerBridgeConfigSchema = 'network.xyo.bridge.worker.config'\nexport const WorkerBridgeConfigSchema: WorkerBridgeConfigSchema = 'network.xyo.bridge.worker.config'\n\nexport type WorkerBridgeConfig<TConfig extends EmptyObject = EmptyObject> = BridgeConfig<TConfig, WorkerBridgeConfigSchema>\n"],"mappings":"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","names":["ArchivistConfigSchema","PackageManifestPayloadSchema","NodeConfigSchema","SentinelConfigSchema","defaultPackageManifest","nodes","config","name","schema","modules","private","public","generateMnemonic","wordlist","forget","HDWallet","ManifestWrapper","WorkerNodeHost","constructor","node","logger","create","config","mnemonic","generateMnemonic","wordlist","manifest","ManifestWrapper","HDWallet","fromPhrase","loadNodes","worker","attachNode","start","listener","event","data","type","message","log","address","response","postMessage","debug","JSON","stringify","self","addEventListener","forget","msgId","query","payloads","module","resolve","direction","result","assertEx","AbstractBridge","creatableModule","LRUCache","WorkerBridgeConfigSchema","WorkerBridge","AbstractBridge","_discoverCache","_targetConfigs","_targetQueries","discoverCache","config","discoverCacheConfig","LRUCache","ttlAutopurge","max","ttl","worker","assertEx","params","createWorkerNode","manifest","defaultPackageManifest","Worker","URL","url","__filename","postMessage","type","Promise","resolve","reject","eventFunc","event","timeout","setTimeout","console","log","removeEventListener","data","clearTimeout","message","JSON","stringify","addEventListener","bridge","create","schema","WorkerBridgeConfigSchema","start","exposeHandler","_id","_options","exposedHandler","getRoots","_force","unexposeHandler","configSchemas","defaultConfigSchema","creatableModule"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Worker.d.ts","sourceRoot":"","sources":["../../../src/worker/Worker.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Worker.d.ts","sourceRoot":"","sources":["../../../src/worker/Worker.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Worker.d.ts","sourceRoot":"","sources":["../../../src/worker/Worker.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Address } from '@xylabs/hex';
|
|
2
|
+
import { Logger } from '@xylabs/logger';
|
|
3
|
+
import { PackageManifestPayload } from '@xyo-network/manifest';
|
|
4
|
+
import { NodeInstance } from '@xyo-network/node-model';
|
|
5
|
+
import { Message, QueryMessage } from '../WorkerBridge';
|
|
6
|
+
export type QueryEvent = MessageEvent<QueryMessage>;
|
|
7
|
+
export interface CreateNodeMessage extends Message<'createNode'> {
|
|
8
|
+
manifest: PackageManifestPayload;
|
|
9
|
+
}
|
|
10
|
+
export type CreateNodeEvent = MessageEvent<CreateNodeMessage>;
|
|
11
|
+
export interface NodeCreatedMessage extends Message<'nodeCreated'> {
|
|
12
|
+
address: Address;
|
|
13
|
+
}
|
|
14
|
+
export declare class WorkerNodeHost {
|
|
15
|
+
protected node: NodeInstance;
|
|
16
|
+
protected logger?: Logger | undefined;
|
|
17
|
+
constructor(node: NodeInstance, logger?: Logger | undefined);
|
|
18
|
+
static create(config: PackageManifestPayload): Promise<WorkerNodeHost>;
|
|
19
|
+
static start(logger?: Logger): void;
|
|
20
|
+
private attachNode;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=WorkerNodeHost.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WorkerNodeHost.d.ts","sourceRoot":"","sources":["../../../src/worker/WorkerNodeHost.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AAEvC,OAAO,EAAmB,sBAAsB,EAAE,MAAM,uBAAuB,CAAA;AAC/E,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AAEtD,OAAO,EAAE,OAAO,EAAE,YAAY,EAAsB,MAAM,iBAAiB,CAAA;AAE3E,MAAM,MAAM,UAAU,GAAG,YAAY,CAAC,YAAY,CAAC,CAAA;AAEnD,MAAM,WAAW,iBAAkB,SAAQ,OAAO,CAAC,YAAY,CAAC;IAC9D,QAAQ,EAAE,sBAAsB,CAAA;CACjC;AAED,MAAM,MAAM,eAAe,GAAG,YAAY,CAAC,iBAAiB,CAAC,CAAA;AAE7D,MAAM,WAAW,kBAAmB,SAAQ,OAAO,CAAC,aAAa,CAAC;IAChE,OAAO,EAAE,OAAO,CAAA;CACjB;AAED,qBAAa,cAAc;IAEvB,SAAS,CAAC,IAAI,EAAE,YAAY;IAC5B,SAAS,CAAC,MAAM,CAAC;gBADP,IAAI,EAAE,YAAY,EAClB,MAAM,CAAC,oBAAQ;WAGd,MAAM,CAAC,MAAM,EAAE,sBAAsB;IASlD,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,MAAM;IAwB5B,OAAO,CAAC,UAAU;CA0BnB"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Address } from '@xylabs/hex';
|
|
2
|
+
import { Logger } from '@xylabs/logger';
|
|
3
|
+
import { PackageManifestPayload } from '@xyo-network/manifest';
|
|
4
|
+
import { NodeInstance } from '@xyo-network/node-model';
|
|
5
|
+
import { Message, QueryMessage } from '../WorkerBridge';
|
|
6
|
+
export type QueryEvent = MessageEvent<QueryMessage>;
|
|
7
|
+
export interface CreateNodeMessage extends Message<'createNode'> {
|
|
8
|
+
manifest: PackageManifestPayload;
|
|
9
|
+
}
|
|
10
|
+
export type CreateNodeEvent = MessageEvent<CreateNodeMessage>;
|
|
11
|
+
export interface NodeCreatedMessage extends Message<'nodeCreated'> {
|
|
12
|
+
address: Address;
|
|
13
|
+
}
|
|
14
|
+
export declare class WorkerNodeHost {
|
|
15
|
+
protected node: NodeInstance;
|
|
16
|
+
protected logger?: Logger | undefined;
|
|
17
|
+
constructor(node: NodeInstance, logger?: Logger | undefined);
|
|
18
|
+
static create(config: PackageManifestPayload): Promise<WorkerNodeHost>;
|
|
19
|
+
static start(logger?: Logger): void;
|
|
20
|
+
private attachNode;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=WorkerNodeHost.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WorkerNodeHost.d.ts","sourceRoot":"","sources":["../../../src/worker/WorkerNodeHost.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AAEvC,OAAO,EAAmB,sBAAsB,EAAE,MAAM,uBAAuB,CAAA;AAC/E,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AAEtD,OAAO,EAAE,OAAO,EAAE,YAAY,EAAsB,MAAM,iBAAiB,CAAA;AAE3E,MAAM,MAAM,UAAU,GAAG,YAAY,CAAC,YAAY,CAAC,CAAA;AAEnD,MAAM,WAAW,iBAAkB,SAAQ,OAAO,CAAC,YAAY,CAAC;IAC9D,QAAQ,EAAE,sBAAsB,CAAA;CACjC;AAED,MAAM,MAAM,eAAe,GAAG,YAAY,CAAC,iBAAiB,CAAC,CAAA;AAE7D,MAAM,WAAW,kBAAmB,SAAQ,OAAO,CAAC,aAAa,CAAC;IAChE,OAAO,EAAE,OAAO,CAAA;CACjB;AAED,qBAAa,cAAc;IAEvB,SAAS,CAAC,IAAI,EAAE,YAAY;IAC5B,SAAS,CAAC,MAAM,CAAC;gBADP,IAAI,EAAE,YAAY,EAClB,MAAM,CAAC,oBAAQ;WAGd,MAAM,CAAC,MAAM,EAAE,sBAAsB;IASlD,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,MAAM;IAwB5B,OAAO,CAAC,UAAU;CA0BnB"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Address } from '@xylabs/hex';
|
|
2
|
+
import { Logger } from '@xylabs/logger';
|
|
3
|
+
import { PackageManifestPayload } from '@xyo-network/manifest';
|
|
4
|
+
import { NodeInstance } from '@xyo-network/node-model';
|
|
5
|
+
import { Message, QueryMessage } from '../WorkerBridge';
|
|
6
|
+
export type QueryEvent = MessageEvent<QueryMessage>;
|
|
7
|
+
export interface CreateNodeMessage extends Message<'createNode'> {
|
|
8
|
+
manifest: PackageManifestPayload;
|
|
9
|
+
}
|
|
10
|
+
export type CreateNodeEvent = MessageEvent<CreateNodeMessage>;
|
|
11
|
+
export interface NodeCreatedMessage extends Message<'nodeCreated'> {
|
|
12
|
+
address: Address;
|
|
13
|
+
}
|
|
14
|
+
export declare class WorkerNodeHost {
|
|
15
|
+
protected node: NodeInstance;
|
|
16
|
+
protected logger?: Logger | undefined;
|
|
17
|
+
constructor(node: NodeInstance, logger?: Logger | undefined);
|
|
18
|
+
static create(config: PackageManifestPayload): Promise<WorkerNodeHost>;
|
|
19
|
+
static start(logger?: Logger): void;
|
|
20
|
+
private attachNode;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=WorkerNodeHost.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WorkerNodeHost.d.ts","sourceRoot":"","sources":["../../../src/worker/WorkerNodeHost.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AAEvC,OAAO,EAAmB,sBAAsB,EAAE,MAAM,uBAAuB,CAAA;AAC/E,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AAEtD,OAAO,EAAE,OAAO,EAAE,YAAY,EAAsB,MAAM,iBAAiB,CAAA;AAE3E,MAAM,MAAM,UAAU,GAAG,YAAY,CAAC,YAAY,CAAC,CAAA;AAEnD,MAAM,WAAW,iBAAkB,SAAQ,OAAO,CAAC,YAAY,CAAC;IAC9D,QAAQ,EAAE,sBAAsB,CAAA;CACjC;AAED,MAAM,MAAM,eAAe,GAAG,YAAY,CAAC,iBAAiB,CAAC,CAAA;AAE7D,MAAM,WAAW,kBAAmB,SAAQ,OAAO,CAAC,aAAa,CAAC;IAChE,OAAO,EAAE,OAAO,CAAA;CACjB;AAED,qBAAa,cAAc;IAEvB,SAAS,CAAC,IAAI,EAAE,YAAY;IAC5B,SAAS,CAAC,MAAM,CAAC;gBADP,IAAI,EAAE,YAAY,EAClB,MAAM,CAAC,oBAAQ;WAGd,MAAM,CAAC,MAAM,EAAE,sBAAsB;IASlD,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,MAAM;IAwB5B,OAAO,CAAC,UAAU;CA0BnB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/worker/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/worker/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/worker/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAA"}
|
package/package.json
ADDED
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@xyo-network/bridge-worker",
|
|
3
|
+
"author": {
|
|
4
|
+
"email": "support@xyo.network",
|
|
5
|
+
"name": "XYO Development Team",
|
|
6
|
+
"url": "https://xyo.network"
|
|
7
|
+
},
|
|
8
|
+
"bugs": {
|
|
9
|
+
"email": "support@xyo.network",
|
|
10
|
+
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
|
|
11
|
+
},
|
|
12
|
+
"dependencies": {
|
|
13
|
+
"@scure/bip39": "^1.3.0",
|
|
14
|
+
"@xylabs/assert": "^3.3.3",
|
|
15
|
+
"@xylabs/forget": "^3.3.3",
|
|
16
|
+
"@xylabs/hex": "^3.3.3",
|
|
17
|
+
"@xylabs/logger": "^3.3.3",
|
|
18
|
+
"@xylabs/object": "^3.3.3",
|
|
19
|
+
"@xylabs/promise": "^3.3.3",
|
|
20
|
+
"@xyo-network/abstract-bridge": "~2.102.0",
|
|
21
|
+
"@xyo-network/account": "~2.102.0",
|
|
22
|
+
"@xyo-network/archivist-model": "~2.102.0",
|
|
23
|
+
"@xyo-network/boundwitness-model": "~2.102.0",
|
|
24
|
+
"@xyo-network/bridge-model": "~2.102.0",
|
|
25
|
+
"@xyo-network/manifest": "~2.102.0",
|
|
26
|
+
"@xyo-network/manifest-model": "~2.102.0",
|
|
27
|
+
"@xyo-network/module-model": "~2.102.0",
|
|
28
|
+
"@xyo-network/node-model": "~2.102.0",
|
|
29
|
+
"@xyo-network/payload-model": "~2.102.0",
|
|
30
|
+
"@xyo-network/sentinel-model": "~2.102.0",
|
|
31
|
+
"lru-cache": "^10.2.2"
|
|
32
|
+
},
|
|
33
|
+
"devDependencies": {
|
|
34
|
+
"@xylabs/ts-scripts-yarn3": "^3.10.4",
|
|
35
|
+
"@xylabs/tsconfig": "^3.10.4",
|
|
36
|
+
"typescript": "^5.4.5"
|
|
37
|
+
},
|
|
38
|
+
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
39
|
+
"types": "dist/node/index.d.ts",
|
|
40
|
+
"exports": {
|
|
41
|
+
".": {
|
|
42
|
+
"browser": {
|
|
43
|
+
"types": "./dist/browser/index.d.ts",
|
|
44
|
+
"default": "./dist/browser/index.js"
|
|
45
|
+
},
|
|
46
|
+
"import": {
|
|
47
|
+
"types": "./dist/node/index.d.ts",
|
|
48
|
+
"default": "./dist/node/index.js"
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
"./package.json": "./package.json"
|
|
52
|
+
},
|
|
53
|
+
"main": "dist/node/index.js",
|
|
54
|
+
"module": "dist/node/index.js",
|
|
55
|
+
"homepage": "https://xyo.network",
|
|
56
|
+
"license": "LGPL-3.0-only",
|
|
57
|
+
"publishConfig": {
|
|
58
|
+
"access": "public"
|
|
59
|
+
},
|
|
60
|
+
"repository": {
|
|
61
|
+
"type": "git",
|
|
62
|
+
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
63
|
+
},
|
|
64
|
+
"scripts": {
|
|
65
|
+
"test": "node --experimental-vm-modules ../../../../../../node_modules/.bin/jest ."
|
|
66
|
+
},
|
|
67
|
+
"sideEffects": false,
|
|
68
|
+
"version": "2.102.0",
|
|
69
|
+
"type": "module"
|
|
70
|
+
}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { assertEx } from '@xylabs/assert'
|
|
2
|
+
import { Address } from '@xylabs/hex'
|
|
3
|
+
import { Promisable } from '@xylabs/promise'
|
|
4
|
+
import { AbstractBridge } from '@xyo-network/abstract-bridge'
|
|
5
|
+
import { QueryBoundWitness } from '@xyo-network/boundwitness-model'
|
|
6
|
+
import { BridgeExposeOptions, BridgeModule, BridgeUnexposeOptions } from '@xyo-network/bridge-model'
|
|
7
|
+
import { PackageManifestPayload } from '@xyo-network/manifest-model'
|
|
8
|
+
import {
|
|
9
|
+
AnyConfigSchema,
|
|
10
|
+
CacheConfig,
|
|
11
|
+
creatableModule,
|
|
12
|
+
ModuleConfig,
|
|
13
|
+
ModuleInstance,
|
|
14
|
+
ModuleParams,
|
|
15
|
+
ModuleQueryResult,
|
|
16
|
+
} from '@xyo-network/module-model'
|
|
17
|
+
import { Payload, Schema } from '@xyo-network/payload-model'
|
|
18
|
+
import { LRUCache } from 'lru-cache'
|
|
19
|
+
|
|
20
|
+
import { defaultPackageManifest } from './defaultNodeManifest'
|
|
21
|
+
import { WorkerBridgeConfig, WorkerBridgeConfigSchema } from './WorkerBridgeConfig'
|
|
22
|
+
|
|
23
|
+
export type WorkerBridgeParams<TConfig extends AnyConfigSchema<WorkerBridgeConfig> = AnyConfigSchema<WorkerBridgeConfig>> = ModuleParams<
|
|
24
|
+
TConfig,
|
|
25
|
+
{
|
|
26
|
+
worker?: Worker
|
|
27
|
+
}
|
|
28
|
+
>
|
|
29
|
+
|
|
30
|
+
export interface Message<T extends string = string> {
|
|
31
|
+
type: T
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export interface QueryMessage extends Message<'xyoQuery'> {
|
|
35
|
+
address: Address
|
|
36
|
+
msgId?: string
|
|
37
|
+
payloads?: Payload[]
|
|
38
|
+
query: QueryBoundWitness
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export interface QueryResultMessage {
|
|
42
|
+
address: Address
|
|
43
|
+
msgId?: string
|
|
44
|
+
result: ModuleQueryResult
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
@creatableModule()
|
|
48
|
+
export class WorkerBridge<TParams extends WorkerBridgeParams = WorkerBridgeParams> extends AbstractBridge<TParams> implements BridgeModule<TParams> {
|
|
49
|
+
static override readonly configSchemas: Schema[] = [...super.configSchemas, WorkerBridgeConfigSchema]
|
|
50
|
+
static override readonly defaultConfigSchema: Schema = WorkerBridgeConfigSchema
|
|
51
|
+
|
|
52
|
+
private _discoverCache?: LRUCache<string, Payload[]>
|
|
53
|
+
private _targetConfigs: Record<string, ModuleConfig> = {}
|
|
54
|
+
private _targetQueries: Record<string, string[]> = {}
|
|
55
|
+
|
|
56
|
+
get discoverCache() {
|
|
57
|
+
const config = this.discoverCacheConfig
|
|
58
|
+
this._discoverCache = this._discoverCache ?? new LRUCache<string, Payload[]>({ ttlAutopurge: true, ...config })
|
|
59
|
+
return this._discoverCache
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
get discoverCacheConfig(): LRUCache.Options<string, Payload[], unknown> {
|
|
63
|
+
const discoverCacheConfig: CacheConfig | undefined = {}
|
|
64
|
+
return { max: 100, ttl: 1000 * 60 * 5, ...discoverCacheConfig }
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
get worker(): Worker {
|
|
68
|
+
return assertEx(this.params.worker)
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
static async createWorkerNode(manifest: PackageManifestPayload = defaultPackageManifest as PackageManifestPayload) {
|
|
72
|
+
const worker = new Worker(new URL('worker/Worker.ts', import.meta?.url ?? __filename))
|
|
73
|
+
worker.postMessage({ manifest, type: 'createNode' })
|
|
74
|
+
|
|
75
|
+
await new Promise((resolve, reject) => {
|
|
76
|
+
const eventFunc = (event: MessageEvent) => {
|
|
77
|
+
const timeout = setTimeout(() => {
|
|
78
|
+
console.log('Node creation timeout')
|
|
79
|
+
worker.removeEventListener('message', eventFunc)
|
|
80
|
+
reject('Timeout')
|
|
81
|
+
}, 1000)
|
|
82
|
+
switch (event.data.type) {
|
|
83
|
+
case 'nodeCreated': {
|
|
84
|
+
clearTimeout(timeout)
|
|
85
|
+
worker.removeEventListener('message', eventFunc)
|
|
86
|
+
resolve(true)
|
|
87
|
+
break
|
|
88
|
+
}
|
|
89
|
+
default: {
|
|
90
|
+
const message: Message = event.data
|
|
91
|
+
console.log(`Unknown Event (nodeCreated listener) [${JSON.stringify(event)}]: ${JSON.stringify(message, null, 2)}`)
|
|
92
|
+
break
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
worker.addEventListener('message', eventFunc)
|
|
97
|
+
})
|
|
98
|
+
|
|
99
|
+
const bridge = await WorkerBridge.create({ config: { schema: WorkerBridgeConfigSchema }, worker })
|
|
100
|
+
await bridge.start()
|
|
101
|
+
return bridge
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
override exposeHandler(_id: string, _options?: BridgeExposeOptions | undefined): Promisable<ModuleInstance[]> {
|
|
105
|
+
return []
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
override exposedHandler(): Promisable<Address[]> {
|
|
109
|
+
return []
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
override getRoots(_force?: boolean | undefined): Promise<ModuleInstance[]> {
|
|
113
|
+
return Promise.resolve([])
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
override unexposeHandler(_id: string, _options?: BridgeUnexposeOptions | undefined): Promisable<ModuleInstance[]> {
|
|
117
|
+
return []
|
|
118
|
+
}
|
|
119
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { EmptyObject } from '@xylabs/object'
|
|
2
|
+
import { BridgeConfig } from '@xyo-network/bridge-model'
|
|
3
|
+
|
|
4
|
+
export type WorkerBridgeConfigSchema = 'network.xyo.bridge.worker.config'
|
|
5
|
+
export const WorkerBridgeConfigSchema: WorkerBridgeConfigSchema = 'network.xyo.bridge.worker.config'
|
|
6
|
+
|
|
7
|
+
export type WorkerBridgeConfig<TConfig extends EmptyObject = EmptyObject> = BridgeConfig<TConfig, WorkerBridgeConfigSchema>
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { ArchivistConfigSchema } from '@xyo-network/archivist-model'
|
|
2
|
+
import { PackageManifestPayload, PackageManifestPayloadSchema } from '@xyo-network/manifest-model'
|
|
3
|
+
import { NodeConfigSchema } from '@xyo-network/node-model'
|
|
4
|
+
import { SentinelConfigSchema } from '@xyo-network/sentinel-model'
|
|
5
|
+
|
|
6
|
+
export const defaultPackageManifest: PackageManifestPayload = {
|
|
7
|
+
nodes: [
|
|
8
|
+
{
|
|
9
|
+
config: {
|
|
10
|
+
name: 'SimpleMemoryDapp',
|
|
11
|
+
schema: NodeConfigSchema,
|
|
12
|
+
},
|
|
13
|
+
modules: {
|
|
14
|
+
private: [
|
|
15
|
+
{
|
|
16
|
+
config: {
|
|
17
|
+
name: 'ScratchArchivist',
|
|
18
|
+
schema: ArchivistConfigSchema,
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
],
|
|
22
|
+
public: [
|
|
23
|
+
{
|
|
24
|
+
config: {
|
|
25
|
+
name: 'SimpleArchivist',
|
|
26
|
+
schema: ArchivistConfigSchema,
|
|
27
|
+
},
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
config: {
|
|
31
|
+
name: 'SimpleSentinel',
|
|
32
|
+
schema: SentinelConfigSchema,
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
],
|
|
36
|
+
},
|
|
37
|
+
},
|
|
38
|
+
],
|
|
39
|
+
schema: PackageManifestPayloadSchema,
|
|
40
|
+
}
|
package/src/docsEntry.ts
ADDED
package/src/index.ts
ADDED