@xyo-network/react-standard-node 2.64.0-rc.7 → 2.64.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/components/ActiveStandardNode.cjs +85 -0
- package/dist/browser/components/ActiveStandardNode.cjs.map +1 -0
- package/dist/browser/components/ActiveStandardNode.d.cts +7 -0
- package/dist/browser/components/ActiveStandardNode.d.cts.map +1 -0
- package/dist/browser/components/ActiveStandardNode.js +27 -4
- package/dist/browser/components/ActiveStandardNode.js.map +1 -1
- package/dist/browser/components/index.cjs +87 -0
- package/dist/browser/components/index.cjs.map +1 -0
- package/dist/browser/components/index.d.cts +2 -0
- package/dist/browser/components/index.d.cts.map +1 -0
- package/dist/browser/components/index.js +63 -1
- package/dist/browser/components/index.js.map +1 -1
- package/dist/browser/contexts/StandardRemoteNodes/Context.cjs +28 -0
- package/dist/{node/contexts/StandardRemoteNodes/Context.mjs.map → browser/contexts/StandardRemoteNodes/Context.cjs.map} +1 -1
- package/dist/browser/contexts/StandardRemoteNodes/Context.d.cts +4 -0
- package/dist/browser/contexts/StandardRemoteNodes/Context.d.cts.map +1 -0
- package/dist/browser/contexts/StandardRemoteNodes/Context.js +2 -1
- package/dist/browser/contexts/StandardRemoteNodes/Context.js.map +1 -1
- package/dist/browser/contexts/StandardRemoteNodes/Providers.cjs +308 -0
- package/dist/browser/contexts/StandardRemoteNodes/Providers.cjs.map +1 -0
- package/dist/browser/contexts/StandardRemoteNodes/Providers.d.cts +11 -0
- package/dist/browser/contexts/StandardRemoteNodes/Providers.d.cts.map +1 -0
- package/dist/browser/contexts/StandardRemoteNodes/Providers.js +245 -7
- package/dist/browser/contexts/StandardRemoteNodes/Providers.js.map +1 -1
- package/dist/browser/contexts/StandardRemoteNodes/State.cjs +19 -0
- package/dist/browser/contexts/StandardRemoteNodes/State.cjs.map +1 -0
- package/dist/browser/contexts/StandardRemoteNodes/State.d.cts +7 -0
- package/dist/browser/contexts/StandardRemoteNodes/State.d.cts.map +1 -0
- package/dist/browser/contexts/StandardRemoteNodes/index.cjs +316 -0
- package/dist/browser/contexts/StandardRemoteNodes/index.cjs.map +1 -0
- package/dist/browser/contexts/StandardRemoteNodes/index.d.cts +5 -0
- package/dist/browser/contexts/StandardRemoteNodes/index.d.cts.map +1 -0
- package/dist/browser/contexts/StandardRemoteNodes/index.js +292 -4
- package/dist/browser/contexts/StandardRemoteNodes/index.js.map +1 -1
- package/dist/browser/contexts/StandardRemoteNodes/use.cjs +34 -0
- package/dist/browser/contexts/StandardRemoteNodes/use.cjs.map +1 -0
- package/dist/browser/contexts/StandardRemoteNodes/use.d.cts +2 -0
- package/dist/browser/contexts/StandardRemoteNodes/use.d.cts.map +1 -0
- package/dist/browser/contexts/StandardRemoteNodes/use.js +8 -2
- package/dist/browser/contexts/StandardRemoteNodes/use.js.map +1 -1
- package/dist/browser/contexts/index.cjs +316 -0
- package/dist/browser/contexts/index.cjs.map +1 -0
- package/dist/browser/contexts/index.d.cts +2 -0
- package/dist/browser/contexts/index.d.cts.map +1 -0
- package/dist/browser/contexts/index.js +292 -1
- package/dist/browser/contexts/index.js.map +1 -1
- package/dist/browser/hooks/index.cjs +50 -0
- package/dist/browser/hooks/index.cjs.map +1 -0
- package/dist/browser/hooks/index.d.cts +2 -0
- package/dist/browser/hooks/index.d.cts.map +1 -0
- package/dist/browser/hooks/index.js +26 -1
- package/dist/browser/hooks/index.js.map +1 -1
- package/dist/browser/hooks/useActiveNodeAddress.cjs +48 -0
- package/dist/browser/hooks/useActiveNodeAddress.cjs.map +1 -0
- package/dist/browser/hooks/useActiveNodeAddress.d.cts +2 -0
- package/dist/browser/hooks/useActiveNodeAddress.d.cts.map +1 -0
- package/dist/browser/hooks/useActiveNodeAddress.js +12 -2
- package/dist/browser/hooks/useActiveNodeAddress.js.map +1 -1
- package/dist/browser/index.cjs +382 -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.js +358 -4
- package/dist/browser/index.js.map +1 -1
- package/dist/browser/lib/Builders/MemoryNodeBuilder.cjs +194 -0
- package/dist/browser/lib/Builders/MemoryNodeBuilder.cjs.map +1 -0
- package/dist/browser/lib/Builders/MemoryNodeBuilder.d.cts +166 -0
- package/dist/browser/lib/Builders/MemoryNodeBuilder.d.cts.map +1 -0
- package/dist/browser/lib/Builders/MemoryNodeBuilder.js +88 -5
- package/dist/browser/lib/Builders/MemoryNodeBuilder.js.map +1 -1
- package/dist/browser/lib/Builders/SentinelBuilder.cjs +54 -0
- package/dist/{node/lib/Builders/SentinelBuilder.mjs.map → browser/lib/Builders/SentinelBuilder.cjs.map} +1 -1
- package/dist/browser/lib/Builders/SentinelBuilder.d.cts +205 -0
- package/dist/browser/lib/Builders/SentinelBuilder.d.cts.map +1 -0
- package/dist/browser/lib/Builders/SentinelBuilder.js +3 -2
- package/dist/browser/lib/Builders/SentinelBuilder.js.map +1 -1
- package/dist/browser/lib/Builders/StorageArchivistBuilder.cjs +76 -0
- package/dist/{node/lib/Builders/StorageArchivistBuilder.mjs.map → browser/lib/Builders/StorageArchivistBuilder.cjs.map} +1 -1
- package/dist/browser/lib/Builders/StorageArchivistBuilder.d.cts +221 -0
- package/dist/browser/lib/Builders/StorageArchivistBuilder.d.cts.map +1 -0
- package/dist/browser/lib/Builders/StorageArchivistBuilder.js +3 -2
- package/dist/browser/lib/Builders/StorageArchivistBuilder.js.map +1 -1
- package/dist/browser/lib/Builders/index.cjs +198 -0
- package/dist/browser/lib/Builders/index.cjs.map +1 -0
- package/dist/browser/lib/Builders/index.d.cts +4 -0
- package/dist/browser/lib/Builders/index.d.cts.map +1 -0
- package/dist/browser/lib/Builders/index.js +174 -3
- package/dist/browser/lib/Builders/index.js.map +1 -1
- package/dist/browser/lib/ModuleAccountPaths.cjs +53 -0
- package/dist/browser/lib/ModuleAccountPaths.cjs.map +1 -0
- package/dist/browser/lib/ModuleAccountPaths.d.cts +4 -0
- package/dist/browser/lib/ModuleAccountPaths.d.cts.map +1 -0
- package/dist/browser/lib/ModuleAccountPaths.js +7 -4
- package/dist/browser/lib/ModuleAccountPaths.js.map +1 -1
- package/dist/browser/lib/ModuleNames.cjs +29 -0
- package/dist/{node/lib/ModuleNames.mjs.map → browser/lib/ModuleNames.cjs.map} +1 -1
- package/dist/browser/lib/ModuleNames.d.cts +3 -0
- package/dist/browser/lib/ModuleNames.d.cts.map +1 -0
- package/dist/browser/lib/ModuleNames.js +3 -2
- package/dist/browser/lib/ModuleNames.js.map +1 -1
- package/dist/browser/lib/buildNodes.cjs +257 -0
- package/dist/browser/lib/buildNodes.cjs.map +1 -0
- package/dist/browser/lib/buildNodes.d.cts +4 -0
- package/dist/browser/lib/buildNodes.d.cts.map +1 -0
- package/dist/browser/lib/buildNodes.js +202 -8
- package/dist/browser/lib/buildNodes.js.map +1 -1
- package/dist/browser/lib/index.cjs +269 -0
- package/dist/browser/lib/index.cjs.map +1 -0
- package/dist/browser/lib/index.d.cts +5 -0
- package/dist/browser/lib/index.d.cts.map +1 -0
- package/dist/browser/lib/index.js +245 -4
- package/dist/browser/lib/index.js.map +1 -1
- package/dist/docs.json +6100 -0
- package/dist/node/components/ActiveStandardNode.cjs +90 -0
- package/dist/node/components/ActiveStandardNode.cjs.map +1 -0
- package/dist/node/components/ActiveStandardNode.d.cts +7 -0
- package/dist/node/components/ActiveStandardNode.d.cts.map +1 -0
- package/dist/node/components/ActiveStandardNode.js +43 -43
- package/dist/node/components/ActiveStandardNode.js.map +1 -1
- package/dist/node/components/index.cjs +92 -0
- package/dist/node/components/index.cjs.map +1 -0
- package/dist/node/components/index.d.cts +2 -0
- package/dist/node/components/index.d.cts.map +1 -0
- package/dist/node/components/index.js +63 -21
- package/dist/node/components/index.js.map +1 -1
- package/dist/node/contexts/StandardRemoteNodes/Context.cjs +32 -0
- package/dist/node/contexts/StandardRemoteNodes/Context.cjs.map +1 -0
- package/dist/node/contexts/StandardRemoteNodes/Context.d.cts +4 -0
- package/dist/node/contexts/StandardRemoteNodes/Context.d.cts.map +1 -0
- package/dist/node/contexts/StandardRemoteNodes/Context.js +5 -28
- package/dist/node/contexts/StandardRemoteNodes/Context.js.map +1 -1
- package/dist/node/contexts/StandardRemoteNodes/Providers.cjs +319 -0
- package/dist/node/contexts/StandardRemoteNodes/Providers.cjs.map +1 -0
- package/dist/node/contexts/StandardRemoteNodes/Providers.d.cts +11 -0
- package/dist/node/contexts/StandardRemoteNodes/Providers.d.cts.map +1 -0
- package/dist/node/contexts/StandardRemoteNodes/Providers.js +263 -44
- package/dist/node/contexts/StandardRemoteNodes/Providers.js.map +1 -1
- package/dist/node/contexts/StandardRemoteNodes/State.cjs +19 -0
- package/dist/node/contexts/StandardRemoteNodes/State.cjs.map +1 -0
- package/dist/node/contexts/StandardRemoteNodes/State.d.cts +7 -0
- package/dist/node/contexts/StandardRemoteNodes/State.d.cts.map +1 -0
- package/dist/node/contexts/StandardRemoteNodes/State.js +0 -16
- package/dist/node/contexts/StandardRemoteNodes/State.js.map +1 -1
- package/dist/node/contexts/StandardRemoteNodes/index.cjs +329 -0
- package/dist/node/contexts/StandardRemoteNodes/index.cjs.map +1 -0
- package/dist/node/contexts/StandardRemoteNodes/index.d.cts +5 -0
- package/dist/node/contexts/StandardRemoteNodes/index.d.cts.map +1 -0
- package/dist/node/contexts/StandardRemoteNodes/index.js +298 -28
- package/dist/node/contexts/StandardRemoteNodes/index.js.map +1 -1
- package/dist/node/contexts/StandardRemoteNodes/use.cjs +38 -0
- package/dist/node/contexts/StandardRemoteNodes/use.cjs.map +1 -0
- package/dist/node/contexts/StandardRemoteNodes/use.d.cts +2 -0
- package/dist/node/contexts/StandardRemoteNodes/use.d.cts.map +1 -0
- package/dist/node/contexts/StandardRemoteNodes/use.js +11 -29
- package/dist/node/contexts/StandardRemoteNodes/use.js.map +1 -1
- package/dist/node/contexts/index.cjs +329 -0
- package/dist/node/contexts/index.cjs.map +1 -0
- package/dist/node/contexts/index.d.cts +2 -0
- package/dist/node/contexts/index.d.cts.map +1 -0
- package/dist/node/contexts/index.js +298 -22
- package/dist/node/contexts/index.js.map +1 -1
- package/dist/node/hooks/index.cjs +54 -0
- package/dist/node/hooks/index.cjs.map +1 -0
- package/dist/node/hooks/index.d.cts +2 -0
- package/dist/node/hooks/index.d.cts.map +1 -0
- package/dist/node/hooks/index.js +25 -21
- package/dist/node/hooks/index.js.map +1 -1
- package/dist/node/hooks/useActiveNodeAddress.cjs +52 -0
- package/dist/node/hooks/useActiveNodeAddress.cjs.map +1 -0
- package/dist/node/hooks/useActiveNodeAddress.d.cts +2 -0
- package/dist/node/hooks/useActiveNodeAddress.d.cts.map +1 -0
- package/dist/node/hooks/useActiveNodeAddress.js +19 -33
- package/dist/node/hooks/useActiveNodeAddress.js.map +1 -1
- package/dist/node/index.cjs +407 -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.js +365 -28
- package/dist/node/index.js.map +1 -1
- package/dist/node/lib/Builders/MemoryNodeBuilder.cjs +201 -0
- package/dist/node/lib/Builders/MemoryNodeBuilder.cjs.map +1 -0
- package/dist/node/lib/Builders/MemoryNodeBuilder.d.cts +166 -0
- package/dist/node/lib/Builders/MemoryNodeBuilder.d.cts.map +1 -0
- package/dist/node/lib/Builders/MemoryNodeBuilder.js +108 -46
- package/dist/node/lib/Builders/MemoryNodeBuilder.js.map +1 -1
- package/dist/node/lib/Builders/SentinelBuilder.cjs +58 -0
- package/dist/node/lib/Builders/SentinelBuilder.cjs.map +1 -0
- package/dist/node/lib/Builders/SentinelBuilder.d.cts +205 -0
- package/dist/node/lib/Builders/SentinelBuilder.d.cts.map +1 -0
- package/dist/node/lib/Builders/SentinelBuilder.js +10 -33
- package/dist/node/lib/Builders/SentinelBuilder.js.map +1 -1
- package/dist/node/lib/Builders/StorageArchivistBuilder.cjs +82 -0
- package/dist/node/lib/Builders/StorageArchivistBuilder.cjs.map +1 -0
- package/dist/node/lib/Builders/StorageArchivistBuilder.d.cts +221 -0
- package/dist/node/lib/Builders/StorageArchivistBuilder.d.cts.map +1 -0
- package/dist/node/lib/Builders/StorageArchivistBuilder.js +18 -39
- package/dist/node/lib/Builders/StorageArchivistBuilder.js.map +1 -1
- package/dist/node/lib/Builders/index.cjs +207 -0
- package/dist/node/lib/Builders/index.cjs.map +1 -0
- package/dist/node/lib/Builders/index.d.cts +4 -0
- package/dist/node/lib/Builders/index.d.cts.map +1 -0
- package/dist/node/lib/Builders/index.js +176 -25
- package/dist/node/lib/Builders/index.js.map +1 -1
- package/dist/node/lib/ModuleAccountPaths.cjs +59 -0
- package/dist/node/lib/ModuleAccountPaths.cjs.map +1 -0
- package/dist/node/lib/ModuleAccountPaths.d.cts +4 -0
- package/dist/node/lib/ModuleAccountPaths.d.cts.map +1 -0
- package/dist/node/lib/ModuleAccountPaths.js +12 -35
- package/dist/node/lib/ModuleAccountPaths.js.map +1 -1
- package/dist/node/lib/ModuleNames.cjs +34 -0
- package/dist/node/lib/ModuleNames.cjs.map +1 -0
- package/dist/node/lib/ModuleNames.d.cts +3 -0
- package/dist/node/lib/ModuleNames.d.cts.map +1 -0
- package/dist/node/lib/ModuleNames.js +5 -29
- package/dist/node/lib/ModuleNames.js.map +1 -1
- package/dist/node/lib/buildNodes.cjs +266 -0
- package/dist/node/lib/buildNodes.cjs.map +1 -0
- package/dist/node/lib/buildNodes.d.cts +4 -0
- package/dist/node/lib/buildNodes.d.cts.map +1 -0
- package/dist/node/lib/buildNodes.js +217 -42
- package/dist/node/lib/buildNodes.js.map +1 -1
- package/dist/node/lib/index.cjs +286 -0
- package/dist/node/lib/index.cjs.map +1 -0
- package/dist/node/lib/index.d.cts +5 -0
- package/dist/node/lib/index.d.cts.map +1 -0
- package/dist/node/lib/index.js +250 -28
- package/dist/node/lib/index.js.map +1 -1
- package/package.json +30 -30
- package/dist/node/components/ActiveStandardNode.mjs +0 -41
- package/dist/node/components/ActiveStandardNode.mjs.map +0 -1
- package/dist/node/components/index.mjs +0 -2
- package/dist/node/components/index.mjs.map +0 -1
- package/dist/node/contexts/StandardRemoteNodes/Context.mjs +0 -6
- package/dist/node/contexts/StandardRemoteNodes/Providers.mjs +0 -49
- package/dist/node/contexts/StandardRemoteNodes/Providers.mjs.map +0 -1
- package/dist/node/contexts/StandardRemoteNodes/State.mjs +0 -1
- package/dist/node/contexts/StandardRemoteNodes/State.mjs.map +0 -1
- package/dist/node/contexts/StandardRemoteNodes/index.mjs +0 -5
- package/dist/node/contexts/StandardRemoteNodes/index.mjs.map +0 -1
- package/dist/node/contexts/StandardRemoteNodes/use.mjs +0 -7
- package/dist/node/contexts/StandardRemoteNodes/use.mjs.map +0 -1
- package/dist/node/contexts/index.mjs +0 -2
- package/dist/node/contexts/index.mjs.map +0 -1
- package/dist/node/hooks/index.mjs +0 -2
- package/dist/node/hooks/index.mjs.map +0 -1
- package/dist/node/hooks/useActiveNodeAddress.mjs +0 -17
- package/dist/node/hooks/useActiveNodeAddress.mjs.map +0 -1
- package/dist/node/index.mjs +0 -5
- package/dist/node/index.mjs.map +0 -1
- package/dist/node/lib/Builders/MemoryNodeBuilder.mjs +0 -90
- package/dist/node/lib/Builders/MemoryNodeBuilder.mjs.map +0 -1
- package/dist/node/lib/Builders/SentinelBuilder.mjs +0 -32
- package/dist/node/lib/Builders/StorageArchivistBuilder.mjs +0 -54
- package/dist/node/lib/Builders/index.mjs +0 -4
- package/dist/node/lib/Builders/index.mjs.map +0 -1
- package/dist/node/lib/ModuleAccountPaths.mjs +0 -27
- package/dist/node/lib/ModuleAccountPaths.mjs.map +0 -1
- package/dist/node/lib/ModuleNames.mjs +0 -7
- package/dist/node/lib/buildNodes.mjs +0 -42
- package/dist/node/lib/buildNodes.mjs.map +0 -1
- package/dist/node/lib/index.mjs +0 -5
- package/dist/node/lib/index.mjs.map +0 -1
|
@@ -1,30 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
var
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var StorageArchivistBuilder_exports = {};
|
|
20
|
-
__export(StorageArchivistBuilder_exports, {
|
|
21
|
-
StorageArchivistBuilder: () => StorageArchivistBuilder
|
|
22
|
-
});
|
|
23
|
-
module.exports = __toCommonJS(StorageArchivistBuilder_exports);
|
|
24
|
-
var import_archivist = require("@xyo-network/archivist");
|
|
25
|
-
var import_node_model = require("@xyo-network/node-model");
|
|
26
|
-
var import_react_shared = require("@xyo-network/react-shared");
|
|
27
|
-
class StorageArchivistBuilder {
|
|
1
|
+
// src/lib/Builders/StorageArchivistBuilder.ts
|
|
2
|
+
import { asArchivistInstance, StorageArchivist, StorageArchivistConfigSchema } from "@xyo-network/archivist";
|
|
3
|
+
import { asNodeInstance } from "@xyo-network/node-model";
|
|
4
|
+
import { assertDefinedEx } from "@xyo-network/react-shared";
|
|
5
|
+
var StorageArchivistBuilder = class {
|
|
28
6
|
constructor(config, account, node) {
|
|
29
7
|
this.config = config;
|
|
30
8
|
this.account = account;
|
|
@@ -33,7 +11,7 @@ class StorageArchivistBuilder {
|
|
|
33
11
|
_archivist;
|
|
34
12
|
remoteArchivist;
|
|
35
13
|
get archivist() {
|
|
36
|
-
return
|
|
14
|
+
return assertDefinedEx(this._archivist, "archivist was not defined upon create");
|
|
37
15
|
}
|
|
38
16
|
static async create(config, account, node) {
|
|
39
17
|
const instance = new this(config, account, node);
|
|
@@ -43,36 +21,37 @@ class StorageArchivistBuilder {
|
|
|
43
21
|
}
|
|
44
22
|
async buildArchivist() {
|
|
45
23
|
const config = this.buildConfig();
|
|
46
|
-
return await
|
|
24
|
+
return await StorageArchivist.create({ account: this.account, config });
|
|
47
25
|
}
|
|
48
26
|
buildConfig() {
|
|
27
|
+
var _a, _b;
|
|
49
28
|
return {
|
|
50
29
|
name: this.config.name,
|
|
51
30
|
namespace: this.config.namespace,
|
|
52
31
|
parents: {
|
|
53
|
-
commit: this.remoteArchivist ? [this.remoteArchivist
|
|
54
|
-
read: this.remoteArchivist ? [this.remoteArchivist
|
|
32
|
+
commit: this.remoteArchivist ? [(_a = this.remoteArchivist) == null ? void 0 : _a.address] : void 0,
|
|
33
|
+
read: this.remoteArchivist ? [(_b = this.remoteArchivist) == null ? void 0 : _b.address] : void 0
|
|
55
34
|
},
|
|
56
|
-
schema:
|
|
35
|
+
schema: StorageArchivistConfigSchema,
|
|
57
36
|
storeParentReads: true,
|
|
58
37
|
type: "local"
|
|
59
38
|
};
|
|
60
39
|
}
|
|
61
40
|
async findParentArchivist() {
|
|
62
|
-
|
|
41
|
+
var _a;
|
|
42
|
+
const node = asNodeInstance(this.node, "node not defined");
|
|
63
43
|
const [bridge] = await node.resolve({ name: ["RemoteNodeBridge"] }) ?? [];
|
|
64
44
|
if (bridge) {
|
|
65
45
|
try {
|
|
66
46
|
const [archivist] = await bridge.resolve({ name: ["Archivist"] }) ?? [];
|
|
67
|
-
return
|
|
47
|
+
return asArchivistInstance(archivist);
|
|
68
48
|
} catch (e) {
|
|
69
|
-
console.error("Error Resolving Parent Archivist", this.node
|
|
49
|
+
console.error("Error Resolving Parent Archivist", (_a = this.node) == null ? void 0 : _a.config.name, this.config);
|
|
70
50
|
}
|
|
71
51
|
}
|
|
72
52
|
}
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
0 && (module.exports = {
|
|
53
|
+
};
|
|
54
|
+
export {
|
|
76
55
|
StorageArchivistBuilder
|
|
77
|
-
}
|
|
56
|
+
};
|
|
78
57
|
//# sourceMappingURL=StorageArchivistBuilder.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/lib/Builders/StorageArchivistBuilder.ts"],"sourcesContent":["import { AccountInstance } from '@xyo-network/account-model'\nimport { ArchivistModule, asArchivistInstance, StorageArchivist, StorageArchivistConfig, StorageArchivistConfigSchema } from '@xyo-network/archivist'\nimport { MemoryNode } from '@xyo-network/node-memory'\nimport { asNodeInstance } from '@xyo-network/node-model'\nimport { assertDefinedEx } from '@xyo-network/react-shared'\n\nexport interface ArchivistBuilderConfig {\n name?: string\n namespace?: string\n}\nexport class StorageArchivistBuilder {\n private _archivist: StorageArchivist | undefined\n private remoteArchivist: ArchivistModule | undefined\n\n protected constructor(\n private config: ArchivistBuilderConfig,\n private account: AccountInstance,\n private node?: MemoryNode,\n ) {}\n\n get archivist() {\n return assertDefinedEx(this._archivist, 'archivist was not defined upon create')\n }\n\n static async create(config: ArchivistBuilderConfig, account: AccountInstance, node: MemoryNode): Promise<StorageArchivistBuilder> {\n const instance = new this(config, account, node)\n instance.remoteArchivist = await instance.findParentArchivist()\n instance._archivist = await instance.buildArchivist()\n return instance\n }\n\n async buildArchivist() {\n const config = this.buildConfig()\n return (await StorageArchivist.create({ account: this.account, config })) as StorageArchivist\n }\n\n buildConfig(): StorageArchivistConfig {\n return {\n name: this.config.name,\n namespace: this.config.namespace,\n parents: {\n commit: this.remoteArchivist ? [this.remoteArchivist?.address] : undefined,\n read: this.remoteArchivist ? [this.remoteArchivist?.address] : undefined,\n },\n schema: StorageArchivistConfigSchema,\n storeParentReads: true,\n type: 'local',\n }\n }\n\n async findParentArchivist() {\n const node = asNodeInstance(this.node, 'node not defined')\n const [bridge] = (await node.resolve({ name: ['RemoteNodeBridge'] })) ?? []\n if (bridge) {\n try {\n const [archivist] = (await bridge.resolve({ name: ['Archivist'] })) ?? []\n return asArchivistInstance(archivist)\n } catch (e) {\n console.error('Error Resolving Parent Archivist', this.node?.config.name, this.config)\n }\n }\n }\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../../../src/lib/Builders/StorageArchivistBuilder.ts"],"sourcesContent":["import { AccountInstance } from '@xyo-network/account-model'\nimport { ArchivistModule, asArchivistInstance, StorageArchivist, StorageArchivistConfig, StorageArchivistConfigSchema } from '@xyo-network/archivist'\nimport { MemoryNode } from '@xyo-network/node-memory'\nimport { asNodeInstance } from '@xyo-network/node-model'\nimport { assertDefinedEx } from '@xyo-network/react-shared'\n\nexport interface ArchivistBuilderConfig {\n name?: string\n namespace?: string\n}\nexport class StorageArchivistBuilder {\n private _archivist: StorageArchivist | undefined\n private remoteArchivist: ArchivistModule | undefined\n\n protected constructor(\n private config: ArchivistBuilderConfig,\n private account: AccountInstance,\n private node?: MemoryNode,\n ) {}\n\n get archivist() {\n return assertDefinedEx(this._archivist, 'archivist was not defined upon create')\n }\n\n static async create(config: ArchivistBuilderConfig, account: AccountInstance, node: MemoryNode): Promise<StorageArchivistBuilder> {\n const instance = new this(config, account, node)\n instance.remoteArchivist = await instance.findParentArchivist()\n instance._archivist = await instance.buildArchivist()\n return instance\n }\n\n async buildArchivist() {\n const config = this.buildConfig()\n return (await StorageArchivist.create({ account: this.account, config })) as StorageArchivist\n }\n\n buildConfig(): StorageArchivistConfig {\n return {\n name: this.config.name,\n namespace: this.config.namespace,\n parents: {\n commit: this.remoteArchivist ? [this.remoteArchivist?.address] : undefined,\n read: this.remoteArchivist ? [this.remoteArchivist?.address] : undefined,\n },\n schema: StorageArchivistConfigSchema,\n storeParentReads: true,\n type: 'local',\n }\n }\n\n async findParentArchivist() {\n const node = asNodeInstance(this.node, 'node not defined')\n const [bridge] = (await node.resolve({ name: ['RemoteNodeBridge'] })) ?? []\n if (bridge) {\n try {\n const [archivist] = (await bridge.resolve({ name: ['Archivist'] })) ?? []\n return asArchivistInstance(archivist)\n } catch (e) {\n console.error('Error Resolving Parent Archivist', this.node?.config.name, this.config)\n }\n }\n }\n}\n"],"mappings":";AACA,SAA0B,qBAAqB,kBAA0C,oCAAoC;AAE7H,SAAS,sBAAsB;AAC/B,SAAS,uBAAuB;AAMzB,IAAM,0BAAN,MAA8B;AAAA,EAIzB,YACA,QACA,SACA,MACR;AAHQ;AACA;AACA;AAAA,EACP;AAAA,EAPK;AAAA,EACA;AAAA,EAQR,IAAI,YAAY;AACd,WAAO,gBAAgB,KAAK,YAAY,uCAAuC;AAAA,EACjF;AAAA,EAEA,aAAa,OAAO,QAAgC,SAA0B,MAAoD;AAChI,UAAM,WAAW,IAAI,KAAK,QAAQ,SAAS,IAAI;AAC/C,aAAS,kBAAkB,MAAM,SAAS,oBAAoB;AAC9D,aAAS,aAAa,MAAM,SAAS,eAAe;AACpD,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,iBAAiB;AACrB,UAAM,SAAS,KAAK,YAAY;AAChC,WAAQ,MAAM,iBAAiB,OAAO,EAAE,SAAS,KAAK,SAAS,OAAO,CAAC;AAAA,EACzE;AAAA,EAEA,cAAsC;AApCxC;AAqCI,WAAO;AAAA,MACL,MAAM,KAAK,OAAO;AAAA,MAClB,WAAW,KAAK,OAAO;AAAA,MACvB,SAAS;AAAA,QACP,QAAQ,KAAK,kBAAkB,EAAC,UAAK,oBAAL,mBAAsB,OAAO,IAAI;AAAA,QACjE,MAAM,KAAK,kBAAkB,EAAC,UAAK,oBAAL,mBAAsB,OAAO,IAAI;AAAA,MACjE;AAAA,MACA,QAAQ;AAAA,MACR,kBAAkB;AAAA,MAClB,MAAM;AAAA,IACR;AAAA,EACF;AAAA,EAEA,MAAM,sBAAsB;AAlD9B;AAmDI,UAAM,OAAO,eAAe,KAAK,MAAM,kBAAkB;AACzD,UAAM,CAAC,MAAM,IAAK,MAAM,KAAK,QAAQ,EAAE,MAAM,CAAC,kBAAkB,EAAE,CAAC,KAAM,CAAC;AAC1E,QAAI,QAAQ;AACV,UAAI;AACF,cAAM,CAAC,SAAS,IAAK,MAAM,OAAO,QAAQ,EAAE,MAAM,CAAC,WAAW,EAAE,CAAC,KAAM,CAAC;AACxE,eAAO,oBAAoB,SAAS;AAAA,MACtC,SAAS,GAAG;AACV,gBAAQ,MAAM,qCAAoC,UAAK,SAAL,mBAAW,OAAO,MAAM,KAAK,MAAM;AAAA,MACvF;AAAA,IACF;AAAA,EACF;AACF;","names":[]}
|
|
@@ -0,0 +1,207 @@
|
|
|
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 __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/lib/Builders/index.ts
|
|
21
|
+
var Builders_exports = {};
|
|
22
|
+
__export(Builders_exports, {
|
|
23
|
+
MemoryNodeBuilder: () => MemoryNodeBuilder,
|
|
24
|
+
SentinelBuilder: () => SentinelBuilder,
|
|
25
|
+
StorageArchivistBuilder: () => StorageArchivistBuilder
|
|
26
|
+
});
|
|
27
|
+
module.exports = __toCommonJS(Builders_exports);
|
|
28
|
+
|
|
29
|
+
// src/lib/Builders/MemoryNodeBuilder.ts
|
|
30
|
+
var import_archivist2 = require("@xyo-network/archivist");
|
|
31
|
+
var import_http_bridge = require("@xyo-network/http-bridge");
|
|
32
|
+
var import_node_memory = require("@xyo-network/node-memory");
|
|
33
|
+
var import_node_model2 = require("@xyo-network/node-model");
|
|
34
|
+
var import_react_shared3 = require("@xyo-network/react-shared");
|
|
35
|
+
|
|
36
|
+
// src/lib/Builders/SentinelBuilder.ts
|
|
37
|
+
var import_react_shared = require("@xyo-network/react-shared");
|
|
38
|
+
var import_sentinel = require("@xyo-network/sentinel");
|
|
39
|
+
var SentinelBuilder = class {
|
|
40
|
+
constructor(config, account) {
|
|
41
|
+
this.config = config;
|
|
42
|
+
this.account = account;
|
|
43
|
+
(0, import_react_shared.assertDefinedEx)(config, "config was not defined");
|
|
44
|
+
}
|
|
45
|
+
_sentinel;
|
|
46
|
+
get sentinel() {
|
|
47
|
+
return (0, import_react_shared.assertDefinedEx)(this._sentinel, "this._sentinel not defined upon create");
|
|
48
|
+
}
|
|
49
|
+
static async create(config, account) {
|
|
50
|
+
const instance = new this(config, account);
|
|
51
|
+
instance._sentinel = await instance.buildSentinel();
|
|
52
|
+
return instance;
|
|
53
|
+
}
|
|
54
|
+
async buildSentinel() {
|
|
55
|
+
const params = this.buildParams();
|
|
56
|
+
return await import_sentinel.MemorySentinel.create(params);
|
|
57
|
+
}
|
|
58
|
+
buildParams() {
|
|
59
|
+
return {
|
|
60
|
+
account: this.account,
|
|
61
|
+
config: this.config
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
// src/lib/Builders/StorageArchivistBuilder.ts
|
|
67
|
+
var import_archivist = require("@xyo-network/archivist");
|
|
68
|
+
var import_node_model = require("@xyo-network/node-model");
|
|
69
|
+
var import_react_shared2 = require("@xyo-network/react-shared");
|
|
70
|
+
var StorageArchivistBuilder = class {
|
|
71
|
+
constructor(config, account, node) {
|
|
72
|
+
this.config = config;
|
|
73
|
+
this.account = account;
|
|
74
|
+
this.node = node;
|
|
75
|
+
}
|
|
76
|
+
_archivist;
|
|
77
|
+
remoteArchivist;
|
|
78
|
+
get archivist() {
|
|
79
|
+
return (0, import_react_shared2.assertDefinedEx)(this._archivist, "archivist was not defined upon create");
|
|
80
|
+
}
|
|
81
|
+
static async create(config, account, node) {
|
|
82
|
+
const instance = new this(config, account, node);
|
|
83
|
+
instance.remoteArchivist = await instance.findParentArchivist();
|
|
84
|
+
instance._archivist = await instance.buildArchivist();
|
|
85
|
+
return instance;
|
|
86
|
+
}
|
|
87
|
+
async buildArchivist() {
|
|
88
|
+
const config = this.buildConfig();
|
|
89
|
+
return await import_archivist.StorageArchivist.create({ account: this.account, config });
|
|
90
|
+
}
|
|
91
|
+
buildConfig() {
|
|
92
|
+
var _a, _b;
|
|
93
|
+
return {
|
|
94
|
+
name: this.config.name,
|
|
95
|
+
namespace: this.config.namespace,
|
|
96
|
+
parents: {
|
|
97
|
+
commit: this.remoteArchivist ? [(_a = this.remoteArchivist) == null ? void 0 : _a.address] : void 0,
|
|
98
|
+
read: this.remoteArchivist ? [(_b = this.remoteArchivist) == null ? void 0 : _b.address] : void 0
|
|
99
|
+
},
|
|
100
|
+
schema: import_archivist.StorageArchivistConfigSchema,
|
|
101
|
+
storeParentReads: true,
|
|
102
|
+
type: "local"
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
async findParentArchivist() {
|
|
106
|
+
var _a;
|
|
107
|
+
const node = (0, import_node_model.asNodeInstance)(this.node, "node not defined");
|
|
108
|
+
const [bridge] = await node.resolve({ name: ["RemoteNodeBridge"] }) ?? [];
|
|
109
|
+
if (bridge) {
|
|
110
|
+
try {
|
|
111
|
+
const [archivist] = await bridge.resolve({ name: ["Archivist"] }) ?? [];
|
|
112
|
+
return (0, import_archivist.asArchivistInstance)(archivist);
|
|
113
|
+
} catch (e) {
|
|
114
|
+
console.error("Error Resolving Parent Archivist", (_a = this.node) == null ? void 0 : _a.config.name, this.config);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
};
|
|
119
|
+
|
|
120
|
+
// src/lib/Builders/MemoryNodeBuilder.ts
|
|
121
|
+
var MemoryNodeBuilder = class {
|
|
122
|
+
_node;
|
|
123
|
+
get node() {
|
|
124
|
+
return (0, import_react_shared3.assertDefinedEx)(this._node, "this._node was not defined upon create");
|
|
125
|
+
}
|
|
126
|
+
static async create({ name, node }, account) {
|
|
127
|
+
const instance = new this();
|
|
128
|
+
const memoryNode = node ?? await import_node_memory.MemoryNode.create({ account, config: { name, schema: import_node_model2.NodeConfigSchema } });
|
|
129
|
+
instance._node = memoryNode;
|
|
130
|
+
return instance;
|
|
131
|
+
}
|
|
132
|
+
/** @deprecated - call specific method that corresponds to a type of archivist (i.e. addArchivistStorage) */
|
|
133
|
+
async addArchivist(account, moduleName, namespace) {
|
|
134
|
+
await this.addArchivistStorage(account, moduleName, namespace);
|
|
135
|
+
}
|
|
136
|
+
async addArchivistMemory(moduleName, account) {
|
|
137
|
+
const config = { name: moduleName, schema: import_archivist2.MemoryArchivistConfigSchema };
|
|
138
|
+
const memoryArchivist = await import_archivist2.MemoryArchivist.create({ account, config });
|
|
139
|
+
await this.attach(memoryArchivist, true);
|
|
140
|
+
}
|
|
141
|
+
async addArchivistStorage(account, moduleName, namespace) {
|
|
142
|
+
const config = { name: moduleName, namespace };
|
|
143
|
+
const { archivist } = await StorageArchivistBuilder.create(config, account, this.node);
|
|
144
|
+
await this.attach(archivist, true);
|
|
145
|
+
}
|
|
146
|
+
async addBridge(apiDomain, moduleName = "RemoteNodeBridge", account) {
|
|
147
|
+
try {
|
|
148
|
+
const bridge = await import_http_bridge.HttpBridge.create({
|
|
149
|
+
account,
|
|
150
|
+
config: { name: moduleName, nodeUrl: `${apiDomain}/node`, schema: import_http_bridge.HttpBridgeConfigSchema, security: { allowAnonymous: true } }
|
|
151
|
+
});
|
|
152
|
+
await this.attach(bridge, true);
|
|
153
|
+
} catch (e) {
|
|
154
|
+
console.error("Error Creating Bridge", e);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
async addSentinel(config, account) {
|
|
158
|
+
const { sentinel } = await SentinelBuilder.create(config, account);
|
|
159
|
+
await this.attach(sentinel, true, true);
|
|
160
|
+
return sentinel;
|
|
161
|
+
}
|
|
162
|
+
async addWitnesses(pluginSetResolver, witnesses = []) {
|
|
163
|
+
await Promise.all(
|
|
164
|
+
pluginSetResolver.witnesses().map(async (pluginSet, index) => {
|
|
165
|
+
var _a;
|
|
166
|
+
const witness = await ((_a = witnesses == null ? void 0 : witnesses[index]) == null ? void 0 : _a.call(witnesses));
|
|
167
|
+
if (witness) {
|
|
168
|
+
try {
|
|
169
|
+
await this.witnessCleanup(witness);
|
|
170
|
+
await this.node.register(witness);
|
|
171
|
+
await this.node.attach(witness.address, true);
|
|
172
|
+
} catch (e) {
|
|
173
|
+
console.error("Error attaching witness", JSON.stringify(pluginSet, null, 2), e);
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
})
|
|
177
|
+
);
|
|
178
|
+
}
|
|
179
|
+
async attach(module2, external, safeAttach) {
|
|
180
|
+
try {
|
|
181
|
+
if (safeAttach) {
|
|
182
|
+
const existingModule = (await this.node.resolve({ address: [module2.address] })).pop();
|
|
183
|
+
if (existingModule) {
|
|
184
|
+
await this.node.detach(existingModule.address);
|
|
185
|
+
await this.node.unregister(existingModule);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
await this.node.register(module2);
|
|
189
|
+
await this.node.attach(module2.address, external);
|
|
190
|
+
} catch (e) {
|
|
191
|
+
throw Error(`Error adding ${module2.config.name ?? module2.address} to MemoryNode: ${e}`);
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
async witnessCleanup(witness) {
|
|
195
|
+
if (this.node.registered().includes(witness.address)) {
|
|
196
|
+
const [existingWitness] = await this.node.resolve({ address: [witness.address] });
|
|
197
|
+
await this.node.unregister(existingWitness);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
};
|
|
201
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
202
|
+
0 && (module.exports = {
|
|
203
|
+
MemoryNodeBuilder,
|
|
204
|
+
SentinelBuilder,
|
|
205
|
+
StorageArchivistBuilder
|
|
206
|
+
});
|
|
207
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/lib/Builders/index.ts","../../../../src/lib/Builders/MemoryNodeBuilder.ts","../../../../src/lib/Builders/SentinelBuilder.ts","../../../../src/lib/Builders/StorageArchivistBuilder.ts"],"sourcesContent":["export * from './MemoryNodeBuilder'\nexport * from './SentinelBuilder'\nexport * from './StorageArchivistBuilder'\n","import { AccountInstance } from '@xyo-network/account-model'\nimport { MemoryArchivist, MemoryArchivistConfig, MemoryArchivistConfigSchema } from '@xyo-network/archivist'\nimport { HttpBridge, HttpBridgeConfigSchema } from '@xyo-network/http-bridge'\nimport { ModuleInstance } from '@xyo-network/module'\nimport { MemoryNode } from '@xyo-network/node-memory'\nimport { NodeConfigSchema } from '@xyo-network/node-model'\nimport { PayloadSetPluginResolver } from '@xyo-network/payloadset-plugin'\nimport { assertDefinedEx } from '@xyo-network/react-shared'\nimport { SentinelConfig } from '@xyo-network/sentinel'\nimport { WitnessInstance, WitnessModule } from '@xyo-network/witness'\n\nimport { SentinelBuilder } from './SentinelBuilder'\nimport { StorageArchivistBuilder } from './StorageArchivistBuilder'\n\nexport interface MemoryNodeBuilderConfig {\n name?: string\n node?: MemoryNode\n}\n\nexport class MemoryNodeBuilder {\n private _node: MemoryNode | undefined\n\n get node() {\n return assertDefinedEx(this._node, 'this._node was not defined upon create')\n }\n\n static async create({ name, node }: MemoryNodeBuilderConfig, account?: AccountInstance): Promise<MemoryNodeBuilder> {\n const instance = new this()\n\n const memoryNode: MemoryNode = node ?? (await MemoryNode.create({ account, config: { name, schema: NodeConfigSchema } }))\n instance._node = memoryNode\n return instance\n }\n\n /** @deprecated - call specific method that corresponds to a type of archivist (i.e. addArchivistStorage) */\n async addArchivist(account: AccountInstance, moduleName?: string, namespace?: string) {\n await this.addArchivistStorage(account, moduleName, namespace)\n }\n\n async addArchivistMemory(moduleName?: string, account?: AccountInstance) {\n const config: MemoryArchivistConfig = { name: moduleName, schema: MemoryArchivistConfigSchema }\n const memoryArchivist = await MemoryArchivist.create({ account, config })\n\n await this.attach(memoryArchivist, true)\n }\n\n async addArchivistStorage(account: AccountInstance, moduleName?: string, namespace?: string) {\n const config = { name: moduleName, namespace }\n const { archivist } = await StorageArchivistBuilder.create(config, account, this.node)\n\n await this.attach(archivist, true)\n }\n\n async addBridge(apiDomain: string, moduleName = 'RemoteNodeBridge', account?: AccountInstance) {\n try {\n const bridge = await HttpBridge.create({\n account,\n config: { name: moduleName, nodeUrl: `${apiDomain}/node`, schema: HttpBridgeConfigSchema, security: { allowAnonymous: true } },\n })\n await this.attach(bridge, true)\n } catch (e) {\n console.error('Error Creating Bridge', e)\n }\n }\n\n async addSentinel(config: SentinelConfig, account: AccountInstance) {\n const { sentinel } = await SentinelBuilder.create(config, account)\n await this.attach(sentinel, true, true)\n return sentinel\n }\n\n async addWitnesses(pluginSetResolver: PayloadSetPluginResolver, witnesses: (() => Promise<WitnessInstance>)[] = []) {\n await Promise.all(\n pluginSetResolver.witnesses().map(async (pluginSet, index) => {\n // Pass the prebuilt witness at the same index\n const witness = await witnesses?.[index]?.()\n if (witness) {\n try {\n await this.witnessCleanup(witness)\n await this.node.register(witness)\n await this.node.attach(witness.address, true)\n } catch (e) {\n console.error('Error attaching witness', JSON.stringify(pluginSet, null, 2), e)\n }\n }\n }),\n )\n }\n\n async attach(module: ModuleInstance, external?: boolean, safeAttach?: boolean) {\n try {\n if (safeAttach) {\n const existingModule = (await this.node.resolve({ address: [module.address] })).pop()\n if (existingModule) {\n await this.node.detach(existingModule.address)\n await this.node.unregister(existingModule)\n }\n }\n await this.node.register(module)\n await this.node.attach(module.address, external)\n } catch (e) {\n throw Error(`Error adding ${module.config.name ?? module.address} to MemoryNode: ${e}`)\n }\n }\n\n private async witnessCleanup(witness: WitnessModule) {\n if (this.node.registered().includes(witness.address)) {\n const [existingWitness] = await this.node.resolve({ address: [witness.address] })\n await this.node.unregister(existingWitness)\n }\n }\n}\n","import { AccountInstance } from '@xyo-network/account-model'\nimport { assertDefinedEx } from '@xyo-network/react-shared'\nimport { MemorySentinel, MemorySentinelParams, SentinelConfig } from '@xyo-network/sentinel'\n\nexport class SentinelBuilder {\n private _sentinel: MemorySentinel | undefined\n\n protected constructor(\n private config: SentinelConfig,\n private account: AccountInstance,\n ) {\n assertDefinedEx(config, 'config was not defined')\n }\n\n get sentinel() {\n return assertDefinedEx(this._sentinel, 'this._sentinel not defined upon create')\n }\n\n static async create(config: SentinelConfig, account: AccountInstance): Promise<SentinelBuilder> {\n const instance = new this(config, account)\n instance._sentinel = await instance.buildSentinel()\n return instance\n }\n\n async buildSentinel() {\n const params = this.buildParams()\n return (await MemorySentinel.create(params)) as MemorySentinel\n }\n\n private buildParams(): MemorySentinelParams {\n return {\n account: this.account,\n config: this.config,\n }\n }\n}\n","import { AccountInstance } from '@xyo-network/account-model'\nimport { ArchivistModule, asArchivistInstance, StorageArchivist, StorageArchivistConfig, StorageArchivistConfigSchema } from '@xyo-network/archivist'\nimport { MemoryNode } from '@xyo-network/node-memory'\nimport { asNodeInstance } from '@xyo-network/node-model'\nimport { assertDefinedEx } from '@xyo-network/react-shared'\n\nexport interface ArchivistBuilderConfig {\n name?: string\n namespace?: string\n}\nexport class StorageArchivistBuilder {\n private _archivist: StorageArchivist | undefined\n private remoteArchivist: ArchivistModule | undefined\n\n protected constructor(\n private config: ArchivistBuilderConfig,\n private account: AccountInstance,\n private node?: MemoryNode,\n ) {}\n\n get archivist() {\n return assertDefinedEx(this._archivist, 'archivist was not defined upon create')\n }\n\n static async create(config: ArchivistBuilderConfig, account: AccountInstance, node: MemoryNode): Promise<StorageArchivistBuilder> {\n const instance = new this(config, account, node)\n instance.remoteArchivist = await instance.findParentArchivist()\n instance._archivist = await instance.buildArchivist()\n return instance\n }\n\n async buildArchivist() {\n const config = this.buildConfig()\n return (await StorageArchivist.create({ account: this.account, config })) as StorageArchivist\n }\n\n buildConfig(): StorageArchivistConfig {\n return {\n name: this.config.name,\n namespace: this.config.namespace,\n parents: {\n commit: this.remoteArchivist ? [this.remoteArchivist?.address] : undefined,\n read: this.remoteArchivist ? [this.remoteArchivist?.address] : undefined,\n },\n schema: StorageArchivistConfigSchema,\n storeParentReads: true,\n type: 'local',\n }\n }\n\n async findParentArchivist() {\n const node = asNodeInstance(this.node, 'node not defined')\n const [bridge] = (await node.resolve({ name: ['RemoteNodeBridge'] })) ?? []\n if (bridge) {\n try {\n const [archivist] = (await bridge.resolve({ name: ['Archivist'] })) ?? []\n return asArchivistInstance(archivist)\n } catch (e) {\n console.error('Error Resolving Parent Archivist', this.node?.config.name, this.config)\n }\n }\n }\n}\n"],"mappings":"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","names":["import_archivist","import_node_model","import_react_shared","import_react_shared","module"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/lib/Builders/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAA;AACnC,cAAc,mBAAmB,CAAA;AACjC,cAAc,2BAA2B,CAAA"}
|
|
@@ -1,27 +1,178 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
1
|
+
// src/lib/Builders/MemoryNodeBuilder.ts
|
|
2
|
+
import { MemoryArchivist, MemoryArchivistConfigSchema } from "@xyo-network/archivist";
|
|
3
|
+
import { HttpBridge, HttpBridgeConfigSchema } from "@xyo-network/http-bridge";
|
|
4
|
+
import { MemoryNode } from "@xyo-network/node-memory";
|
|
5
|
+
import { NodeConfigSchema } from "@xyo-network/node-model";
|
|
6
|
+
import { assertDefinedEx as assertDefinedEx3 } from "@xyo-network/react-shared";
|
|
7
|
+
|
|
8
|
+
// src/lib/Builders/SentinelBuilder.ts
|
|
9
|
+
import { assertDefinedEx } from "@xyo-network/react-shared";
|
|
10
|
+
import { MemorySentinel } from "@xyo-network/sentinel";
|
|
11
|
+
var SentinelBuilder = class {
|
|
12
|
+
constructor(config, account) {
|
|
13
|
+
this.config = config;
|
|
14
|
+
this.account = account;
|
|
15
|
+
assertDefinedEx(config, "config was not defined");
|
|
16
|
+
}
|
|
17
|
+
_sentinel;
|
|
18
|
+
get sentinel() {
|
|
19
|
+
return assertDefinedEx(this._sentinel, "this._sentinel not defined upon create");
|
|
20
|
+
}
|
|
21
|
+
static async create(config, account) {
|
|
22
|
+
const instance = new this(config, account);
|
|
23
|
+
instance._sentinel = await instance.buildSentinel();
|
|
24
|
+
return instance;
|
|
25
|
+
}
|
|
26
|
+
async buildSentinel() {
|
|
27
|
+
const params = this.buildParams();
|
|
28
|
+
return await MemorySentinel.create(params);
|
|
29
|
+
}
|
|
30
|
+
buildParams() {
|
|
31
|
+
return {
|
|
32
|
+
account: this.account,
|
|
33
|
+
config: this.config
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
// src/lib/Builders/StorageArchivistBuilder.ts
|
|
39
|
+
import { asArchivistInstance, StorageArchivist, StorageArchivistConfigSchema } from "@xyo-network/archivist";
|
|
40
|
+
import { asNodeInstance } from "@xyo-network/node-model";
|
|
41
|
+
import { assertDefinedEx as assertDefinedEx2 } from "@xyo-network/react-shared";
|
|
42
|
+
var StorageArchivistBuilder = class {
|
|
43
|
+
constructor(config, account, node) {
|
|
44
|
+
this.config = config;
|
|
45
|
+
this.account = account;
|
|
46
|
+
this.node = node;
|
|
47
|
+
}
|
|
48
|
+
_archivist;
|
|
49
|
+
remoteArchivist;
|
|
50
|
+
get archivist() {
|
|
51
|
+
return assertDefinedEx2(this._archivist, "archivist was not defined upon create");
|
|
52
|
+
}
|
|
53
|
+
static async create(config, account, node) {
|
|
54
|
+
const instance = new this(config, account, node);
|
|
55
|
+
instance.remoteArchivist = await instance.findParentArchivist();
|
|
56
|
+
instance._archivist = await instance.buildArchivist();
|
|
57
|
+
return instance;
|
|
58
|
+
}
|
|
59
|
+
async buildArchivist() {
|
|
60
|
+
const config = this.buildConfig();
|
|
61
|
+
return await StorageArchivist.create({ account: this.account, config });
|
|
62
|
+
}
|
|
63
|
+
buildConfig() {
|
|
64
|
+
var _a, _b;
|
|
65
|
+
return {
|
|
66
|
+
name: this.config.name,
|
|
67
|
+
namespace: this.config.namespace,
|
|
68
|
+
parents: {
|
|
69
|
+
commit: this.remoteArchivist ? [(_a = this.remoteArchivist) == null ? void 0 : _a.address] : void 0,
|
|
70
|
+
read: this.remoteArchivist ? [(_b = this.remoteArchivist) == null ? void 0 : _b.address] : void 0
|
|
71
|
+
},
|
|
72
|
+
schema: StorageArchivistConfigSchema,
|
|
73
|
+
storeParentReads: true,
|
|
74
|
+
type: "local"
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
async findParentArchivist() {
|
|
78
|
+
var _a;
|
|
79
|
+
const node = asNodeInstance(this.node, "node not defined");
|
|
80
|
+
const [bridge] = await node.resolve({ name: ["RemoteNodeBridge"] }) ?? [];
|
|
81
|
+
if (bridge) {
|
|
82
|
+
try {
|
|
83
|
+
const [archivist] = await bridge.resolve({ name: ["Archivist"] }) ?? [];
|
|
84
|
+
return asArchivistInstance(archivist);
|
|
85
|
+
} catch (e) {
|
|
86
|
+
console.error("Error Resolving Parent Archivist", (_a = this.node) == null ? void 0 : _a.config.name, this.config);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
// src/lib/Builders/MemoryNodeBuilder.ts
|
|
93
|
+
var MemoryNodeBuilder = class {
|
|
94
|
+
_node;
|
|
95
|
+
get node() {
|
|
96
|
+
return assertDefinedEx3(this._node, "this._node was not defined upon create");
|
|
97
|
+
}
|
|
98
|
+
static async create({ name, node }, account) {
|
|
99
|
+
const instance = new this();
|
|
100
|
+
const memoryNode = node ?? await MemoryNode.create({ account, config: { name, schema: NodeConfigSchema } });
|
|
101
|
+
instance._node = memoryNode;
|
|
102
|
+
return instance;
|
|
103
|
+
}
|
|
104
|
+
/** @deprecated - call specific method that corresponds to a type of archivist (i.e. addArchivistStorage) */
|
|
105
|
+
async addArchivist(account, moduleName, namespace) {
|
|
106
|
+
await this.addArchivistStorage(account, moduleName, namespace);
|
|
107
|
+
}
|
|
108
|
+
async addArchivistMemory(moduleName, account) {
|
|
109
|
+
const config = { name: moduleName, schema: MemoryArchivistConfigSchema };
|
|
110
|
+
const memoryArchivist = await MemoryArchivist.create({ account, config });
|
|
111
|
+
await this.attach(memoryArchivist, true);
|
|
112
|
+
}
|
|
113
|
+
async addArchivistStorage(account, moduleName, namespace) {
|
|
114
|
+
const config = { name: moduleName, namespace };
|
|
115
|
+
const { archivist } = await StorageArchivistBuilder.create(config, account, this.node);
|
|
116
|
+
await this.attach(archivist, true);
|
|
117
|
+
}
|
|
118
|
+
async addBridge(apiDomain, moduleName = "RemoteNodeBridge", account) {
|
|
119
|
+
try {
|
|
120
|
+
const bridge = await HttpBridge.create({
|
|
121
|
+
account,
|
|
122
|
+
config: { name: moduleName, nodeUrl: `${apiDomain}/node`, schema: HttpBridgeConfigSchema, security: { allowAnonymous: true } }
|
|
123
|
+
});
|
|
124
|
+
await this.attach(bridge, true);
|
|
125
|
+
} catch (e) {
|
|
126
|
+
console.error("Error Creating Bridge", e);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
async addSentinel(config, account) {
|
|
130
|
+
const { sentinel } = await SentinelBuilder.create(config, account);
|
|
131
|
+
await this.attach(sentinel, true, true);
|
|
132
|
+
return sentinel;
|
|
133
|
+
}
|
|
134
|
+
async addWitnesses(pluginSetResolver, witnesses = []) {
|
|
135
|
+
await Promise.all(
|
|
136
|
+
pluginSetResolver.witnesses().map(async (pluginSet, index) => {
|
|
137
|
+
var _a;
|
|
138
|
+
const witness = await ((_a = witnesses == null ? void 0 : witnesses[index]) == null ? void 0 : _a.call(witnesses));
|
|
139
|
+
if (witness) {
|
|
140
|
+
try {
|
|
141
|
+
await this.witnessCleanup(witness);
|
|
142
|
+
await this.node.register(witness);
|
|
143
|
+
await this.node.attach(witness.address, true);
|
|
144
|
+
} catch (e) {
|
|
145
|
+
console.error("Error attaching witness", JSON.stringify(pluginSet, null, 2), e);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
})
|
|
149
|
+
);
|
|
150
|
+
}
|
|
151
|
+
async attach(module, external, safeAttach) {
|
|
152
|
+
try {
|
|
153
|
+
if (safeAttach) {
|
|
154
|
+
const existingModule = (await this.node.resolve({ address: [module.address] })).pop();
|
|
155
|
+
if (existingModule) {
|
|
156
|
+
await this.node.detach(existingModule.address);
|
|
157
|
+
await this.node.unregister(existingModule);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
await this.node.register(module);
|
|
161
|
+
await this.node.attach(module.address, external);
|
|
162
|
+
} catch (e) {
|
|
163
|
+
throw Error(`Error adding ${module.config.name ?? module.address} to MemoryNode: ${e}`);
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
async witnessCleanup(witness) {
|
|
167
|
+
if (this.node.registered().includes(witness.address)) {
|
|
168
|
+
const [existingWitness] = await this.node.resolve({ address: [witness.address] });
|
|
169
|
+
await this.node.unregister(existingWitness);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
};
|
|
173
|
+
export {
|
|
174
|
+
MemoryNodeBuilder,
|
|
175
|
+
SentinelBuilder,
|
|
176
|
+
StorageArchivistBuilder
|
|
13
177
|
};
|
|
14
|
-
var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
|
|
15
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
16
|
-
var Builders_exports = {};
|
|
17
|
-
module.exports = __toCommonJS(Builders_exports);
|
|
18
|
-
__reExport(Builders_exports, require("./MemoryNodeBuilder"), module.exports);
|
|
19
|
-
__reExport(Builders_exports, require("./SentinelBuilder"), module.exports);
|
|
20
|
-
__reExport(Builders_exports, require("./StorageArchivistBuilder"), module.exports);
|
|
21
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
22
|
-
0 && (module.exports = {
|
|
23
|
-
...require("./MemoryNodeBuilder"),
|
|
24
|
-
...require("./SentinelBuilder"),
|
|
25
|
-
...require("./StorageArchivistBuilder")
|
|
26
|
-
});
|
|
27
178
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/lib/Builders/index.ts"],"sourcesContent":["export * from './MemoryNodeBuilder'\nexport * from './SentinelBuilder'\nexport * from './StorageArchivistBuilder'\n"],"mappings":";;;;;;;;;;;;;;;AAAA;AAAA;AAAA,6BAAc,gCAAd;AACA,6BAAc,8BADd;AAEA,6BAAc,sCAFd;","names":[]}
|
|
1
|
+
{"version":3,"sources":["../../../../src/lib/Builders/MemoryNodeBuilder.ts","../../../../src/lib/Builders/SentinelBuilder.ts","../../../../src/lib/Builders/StorageArchivistBuilder.ts"],"sourcesContent":["import { AccountInstance } from '@xyo-network/account-model'\nimport { MemoryArchivist, MemoryArchivistConfig, MemoryArchivistConfigSchema } from '@xyo-network/archivist'\nimport { HttpBridge, HttpBridgeConfigSchema } from '@xyo-network/http-bridge'\nimport { ModuleInstance } from '@xyo-network/module'\nimport { MemoryNode } from '@xyo-network/node-memory'\nimport { NodeConfigSchema } from '@xyo-network/node-model'\nimport { PayloadSetPluginResolver } from '@xyo-network/payloadset-plugin'\nimport { assertDefinedEx } from '@xyo-network/react-shared'\nimport { SentinelConfig } from '@xyo-network/sentinel'\nimport { WitnessInstance, WitnessModule } from '@xyo-network/witness'\n\nimport { SentinelBuilder } from './SentinelBuilder'\nimport { StorageArchivistBuilder } from './StorageArchivistBuilder'\n\nexport interface MemoryNodeBuilderConfig {\n name?: string\n node?: MemoryNode\n}\n\nexport class MemoryNodeBuilder {\n private _node: MemoryNode | undefined\n\n get node() {\n return assertDefinedEx(this._node, 'this._node was not defined upon create')\n }\n\n static async create({ name, node }: MemoryNodeBuilderConfig, account?: AccountInstance): Promise<MemoryNodeBuilder> {\n const instance = new this()\n\n const memoryNode: MemoryNode = node ?? (await MemoryNode.create({ account, config: { name, schema: NodeConfigSchema } }))\n instance._node = memoryNode\n return instance\n }\n\n /** @deprecated - call specific method that corresponds to a type of archivist (i.e. addArchivistStorage) */\n async addArchivist(account: AccountInstance, moduleName?: string, namespace?: string) {\n await this.addArchivistStorage(account, moduleName, namespace)\n }\n\n async addArchivistMemory(moduleName?: string, account?: AccountInstance) {\n const config: MemoryArchivistConfig = { name: moduleName, schema: MemoryArchivistConfigSchema }\n const memoryArchivist = await MemoryArchivist.create({ account, config })\n\n await this.attach(memoryArchivist, true)\n }\n\n async addArchivistStorage(account: AccountInstance, moduleName?: string, namespace?: string) {\n const config = { name: moduleName, namespace }\n const { archivist } = await StorageArchivistBuilder.create(config, account, this.node)\n\n await this.attach(archivist, true)\n }\n\n async addBridge(apiDomain: string, moduleName = 'RemoteNodeBridge', account?: AccountInstance) {\n try {\n const bridge = await HttpBridge.create({\n account,\n config: { name: moduleName, nodeUrl: `${apiDomain}/node`, schema: HttpBridgeConfigSchema, security: { allowAnonymous: true } },\n })\n await this.attach(bridge, true)\n } catch (e) {\n console.error('Error Creating Bridge', e)\n }\n }\n\n async addSentinel(config: SentinelConfig, account: AccountInstance) {\n const { sentinel } = await SentinelBuilder.create(config, account)\n await this.attach(sentinel, true, true)\n return sentinel\n }\n\n async addWitnesses(pluginSetResolver: PayloadSetPluginResolver, witnesses: (() => Promise<WitnessInstance>)[] = []) {\n await Promise.all(\n pluginSetResolver.witnesses().map(async (pluginSet, index) => {\n // Pass the prebuilt witness at the same index\n const witness = await witnesses?.[index]?.()\n if (witness) {\n try {\n await this.witnessCleanup(witness)\n await this.node.register(witness)\n await this.node.attach(witness.address, true)\n } catch (e) {\n console.error('Error attaching witness', JSON.stringify(pluginSet, null, 2), e)\n }\n }\n }),\n )\n }\n\n async attach(module: ModuleInstance, external?: boolean, safeAttach?: boolean) {\n try {\n if (safeAttach) {\n const existingModule = (await this.node.resolve({ address: [module.address] })).pop()\n if (existingModule) {\n await this.node.detach(existingModule.address)\n await this.node.unregister(existingModule)\n }\n }\n await this.node.register(module)\n await this.node.attach(module.address, external)\n } catch (e) {\n throw Error(`Error adding ${module.config.name ?? module.address} to MemoryNode: ${e}`)\n }\n }\n\n private async witnessCleanup(witness: WitnessModule) {\n if (this.node.registered().includes(witness.address)) {\n const [existingWitness] = await this.node.resolve({ address: [witness.address] })\n await this.node.unregister(existingWitness)\n }\n }\n}\n","import { AccountInstance } from '@xyo-network/account-model'\nimport { assertDefinedEx } from '@xyo-network/react-shared'\nimport { MemorySentinel, MemorySentinelParams, SentinelConfig } from '@xyo-network/sentinel'\n\nexport class SentinelBuilder {\n private _sentinel: MemorySentinel | undefined\n\n protected constructor(\n private config: SentinelConfig,\n private account: AccountInstance,\n ) {\n assertDefinedEx(config, 'config was not defined')\n }\n\n get sentinel() {\n return assertDefinedEx(this._sentinel, 'this._sentinel not defined upon create')\n }\n\n static async create(config: SentinelConfig, account: AccountInstance): Promise<SentinelBuilder> {\n const instance = new this(config, account)\n instance._sentinel = await instance.buildSentinel()\n return instance\n }\n\n async buildSentinel() {\n const params = this.buildParams()\n return (await MemorySentinel.create(params)) as MemorySentinel\n }\n\n private buildParams(): MemorySentinelParams {\n return {\n account: this.account,\n config: this.config,\n }\n }\n}\n","import { AccountInstance } from '@xyo-network/account-model'\nimport { ArchivistModule, asArchivistInstance, StorageArchivist, StorageArchivistConfig, StorageArchivistConfigSchema } from '@xyo-network/archivist'\nimport { MemoryNode } from '@xyo-network/node-memory'\nimport { asNodeInstance } from '@xyo-network/node-model'\nimport { assertDefinedEx } from '@xyo-network/react-shared'\n\nexport interface ArchivistBuilderConfig {\n name?: string\n namespace?: string\n}\nexport class StorageArchivistBuilder {\n private _archivist: StorageArchivist | undefined\n private remoteArchivist: ArchivistModule | undefined\n\n protected constructor(\n private config: ArchivistBuilderConfig,\n private account: AccountInstance,\n private node?: MemoryNode,\n ) {}\n\n get archivist() {\n return assertDefinedEx(this._archivist, 'archivist was not defined upon create')\n }\n\n static async create(config: ArchivistBuilderConfig, account: AccountInstance, node: MemoryNode): Promise<StorageArchivistBuilder> {\n const instance = new this(config, account, node)\n instance.remoteArchivist = await instance.findParentArchivist()\n instance._archivist = await instance.buildArchivist()\n return instance\n }\n\n async buildArchivist() {\n const config = this.buildConfig()\n return (await StorageArchivist.create({ account: this.account, config })) as StorageArchivist\n }\n\n buildConfig(): StorageArchivistConfig {\n return {\n name: this.config.name,\n namespace: this.config.namespace,\n parents: {\n commit: this.remoteArchivist ? [this.remoteArchivist?.address] : undefined,\n read: this.remoteArchivist ? [this.remoteArchivist?.address] : undefined,\n },\n schema: StorageArchivistConfigSchema,\n storeParentReads: true,\n type: 'local',\n }\n }\n\n async findParentArchivist() {\n const node = asNodeInstance(this.node, 'node not defined')\n const [bridge] = (await node.resolve({ name: ['RemoteNodeBridge'] })) ?? []\n if (bridge) {\n try {\n const [archivist] = (await bridge.resolve({ name: ['Archivist'] })) ?? []\n return asArchivistInstance(archivist)\n } catch (e) {\n console.error('Error Resolving Parent Archivist', this.node?.config.name, this.config)\n }\n }\n }\n}\n"],"mappings":"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","names":["assertDefinedEx","assertDefinedEx","assertDefinedEx"]}
|
|
@@ -0,0 +1,59 @@
|
|
|
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 __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/lib/ModuleAccountPaths.ts
|
|
21
|
+
var ModuleAccountPaths_exports = {};
|
|
22
|
+
__export(ModuleAccountPaths_exports, {
|
|
23
|
+
GlobalNodeOffsetPath: () => GlobalNodeOffsetPath,
|
|
24
|
+
RemoteNodeArchivistOffsetPaths: () => RemoteNodeArchivistOffsetPaths,
|
|
25
|
+
RemoteNodeOffsetPaths: () => RemoteNodeOffsetPaths
|
|
26
|
+
});
|
|
27
|
+
module.exports = __toCommonJS(ModuleAccountPaths_exports);
|
|
28
|
+
|
|
29
|
+
// src/lib/ModuleNames.ts
|
|
30
|
+
var RootStorageArchivist = "RootStorageArchivist";
|
|
31
|
+
|
|
32
|
+
// src/lib/ModuleAccountPaths.ts
|
|
33
|
+
var GlobalNodeOffsetPath = "15";
|
|
34
|
+
var RemoteNodeOffsetPaths = {
|
|
35
|
+
Kerplunk: "112",
|
|
36
|
+
Local: "111",
|
|
37
|
+
Main: "113"
|
|
38
|
+
};
|
|
39
|
+
var RemoteNodeArchivistOffsetPaths = {
|
|
40
|
+
Kerplunk: {
|
|
41
|
+
MemoryNode: "117",
|
|
42
|
+
[RootStorageArchivist]: "119"
|
|
43
|
+
},
|
|
44
|
+
Local: {
|
|
45
|
+
MemoryNode: "114",
|
|
46
|
+
[RootStorageArchivist]: "116"
|
|
47
|
+
},
|
|
48
|
+
Main: {
|
|
49
|
+
MemoryNode: "120",
|
|
50
|
+
[RootStorageArchivist]: "122"
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
54
|
+
0 && (module.exports = {
|
|
55
|
+
GlobalNodeOffsetPath,
|
|
56
|
+
RemoteNodeArchivistOffsetPaths,
|
|
57
|
+
RemoteNodeOffsetPaths
|
|
58
|
+
});
|
|
59
|
+
//# sourceMappingURL=ModuleAccountPaths.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/lib/ModuleAccountPaths.ts","../../../src/lib/ModuleNames.ts"],"sourcesContent":["import { RootStorageArchivist } from './ModuleNames'\n\nexport const GlobalNodeOffsetPath = '15'\n\nexport const RemoteNodeOffsetPaths: Record<string, string> = {\n Kerplunk: '112',\n Local: '111',\n Main: '113',\n}\n\nexport const RemoteNodeArchivistOffsetPaths: Record<string, Record<string, string>> = {\n Kerplunk: {\n MemoryNode: '117',\n [RootStorageArchivist]: '119',\n },\n Local: {\n MemoryNode: '114',\n [RootStorageArchivist]: '116',\n },\n Main: {\n MemoryNode: '120',\n [RootStorageArchivist]: '122',\n },\n}\n","export const GlobalNode = 'GlobalNode'\n\nexport const RootStorageArchivist = 'RootStorageArchivist'\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACEO,IAAM,uBAAuB;;;ADA7B,IAAM,uBAAuB;AAE7B,IAAM,wBAAgD;AAAA,EAC3D,UAAU;AAAA,EACV,OAAO;AAAA,EACP,MAAM;AACR;AAEO,IAAM,iCAAyE;AAAA,EACpF,UAAU;AAAA,IACR,YAAY;AAAA,IACZ,CAAC,oBAAoB,GAAG;AAAA,EAC1B;AAAA,EACA,OAAO;AAAA,IACL,YAAY;AAAA,IACZ,CAAC,oBAAoB,GAAG;AAAA,EAC1B;AAAA,EACA,MAAM;AAAA,IACJ,YAAY;AAAA,IACZ,CAAC,oBAAoB,GAAG;AAAA,EAC1B;AACF;","names":[]}
|