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