@xyo-network/module-abstract 2.111.3 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/neutral/index.d.ts +221 -6
- package/package.json +23 -42
- package/xy.config.ts +12 -0
- package/dist/browser/AbstractModule.d.cts +0 -104
- package/dist/browser/AbstractModule.d.cts.map +0 -1
- package/dist/browser/AbstractModule.d.mts +0 -104
- package/dist/browser/AbstractModule.d.mts.map +0 -1
- package/dist/browser/AbstractModule.d.ts +0 -104
- package/dist/browser/AbstractModule.d.ts.map +0 -1
- package/dist/browser/AbstractModuleInstance.d.cts +0 -54
- package/dist/browser/AbstractModuleInstance.d.cts.map +0 -1
- package/dist/browser/AbstractModuleInstance.d.mts +0 -54
- package/dist/browser/AbstractModuleInstance.d.mts.map +0 -1
- package/dist/browser/AbstractModuleInstance.d.ts +0 -54
- package/dist/browser/AbstractModuleInstance.d.ts.map +0 -1
- package/dist/browser/BaseEmitter.d.cts +0 -17
- package/dist/browser/BaseEmitter.d.cts.map +0 -1
- package/dist/browser/BaseEmitter.d.mts +0 -17
- package/dist/browser/BaseEmitter.d.mts.map +0 -1
- package/dist/browser/BaseEmitter.d.ts +0 -17
- package/dist/browser/BaseEmitter.d.ts.map +0 -1
- package/dist/browser/Error.d.cts +0 -19
- package/dist/browser/Error.d.cts.map +0 -1
- package/dist/browser/Error.d.mts +0 -19
- package/dist/browser/Error.d.mts.map +0 -1
- package/dist/browser/Error.d.ts +0 -19
- package/dist/browser/Error.d.ts.map +0 -1
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.d.cts +0 -17
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.d.cts.map +0 -1
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.d.mts +0 -17
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.d.mts.map +0 -1
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.d.ts +0 -17
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.d.ts.map +0 -1
- package/dist/browser/QueryValidator/QueryValidator.d.cts +0 -8
- package/dist/browser/QueryValidator/QueryValidator.d.cts.map +0 -1
- package/dist/browser/QueryValidator/QueryValidator.d.mts +0 -8
- package/dist/browser/QueryValidator/QueryValidator.d.mts.map +0 -1
- package/dist/browser/QueryValidator/QueryValidator.d.ts +0 -8
- package/dist/browser/QueryValidator/QueryValidator.d.ts.map +0 -1
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.cts +0 -18
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.cts.map +0 -1
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.mts +0 -18
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.mts.map +0 -1
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.ts +0 -18
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.ts.map +0 -1
- package/dist/browser/QueryValidator/index.d.cts +0 -4
- package/dist/browser/QueryValidator/index.d.cts.map +0 -1
- package/dist/browser/QueryValidator/index.d.mts +0 -4
- package/dist/browser/QueryValidator/index.d.mts.map +0 -1
- package/dist/browser/QueryValidator/index.d.ts +0 -4
- package/dist/browser/QueryValidator/index.d.ts.map +0 -1
- package/dist/browser/determineAccount.d.cts +0 -14
- package/dist/browser/determineAccount.d.cts.map +0 -1
- package/dist/browser/determineAccount.d.mts +0 -14
- package/dist/browser/determineAccount.d.mts.map +0 -1
- package/dist/browser/determineAccount.d.ts +0 -14
- package/dist/browser/determineAccount.d.ts.map +0 -1
- package/dist/browser/index.cjs +0 -1069
- package/dist/browser/index.cjs.map +0 -1
- package/dist/browser/index.d.cts +0 -6
- package/dist/browser/index.d.cts.map +0 -1
- package/dist/browser/index.d.mts +0 -6
- package/dist/browser/index.d.mts.map +0 -1
- package/dist/browser/index.d.ts +0 -6
- package/dist/browser/index.d.ts.map +0 -1
- package/dist/browser/index.mjs +0 -1048
- package/dist/browser/index.mjs.map +0 -1
- package/dist/neutral/AbstractModule.d.cts +0 -104
- package/dist/neutral/AbstractModule.d.cts.map +0 -1
- package/dist/neutral/AbstractModule.d.mts +0 -104
- package/dist/neutral/AbstractModule.d.mts.map +0 -1
- package/dist/neutral/AbstractModule.d.ts +0 -104
- package/dist/neutral/AbstractModule.d.ts.map +0 -1
- package/dist/neutral/AbstractModuleInstance.d.cts +0 -54
- package/dist/neutral/AbstractModuleInstance.d.cts.map +0 -1
- package/dist/neutral/AbstractModuleInstance.d.mts +0 -54
- package/dist/neutral/AbstractModuleInstance.d.mts.map +0 -1
- package/dist/neutral/AbstractModuleInstance.d.ts +0 -54
- package/dist/neutral/AbstractModuleInstance.d.ts.map +0 -1
- package/dist/neutral/BaseEmitter.d.cts +0 -17
- package/dist/neutral/BaseEmitter.d.cts.map +0 -1
- package/dist/neutral/BaseEmitter.d.mts +0 -17
- package/dist/neutral/BaseEmitter.d.mts.map +0 -1
- package/dist/neutral/BaseEmitter.d.ts +0 -17
- package/dist/neutral/BaseEmitter.d.ts.map +0 -1
- package/dist/neutral/Error.d.cts +0 -19
- package/dist/neutral/Error.d.cts.map +0 -1
- package/dist/neutral/Error.d.mts +0 -19
- package/dist/neutral/Error.d.mts.map +0 -1
- package/dist/neutral/Error.d.ts +0 -19
- package/dist/neutral/Error.d.ts.map +0 -1
- package/dist/neutral/QueryValidator/ModuleConfigQueryValidator.d.cts +0 -17
- package/dist/neutral/QueryValidator/ModuleConfigQueryValidator.d.cts.map +0 -1
- package/dist/neutral/QueryValidator/ModuleConfigQueryValidator.d.mts +0 -17
- package/dist/neutral/QueryValidator/ModuleConfigQueryValidator.d.mts.map +0 -1
- package/dist/neutral/QueryValidator/ModuleConfigQueryValidator.d.ts +0 -17
- package/dist/neutral/QueryValidator/ModuleConfigQueryValidator.d.ts.map +0 -1
- package/dist/neutral/QueryValidator/QueryValidator.d.cts +0 -8
- package/dist/neutral/QueryValidator/QueryValidator.d.cts.map +0 -1
- package/dist/neutral/QueryValidator/QueryValidator.d.mts +0 -8
- package/dist/neutral/QueryValidator/QueryValidator.d.mts.map +0 -1
- package/dist/neutral/QueryValidator/QueryValidator.d.ts +0 -8
- package/dist/neutral/QueryValidator/QueryValidator.d.ts.map +0 -1
- package/dist/neutral/QueryValidator/SupportedQueryValidator.d.cts +0 -18
- package/dist/neutral/QueryValidator/SupportedQueryValidator.d.cts.map +0 -1
- package/dist/neutral/QueryValidator/SupportedQueryValidator.d.mts +0 -18
- package/dist/neutral/QueryValidator/SupportedQueryValidator.d.mts.map +0 -1
- package/dist/neutral/QueryValidator/SupportedQueryValidator.d.ts +0 -18
- package/dist/neutral/QueryValidator/SupportedQueryValidator.d.ts.map +0 -1
- package/dist/neutral/QueryValidator/index.d.cts +0 -4
- package/dist/neutral/QueryValidator/index.d.cts.map +0 -1
- package/dist/neutral/QueryValidator/index.d.mts +0 -4
- package/dist/neutral/QueryValidator/index.d.mts.map +0 -1
- package/dist/neutral/QueryValidator/index.d.ts +0 -4
- package/dist/neutral/QueryValidator/index.d.ts.map +0 -1
- package/dist/neutral/determineAccount.d.cts +0 -14
- package/dist/neutral/determineAccount.d.cts.map +0 -1
- package/dist/neutral/determineAccount.d.mts +0 -14
- package/dist/neutral/determineAccount.d.mts.map +0 -1
- package/dist/neutral/determineAccount.d.ts +0 -14
- package/dist/neutral/determineAccount.d.ts.map +0 -1
- package/dist/neutral/index.cjs +0 -1069
- package/dist/neutral/index.cjs.map +0 -1
- package/dist/neutral/index.d.cts +0 -6
- package/dist/neutral/index.d.cts.map +0 -1
- package/dist/neutral/index.d.mts +0 -6
- package/dist/neutral/index.d.mts.map +0 -1
- package/dist/neutral/index.d.ts.map +0 -1
- package/dist/node/AbstractModule.d.cts +0 -104
- package/dist/node/AbstractModule.d.cts.map +0 -1
- package/dist/node/AbstractModule.d.mts +0 -104
- package/dist/node/AbstractModule.d.mts.map +0 -1
- package/dist/node/AbstractModule.d.ts +0 -104
- package/dist/node/AbstractModule.d.ts.map +0 -1
- package/dist/node/AbstractModuleInstance.d.cts +0 -54
- package/dist/node/AbstractModuleInstance.d.cts.map +0 -1
- package/dist/node/AbstractModuleInstance.d.mts +0 -54
- package/dist/node/AbstractModuleInstance.d.mts.map +0 -1
- package/dist/node/AbstractModuleInstance.d.ts +0 -54
- package/dist/node/AbstractModuleInstance.d.ts.map +0 -1
- package/dist/node/BaseEmitter.d.cts +0 -17
- package/dist/node/BaseEmitter.d.cts.map +0 -1
- package/dist/node/BaseEmitter.d.mts +0 -17
- package/dist/node/BaseEmitter.d.mts.map +0 -1
- package/dist/node/BaseEmitter.d.ts +0 -17
- package/dist/node/BaseEmitter.d.ts.map +0 -1
- package/dist/node/Error.d.cts +0 -19
- package/dist/node/Error.d.cts.map +0 -1
- package/dist/node/Error.d.mts +0 -19
- package/dist/node/Error.d.mts.map +0 -1
- package/dist/node/Error.d.ts +0 -19
- package/dist/node/Error.d.ts.map +0 -1
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.cts +0 -17
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.cts.map +0 -1
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.mts +0 -17
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.mts.map +0 -1
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.ts +0 -17
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.ts.map +0 -1
- package/dist/node/QueryValidator/QueryValidator.d.cts +0 -8
- package/dist/node/QueryValidator/QueryValidator.d.cts.map +0 -1
- package/dist/node/QueryValidator/QueryValidator.d.mts +0 -8
- package/dist/node/QueryValidator/QueryValidator.d.mts.map +0 -1
- package/dist/node/QueryValidator/QueryValidator.d.ts +0 -8
- package/dist/node/QueryValidator/QueryValidator.d.ts.map +0 -1
- package/dist/node/QueryValidator/SupportedQueryValidator.d.cts +0 -18
- package/dist/node/QueryValidator/SupportedQueryValidator.d.cts.map +0 -1
- package/dist/node/QueryValidator/SupportedQueryValidator.d.mts +0 -18
- package/dist/node/QueryValidator/SupportedQueryValidator.d.mts.map +0 -1
- package/dist/node/QueryValidator/SupportedQueryValidator.d.ts +0 -18
- package/dist/node/QueryValidator/SupportedQueryValidator.d.ts.map +0 -1
- package/dist/node/QueryValidator/index.d.cts +0 -4
- package/dist/node/QueryValidator/index.d.cts.map +0 -1
- package/dist/node/QueryValidator/index.d.mts +0 -4
- package/dist/node/QueryValidator/index.d.mts.map +0 -1
- package/dist/node/QueryValidator/index.d.ts +0 -4
- package/dist/node/QueryValidator/index.d.ts.map +0 -1
- package/dist/node/determineAccount.d.cts +0 -14
- package/dist/node/determineAccount.d.cts.map +0 -1
- package/dist/node/determineAccount.d.mts +0 -14
- package/dist/node/determineAccount.d.mts.map +0 -1
- package/dist/node/determineAccount.d.ts +0 -14
- package/dist/node/determineAccount.d.ts.map +0 -1
- package/dist/node/index.cjs +0 -1099
- package/dist/node/index.cjs.map +0 -1
- package/dist/node/index.d.cts +0 -6
- package/dist/node/index.d.cts.map +0 -1
- package/dist/node/index.d.mts +0 -6
- package/dist/node/index.d.mts.map +0 -1
- package/dist/node/index.d.ts +0 -6
- package/dist/node/index.d.ts.map +0 -1
- package/dist/node/index.mjs +0 -1068
- package/dist/node/index.mjs.map +0 -1
package/dist/neutral/index.cjs
DELETED
|
@@ -1,1069 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
7
|
-
var __export = (target, all) => {
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
11
|
-
var __copyProps = (to, from, except, desc) => {
|
|
12
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
-
for (let key of __getOwnPropNames(from))
|
|
14
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
19
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
20
|
-
|
|
21
|
-
// src/index.ts
|
|
22
|
-
var src_exports = {};
|
|
23
|
-
__export(src_exports, {
|
|
24
|
-
AbstractModule: () => AbstractModule,
|
|
25
|
-
AbstractModuleInstance: () => AbstractModuleInstance,
|
|
26
|
-
BaseEmitter: () => BaseEmitter,
|
|
27
|
-
ModuleConfigQueryValidator: () => ModuleConfigQueryValidator,
|
|
28
|
-
ModuleErrorBuilder: () => ModuleErrorBuilder,
|
|
29
|
-
SupportedQueryValidator: () => SupportedQueryValidator,
|
|
30
|
-
isQuerySupportedByModule: () => isQuerySupportedByModule
|
|
31
|
-
});
|
|
32
|
-
module.exports = __toCommonJS(src_exports);
|
|
33
|
-
|
|
34
|
-
// src/AbstractModule.ts
|
|
35
|
-
var import_assert2 = require("@xylabs/assert");
|
|
36
|
-
var import_error = require("@xylabs/error");
|
|
37
|
-
var import_exists = require("@xylabs/exists");
|
|
38
|
-
var import_forget = require("@xylabs/forget");
|
|
39
|
-
var import_lodash = require("@xylabs/lodash");
|
|
40
|
-
var import_logger = require("@xylabs/logger");
|
|
41
|
-
var import_object2 = require("@xylabs/object");
|
|
42
|
-
var import_promise = require("@xylabs/promise");
|
|
43
|
-
var import_account2 = require("@xyo-network/account");
|
|
44
|
-
var import_archivist_model = require("@xyo-network/archivist-model");
|
|
45
|
-
var import_boundwitness_builder = require("@xyo-network/boundwitness-builder");
|
|
46
|
-
var import_boundwitness_wrapper3 = require("@xyo-network/boundwitness-wrapper");
|
|
47
|
-
var import_config_payload_plugin = require("@xyo-network/config-payload-plugin");
|
|
48
|
-
var import_module_model = require("@xyo-network/module-model");
|
|
49
|
-
var import_payload_builder2 = require("@xyo-network/payload-builder");
|
|
50
|
-
var import_query_payload_plugin = require("@xyo-network/query-payload-plugin");
|
|
51
|
-
var import_lru_cache = require("lru-cache");
|
|
52
|
-
|
|
53
|
-
// src/BaseEmitter.ts
|
|
54
|
-
var import_object = require("@xylabs/object");
|
|
55
|
-
var import_module_events = require("@xyo-network/module-events");
|
|
56
|
-
var BaseEmitter = class extends import_object.Base {
|
|
57
|
-
static {
|
|
58
|
-
__name(this, "BaseEmitter");
|
|
59
|
-
}
|
|
60
|
-
// just here to query types
|
|
61
|
-
eventData = {};
|
|
62
|
-
events;
|
|
63
|
-
constructor(params) {
|
|
64
|
-
super(params);
|
|
65
|
-
this.events = new import_module_events.Events();
|
|
66
|
-
}
|
|
67
|
-
clearListeners(eventNames) {
|
|
68
|
-
return this.events.clearListeners(eventNames);
|
|
69
|
-
}
|
|
70
|
-
emit(eventName, eventArgs) {
|
|
71
|
-
return this.events.emit(eventName, eventArgs);
|
|
72
|
-
}
|
|
73
|
-
emitSerial(eventName, eventArgs) {
|
|
74
|
-
return this.events.emitSerial(eventName, eventArgs);
|
|
75
|
-
}
|
|
76
|
-
listenerCount(eventNames) {
|
|
77
|
-
return this.events.listenerCount(eventNames);
|
|
78
|
-
}
|
|
79
|
-
off(eventNames, listener) {
|
|
80
|
-
return this.events.off(eventNames, listener);
|
|
81
|
-
}
|
|
82
|
-
offAny(listener) {
|
|
83
|
-
return this.events.offAny(listener);
|
|
84
|
-
}
|
|
85
|
-
on(eventNames, listener) {
|
|
86
|
-
return this.events.on(eventNames, listener);
|
|
87
|
-
}
|
|
88
|
-
onAny(listener) {
|
|
89
|
-
return this.events.onAny(listener);
|
|
90
|
-
}
|
|
91
|
-
once(eventName, listener) {
|
|
92
|
-
return this.events.once(eventName, listener);
|
|
93
|
-
}
|
|
94
|
-
};
|
|
95
|
-
|
|
96
|
-
// src/determineAccount.ts
|
|
97
|
-
var import_assert = require("@xylabs/assert");
|
|
98
|
-
var import_account = require("@xyo-network/account");
|
|
99
|
-
var isDetermineAccountFromAccountParams = /* @__PURE__ */ __name((params) => {
|
|
100
|
-
(0, import_assert.assertEx)(!params.accountPath, () => "accountPath may not be provided when account is provided");
|
|
101
|
-
return !!params.account;
|
|
102
|
-
}, "isDetermineAccountFromAccountParams");
|
|
103
|
-
var isDetermineAccountFromWalletParams = /* @__PURE__ */ __name((params) => {
|
|
104
|
-
return !!params.wallet;
|
|
105
|
-
}, "isDetermineAccountFromWalletParams");
|
|
106
|
-
async function determineAccount(params, allowRandomAccount = true) {
|
|
107
|
-
if (isDetermineAccountFromAccountParams(params)) {
|
|
108
|
-
if (params.account === "random") {
|
|
109
|
-
(0, import_assert.assertEx)(allowRandomAccount, () => "Random address not allowed");
|
|
110
|
-
return await import_account.Account.random();
|
|
111
|
-
}
|
|
112
|
-
return params.account;
|
|
113
|
-
}
|
|
114
|
-
if (isDetermineAccountFromWalletParams(params)) {
|
|
115
|
-
return (0, import_assert.assertEx)(params.accountPath ? await params.wallet.derivePath(params.accountPath) : params.wallet, () => "Failed to derive account from path");
|
|
116
|
-
}
|
|
117
|
-
console.warn("AbstractModule.determineAccount: No account or wallet provided - Creating Random account");
|
|
118
|
-
return await import_account.Account.random();
|
|
119
|
-
}
|
|
120
|
-
__name(determineAccount, "determineAccount");
|
|
121
|
-
|
|
122
|
-
// src/Error.ts
|
|
123
|
-
var import_payload_builder = require("@xyo-network/payload-builder");
|
|
124
|
-
var import_payload_model = require("@xyo-network/payload-model");
|
|
125
|
-
var ModuleErrorBuilder = class extends import_payload_builder.PayloadBuilder {
|
|
126
|
-
static {
|
|
127
|
-
__name(this, "ModuleErrorBuilder");
|
|
128
|
-
}
|
|
129
|
-
_details;
|
|
130
|
-
_message;
|
|
131
|
-
_name;
|
|
132
|
-
_query;
|
|
133
|
-
_sources;
|
|
134
|
-
constructor() {
|
|
135
|
-
super({
|
|
136
|
-
schema: import_payload_model.ModuleErrorSchema
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
build() {
|
|
140
|
-
this.fields({
|
|
141
|
-
details: this._details,
|
|
142
|
-
message: this._message,
|
|
143
|
-
name: this._name,
|
|
144
|
-
query: this._query,
|
|
145
|
-
schema: import_payload_model.ModuleErrorSchema,
|
|
146
|
-
sources: this._sources
|
|
147
|
-
});
|
|
148
|
-
return super.build();
|
|
149
|
-
}
|
|
150
|
-
details(details) {
|
|
151
|
-
this._details = details;
|
|
152
|
-
return this;
|
|
153
|
-
}
|
|
154
|
-
message(message) {
|
|
155
|
-
this._message = message;
|
|
156
|
-
return this;
|
|
157
|
-
}
|
|
158
|
-
name(name) {
|
|
159
|
-
this._name = name;
|
|
160
|
-
return this;
|
|
161
|
-
}
|
|
162
|
-
query(query) {
|
|
163
|
-
this._query = query;
|
|
164
|
-
return this;
|
|
165
|
-
}
|
|
166
|
-
sources(sources) {
|
|
167
|
-
this._sources = sources;
|
|
168
|
-
return this;
|
|
169
|
-
}
|
|
170
|
-
};
|
|
171
|
-
|
|
172
|
-
// src/QueryValidator/ModuleConfigQueryValidator.ts
|
|
173
|
-
var import_boundwitness_wrapper = require("@xyo-network/boundwitness-wrapper");
|
|
174
|
-
var delimiter = "";
|
|
175
|
-
var ModuleConfigQueryValidator = class {
|
|
176
|
-
static {
|
|
177
|
-
__name(this, "ModuleConfigQueryValidator");
|
|
178
|
-
}
|
|
179
|
-
allowed = {};
|
|
180
|
-
disallowed = {};
|
|
181
|
-
hasAllowedRules;
|
|
182
|
-
hasDisallowedRules;
|
|
183
|
-
hasRules;
|
|
184
|
-
constructor(config) {
|
|
185
|
-
if (config?.security?.allowed) {
|
|
186
|
-
for (const [schema, addresses] of Object.entries(config.security?.allowed)) {
|
|
187
|
-
this.allowed[schema] = addresses.map(toAddressesString);
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
if (config?.security?.disallowed) {
|
|
191
|
-
for (const [schema, addresses] of Object.entries(config.security?.disallowed)) {
|
|
192
|
-
this.disallowed[schema] = addresses.map(toAddressesString);
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
this.hasAllowedRules = Object.keys(this.allowed).length > 0;
|
|
196
|
-
this.hasDisallowedRules = Object.keys(this.disallowed).length > 0;
|
|
197
|
-
this.hasRules = this.hasAllowedRules || this.hasDisallowedRules;
|
|
198
|
-
}
|
|
199
|
-
queryable = /* @__PURE__ */ __name(async (query, payloads) => {
|
|
200
|
-
if (!this.hasRules) return true;
|
|
201
|
-
const addresses = query.addresses;
|
|
202
|
-
if (addresses.length === 0) return false;
|
|
203
|
-
const wrapper = await import_boundwitness_wrapper.QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
204
|
-
const schema = (await wrapper.getQuery()).schema;
|
|
205
|
-
return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses);
|
|
206
|
-
}, "queryable");
|
|
207
|
-
queryAllowed = /* @__PURE__ */ __name((schema, addresses) => {
|
|
208
|
-
if (!this.hasAllowedRules) return true;
|
|
209
|
-
if (addresses.length > 1) {
|
|
210
|
-
const signatories = toAddressesString(addresses);
|
|
211
|
-
const validCosigners = this.allowed?.[schema]?.includes(signatories);
|
|
212
|
-
if (validCosigners) return true;
|
|
213
|
-
}
|
|
214
|
-
return addresses.every((address) => this.allowed?.[schema]?.includes(address) || false);
|
|
215
|
-
}, "queryAllowed");
|
|
216
|
-
queryDisallowed = /* @__PURE__ */ __name((schema, addresses) => {
|
|
217
|
-
if (!this.hasDisallowedRules) return false;
|
|
218
|
-
return addresses.some((address) => this.disallowed?.[schema]?.includes(address));
|
|
219
|
-
}, "queryDisallowed");
|
|
220
|
-
};
|
|
221
|
-
var toAddressesString = /* @__PURE__ */ __name((addresses) => {
|
|
222
|
-
return Array.isArray(addresses) ? addresses.sort().map((address) => address.toLowerCase()).join(delimiter) : addresses.toLowerCase();
|
|
223
|
-
}, "toAddressesString");
|
|
224
|
-
|
|
225
|
-
// src/QueryValidator/SupportedQueryValidator.ts
|
|
226
|
-
var import_boundwitness_wrapper2 = require("@xyo-network/boundwitness-wrapper");
|
|
227
|
-
var isQuerySupportedByModule = /* @__PURE__ */ __name(async (mod, query, payloads) => {
|
|
228
|
-
const wrapper = await import_boundwitness_wrapper2.QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
229
|
-
const schema = (await wrapper.getQuery()).schema;
|
|
230
|
-
return mod.queries.includes(schema);
|
|
231
|
-
}, "isQuerySupportedByModule");
|
|
232
|
-
var SupportedQueryValidator = class {
|
|
233
|
-
static {
|
|
234
|
-
__name(this, "SupportedQueryValidator");
|
|
235
|
-
}
|
|
236
|
-
mod;
|
|
237
|
-
constructor(mod) {
|
|
238
|
-
this.mod = mod;
|
|
239
|
-
this.queryable = (query, payloads) => {
|
|
240
|
-
return isQuerySupportedByModule(this.mod, query, payloads);
|
|
241
|
-
};
|
|
242
|
-
}
|
|
243
|
-
queryable;
|
|
244
|
-
};
|
|
245
|
-
|
|
246
|
-
// src/AbstractModule.ts
|
|
247
|
-
var MODULE_NOT_STARTED = "Module not Started";
|
|
248
|
-
var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
249
|
-
static {
|
|
250
|
-
__name(this, "AbstractModule");
|
|
251
|
-
}
|
|
252
|
-
static allowRandomAccount = true;
|
|
253
|
-
static configSchemas = [
|
|
254
|
-
import_module_model.ModuleConfigSchema
|
|
255
|
-
];
|
|
256
|
-
static defaultConfigSchema = import_module_model.ModuleConfigSchema;
|
|
257
|
-
static defaultLogger = new import_logger.ConsoleLogger(import_logger.LogLevel.warn);
|
|
258
|
-
static enableLazyLoad = false;
|
|
259
|
-
static labels = {};
|
|
260
|
-
static uniqueName = (0, import_object2.globallyUnique)("AbstractModule", _AbstractModule, "xyo");
|
|
261
|
-
static privateConstructorKey = Date.now().toString();
|
|
262
|
-
_account;
|
|
263
|
-
// cache manifest based on maxDepth
|
|
264
|
-
_cachedManifests = new import_lru_cache.LRUCache({
|
|
265
|
-
max: 10,
|
|
266
|
-
ttl: 1e3 * 60 * 5
|
|
267
|
-
});
|
|
268
|
-
_lastError;
|
|
269
|
-
_startPromise = void 0;
|
|
270
|
-
_started = void 0;
|
|
271
|
-
moduleConfigQueryValidator;
|
|
272
|
-
supportedQueryValidator;
|
|
273
|
-
_busyCount = 0;
|
|
274
|
-
_logger = void 0;
|
|
275
|
-
_status = "stopped";
|
|
276
|
-
constructor(privateConstructorKey, params, account) {
|
|
277
|
-
(0, import_assert2.assertEx)(_AbstractModule.privateConstructorKey === privateConstructorKey, () => "Use create function instead of constructor");
|
|
278
|
-
const mutatedParams = {
|
|
279
|
-
...params
|
|
280
|
-
};
|
|
281
|
-
super(mutatedParams);
|
|
282
|
-
this._account = account;
|
|
283
|
-
this.supportedQueryValidator = new SupportedQueryValidator(this).queryable;
|
|
284
|
-
this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams?.config).queryable;
|
|
285
|
-
}
|
|
286
|
-
get account() {
|
|
287
|
-
return (0, import_assert2.assertEx)(this._account, () => "Missing account");
|
|
288
|
-
}
|
|
289
|
-
get additionalSigners() {
|
|
290
|
-
return this.params.additionalSigners ?? [];
|
|
291
|
-
}
|
|
292
|
-
get address() {
|
|
293
|
-
return this._account?.address;
|
|
294
|
-
}
|
|
295
|
-
get allowAnonymous() {
|
|
296
|
-
return !!this.config.security?.allowAnonymous;
|
|
297
|
-
}
|
|
298
|
-
get allowNameResolution() {
|
|
299
|
-
return this.params.allowNameResolution ?? true;
|
|
300
|
-
}
|
|
301
|
-
get archiving() {
|
|
302
|
-
return this.config.archiving;
|
|
303
|
-
}
|
|
304
|
-
get archivist() {
|
|
305
|
-
return this.config.archivist;
|
|
306
|
-
}
|
|
307
|
-
get config() {
|
|
308
|
-
return this.params.config;
|
|
309
|
-
}
|
|
310
|
-
get dead() {
|
|
311
|
-
return this.status === "dead";
|
|
312
|
-
}
|
|
313
|
-
get ephemeralQueryAccountEnabled() {
|
|
314
|
-
return !!this.params.ephemeralQueryAccountEnabled;
|
|
315
|
-
}
|
|
316
|
-
get id() {
|
|
317
|
-
return this.modName ?? this.address;
|
|
318
|
-
}
|
|
319
|
-
get logger() {
|
|
320
|
-
const consoleLogger = this.config.consoleLogger;
|
|
321
|
-
this._logger = this._logger ?? consoleLogger ? new import_logger.ConsoleLogger(consoleLogger) : this.params?.logger ?? _AbstractModule.defaultLogger ?? import_object2.Base.defaultLogger;
|
|
322
|
-
return this._logger;
|
|
323
|
-
}
|
|
324
|
-
get modName() {
|
|
325
|
-
return this.config.name;
|
|
326
|
-
}
|
|
327
|
-
get priority() {
|
|
328
|
-
return import_module_model.ObjectResolverPriority.Normal;
|
|
329
|
-
}
|
|
330
|
-
get queries() {
|
|
331
|
-
return [
|
|
332
|
-
import_module_model.ModuleAddressQuerySchema,
|
|
333
|
-
import_module_model.ModuleSubscribeQuerySchema,
|
|
334
|
-
import_module_model.ModuleManifestQuerySchema,
|
|
335
|
-
import_module_model.ModuleStateQuerySchema
|
|
336
|
-
];
|
|
337
|
-
}
|
|
338
|
-
get status() {
|
|
339
|
-
return this._status;
|
|
340
|
-
}
|
|
341
|
-
get timestamp() {
|
|
342
|
-
return this.config.timestamp ?? false;
|
|
343
|
-
}
|
|
344
|
-
set status(value) {
|
|
345
|
-
if (this._status !== "dead") {
|
|
346
|
-
this._status = value;
|
|
347
|
-
}
|
|
348
|
-
}
|
|
349
|
-
static _getRootFunction(funcName) {
|
|
350
|
-
let anyThis = this;
|
|
351
|
-
while (anyThis.__proto__[funcName]) {
|
|
352
|
-
anyThis = anyThis.__proto__;
|
|
353
|
-
}
|
|
354
|
-
return anyThis[funcName];
|
|
355
|
-
}
|
|
356
|
-
static _noOverride(functionName) {
|
|
357
|
-
const thisFunc = this[functionName];
|
|
358
|
-
const rootFunc = this._getRootFunction(functionName);
|
|
359
|
-
(0, import_assert2.assertEx)(thisFunc === rootFunc, () => `Override not allowed for [${functionName}] - override ${functionName}Handler instead`);
|
|
360
|
-
}
|
|
361
|
-
static async create(params) {
|
|
362
|
-
this._noOverride("create");
|
|
363
|
-
if (!this.configSchemas || this.configSchemas.length === 0) {
|
|
364
|
-
throw new Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`);
|
|
365
|
-
}
|
|
366
|
-
if (!this.defaultConfigSchema) {
|
|
367
|
-
throw new Error(`Missing defaultConfigSchema [${params?.config?.schema}][${this.name}]`);
|
|
368
|
-
}
|
|
369
|
-
(0, import_assert2.assertEx)(params?.config?.name === void 0 || (0, import_module_model.isModuleName)(params.config.name), () => `Invalid module name: ${params?.config?.name}`);
|
|
370
|
-
const { account } = params ?? {};
|
|
371
|
-
const schema = params?.config?.schema ?? this.defaultConfigSchema;
|
|
372
|
-
const allowedSchemas = this.configSchemas;
|
|
373
|
-
(0, import_assert2.assertEx)(allowedSchemas.includes(schema), () => `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`);
|
|
374
|
-
const mutatedConfig = {
|
|
375
|
-
...params?.config,
|
|
376
|
-
schema
|
|
377
|
-
};
|
|
378
|
-
params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`);
|
|
379
|
-
const mutatedParams = {
|
|
380
|
-
...params,
|
|
381
|
-
config: mutatedConfig
|
|
382
|
-
};
|
|
383
|
-
const activeLogger = params?.logger ?? _AbstractModule.defaultLogger;
|
|
384
|
-
const generatedAccount = await _AbstractModule.determineAccount({
|
|
385
|
-
account
|
|
386
|
-
});
|
|
387
|
-
const address = generatedAccount.address;
|
|
388
|
-
mutatedParams.logger = activeLogger ? new import_logger.IdLogger(activeLogger, () => `0x${address}`) : void 0;
|
|
389
|
-
const newModule = new this(_AbstractModule.privateConstructorKey, mutatedParams, generatedAccount, address);
|
|
390
|
-
if (!_AbstractModule.enableLazyLoad) {
|
|
391
|
-
await newModule.start?.();
|
|
392
|
-
}
|
|
393
|
-
return newModule;
|
|
394
|
-
}
|
|
395
|
-
static async determineAccount(params) {
|
|
396
|
-
return await determineAccount(params, this.allowRandomAccount);
|
|
397
|
-
}
|
|
398
|
-
static factory(params) {
|
|
399
|
-
return import_module_model.ModuleFactory.withParams(this, params);
|
|
400
|
-
}
|
|
401
|
-
_getRootFunction(funcName) {
|
|
402
|
-
let anyThis = this;
|
|
403
|
-
while (anyThis.__proto__[funcName]) {
|
|
404
|
-
anyThis = anyThis.__proto__;
|
|
405
|
-
}
|
|
406
|
-
return anyThis[funcName];
|
|
407
|
-
}
|
|
408
|
-
async busy(closure) {
|
|
409
|
-
if (this._busyCount <= 0) {
|
|
410
|
-
this._busyCount = 0;
|
|
411
|
-
const args = {
|
|
412
|
-
busy: true,
|
|
413
|
-
mod: this
|
|
414
|
-
};
|
|
415
|
-
await this.emit("moduleBusy", args);
|
|
416
|
-
}
|
|
417
|
-
this._busyCount++;
|
|
418
|
-
try {
|
|
419
|
-
return await closure();
|
|
420
|
-
} finally {
|
|
421
|
-
this._busyCount--;
|
|
422
|
-
if (this._busyCount <= 0) {
|
|
423
|
-
this._busyCount = 0;
|
|
424
|
-
const args = {
|
|
425
|
-
busy: false,
|
|
426
|
-
mod: this
|
|
427
|
-
};
|
|
428
|
-
await this.emit("moduleBusy", args);
|
|
429
|
-
}
|
|
430
|
-
}
|
|
431
|
-
}
|
|
432
|
-
emit(eventName, eventArgs) {
|
|
433
|
-
return super.emit(eventName, eventArgs);
|
|
434
|
-
}
|
|
435
|
-
previousHash() {
|
|
436
|
-
this._checkDead();
|
|
437
|
-
return this.account.previousHash;
|
|
438
|
-
}
|
|
439
|
-
async query(query, payloads, queryConfig) {
|
|
440
|
-
this._checkDead();
|
|
441
|
-
this._noOverride("query");
|
|
442
|
-
const sourceQuery = await import_payload_builder2.PayloadBuilder.build((0, import_assert2.assertEx)(import_boundwitness_wrapper3.QueryBoundWitnessWrapper.unwrap(query), () => "Invalid query"));
|
|
443
|
-
return await this.busy(async () => {
|
|
444
|
-
const resultPayloads = [];
|
|
445
|
-
const errorPayloads = [];
|
|
446
|
-
const queryAccount = this.ephemeralQueryAccountEnabled ? await import_account2.Account.random() : void 0;
|
|
447
|
-
try {
|
|
448
|
-
await this.started("throw");
|
|
449
|
-
if (!this.allowAnonymous && query.addresses.length === 0) {
|
|
450
|
-
throw new Error(`Anonymous Queries not allowed, but running anyway [${this.modName}], [${this.address}]`);
|
|
451
|
-
}
|
|
452
|
-
if (queryConfig?.allowedQueries) {
|
|
453
|
-
(0, import_assert2.assertEx)(queryConfig?.allowedQueries.includes(sourceQuery.schema), () => `Query not allowed [${sourceQuery.schema}]`);
|
|
454
|
-
}
|
|
455
|
-
resultPayloads.push(...await this.queryHandler(sourceQuery, payloads, queryConfig));
|
|
456
|
-
} catch (ex) {
|
|
457
|
-
await (0, import_error.handleErrorAsync)(ex, async (err) => {
|
|
458
|
-
const error = err;
|
|
459
|
-
this._lastError = error;
|
|
460
|
-
errorPayloads.push(await new ModuleErrorBuilder().sources([
|
|
461
|
-
sourceQuery.$hash
|
|
462
|
-
]).name(this.modName ?? "<Unknown>").query(sourceQuery.schema).details(error.details).message(error.message).build());
|
|
463
|
-
});
|
|
464
|
-
}
|
|
465
|
-
if (this.timestamp) {
|
|
466
|
-
const timestamp = {
|
|
467
|
-
schema: "network.xyo.timestamp",
|
|
468
|
-
timestamp: Date.now()
|
|
469
|
-
};
|
|
470
|
-
resultPayloads.push(timestamp);
|
|
471
|
-
}
|
|
472
|
-
const result = await this.bindQueryResult(sourceQuery, resultPayloads, queryAccount ? [
|
|
473
|
-
queryAccount
|
|
474
|
-
] : [], errorPayloads);
|
|
475
|
-
const args = {
|
|
476
|
-
mod: this,
|
|
477
|
-
payloads,
|
|
478
|
-
query: sourceQuery,
|
|
479
|
-
result
|
|
480
|
-
};
|
|
481
|
-
await this.emit("moduleQueried", args);
|
|
482
|
-
return result;
|
|
483
|
-
});
|
|
484
|
-
}
|
|
485
|
-
async queryable(query, payloads, queryConfig) {
|
|
486
|
-
if (this.dead) {
|
|
487
|
-
return false;
|
|
488
|
-
}
|
|
489
|
-
if (!await this.started("warn")) return false;
|
|
490
|
-
const configValidator = queryConfig ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable : this.moduleConfigQueryValidator;
|
|
491
|
-
const validators = [
|
|
492
|
-
this.supportedQueryValidator,
|
|
493
|
-
configValidator
|
|
494
|
-
];
|
|
495
|
-
return validators.every((validator) => validator(query, payloads));
|
|
496
|
-
}
|
|
497
|
-
start(_timeout) {
|
|
498
|
-
this._startPromise = this._startPromise ?? this.startHandler();
|
|
499
|
-
const result = this._startPromise;
|
|
500
|
-
this.status = result ? "started" : "dead";
|
|
501
|
-
return result;
|
|
502
|
-
}
|
|
503
|
-
async started(notStartedAction = "log", tryStart = true) {
|
|
504
|
-
const started = await this._started;
|
|
505
|
-
if (started === true) {
|
|
506
|
-
return true;
|
|
507
|
-
}
|
|
508
|
-
if (!started) {
|
|
509
|
-
this._started = (async () => {
|
|
510
|
-
if (tryStart) {
|
|
511
|
-
try {
|
|
512
|
-
await this.start();
|
|
513
|
-
return true;
|
|
514
|
-
} catch (ex) {
|
|
515
|
-
(0, import_error.handleError)(ex, (error) => {
|
|
516
|
-
this.logger?.warn(`Autostart of Module Failed: ${error.message})`);
|
|
517
|
-
this._started = void 0;
|
|
518
|
-
});
|
|
519
|
-
}
|
|
520
|
-
}
|
|
521
|
-
switch (notStartedAction) {
|
|
522
|
-
case "throw": {
|
|
523
|
-
throw new Error(`${MODULE_NOT_STARTED} [${this.address}]`);
|
|
524
|
-
}
|
|
525
|
-
case "warn": {
|
|
526
|
-
this.logger?.warn(MODULE_NOT_STARTED);
|
|
527
|
-
break;
|
|
528
|
-
}
|
|
529
|
-
case "error": {
|
|
530
|
-
this.logger?.error(MODULE_NOT_STARTED);
|
|
531
|
-
break;
|
|
532
|
-
}
|
|
533
|
-
case "none": {
|
|
534
|
-
break;
|
|
535
|
-
}
|
|
536
|
-
default: {
|
|
537
|
-
this.logger?.log(MODULE_NOT_STARTED);
|
|
538
|
-
break;
|
|
539
|
-
}
|
|
540
|
-
}
|
|
541
|
-
return false;
|
|
542
|
-
})();
|
|
543
|
-
}
|
|
544
|
-
if (!this._started) {
|
|
545
|
-
throw "Failed to create start promise";
|
|
546
|
-
}
|
|
547
|
-
return await this._started;
|
|
548
|
-
}
|
|
549
|
-
async stop(_timeout) {
|
|
550
|
-
return await this.busy(async () => {
|
|
551
|
-
const result = await this.stopHandler();
|
|
552
|
-
this._started = void 0;
|
|
553
|
-
this._startPromise = void 0;
|
|
554
|
-
this.status = result ? "stopped" : "dead";
|
|
555
|
-
return result;
|
|
556
|
-
});
|
|
557
|
-
}
|
|
558
|
-
_checkDead() {
|
|
559
|
-
if (this.dead) {
|
|
560
|
-
throw new import_module_model.DeadModuleError(this.id, this._lastError);
|
|
561
|
-
}
|
|
562
|
-
}
|
|
563
|
-
_noOverride(functionName) {
|
|
564
|
-
const thisFunc = this[functionName];
|
|
565
|
-
const rootFunc = this._getRootFunction(functionName);
|
|
566
|
-
(0, import_assert2.assertEx)(thisFunc === rootFunc, () => `Override not allowed for [${functionName}] - override ${functionName}Handler instead`);
|
|
567
|
-
}
|
|
568
|
-
async archivistInstance(required = false) {
|
|
569
|
-
const archivist = this.archivist;
|
|
570
|
-
if (!archivist) {
|
|
571
|
-
if (required) {
|
|
572
|
-
throw new Error("No archivist specified");
|
|
573
|
-
}
|
|
574
|
-
return void 0;
|
|
575
|
-
}
|
|
576
|
-
const resolved = await this.upResolver.resolve(archivist) ?? await this.downResolver.resolve(archivist);
|
|
577
|
-
if (required) {
|
|
578
|
-
(0, import_assert2.assertEx)(resolved, () => `Unable to resolve archivist [${archivist}]`);
|
|
579
|
-
}
|
|
580
|
-
return resolved ? (0, import_archivist_model.asArchivistInstance)(resolved, () => `Specified archivist is not an Archivist [${archivist}]`) : void 0;
|
|
581
|
-
}
|
|
582
|
-
bindHashes(hashes, schema, account) {
|
|
583
|
-
return new import_promise.PromiseEx((resolve) => {
|
|
584
|
-
const result = this.bindHashesInternal(hashes, schema, account);
|
|
585
|
-
resolve?.(result);
|
|
586
|
-
return result;
|
|
587
|
-
}, account);
|
|
588
|
-
}
|
|
589
|
-
async bindHashesInternal(hashes, schema, account = this.account) {
|
|
590
|
-
const builder = new import_boundwitness_builder.BoundWitnessBuilder().hashes(hashes, schema).signer(account);
|
|
591
|
-
const result = (await builder.build())[0];
|
|
592
|
-
this.logger?.debug(`result: ${JSON.stringify(result, null, 2)}`);
|
|
593
|
-
return result;
|
|
594
|
-
}
|
|
595
|
-
bindQuery(query, payloads, account, additionalSigners) {
|
|
596
|
-
return new import_promise.PromiseEx(async (resolve) => {
|
|
597
|
-
const result = await this.bindQueryInternal(query, payloads, account, additionalSigners);
|
|
598
|
-
resolve?.(result);
|
|
599
|
-
return result;
|
|
600
|
-
}, account);
|
|
601
|
-
}
|
|
602
|
-
async bindQueryInternal(query, payloads, account = this.account, additionalSigners = []) {
|
|
603
|
-
const accounts = [
|
|
604
|
-
account,
|
|
605
|
-
...additionalSigners
|
|
606
|
-
].filter(import_exists.exists);
|
|
607
|
-
const builder = await new import_boundwitness_builder.QueryBoundWitnessBuilder().payloads(payloads).signers(accounts).query(query);
|
|
608
|
-
let additional = [];
|
|
609
|
-
if (this.config.certify) {
|
|
610
|
-
additional = await this.certifyParents();
|
|
611
|
-
await builder.additional(additional);
|
|
612
|
-
}
|
|
613
|
-
const [bw, payloadsOut, errors] = await builder.build();
|
|
614
|
-
return [
|
|
615
|
-
bw,
|
|
616
|
-
[
|
|
617
|
-
...payloadsOut,
|
|
618
|
-
...additional
|
|
619
|
-
],
|
|
620
|
-
errors
|
|
621
|
-
];
|
|
622
|
-
}
|
|
623
|
-
async bindQueryResult(query, payloads, additionalWitnesses = [], errors) {
|
|
624
|
-
const builder = new import_boundwitness_builder.BoundWitnessBuilder().payloads(payloads).errors(errors).sourceQuery(query.$hash);
|
|
625
|
-
const witnesses = [
|
|
626
|
-
this.account,
|
|
627
|
-
...additionalWitnesses
|
|
628
|
-
].filter(import_exists.exists);
|
|
629
|
-
builder.signers(witnesses);
|
|
630
|
-
const result = [
|
|
631
|
-
(await builder.build())[0],
|
|
632
|
-
await Promise.all(payloads.map((payload) => import_payload_builder2.PayloadBuilder.build(payload))),
|
|
633
|
-
await Promise.all((errors ?? [])?.map((error) => import_payload_builder2.PayloadBuilder.build(error)))
|
|
634
|
-
];
|
|
635
|
-
if (this.archiving && this.isAllowedArchivingQuery(query.schema)) {
|
|
636
|
-
(0, import_forget.forget)(this.storeToArchivists(result.flat()));
|
|
637
|
-
}
|
|
638
|
-
return result;
|
|
639
|
-
}
|
|
640
|
-
async generateConfigAndAddress(_maxDepth) {
|
|
641
|
-
const config = await import_payload_builder2.PayloadBuilder.build(this.config);
|
|
642
|
-
const address = await new import_payload_builder2.PayloadBuilder({
|
|
643
|
-
schema: import_module_model.AddressSchema
|
|
644
|
-
}).fields({
|
|
645
|
-
address: this.address
|
|
646
|
-
}).build();
|
|
647
|
-
const queries = await Promise.all(this.queries.map(async (query) => {
|
|
648
|
-
return await new import_payload_builder2.PayloadBuilder({
|
|
649
|
-
schema: import_query_payload_plugin.QuerySchema
|
|
650
|
-
}).fields({
|
|
651
|
-
query
|
|
652
|
-
}).build();
|
|
653
|
-
}));
|
|
654
|
-
const configSchema = await import_payload_builder2.PayloadBuilder.build({
|
|
655
|
-
config: config.schema,
|
|
656
|
-
schema: import_config_payload_plugin.ConfigSchema
|
|
657
|
-
});
|
|
658
|
-
return (0, import_lodash.compact)([
|
|
659
|
-
config,
|
|
660
|
-
configSchema,
|
|
661
|
-
address,
|
|
662
|
-
...queries
|
|
663
|
-
]);
|
|
664
|
-
}
|
|
665
|
-
async generateDescribe() {
|
|
666
|
-
const description = {
|
|
667
|
-
address: this.address,
|
|
668
|
-
queries: this.queries,
|
|
669
|
-
schema: import_module_model.ModuleDescriptionSchema
|
|
670
|
-
};
|
|
671
|
-
if (this.config?.name) {
|
|
672
|
-
description.name = this.modName;
|
|
673
|
-
}
|
|
674
|
-
const discover = await this.generateConfigAndAddress();
|
|
675
|
-
description.children = (0, import_lodash.compact)(discover?.map((payload) => {
|
|
676
|
-
const address = payload.schema === import_module_model.AddressSchema ? payload.address : void 0;
|
|
677
|
-
return address == this.address ? void 0 : address;
|
|
678
|
-
}) ?? []);
|
|
679
|
-
return description;
|
|
680
|
-
}
|
|
681
|
-
/** @deprecated use archivistInstance() instead */
|
|
682
|
-
async getArchivist() {
|
|
683
|
-
return await this.archivistInstance();
|
|
684
|
-
}
|
|
685
|
-
isAllowedArchivingQuery(schema) {
|
|
686
|
-
const queries = this.archiving?.queries;
|
|
687
|
-
if (queries) {
|
|
688
|
-
return queries.includes(schema);
|
|
689
|
-
}
|
|
690
|
-
return true;
|
|
691
|
-
}
|
|
692
|
-
manifestHandler(_maxDepth = 1, _ignoreAddresses = []) {
|
|
693
|
-
throw new Error("Not supported");
|
|
694
|
-
}
|
|
695
|
-
moduleAddressHandler() {
|
|
696
|
-
const address = this.address;
|
|
697
|
-
const name = this.modName;
|
|
698
|
-
const previousHash = this.address;
|
|
699
|
-
const moduleAccount = name ? {
|
|
700
|
-
address,
|
|
701
|
-
name,
|
|
702
|
-
schema: import_module_model.AddressSchema
|
|
703
|
-
} : {
|
|
704
|
-
address,
|
|
705
|
-
schema: import_module_model.AddressSchema
|
|
706
|
-
};
|
|
707
|
-
const moduleAccountPreviousHash = previousHash ? {
|
|
708
|
-
address,
|
|
709
|
-
previousHash,
|
|
710
|
-
schema: import_module_model.AddressPreviousHashSchema
|
|
711
|
-
} : {
|
|
712
|
-
address,
|
|
713
|
-
schema: import_module_model.AddressSchema
|
|
714
|
-
};
|
|
715
|
-
return [
|
|
716
|
-
moduleAccount,
|
|
717
|
-
moduleAccountPreviousHash
|
|
718
|
-
];
|
|
719
|
-
}
|
|
720
|
-
async queryHandler(query, payloads, queryConfig) {
|
|
721
|
-
await this.started("throw");
|
|
722
|
-
const wrapper = await import_boundwitness_wrapper3.QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
723
|
-
const queryPayload = await wrapper.getQuery();
|
|
724
|
-
(0, import_assert2.assertEx)(await this.queryable(query, payloads, queryConfig));
|
|
725
|
-
const resultPayloads = [];
|
|
726
|
-
switch (queryPayload.schema) {
|
|
727
|
-
case import_module_model.ModuleManifestQuerySchema: {
|
|
728
|
-
resultPayloads.push(await this.manifestHandler(queryPayload.maxDepth));
|
|
729
|
-
break;
|
|
730
|
-
}
|
|
731
|
-
case import_module_model.ModuleAddressQuerySchema: {
|
|
732
|
-
resultPayloads.push(...await this.moduleAddressHandler());
|
|
733
|
-
break;
|
|
734
|
-
}
|
|
735
|
-
case import_module_model.ModuleStateQuerySchema: {
|
|
736
|
-
resultPayloads.push(...await this.stateHandler());
|
|
737
|
-
break;
|
|
738
|
-
}
|
|
739
|
-
case import_module_model.ModuleSubscribeQuerySchema: {
|
|
740
|
-
this.subscribeHandler();
|
|
741
|
-
break;
|
|
742
|
-
}
|
|
743
|
-
default: {
|
|
744
|
-
throw new Error(`Unsupported Query [${queryPayload.schema}]`);
|
|
745
|
-
}
|
|
746
|
-
}
|
|
747
|
-
return resultPayloads;
|
|
748
|
-
}
|
|
749
|
-
async startHandler() {
|
|
750
|
-
this.validateConfig();
|
|
751
|
-
await Promise.resolve();
|
|
752
|
-
this._started = true;
|
|
753
|
-
return true;
|
|
754
|
-
}
|
|
755
|
-
async stateHandler() {
|
|
756
|
-
return [
|
|
757
|
-
await this.manifestHandler(),
|
|
758
|
-
...await this.generateConfigAndAddress(),
|
|
759
|
-
await this.generateDescribe()
|
|
760
|
-
];
|
|
761
|
-
}
|
|
762
|
-
stopHandler(_timeout) {
|
|
763
|
-
this._started = void 0;
|
|
764
|
-
return true;
|
|
765
|
-
}
|
|
766
|
-
subscribeHandler() {
|
|
767
|
-
return;
|
|
768
|
-
}
|
|
769
|
-
validateConfig(config, parents = []) {
|
|
770
|
-
return Object.entries(config ?? this.config ?? {}).reduce((valid, [key, value]) => {
|
|
771
|
-
switch (typeof value) {
|
|
772
|
-
case "function": {
|
|
773
|
-
this.logger?.warn(`Fields of type function not allowed in config [${parents?.join(".")}.${key}]`);
|
|
774
|
-
return false;
|
|
775
|
-
}
|
|
776
|
-
case "object": {
|
|
777
|
-
if (Array.isArray(value)) {
|
|
778
|
-
return (
|
|
779
|
-
// eslint-disable-next-line unicorn/no-array-reduce
|
|
780
|
-
value.reduce((valid2, value2) => {
|
|
781
|
-
return this.validateConfig(value2, [
|
|
782
|
-
...parents,
|
|
783
|
-
key
|
|
784
|
-
]) && valid2;
|
|
785
|
-
}, true) && valid
|
|
786
|
-
);
|
|
787
|
-
}
|
|
788
|
-
if (!(0, import_module_model.serializableField)(value)) {
|
|
789
|
-
this.logger?.warn(`Fields that are not serializable to JSON are not allowed in config [${parents?.join(".")}.${key}]`);
|
|
790
|
-
return false;
|
|
791
|
-
}
|
|
792
|
-
return value ? this.validateConfig(value, [
|
|
793
|
-
...parents,
|
|
794
|
-
key
|
|
795
|
-
]) && valid : true;
|
|
796
|
-
}
|
|
797
|
-
default: {
|
|
798
|
-
return valid;
|
|
799
|
-
}
|
|
800
|
-
}
|
|
801
|
-
}, true);
|
|
802
|
-
}
|
|
803
|
-
};
|
|
804
|
-
|
|
805
|
-
// src/AbstractModuleInstance.ts
|
|
806
|
-
var import_assert3 = require("@xylabs/assert");
|
|
807
|
-
var import_exists2 = require("@xylabs/exists");
|
|
808
|
-
var import_lodash2 = require("@xylabs/lodash");
|
|
809
|
-
var import_object3 = require("@xylabs/object");
|
|
810
|
-
var import_archivist_model2 = require("@xyo-network/archivist-model");
|
|
811
|
-
var import_manifest_model = require("@xyo-network/manifest-model");
|
|
812
|
-
var import_module_model2 = require("@xyo-network/module-model");
|
|
813
|
-
var import_module_resolver = require("@xyo-network/module-resolver");
|
|
814
|
-
var import_node_model = require("@xyo-network/node-model");
|
|
815
|
-
var AbstractModuleInstance = class _AbstractModuleInstance extends AbstractModule {
|
|
816
|
-
static {
|
|
817
|
-
__name(this, "AbstractModuleInstance");
|
|
818
|
-
}
|
|
819
|
-
static uniqueName = (0, import_object3.globallyUnique)("AbstractModuleInstance", _AbstractModuleInstance, "xyo");
|
|
820
|
-
// switches between old and new resolution system
|
|
821
|
-
static useNewResolver = false;
|
|
822
|
-
_downResolver;
|
|
823
|
-
_parents = [];
|
|
824
|
-
_privateResolver;
|
|
825
|
-
_upResolver;
|
|
826
|
-
constructor(privateConstructorKey, params, account) {
|
|
827
|
-
(0, import_assert3.assertEx)(AbstractModule.privateConstructorKey === privateConstructorKey, () => "Use create function instead of constructor");
|
|
828
|
-
const mutatedParams = {
|
|
829
|
-
...params
|
|
830
|
-
};
|
|
831
|
-
const addToResolvers = mutatedParams.addToResolvers ?? true;
|
|
832
|
-
super(privateConstructorKey, mutatedParams, account);
|
|
833
|
-
if (addToResolvers) {
|
|
834
|
-
this.upResolver.add(this);
|
|
835
|
-
this.downResolver.add(this);
|
|
836
|
-
}
|
|
837
|
-
}
|
|
838
|
-
get downResolver() {
|
|
839
|
-
this._downResolver = this._downResolver ?? new import_module_resolver.CompositeModuleResolver({
|
|
840
|
-
allowNameResolution: this.allowNameResolution,
|
|
841
|
-
moduleIdentifierTransformers: this.params.moduleIdentifierTransformers,
|
|
842
|
-
root: this
|
|
843
|
-
});
|
|
844
|
-
return this._downResolver;
|
|
845
|
-
}
|
|
846
|
-
get modName() {
|
|
847
|
-
return super.modName;
|
|
848
|
-
}
|
|
849
|
-
get moduleIdentifierTransformers() {
|
|
850
|
-
return this.params.moduleIdentifierTransformers ?? import_module_model2.ResolveHelper.transformers;
|
|
851
|
-
}
|
|
852
|
-
get privateResolver() {
|
|
853
|
-
this._privateResolver = this._privateResolver ?? new import_module_resolver.CompositeModuleResolver({
|
|
854
|
-
allowNameResolution: this.allowNameResolution,
|
|
855
|
-
moduleIdentifierTransformers: this.params.moduleIdentifierTransformers,
|
|
856
|
-
root: this
|
|
857
|
-
});
|
|
858
|
-
return this._privateResolver;
|
|
859
|
-
}
|
|
860
|
-
get root() {
|
|
861
|
-
return this;
|
|
862
|
-
}
|
|
863
|
-
get upResolver() {
|
|
864
|
-
this._upResolver = this._upResolver ?? new import_module_resolver.CompositeModuleResolver({
|
|
865
|
-
allowNameResolution: this.allowNameResolution,
|
|
866
|
-
moduleIdentifierTransformers: this.params.moduleIdentifierTransformers,
|
|
867
|
-
root: this
|
|
868
|
-
});
|
|
869
|
-
return this._upResolver;
|
|
870
|
-
}
|
|
871
|
-
addParent(mod) {
|
|
872
|
-
const existingEntry = this._parents.find((parent) => parent.address === mod.address);
|
|
873
|
-
if (!existingEntry) {
|
|
874
|
-
this._parents.push((0, import_node_model.asNodeInstance)(mod, "Only NodeInstances can be parents"));
|
|
875
|
-
}
|
|
876
|
-
}
|
|
877
|
-
async certifyParents() {
|
|
878
|
-
const parents = await this.parents();
|
|
879
|
-
return (await Promise.all(parents.map(async (parent) => {
|
|
880
|
-
const [bw, payloads, errors] = await parent.certifyQuery(this.address);
|
|
881
|
-
return errors.length === 0 ? [
|
|
882
|
-
bw,
|
|
883
|
-
...payloads
|
|
884
|
-
] : [];
|
|
885
|
-
}))).flat();
|
|
886
|
-
}
|
|
887
|
-
manifest(maxDepth) {
|
|
888
|
-
this._checkDead();
|
|
889
|
-
return this.busy(async () => {
|
|
890
|
-
return await this.manifestHandler(maxDepth);
|
|
891
|
-
});
|
|
892
|
-
}
|
|
893
|
-
async manifestQuery(account, maxDepth) {
|
|
894
|
-
const queryPayload = {
|
|
895
|
-
schema: import_module_model2.ModuleManifestQuerySchema,
|
|
896
|
-
...maxDepth === void 0 ? {} : {
|
|
897
|
-
maxDepth
|
|
898
|
-
}
|
|
899
|
-
};
|
|
900
|
-
return await this.sendQueryRaw(queryPayload, void 0, account);
|
|
901
|
-
}
|
|
902
|
-
moduleAddress() {
|
|
903
|
-
this._checkDead();
|
|
904
|
-
return this.busy(async () => {
|
|
905
|
-
return await this.moduleAddressHandler();
|
|
906
|
-
});
|
|
907
|
-
}
|
|
908
|
-
parents() {
|
|
909
|
-
return this._parents;
|
|
910
|
-
}
|
|
911
|
-
privateChildren() {
|
|
912
|
-
return [];
|
|
913
|
-
}
|
|
914
|
-
publicChildren() {
|
|
915
|
-
return [];
|
|
916
|
-
}
|
|
917
|
-
removeParent(address) {
|
|
918
|
-
this._parents = this._parents.filter((item) => item.address !== address);
|
|
919
|
-
}
|
|
920
|
-
async resolve(idOrFilter = "*", options = {}) {
|
|
921
|
-
if (_AbstractModuleInstance.useNewResolver) {
|
|
922
|
-
if (idOrFilter === "*") {
|
|
923
|
-
const { maxDepth = 10, direction } = options;
|
|
924
|
-
if (direction === "down") {
|
|
925
|
-
return await (0, import_module_model2.resolveAllDown)(this, maxDepth);
|
|
926
|
-
}
|
|
927
|
-
if (direction === "up") {
|
|
928
|
-
return await (0, import_module_model2.resolveAllUp)(this, maxDepth);
|
|
929
|
-
}
|
|
930
|
-
return await (0, import_module_model2.resolveAll)(this, maxDepth);
|
|
931
|
-
} else if (typeof idOrFilter === "string") {
|
|
932
|
-
return await (0, import_module_model2.resolvePathToInstance)(this, idOrFilter, true);
|
|
933
|
-
} else {
|
|
934
|
-
if ((0, import_module_model2.isNameModuleFilter)(idOrFilter)) {
|
|
935
|
-
return (await Promise.all(idOrFilter.name.map(async (id) => await (0, import_module_model2.resolveLocalNameToInstance)(this, id)))).filter(import_exists2.exists);
|
|
936
|
-
} else if ((0, import_module_model2.isAddressModuleFilter)(idOrFilter)) {
|
|
937
|
-
return (await Promise.all(idOrFilter.address.map(async (id) => await (0, import_module_model2.resolveAddressToInstance)(this, id)))).filter(import_exists2.exists);
|
|
938
|
-
} else {
|
|
939
|
-
throw new TypeError("Invalid filter");
|
|
940
|
-
}
|
|
941
|
-
}
|
|
942
|
-
} else {
|
|
943
|
-
const config = {
|
|
944
|
-
address: this.address,
|
|
945
|
-
dead: this.dead,
|
|
946
|
-
downResolver: this.downResolver,
|
|
947
|
-
logger: this.logger,
|
|
948
|
-
mod: this,
|
|
949
|
-
transformers: this.moduleIdentifierTransformers,
|
|
950
|
-
upResolver: this.upResolver
|
|
951
|
-
};
|
|
952
|
-
if (idOrFilter === "*") {
|
|
953
|
-
return await import_module_model2.ResolveHelper.resolve(config, idOrFilter, options);
|
|
954
|
-
}
|
|
955
|
-
switch (typeof idOrFilter) {
|
|
956
|
-
case "string": {
|
|
957
|
-
return await import_module_model2.ResolveHelper.resolve(config, idOrFilter, options);
|
|
958
|
-
}
|
|
959
|
-
case "object": {
|
|
960
|
-
return (await import_module_model2.ResolveHelper.resolve(config, idOrFilter, options)).filter((mod) => mod.address !== this.address);
|
|
961
|
-
}
|
|
962
|
-
default: {
|
|
963
|
-
return (await import_module_model2.ResolveHelper.resolve(config, idOrFilter, options)).filter((mod) => mod.address !== this.address);
|
|
964
|
-
}
|
|
965
|
-
}
|
|
966
|
-
}
|
|
967
|
-
}
|
|
968
|
-
resolveIdentifier(id, options) {
|
|
969
|
-
const { direction = "all" } = options ?? {};
|
|
970
|
-
switch (direction) {
|
|
971
|
-
case "down": {
|
|
972
|
-
return this.downResolver.resolveIdentifier(id, options);
|
|
973
|
-
}
|
|
974
|
-
default: {
|
|
975
|
-
const mutatedOptions = {
|
|
976
|
-
...options,
|
|
977
|
-
direction: "all"
|
|
978
|
-
};
|
|
979
|
-
return this.upResolver.resolveIdentifier(id, mutatedOptions);
|
|
980
|
-
}
|
|
981
|
-
}
|
|
982
|
-
}
|
|
983
|
-
async resolvePrivate(id = "*", options = {}) {
|
|
984
|
-
return await this.privateResolver.resolve(id, options) ?? await this.upResolver.resolve(id, options) ?? await this.downResolver.resolve(id, options);
|
|
985
|
-
}
|
|
986
|
-
async siblings() {
|
|
987
|
-
return (await Promise.all((await this.parents()).map((parent) => parent.publicChildren()))).flat().filter(import_module_model2.duplicateModules);
|
|
988
|
-
}
|
|
989
|
-
/* override start(_timeout?: number): Promisable<boolean> {
|
|
990
|
-
if (this.parents.length === 0) {
|
|
991
|
-
this.logger.warn(`Module is being started without being attached to a parent: ${this.id} [${this.address}]`)
|
|
992
|
-
}
|
|
993
|
-
return super.start()
|
|
994
|
-
} */
|
|
995
|
-
state() {
|
|
996
|
-
this._checkDead();
|
|
997
|
-
return this.busy(async () => {
|
|
998
|
-
return await this.stateHandler();
|
|
999
|
-
});
|
|
1000
|
-
}
|
|
1001
|
-
async stateQuery(account) {
|
|
1002
|
-
const queryPayload = {
|
|
1003
|
-
schema: import_module_model2.ModuleStateQuerySchema
|
|
1004
|
-
};
|
|
1005
|
-
return await this.sendQueryRaw(queryPayload, void 0, account);
|
|
1006
|
-
}
|
|
1007
|
-
subscribe(_queryAccount) {
|
|
1008
|
-
this._checkDead();
|
|
1009
|
-
return this.subscribeHandler();
|
|
1010
|
-
}
|
|
1011
|
-
async manifestHandler(maxDepth = 1, _ignoreAddresses = []) {
|
|
1012
|
-
const cachedResult = this._cachedManifests.get(maxDepth);
|
|
1013
|
-
if (cachedResult) {
|
|
1014
|
-
return cachedResult;
|
|
1015
|
-
}
|
|
1016
|
-
const modName = this.modName ?? "<Anonymous>";
|
|
1017
|
-
const children = await this.publicChildren();
|
|
1018
|
-
const childAddressToName = {};
|
|
1019
|
-
for (const child of children) {
|
|
1020
|
-
if (child.address !== this.address) {
|
|
1021
|
-
childAddressToName[child.address] = child.modName ?? null;
|
|
1022
|
-
}
|
|
1023
|
-
}
|
|
1024
|
-
const result = {
|
|
1025
|
-
config: {
|
|
1026
|
-
name: modName,
|
|
1027
|
-
...this.config
|
|
1028
|
-
},
|
|
1029
|
-
schema: import_manifest_model.ModuleManifestPayloadSchema,
|
|
1030
|
-
status: {
|
|
1031
|
-
address: this.address,
|
|
1032
|
-
children: childAddressToName
|
|
1033
|
-
}
|
|
1034
|
-
};
|
|
1035
|
-
this._cachedManifests.set(maxDepth, result);
|
|
1036
|
-
return result;
|
|
1037
|
-
}
|
|
1038
|
-
async resolveArchivingArchivists() {
|
|
1039
|
-
const archivists = this.archiving?.archivists;
|
|
1040
|
-
if (!archivists) return [];
|
|
1041
|
-
const resolved = await Promise.all(archivists.map((archivist) => this.resolve(archivist)));
|
|
1042
|
-
return (0, import_lodash2.compact)(resolved.map((mod) => (0, import_archivist_model2.asArchivistInstance)(mod)));
|
|
1043
|
-
}
|
|
1044
|
-
async sendQuery(queryPayload, payloads, account) {
|
|
1045
|
-
const queryResults = await this.sendQueryRaw(queryPayload, payloads, account);
|
|
1046
|
-
const [, resultPayloads, errors] = queryResults;
|
|
1047
|
-
if (errors && errors.length > 0) {
|
|
1048
|
-
throw errors[0];
|
|
1049
|
-
}
|
|
1050
|
-
return resultPayloads;
|
|
1051
|
-
}
|
|
1052
|
-
async sendQueryRaw(queryPayload, payloads, account) {
|
|
1053
|
-
const query = await this.bindQuery(queryPayload, payloads, account, this.additionalSigners);
|
|
1054
|
-
return await this.query(query[0], query[1]);
|
|
1055
|
-
}
|
|
1056
|
-
async storeToArchivists(payloads) {
|
|
1057
|
-
try {
|
|
1058
|
-
const archivists = await this.resolveArchivingArchivists();
|
|
1059
|
-
return (await Promise.all(archivists.map((archivist) => {
|
|
1060
|
-
return archivist.insert?.(payloads);
|
|
1061
|
-
}))).map(([bw]) => bw);
|
|
1062
|
-
} catch (ex) {
|
|
1063
|
-
const error = ex;
|
|
1064
|
-
this.logger.error(`Error storing to archivists: ${error.message}`);
|
|
1065
|
-
return [];
|
|
1066
|
-
}
|
|
1067
|
-
}
|
|
1068
|
-
};
|
|
1069
|
-
//# sourceMappingURL=index.cjs.map
|