@xyo-network/bridge-abstract 2.111.3 → 3.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (138) hide show
  1. package/dist/neutral/index.d.ts +206 -5
  2. package/package.json +37 -56
  3. package/xy.config.ts +12 -0
  4. package/dist/browser/AbstractBridge.d.cts +0 -34
  5. package/dist/browser/AbstractBridge.d.cts.map +0 -1
  6. package/dist/browser/AbstractBridge.d.mts +0 -34
  7. package/dist/browser/AbstractBridge.d.mts.map +0 -1
  8. package/dist/browser/AbstractBridge.d.ts +0 -34
  9. package/dist/browser/AbstractBridge.d.ts.map +0 -1
  10. package/dist/browser/AbstractBridgeModuleResolver.d.cts +0 -22
  11. package/dist/browser/AbstractBridgeModuleResolver.d.cts.map +0 -1
  12. package/dist/browser/AbstractBridgeModuleResolver.d.mts +0 -22
  13. package/dist/browser/AbstractBridgeModuleResolver.d.mts.map +0 -1
  14. package/dist/browser/AbstractBridgeModuleResolver.d.ts +0 -22
  15. package/dist/browser/AbstractBridgeModuleResolver.d.ts.map +0 -1
  16. package/dist/browser/AbstractModuleProxy/AbstractModuleProxy.d.cts +0 -77
  17. package/dist/browser/AbstractModuleProxy/AbstractModuleProxy.d.cts.map +0 -1
  18. package/dist/browser/AbstractModuleProxy/AbstractModuleProxy.d.mts +0 -77
  19. package/dist/browser/AbstractModuleProxy/AbstractModuleProxy.d.mts.map +0 -1
  20. package/dist/browser/AbstractModuleProxy/AbstractModuleProxy.d.ts +0 -77
  21. package/dist/browser/AbstractModuleProxy/AbstractModuleProxy.d.ts.map +0 -1
  22. package/dist/browser/AbstractModuleProxy/ModuleProxyResolver.d.cts +0 -79
  23. package/dist/browser/AbstractModuleProxy/ModuleProxyResolver.d.cts.map +0 -1
  24. package/dist/browser/AbstractModuleProxy/ModuleProxyResolver.d.mts +0 -79
  25. package/dist/browser/AbstractModuleProxy/ModuleProxyResolver.d.mts.map +0 -1
  26. package/dist/browser/AbstractModuleProxy/ModuleProxyResolver.d.ts +0 -79
  27. package/dist/browser/AbstractModuleProxy/ModuleProxyResolver.d.ts.map +0 -1
  28. package/dist/browser/AbstractModuleProxy/index.d.cts +0 -3
  29. package/dist/browser/AbstractModuleProxy/index.d.cts.map +0 -1
  30. package/dist/browser/AbstractModuleProxy/index.d.mts +0 -3
  31. package/dist/browser/AbstractModuleProxy/index.d.mts.map +0 -1
  32. package/dist/browser/AbstractModuleProxy/index.d.ts +0 -3
  33. package/dist/browser/AbstractModuleProxy/index.d.ts.map +0 -1
  34. package/dist/browser/index.cjs +0 -606
  35. package/dist/browser/index.cjs.map +0 -1
  36. package/dist/browser/index.d.cts +0 -5
  37. package/dist/browser/index.d.cts.map +0 -1
  38. package/dist/browser/index.d.mts +0 -5
  39. package/dist/browser/index.d.mts.map +0 -1
  40. package/dist/browser/index.d.ts +0 -5
  41. package/dist/browser/index.d.ts.map +0 -1
  42. package/dist/browser/index.mjs +0 -585
  43. package/dist/browser/index.mjs.map +0 -1
  44. package/dist/browser/wrapModuleWithType.d.cts +0 -5
  45. package/dist/browser/wrapModuleWithType.d.cts.map +0 -1
  46. package/dist/browser/wrapModuleWithType.d.mts +0 -5
  47. package/dist/browser/wrapModuleWithType.d.mts.map +0 -1
  48. package/dist/browser/wrapModuleWithType.d.ts +0 -5
  49. package/dist/browser/wrapModuleWithType.d.ts.map +0 -1
  50. package/dist/neutral/AbstractBridge.d.cts +0 -34
  51. package/dist/neutral/AbstractBridge.d.cts.map +0 -1
  52. package/dist/neutral/AbstractBridge.d.mts +0 -34
  53. package/dist/neutral/AbstractBridge.d.mts.map +0 -1
  54. package/dist/neutral/AbstractBridge.d.ts +0 -34
  55. package/dist/neutral/AbstractBridge.d.ts.map +0 -1
  56. package/dist/neutral/AbstractBridgeModuleResolver.d.cts +0 -22
  57. package/dist/neutral/AbstractBridgeModuleResolver.d.cts.map +0 -1
  58. package/dist/neutral/AbstractBridgeModuleResolver.d.mts +0 -22
  59. package/dist/neutral/AbstractBridgeModuleResolver.d.mts.map +0 -1
  60. package/dist/neutral/AbstractBridgeModuleResolver.d.ts +0 -22
  61. package/dist/neutral/AbstractBridgeModuleResolver.d.ts.map +0 -1
  62. package/dist/neutral/AbstractModuleProxy/AbstractModuleProxy.d.cts +0 -77
  63. package/dist/neutral/AbstractModuleProxy/AbstractModuleProxy.d.cts.map +0 -1
  64. package/dist/neutral/AbstractModuleProxy/AbstractModuleProxy.d.mts +0 -77
  65. package/dist/neutral/AbstractModuleProxy/AbstractModuleProxy.d.mts.map +0 -1
  66. package/dist/neutral/AbstractModuleProxy/AbstractModuleProxy.d.ts +0 -77
  67. package/dist/neutral/AbstractModuleProxy/AbstractModuleProxy.d.ts.map +0 -1
  68. package/dist/neutral/AbstractModuleProxy/ModuleProxyResolver.d.cts +0 -79
  69. package/dist/neutral/AbstractModuleProxy/ModuleProxyResolver.d.cts.map +0 -1
  70. package/dist/neutral/AbstractModuleProxy/ModuleProxyResolver.d.mts +0 -79
  71. package/dist/neutral/AbstractModuleProxy/ModuleProxyResolver.d.mts.map +0 -1
  72. package/dist/neutral/AbstractModuleProxy/ModuleProxyResolver.d.ts +0 -79
  73. package/dist/neutral/AbstractModuleProxy/ModuleProxyResolver.d.ts.map +0 -1
  74. package/dist/neutral/AbstractModuleProxy/index.d.cts +0 -3
  75. package/dist/neutral/AbstractModuleProxy/index.d.cts.map +0 -1
  76. package/dist/neutral/AbstractModuleProxy/index.d.mts +0 -3
  77. package/dist/neutral/AbstractModuleProxy/index.d.mts.map +0 -1
  78. package/dist/neutral/AbstractModuleProxy/index.d.ts +0 -3
  79. package/dist/neutral/AbstractModuleProxy/index.d.ts.map +0 -1
  80. package/dist/neutral/index.cjs +0 -606
  81. package/dist/neutral/index.cjs.map +0 -1
  82. package/dist/neutral/index.d.cts +0 -5
  83. package/dist/neutral/index.d.cts.map +0 -1
  84. package/dist/neutral/index.d.mts +0 -5
  85. package/dist/neutral/index.d.mts.map +0 -1
  86. package/dist/neutral/index.d.ts.map +0 -1
  87. package/dist/neutral/wrapModuleWithType.d.cts +0 -5
  88. package/dist/neutral/wrapModuleWithType.d.cts.map +0 -1
  89. package/dist/neutral/wrapModuleWithType.d.mts +0 -5
  90. package/dist/neutral/wrapModuleWithType.d.mts.map +0 -1
  91. package/dist/neutral/wrapModuleWithType.d.ts +0 -5
  92. package/dist/neutral/wrapModuleWithType.d.ts.map +0 -1
  93. package/dist/node/AbstractBridge.d.cts +0 -34
  94. package/dist/node/AbstractBridge.d.cts.map +0 -1
  95. package/dist/node/AbstractBridge.d.mts +0 -34
  96. package/dist/node/AbstractBridge.d.mts.map +0 -1
  97. package/dist/node/AbstractBridge.d.ts +0 -34
  98. package/dist/node/AbstractBridge.d.ts.map +0 -1
  99. package/dist/node/AbstractBridgeModuleResolver.d.cts +0 -22
  100. package/dist/node/AbstractBridgeModuleResolver.d.cts.map +0 -1
  101. package/dist/node/AbstractBridgeModuleResolver.d.mts +0 -22
  102. package/dist/node/AbstractBridgeModuleResolver.d.mts.map +0 -1
  103. package/dist/node/AbstractBridgeModuleResolver.d.ts +0 -22
  104. package/dist/node/AbstractBridgeModuleResolver.d.ts.map +0 -1
  105. package/dist/node/AbstractModuleProxy/AbstractModuleProxy.d.cts +0 -77
  106. package/dist/node/AbstractModuleProxy/AbstractModuleProxy.d.cts.map +0 -1
  107. package/dist/node/AbstractModuleProxy/AbstractModuleProxy.d.mts +0 -77
  108. package/dist/node/AbstractModuleProxy/AbstractModuleProxy.d.mts.map +0 -1
  109. package/dist/node/AbstractModuleProxy/AbstractModuleProxy.d.ts +0 -77
  110. package/dist/node/AbstractModuleProxy/AbstractModuleProxy.d.ts.map +0 -1
  111. package/dist/node/AbstractModuleProxy/ModuleProxyResolver.d.cts +0 -79
  112. package/dist/node/AbstractModuleProxy/ModuleProxyResolver.d.cts.map +0 -1
  113. package/dist/node/AbstractModuleProxy/ModuleProxyResolver.d.mts +0 -79
  114. package/dist/node/AbstractModuleProxy/ModuleProxyResolver.d.mts.map +0 -1
  115. package/dist/node/AbstractModuleProxy/ModuleProxyResolver.d.ts +0 -79
  116. package/dist/node/AbstractModuleProxy/ModuleProxyResolver.d.ts.map +0 -1
  117. package/dist/node/AbstractModuleProxy/index.d.cts +0 -3
  118. package/dist/node/AbstractModuleProxy/index.d.cts.map +0 -1
  119. package/dist/node/AbstractModuleProxy/index.d.mts +0 -3
  120. package/dist/node/AbstractModuleProxy/index.d.mts.map +0 -1
  121. package/dist/node/AbstractModuleProxy/index.d.ts +0 -3
  122. package/dist/node/AbstractModuleProxy/index.d.ts.map +0 -1
  123. package/dist/node/index.cjs +0 -630
  124. package/dist/node/index.cjs.map +0 -1
  125. package/dist/node/index.d.cts +0 -5
  126. package/dist/node/index.d.cts.map +0 -1
  127. package/dist/node/index.d.mts +0 -5
  128. package/dist/node/index.d.mts.map +0 -1
  129. package/dist/node/index.d.ts +0 -5
  130. package/dist/node/index.d.ts.map +0 -1
  131. package/dist/node/index.mjs +0 -601
  132. package/dist/node/index.mjs.map +0 -1
  133. package/dist/node/wrapModuleWithType.d.cts +0 -5
  134. package/dist/node/wrapModuleWithType.d.cts.map +0 -1
  135. package/dist/node/wrapModuleWithType.d.mts +0 -5
  136. package/dist/node/wrapModuleWithType.d.mts.map +0 -1
  137. package/dist/node/wrapModuleWithType.d.ts +0 -5
  138. package/dist/node/wrapModuleWithType.d.ts.map +0 -1
@@ -1,585 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
-
4
- // src/AbstractBridge.ts
5
- import { assertEx } from "@xylabs/assert";
6
- import { exists } from "@xylabs/exists";
7
- import { forget } from "@xylabs/forget";
8
- import { globallyUnique } from "@xylabs/object";
9
- import { asArchivistInstance } from "@xyo-network/archivist-model";
10
- import { QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
11
- import { BridgeConfigSchema, BridgeConnectQuerySchema, BridgeDisconnectQuerySchema, BridgeExposeQuerySchema, BridgeUnexposeQuerySchema, ModuleFilterPayloadSchema } from "@xyo-network/bridge-model";
12
- import { AbstractModuleInstance } from "@xyo-network/module-abstract";
13
- import { AddressSchema, isAddressModuleFilter, isNameModuleFilter, resolveAddressToInstance, resolvePathToAddress, transformModuleIdentifier } from "@xyo-network/module-model";
14
- import { isPayloadOfSchemaType } from "@xyo-network/payload-model";
15
- var AbstractBridge = class _AbstractBridge extends AbstractModuleInstance {
16
- static {
17
- __name(this, "AbstractBridge");
18
- }
19
- static configSchemas = [
20
- ...super.configSchemas,
21
- BridgeConfigSchema
22
- ];
23
- static defaultConfigSchema = BridgeConfigSchema;
24
- static uniqueName = globallyUnique("AbstractBridge", _AbstractBridge, "xyo");
25
- _roots;
26
- get allowNameResolution() {
27
- return this.params.allowNameResolution ?? true;
28
- }
29
- get discoverRoots() {
30
- return this.config.client?.discoverRoots ?? this.config.discoverRoots ?? (this.config.client === void 0 ? false : "start");
31
- }
32
- get queries() {
33
- return [
34
- BridgeConnectQuerySchema,
35
- BridgeDisconnectQuerySchema,
36
- BridgeExposeQuerySchema,
37
- BridgeUnexposeQuerySchema,
38
- ...super.queries
39
- ];
40
- }
41
- get resolver() {
42
- return assertEx(this.params.resolver, () => "No resolver provided");
43
- }
44
- async expose(id, options) {
45
- this._noOverride("expose");
46
- assertEx(id !== "*", () => "Exposing '*' not supported");
47
- const addressToExpose = assertEx(await resolvePathToAddress(this, id), () => `Module to expose not found [${id}]`);
48
- console.log(`expose: ${addressToExpose}`);
49
- const modules = await this.exposeHandler(addressToExpose, options);
50
- await this.emit("exposed", {
51
- mod: this,
52
- modules
53
- });
54
- return modules;
55
- }
56
- async exposed() {
57
- this._noOverride("exposed");
58
- return await this.exposedHandler();
59
- }
60
- // eslint-disable-next-line complexity
61
- async resolve(idOrFilter = "*", options = {}) {
62
- const roots = this._roots ?? [];
63
- const workingSet = options.direction === "up" ? [
64
- this
65
- ] : [
66
- ...roots,
67
- this
68
- ];
69
- if (idOrFilter === "*") {
70
- const remainingDepth = (options.maxDepth ?? 5) - 1;
71
- return remainingDepth <= 0 ? workingSet : [
72
- ...workingSet,
73
- ...(await Promise.all(roots.map((mod) => mod.resolve("*", {
74
- ...options,
75
- maxDepth: remainingDepth
76
- })))).flat()
77
- ];
78
- }
79
- switch (typeof idOrFilter) {
80
- case "string": {
81
- const parts = idOrFilter.split(":");
82
- const first = assertEx(parts.shift(), () => "Missing module identifier");
83
- const firstId = await transformModuleIdentifier(first, this.moduleIdentifierTransformers);
84
- const result = workingSet.find((mod) => {
85
- return firstId === mod.address || firstId === mod.modName;
86
- });
87
- return parts.length === 0 ? result : result?.resolve(parts.join(":"), options);
88
- }
89
- case "object": {
90
- const results = [];
91
- if (isNameModuleFilter(idOrFilter)) {
92
- for (const mod of workingSet) {
93
- if (mod.modName && idOrFilter.name.includes(mod.modName)) results.push(mod);
94
- }
95
- }
96
- if (isAddressModuleFilter(idOrFilter)) {
97
- for (const mod of workingSet) {
98
- if (mod.modName && idOrFilter.address.includes(mod.address)) results.push(mod);
99
- }
100
- }
101
- return results;
102
- }
103
- default: {
104
- return;
105
- }
106
- }
107
- }
108
- async startHandler() {
109
- if (this.discoverRoots === "lazy") {
110
- forget(this.getRoots());
111
- } else if (this.discoverRoots === "start") {
112
- await this.getRoots();
113
- }
114
- return true;
115
- }
116
- async unexpose(id, options) {
117
- this._noOverride("unexpose");
118
- const addressToUnexpose = assertEx(await resolvePathToAddress(this, id), () => `Module to unexpose not found [${id}]`);
119
- const modules = await this.unexposeHandler(addressToUnexpose, options);
120
- await this.emit("unexposed", {
121
- mod: this,
122
- modules
123
- });
124
- return modules.map((mod) => mod.address);
125
- }
126
- async queryHandler(query, payloads) {
127
- const wrapper = await QueryBoundWitnessWrapper.parseQuery(query, payloads);
128
- const queryPayload = await wrapper.getQuery();
129
- const resultPayloads = [];
130
- switch (queryPayload.schema) {
131
- case BridgeExposeQuerySchema: {
132
- const filterPayloads = (payloads ?? []).filter(isPayloadOfSchemaType(ModuleFilterPayloadSchema));
133
- assertEx(filterPayloads, () => "At least one filter is required");
134
- await Promise.all(filterPayloads.map(async (filter) => {
135
- const { id, ...options } = filter;
136
- const modules = await this.expose(id, options);
137
- for (const mod of modules) {
138
- const addressPayload = {
139
- address: mod.address,
140
- schema: AddressSchema
141
- };
142
- resultPayloads.push(addressPayload);
143
- }
144
- }));
145
- break;
146
- }
147
- case BridgeUnexposeQuerySchema: {
148
- const filterPayloads = (payloads ?? []).filter(isPayloadOfSchemaType(ModuleFilterPayloadSchema));
149
- assertEx(filterPayloads, () => "At least one filter is required");
150
- await Promise.all(filterPayloads.map(async (filter) => {
151
- const { id, ...options } = filter;
152
- const moduleAddresses = await this.unexpose(id, options);
153
- for (const address of moduleAddresses) {
154
- const addressPayload = {
155
- address,
156
- schema: AddressSchema
157
- };
158
- resultPayloads.push(addressPayload);
159
- }
160
- }));
161
- break;
162
- }
163
- default: {
164
- return await super.queryHandler(query, payloads);
165
- }
166
- }
167
- return resultPayloads;
168
- }
169
- async resolveArchivingArchivists() {
170
- const archivists = this.archiving?.archivists;
171
- if (!archivists) return [];
172
- const resolvedAddresses = (await Promise.all(archivists.map(async (archivist) => (await Promise.all((await this.parents()).map((parent) => resolvePathToAddress(parent, archivist)))).filter(exists)))).flat().filter(exists);
173
- const resolved = (await Promise.all(resolvedAddresses.map((address) => resolveAddressToInstance(this, address)))).filter(exists);
174
- return resolved.map((mod) => asArchivistInstance(mod)).filter(exists);
175
- }
176
- };
177
-
178
- // src/AbstractBridgeModuleResolver.ts
179
- import { ObjectResolverPriority } from "@xyo-network/module-model";
180
- import { CompositeModuleResolver } from "@xyo-network/module-resolver";
181
- var AbstractBridgeModuleResolver = class extends CompositeModuleResolver {
182
- static {
183
- __name(this, "AbstractBridgeModuleResolver");
184
- }
185
- get priority() {
186
- return ObjectResolverPriority.VeryLow;
187
- }
188
- async resolveHandler(id, options, _params) {
189
- if (id === "*") {
190
- return [];
191
- }
192
- return await super.resolveHandler(id, options);
193
- }
194
- };
195
-
196
- // src/AbstractModuleProxy/AbstractModuleProxy.ts
197
- import { assertEx as assertEx3 } from "@xylabs/assert";
198
- import { forget as forget2 } from "@xylabs/forget";
199
- import { asAddress } from "@xylabs/hex";
200
- import { compact } from "@xylabs/lodash";
201
- import { toJsonString } from "@xylabs/object";
202
- import { BoundWitnessWrapper, QueryBoundWitnessWrapper as QueryBoundWitnessWrapper2 } from "@xyo-network/boundwitness-wrapper";
203
- import { ModuleManifestPayloadSchema, NodeManifestPayloadSchema } from "@xyo-network/manifest-model";
204
- import { AbstractModuleInstance as AbstractModuleInstance2 } from "@xyo-network/module-abstract";
205
- import { AddressPreviousHashSchema, DeadModuleError, ModuleAddressQuerySchema, ModuleManifestQuerySchema, ModuleStateQuerySchema } from "@xyo-network/module-model";
206
- import { ModuleWrapper } from "@xyo-network/module-wrapper";
207
- import { PayloadBuilder } from "@xyo-network/payload-builder";
208
- import { isPayloadOfSchemaType as isPayloadOfSchemaType2, ModuleErrorSchema } from "@xyo-network/payload-model";
209
- import { QuerySchema } from "@xyo-network/query-payload-plugin";
210
- import { LRUCache } from "lru-cache";
211
-
212
- // src/AbstractModuleProxy/ModuleProxyResolver.ts
213
- import { assertEx as assertEx2 } from "@xylabs/assert";
214
- import { exists as exists2 } from "@xylabs/exists";
215
- import { Account } from "@xyo-network/account";
216
- import { isAddressModuleFilter as isAddressModuleFilter2, isNameModuleFilter as isNameModuleFilter2, ObjectResolverPriority as ObjectResolverPriority2 } from "@xyo-network/module-model";
217
- import { CompositeModuleResolver as CompositeModuleResolver2 } from "@xyo-network/module-resolver";
218
-
219
- // src/wrapModuleWithType.ts
220
- import { isArchivistModule } from "@xyo-network/archivist-model";
221
- import { ArchivistWrapper } from "@xyo-network/archivist-wrapper";
222
- import { isDivinerModule } from "@xyo-network/diviner-model";
223
- import { DivinerWrapper } from "@xyo-network/diviner-wrapper";
224
- import { isNodeModule } from "@xyo-network/node-model";
225
- import { NodeWrapper } from "@xyo-network/node-wrapper";
226
- import { isSentinelModule } from "@xyo-network/sentinel-model";
227
- import { SentinelWrapper } from "@xyo-network/sentinel-wrapper";
228
- import { isWitnessModule } from "@xyo-network/witness-model";
229
- import { WitnessWrapper } from "@xyo-network/witness-wrapper";
230
- var wrapModuleWithType = /* @__PURE__ */ __name((mod, account) => {
231
- if (isArchivistModule(mod)) {
232
- return ArchivistWrapper.wrap(mod, account);
233
- }
234
- if (isDivinerModule(mod)) {
235
- return DivinerWrapper.wrap(mod, account);
236
- }
237
- if (isNodeModule(mod)) {
238
- return NodeWrapper.wrap(mod, account);
239
- }
240
- if (isSentinelModule(mod)) {
241
- return SentinelWrapper.wrap(mod, account);
242
- }
243
- if (isWitnessModule(mod)) {
244
- return WitnessWrapper.wrap(mod, account);
245
- }
246
- throw "Failed to wrap";
247
- }, "wrapModuleWithType");
248
-
249
- // src/AbstractModuleProxy/ModuleProxyResolver.ts
250
- var ModuleProxyResolver = class {
251
- static {
252
- __name(this, "ModuleProxyResolver");
253
- }
254
- options;
255
- downResolver;
256
- constructor(options) {
257
- this.options = options;
258
- this.downResolver = new CompositeModuleResolver2({
259
- moduleIdentifierTransformers: options.moduleIdentifierTransformers,
260
- root: this.root
261
- });
262
- }
263
- get priority() {
264
- return ObjectResolverPriority2.VeryLow;
265
- }
266
- get root() {
267
- return this.options.mod;
268
- }
269
- get childAddressMap() {
270
- return this.options.childAddressMap;
271
- }
272
- get host() {
273
- return this.options.host;
274
- }
275
- get mod() {
276
- return this.options.mod;
277
- }
278
- addResolver(_resolver) {
279
- throw new Error("Not supported");
280
- }
281
- childManifest(address) {
282
- return this.options.childManifests?.[address];
283
- }
284
- childState(address) {
285
- return this.options.childStates?.[address];
286
- }
287
- removeResolver(_resolver) {
288
- throw new Error("Not supported");
289
- }
290
- // eslint-disable-next-line complexity
291
- async resolve(idOrFilter = "*", options) {
292
- const direction = options?.direction ?? "all";
293
- if (idOrFilter === "*") {
294
- const childAddresses = Object.keys(this.childAddressMap);
295
- const resolvedChildren = await Promise.all(childAddresses.map((address) => this.resolve(address, options)));
296
- return resolvedChildren.filter(exists2);
297
- } else if (typeof idOrFilter === "string") {
298
- const idParts = idOrFilter.split(":");
299
- const firstPart = assertEx2(idParts.shift(), () => "Invalid module identifier at first position");
300
- const firstPartAddress = await this.resolveIdentifier(firstPart);
301
- if (firstPartAddress) {
302
- const remainingParts = idParts.length > 0 ? idParts.join(":") : void 0;
303
- if (direction === "down" || direction === "all") {
304
- const downResolverModule = await this.downResolver.resolve(firstPartAddress);
305
- if (downResolverModule) {
306
- return remainingParts ? downResolverModule.resolve(remainingParts, options) : downResolverModule;
307
- }
308
- console.log(`ModuleProxyResolver: ${firstPartAddress} | ${this.root.address}`);
309
- if (firstPartAddress === this.root.address) {
310
- const wrapped = wrapModuleWithType(this.root, await Account.random());
311
- return remainingParts ? wrapped?.resolve(remainingParts, options) : wrapped;
312
- }
313
- const addressToProxy = Object.keys(this.childAddressMap).includes(firstPartAddress) ? firstPartAddress : Object.entries(this.childAddressMap).find(([_, value]) => value === firstPartAddress)?.[0];
314
- if (addressToProxy) {
315
- const proxy = await this.host.resolve(addressToProxy, {
316
- ...options,
317
- direction: "down"
318
- });
319
- if (proxy) {
320
- const wrapped = wrapModuleWithType(proxy, await Account.random());
321
- return remainingParts ? wrapped?.resolve(remainingParts, options) : wrapped;
322
- }
323
- return;
324
- }
325
- }
326
- }
327
- return;
328
- } else {
329
- const filter = idOrFilter;
330
- if (isAddressModuleFilter2(filter)) {
331
- return (await Promise.all(filter.address.map((item) => this.resolve(item, options)))).filter(exists2);
332
- } else if (isNameModuleFilter2(filter)) {
333
- return (await Promise.all(filter.name.map((item) => this.resolve(item, options)))).filter(exists2);
334
- }
335
- }
336
- }
337
- resolveIdentifier(id, _options) {
338
- if (this.childAddressMap[id]) {
339
- return id;
340
- }
341
- if (this.root.address === id) {
342
- return this.root.address;
343
- }
344
- if (this.root.modName === id) {
345
- return this.root.address;
346
- }
347
- const addressFromName = Object.entries(this.childAddressMap).find(([, name]) => name === id)?.[0];
348
- if (addressFromName) {
349
- return addressFromName;
350
- }
351
- }
352
- async resolvePrivate(id, _options) {
353
- if (id === "*") return await Promise.resolve([]);
354
- }
355
- };
356
-
357
- // src/AbstractModuleProxy/AbstractModuleProxy.ts
358
- var AbstractModuleProxy = class _AbstractModuleProxy extends AbstractModuleInstance2 {
359
- static {
360
- __name(this, "AbstractModuleProxy");
361
- }
362
- static requiredQueries = [
363
- ModuleStateQuerySchema
364
- ];
365
- _config;
366
- _publicChildren;
367
- _state = void 0;
368
- _stateInProcess = false;
369
- _spamTrap = new LRUCache({
370
- max: 1e3,
371
- ttl: 1e3 * 60,
372
- ttlAutopurge: true
373
- });
374
- constructor(params) {
375
- params.addToResolvers = false;
376
- super(_AbstractModuleProxy.privateConstructorKey, params, params.account);
377
- }
378
- get address() {
379
- return this.params.moduleAddress;
380
- }
381
- get archiving() {
382
- return this.params?.archiving;
383
- }
384
- get config() {
385
- return assertEx3(this._config, () => "Config not set");
386
- }
387
- get queries() {
388
- const queryPayloads = assertEx3(this._state, () => "Module state not found. Make sure proxy has been started").filter((item) => isPayloadOfSchemaType2(QuerySchema)(item));
389
- return queryPayloads.map((payload) => payload.query);
390
- }
391
- static hasRequiredQueries(mod) {
392
- return this.missingRequiredQueries(mod).length === 0;
393
- }
394
- static missingRequiredQueries(mod) {
395
- const moduleQueries = mod.queries;
396
- return compact(this.requiredQueries.map((query) => {
397
- return moduleQueries.includes(query) ? null : query;
398
- }));
399
- }
400
- async addressPreviousHash() {
401
- const queryPayload = {
402
- schema: ModuleAddressQuerySchema
403
- };
404
- const result = assertEx3((await this.sendQuery(queryPayload, void 0, this.account)).find(isPayloadOfSchemaType2(AddressPreviousHashSchema)), () => "Result did not include correct payload");
405
- return result;
406
- }
407
- childAddressByName(name) {
408
- const nodeManifests = this._state?.filter(isPayloadOfSchemaType2(NodeManifestPayloadSchema));
409
- const childPairs = nodeManifests?.flatMap((nodeManifest) => Object.entries(nodeManifest.status?.children ?? {}));
410
- return asAddress(childPairs?.find(([_, childName]) => childName === name)?.[0]);
411
- }
412
- async childAddressMap() {
413
- let nodeManifests = isPayloadOfSchemaType2(NodeManifestPayloadSchema)(this.params.manifest) ? [
414
- this.params.manifest
415
- ] : void 0;
416
- const result = {};
417
- if (nodeManifests === void 0) {
418
- const state = await this.state();
419
- nodeManifests = state.filter(isPayloadOfSchemaType2(NodeManifestPayloadSchema));
420
- }
421
- for (const manifest of nodeManifests ?? []) {
422
- const children = manifest.modules?.public ?? [];
423
- for (const child of children) {
424
- if (typeof child === "object") {
425
- const address = child.status?.address;
426
- if (address) {
427
- result[address] = child.config.name ?? null;
428
- }
429
- }
430
- }
431
- }
432
- return result;
433
- }
434
- async manifest(maxDepth) {
435
- const queryPayload = {
436
- schema: ModuleManifestQuerySchema,
437
- ...maxDepth === void 0 ? {} : {
438
- maxDepth
439
- }
440
- };
441
- return (await this.sendQuery(queryPayload))[0];
442
- }
443
- async moduleAddress() {
444
- const queryPayload = {
445
- schema: ModuleAddressQuerySchema
446
- };
447
- return await this.sendQuery(queryPayload);
448
- }
449
- async previousHash() {
450
- const queryPayload = {
451
- schema: ModuleAddressQuerySchema
452
- };
453
- return (await this.sendQuery(queryPayload)).pop().previousHash;
454
- }
455
- async publicChildren() {
456
- this._publicChildren = this._publicChildren ?? await super.publicChildren();
457
- return this._publicChildren;
458
- }
459
- async query(query, payloads) {
460
- this._checkDead();
461
- return await this.busy(async () => {
462
- try {
463
- await this.checkSpam(query);
464
- if (this.archiving && this.isAllowedArchivingQuery(query.schema)) {
465
- forget2(this.storeToArchivists([
466
- query,
467
- ...payloads ?? []
468
- ]));
469
- }
470
- this.params.onQuerySendStarted?.({
471
- payloads,
472
- query
473
- });
474
- const result = await this.proxyQueryHandler(query, payloads);
475
- this.params.onQuerySendFinished?.({
476
- payloads,
477
- query,
478
- result,
479
- status: "success"
480
- });
481
- if (this.archiving && this.isAllowedArchivingQuery(query.schema)) {
482
- forget2(this.storeToArchivists(result.flat()));
483
- }
484
- forget2(this.emit("moduleQueried", {
485
- mod: this,
486
- payloads,
487
- query,
488
- result
489
- }));
490
- return result;
491
- } catch (ex) {
492
- this.params.onQuerySendFinished?.({
493
- payloads,
494
- query,
495
- status: "failure"
496
- });
497
- const error = ex;
498
- this._lastError = error;
499
- const deadError = new DeadModuleError(this.address, error);
500
- const errorPayload = {
501
- message: deadError.message,
502
- name: deadError.name,
503
- schema: ModuleErrorSchema
504
- };
505
- const sourceQuery = await PayloadBuilder.build(assertEx3(QueryBoundWitnessWrapper2.unwrap(query), () => "Invalid query"));
506
- return await this.bindQueryResult(sourceQuery, [], void 0, [
507
- errorPayload
508
- ]);
509
- }
510
- });
511
- }
512
- queryHandler(_query, _payloads, _queryConfig) {
513
- throw new Error("queryHandler should never be called");
514
- }
515
- async queryable(_query, _payloads, _queryConfig) {
516
- return await Promise.resolve(true);
517
- }
518
- async resolveArchivingArchivists() {
519
- return await this.params.archiving?.resolveArchivists() ?? [];
520
- }
521
- setConfig(config) {
522
- this._config = config;
523
- }
524
- setState(state) {
525
- this._state = state;
526
- }
527
- async startHandler() {
528
- let manifest = this.params.manifest;
529
- if (!manifest) {
530
- const state = await this.state();
531
- const manifestPayload = state.find((payload) => isPayloadOfSchemaType2(NodeManifestPayloadSchema)(payload) || isPayloadOfSchemaType2(ModuleManifestPayloadSchema)(payload));
532
- manifest = assertEx3(manifestPayload, () => "Can't find manifest payload");
533
- }
534
- this.setConfig({
535
- ...manifest.config
536
- });
537
- this.downResolver.addResolver(new ModuleProxyResolver({
538
- childAddressMap: await this.childAddressMap(),
539
- host: this.params.host,
540
- mod: this,
541
- moduleIdentifierTransformers: this.params.moduleIdentifierTransformers
542
- }));
543
- return await super.startHandler();
544
- }
545
- async state() {
546
- if (this._state === void 0) {
547
- const stateQueryPayload = {
548
- query: ModuleStateQuerySchema,
549
- schema: QuerySchema
550
- };
551
- const manifestQueryPayload = {
552
- query: ModuleManifestQuerySchema,
553
- schema: QuerySchema
554
- };
555
- this._state = [
556
- stateQueryPayload,
557
- manifestQueryPayload
558
- ];
559
- const wrapper = ModuleWrapper.wrap(this, this.account);
560
- this._state = await wrapper.state();
561
- }
562
- return this._state;
563
- }
564
- async filterErrors(result) {
565
- const wrapper = await BoundWitnessWrapper.wrap(result[0], result[1]);
566
- return wrapper.payloadsBySchema(ModuleErrorSchema);
567
- }
568
- // this checks and warns if we are getting spammed by the same query
569
- async checkSpam(query) {
570
- const hash = await PayloadBuilder.hash(query);
571
- const previousCount = this._spamTrap.get(hash) ?? 0;
572
- if (previousCount > 0) {
573
- this.logger?.warn(`Spam trap triggered for query: ${hash} from ${toJsonString(query.addresses)}`);
574
- }
575
- this._spamTrap.set(hash, previousCount + 1);
576
- }
577
- };
578
- export {
579
- AbstractBridge,
580
- AbstractBridgeModuleResolver,
581
- AbstractModuleProxy,
582
- ModuleProxyResolver,
583
- wrapModuleWithType
584
- };
585
- //# sourceMappingURL=index.mjs.map