@xyo-network/diviner-temporal-indexing-memory 2.106.0 → 2.107.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 (85) hide show
  1. package/dist/browser/DivinerQueryToIndexQueryDiviner/Diviner.d.cts +0 -23
  2. package/dist/browser/DivinerQueryToIndexQueryDiviner/Diviner.d.cts.map +1 -1
  3. package/dist/browser/DivinerQueryToIndexQueryDiviner/Diviner.d.mts +0 -23
  4. package/dist/browser/DivinerQueryToIndexQueryDiviner/Diviner.d.mts.map +1 -1
  5. package/dist/browser/DivinerQueryToIndexQueryDiviner/Diviner.d.ts +0 -23
  6. package/dist/browser/DivinerQueryToIndexQueryDiviner/Diviner.d.ts.map +1 -1
  7. package/dist/browser/IndexCandidateToIndexDiviner/Diviner.d.cts +0 -26
  8. package/dist/browser/IndexCandidateToIndexDiviner/Diviner.d.cts.map +1 -1
  9. package/dist/browser/IndexCandidateToIndexDiviner/Diviner.d.mts +0 -26
  10. package/dist/browser/IndexCandidateToIndexDiviner/Diviner.d.mts.map +1 -1
  11. package/dist/browser/IndexCandidateToIndexDiviner/Diviner.d.ts +0 -26
  12. package/dist/browser/IndexCandidateToIndexDiviner/Diviner.d.ts.map +1 -1
  13. package/dist/browser/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.cts +0 -3
  14. package/dist/browser/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.cts.map +1 -1
  15. package/dist/browser/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.mts +0 -3
  16. package/dist/browser/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.mts.map +1 -1
  17. package/dist/browser/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.ts +0 -3
  18. package/dist/browser/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.ts.map +1 -1
  19. package/dist/browser/StateToIndexCandidateDiviner/Diviner.d.cts +19 -44
  20. package/dist/browser/StateToIndexCandidateDiviner/Diviner.d.cts.map +1 -1
  21. package/dist/browser/StateToIndexCandidateDiviner/Diviner.d.mts +19 -44
  22. package/dist/browser/StateToIndexCandidateDiviner/Diviner.d.mts.map +1 -1
  23. package/dist/browser/StateToIndexCandidateDiviner/Diviner.d.ts +19 -44
  24. package/dist/browser/StateToIndexCandidateDiviner/Diviner.d.ts.map +1 -1
  25. package/dist/browser/index.cjs +1 -401
  26. package/dist/browser/index.cjs.map +1 -1
  27. package/dist/browser/index.js +1 -380
  28. package/dist/browser/index.js.map +1 -1
  29. package/dist/neutral/DivinerQueryToIndexQueryDiviner/Diviner.d.cts +0 -23
  30. package/dist/neutral/DivinerQueryToIndexQueryDiviner/Diviner.d.cts.map +1 -1
  31. package/dist/neutral/DivinerQueryToIndexQueryDiviner/Diviner.d.mts +0 -23
  32. package/dist/neutral/DivinerQueryToIndexQueryDiviner/Diviner.d.mts.map +1 -1
  33. package/dist/neutral/DivinerQueryToIndexQueryDiviner/Diviner.d.ts +0 -23
  34. package/dist/neutral/DivinerQueryToIndexQueryDiviner/Diviner.d.ts.map +1 -1
  35. package/dist/neutral/IndexCandidateToIndexDiviner/Diviner.d.cts +0 -26
  36. package/dist/neutral/IndexCandidateToIndexDiviner/Diviner.d.cts.map +1 -1
  37. package/dist/neutral/IndexCandidateToIndexDiviner/Diviner.d.mts +0 -26
  38. package/dist/neutral/IndexCandidateToIndexDiviner/Diviner.d.mts.map +1 -1
  39. package/dist/neutral/IndexCandidateToIndexDiviner/Diviner.d.ts +0 -26
  40. package/dist/neutral/IndexCandidateToIndexDiviner/Diviner.d.ts.map +1 -1
  41. package/dist/neutral/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.cts +0 -3
  42. package/dist/neutral/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.cts.map +1 -1
  43. package/dist/neutral/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.mts +0 -3
  44. package/dist/neutral/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.mts.map +1 -1
  45. package/dist/neutral/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.ts +0 -3
  46. package/dist/neutral/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.ts.map +1 -1
  47. package/dist/neutral/StateToIndexCandidateDiviner/Diviner.d.cts +19 -44
  48. package/dist/neutral/StateToIndexCandidateDiviner/Diviner.d.cts.map +1 -1
  49. package/dist/neutral/StateToIndexCandidateDiviner/Diviner.d.mts +19 -44
  50. package/dist/neutral/StateToIndexCandidateDiviner/Diviner.d.mts.map +1 -1
  51. package/dist/neutral/StateToIndexCandidateDiviner/Diviner.d.ts +19 -44
  52. package/dist/neutral/StateToIndexCandidateDiviner/Diviner.d.ts.map +1 -1
  53. package/dist/neutral/index.cjs +1 -401
  54. package/dist/neutral/index.cjs.map +1 -1
  55. package/dist/neutral/index.js +1 -380
  56. package/dist/neutral/index.js.map +1 -1
  57. package/dist/node/DivinerQueryToIndexQueryDiviner/Diviner.d.cts +0 -23
  58. package/dist/node/DivinerQueryToIndexQueryDiviner/Diviner.d.cts.map +1 -1
  59. package/dist/node/DivinerQueryToIndexQueryDiviner/Diviner.d.mts +0 -23
  60. package/dist/node/DivinerQueryToIndexQueryDiviner/Diviner.d.mts.map +1 -1
  61. package/dist/node/DivinerQueryToIndexQueryDiviner/Diviner.d.ts +0 -23
  62. package/dist/node/DivinerQueryToIndexQueryDiviner/Diviner.d.ts.map +1 -1
  63. package/dist/node/IndexCandidateToIndexDiviner/Diviner.d.cts +0 -26
  64. package/dist/node/IndexCandidateToIndexDiviner/Diviner.d.cts.map +1 -1
  65. package/dist/node/IndexCandidateToIndexDiviner/Diviner.d.mts +0 -26
  66. package/dist/node/IndexCandidateToIndexDiviner/Diviner.d.mts.map +1 -1
  67. package/dist/node/IndexCandidateToIndexDiviner/Diviner.d.ts +0 -26
  68. package/dist/node/IndexCandidateToIndexDiviner/Diviner.d.ts.map +1 -1
  69. package/dist/node/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.cts +0 -3
  70. package/dist/node/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.cts.map +1 -1
  71. package/dist/node/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.mts +0 -3
  72. package/dist/node/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.mts.map +1 -1
  73. package/dist/node/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.ts +0 -3
  74. package/dist/node/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.d.ts.map +1 -1
  75. package/dist/node/StateToIndexCandidateDiviner/Diviner.d.cts +19 -44
  76. package/dist/node/StateToIndexCandidateDiviner/Diviner.d.cts.map +1 -1
  77. package/dist/node/StateToIndexCandidateDiviner/Diviner.d.mts +19 -44
  78. package/dist/node/StateToIndexCandidateDiviner/Diviner.d.mts.map +1 -1
  79. package/dist/node/StateToIndexCandidateDiviner/Diviner.d.ts +19 -44
  80. package/dist/node/StateToIndexCandidateDiviner/Diviner.d.ts.map +1 -1
  81. package/dist/node/index.cjs +1 -414
  82. package/dist/node/index.cjs.map +1 -1
  83. package/dist/node/index.js +1 -385
  84. package/dist/node/index.js.map +1 -1
  85. package/package.json +29 -29
@@ -1,381 +1,2 @@
1
- var __defProp = Object.defineProperty;
2
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
-
4
- // src/Diviner.ts
5
- import { IndexingDiviner } from "@xyo-network/diviner-indexing-memory";
6
- import { TemporalIndexingDivinerConfigSchema } from "@xyo-network/diviner-temporal-indexing-model";
7
- var TemporalIndexingDiviner = class extends IndexingDiviner {
8
- static {
9
- __name(this, "TemporalIndexingDiviner");
10
- }
11
- static configSchemas = [
12
- ...super.configSchemas,
13
- TemporalIndexingDivinerConfigSchema
14
- ];
15
- static defaultConfigSchema = TemporalIndexingDivinerConfigSchema;
16
- async startHandler() {
17
- await super.startHandler();
18
- return true;
19
- }
20
- };
21
-
22
- // src/DivinerQueryToIndexQueryDiviner/Diviner.ts
23
- import { AbstractDiviner } from "@xyo-network/diviner-abstract";
24
- import { jsonPathToTransformersDictionary, reducePayloads } from "@xyo-network/diviner-jsonpath-aggregate-memory";
25
- import { PayloadDivinerQuerySchema } from "@xyo-network/diviner-payload-model";
26
- import { TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema, TemporalIndexingDivinerResultIndexSchema } from "@xyo-network/diviner-temporal-indexing-model";
27
- import { PayloadBuilder } from "@xyo-network/payload-builder";
28
- import { isPayloadOfSchemaType } from "@xyo-network/payload-model";
29
- var TemporalIndexingDivinerDivinerQueryToIndexQueryDiviner = class extends AbstractDiviner {
30
- static {
31
- __name(this, "TemporalIndexingDivinerDivinerQueryToIndexQueryDiviner");
32
- }
33
- static configSchemas = [
34
- ...super.configSchemas,
35
- TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema
36
- ];
37
- static defaultConfigSchema = TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema;
38
- static labels = {
39
- ...super.labels,
40
- "network.xyo.diviner.stage": "divinerQueryToIndexQueryDiviner"
41
- };
42
- _indexableSchemas;
43
- _payloadTransformers;
44
- /**
45
- * The schema of the diviner query payloads
46
- */
47
- get divinerQuerySchema() {
48
- return this.config.divinerQuerySchema ?? PayloadDivinerQuerySchema;
49
- }
50
- /**
51
- * The schema of the index query payloads
52
- */
53
- get indexQuerySchema() {
54
- return this.config.indexQuerySchema ?? PayloadDivinerQuerySchema;
55
- }
56
- /**
57
- * The schema of the index payloads
58
- */
59
- get indexSchema() {
60
- return this.config.indexSchema ?? TemporalIndexingDivinerResultIndexSchema;
61
- }
62
- /**
63
- * List of indexable schemas for this diviner
64
- */
65
- get indexableSchemas() {
66
- if (!this._indexableSchemas) this._indexableSchemas = Object.keys(this.schemaTransforms);
67
- return this._indexableSchemas;
68
- }
69
- /**
70
- * Dictionary of schemas to payload transformers for creating indexes
71
- * from the payloads within a Bound Witness
72
- */
73
- get payloadTransformers() {
74
- if (!this._payloadTransformers) this._payloadTransformers = jsonPathToTransformersDictionary(this.schemaTransforms);
75
- return this._payloadTransformers;
76
- }
77
- /**
78
- * The dictionary of schemas to JSON Path transform expressions for creating indexes
79
- * from the payloads within a Bound Witness
80
- */
81
- get schemaTransforms() {
82
- return this.config?.schemaTransforms ?? {
83
- [this.divinerQuerySchema]: [
84
- {
85
- defaultValue: 1,
86
- destinationField: "limit",
87
- sourcePathExpression: "$.limit"
88
- },
89
- {
90
- defaultValue: 0,
91
- destinationField: "offset",
92
- sourcePathExpression: "$.offset"
93
- },
94
- {
95
- defaultValue: "desc",
96
- destinationField: "order",
97
- sourcePathExpression: "$.order"
98
- }
99
- ]
100
- };
101
- }
102
- async divineHandler(payloads = []) {
103
- const queries = payloads.filter(isPayloadOfSchemaType(this.divinerQuerySchema));
104
- if (queries.length > 0) {
105
- const results = await Promise.all(queries.map(async (query) => {
106
- const fields = await reducePayloads([
107
- query
108
- ], this.payloadTransformers, this.indexQuerySchema);
109
- fields.schemas = [
110
- this.indexSchema
111
- ];
112
- delete fields.sources;
113
- return await new PayloadBuilder({
114
- schema: this.indexQuerySchema
115
- }).fields(fields).build();
116
- }));
117
- return results;
118
- }
119
- return [];
120
- }
121
- };
122
-
123
- // src/IndexCandidateToIndexDiviner/Diviner.ts
124
- import { containsAll } from "@xylabs/array";
125
- import { assertEx } from "@xylabs/assert";
126
- import { exists } from "@xylabs/exists";
127
- import { isBoundWitnessWithMeta } from "@xyo-network/boundwitness-model";
128
- import { AbstractDiviner as AbstractDiviner2 } from "@xyo-network/diviner-abstract";
129
- import { jsonPathToTransformersDictionary as jsonPathToTransformersDictionary2 } from "@xyo-network/diviner-jsonpath-aggregate-memory";
130
- import { TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema, TemporalIndexingDivinerResultIndexSchema as TemporalIndexingDivinerResultIndexSchema2 } from "@xyo-network/diviner-temporal-indexing-model";
131
- import { PayloadBuilder as PayloadBuilder2 } from "@xyo-network/payload-builder";
132
- import { isAnyPayload } from "@xyo-network/payload-model";
133
- import { intraBoundwitnessSchemaCombinations } from "@xyo-network/payload-utils";
134
- var moduleName = "TemporalIndexingDivinerIndexCandidateToIndexDiviner";
135
- var TemporalIndexingDivinerIndexCandidateToIndexDiviner = class extends AbstractDiviner2 {
136
- static {
137
- __name(this, "TemporalIndexingDivinerIndexCandidateToIndexDiviner");
138
- }
139
- static configSchemas = [
140
- ...super.configSchemas,
141
- TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema
142
- ];
143
- static defaultConfigSchema = TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema;
144
- static labels = {
145
- ...super.labels,
146
- "network.xyo.diviner.stage": "indexCandidateToIndexDiviner"
147
- };
148
- _indexableSchemas;
149
- _payloadTransformers;
150
- /**
151
- * List of indexable schemas for this diviner
152
- */
153
- get indexableSchemas() {
154
- if (!this._indexableSchemas) this._indexableSchemas = Object.keys(this.schemaTransforms);
155
- return this._indexableSchemas;
156
- }
157
- /**
158
- * Dictionary of schemas to payload transformers for creating indexes
159
- * from the payloads within a Bound Witness
160
- */
161
- get payloadTransformers() {
162
- if (!this._payloadTransformers) this._payloadTransformers = jsonPathToTransformersDictionary2(this.schemaTransforms);
163
- return this._payloadTransformers;
164
- }
165
- /**
166
- * The dictionary of schemas to JSON Path transform expressions for creating indexes
167
- * from the payloads within a Bound Witness
168
- */
169
- get schemaTransforms() {
170
- return assertEx(this.config?.schemaTransforms, () => `${moduleName}: Missing config.schemaTransforms section`);
171
- }
172
- async divineHandler(payloads = []) {
173
- const builtPayloads = await Promise.all(payloads.map((payload) => PayloadBuilder2.build(payload)));
174
- const indexableBoundWitnesses = builtPayloads.filter(isBoundWitnessWithMeta).filter((bw) => containsAll(bw.payload_schemas, this.indexableSchemas));
175
- const indexablePayloads = builtPayloads.filter((p) => this.isIndexablePayload(p));
176
- if (indexableBoundWitnesses.length === 0 || indexablePayloads.length === 0) return [];
177
- const [bwDictionary, payloadDictionary] = await Promise.all([
178
- PayloadBuilder2.toDataHashMap(indexableBoundWitnesses),
179
- PayloadBuilder2.toDataHashMap(indexablePayloads)
180
- ]);
181
- const validIndexableTuples = [];
182
- for (const [bwHash, bw] of Object.entries(bwDictionary)) {
183
- const combinations = intraBoundwitnessSchemaCombinations(bw, this.indexableSchemas);
184
- for (const combination of combinations) {
185
- const indexablePayloads2 = combination.map((hash) => payloadDictionary[hash]).filter(exists);
186
- if (indexablePayloads2.length === this.indexableSchemas.length) {
187
- validIndexableTuples.push([
188
- bwHash,
189
- ...combination
190
- ]);
191
- }
192
- }
193
- }
194
- const indexes = await Promise.all(validIndexableTuples.map(async ([bwHash, ...sourcePayloadHashes]) => {
195
- const sourcePayloads = sourcePayloadHashes.map((hash) => payloadDictionary[hash]);
196
- const indexFields = sourcePayloads.flatMap((payload) => {
197
- const transformers = this.payloadTransformers[payload.schema];
198
- return transformers ? transformers.map((transform) => transform(payload)) : [];
199
- });
200
- const sources = [
201
- bwHash,
202
- ...sourcePayloadHashes
203
- ];
204
- return await new PayloadBuilder2({
205
- schema: TemporalIndexingDivinerResultIndexSchema2
206
- }).fields(Object.assign({
207
- sources
208
- }, ...indexFields)).build();
209
- }));
210
- return indexes.flat();
211
- }
212
- /**
213
- * Identifies if a payload is one that is indexed by this diviner
214
- * @param x The candidate payload
215
- * @returns True if the payload is one indexed by this diviner, false otherwise
216
- */
217
- isIndexablePayload = /* @__PURE__ */ __name((x) => {
218
- return isAnyPayload(x) && this.indexableSchemas.includes(x?.schema);
219
- }, "isIndexablePayload");
220
- /**
221
- * Identifies if a schema is one that is indexed by this diviner
222
- * @param schema The candidate schema
223
- * @returns True if this schema is one indexed by this diviner, false otherwise
224
- */
225
- isIndexableSchema = /* @__PURE__ */ __name((schema) => {
226
- return typeof schema === "string" ? this.indexableSchemas.includes(schema) : false;
227
- }, "isIndexableSchema");
228
- };
229
-
230
- // src/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.ts
231
- import { AbstractDiviner as AbstractDiviner3 } from "@xyo-network/diviner-abstract";
232
- import { isPayloadDivinerQueryPayload } from "@xyo-network/diviner-payload-model";
233
- import { TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema } from "@xyo-network/diviner-temporal-indexing-model";
234
- var TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDiviner = class extends AbstractDiviner3 {
235
- static {
236
- __name(this, "TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDiviner");
237
- }
238
- static configSchemas = [
239
- ...super.configSchemas,
240
- TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema
241
- ];
242
- static defaultConfigSchema = TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema;
243
- static labels = {
244
- ...super.labels,
245
- "network.xyo.diviner.stage": "indexQueryResponseToDivinerQueryResponseDiviner"
246
- };
247
- async divineHandler(payloads = []) {
248
- const responses = payloads.filter((p) => !isPayloadDivinerQueryPayload(p));
249
- return await Promise.resolve(responses);
250
- }
251
- };
252
-
253
- // src/StateToIndexCandidateDiviner/Diviner.ts
254
- import { assertEx as assertEx2 } from "@xylabs/assert";
255
- import { exists as exists2 } from "@xylabs/exists";
256
- import { ArchivistWrapper } from "@xyo-network/archivist-wrapper";
257
- import { isBoundWitnessWithMeta as isBoundWitnessWithMeta2 } from "@xyo-network/boundwitness-model";
258
- import { AbstractDiviner as AbstractDiviner4 } from "@xyo-network/diviner-abstract";
259
- import { BoundWitnessDivinerQuerySchema } from "@xyo-network/diviner-boundwitness-model";
260
- import { TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema } from "@xyo-network/diviner-temporal-indexing-model";
261
- import { DivinerWrapper } from "@xyo-network/diviner-wrapper";
262
- import { isModuleState, ModuleStateSchema } from "@xyo-network/module-model";
263
- import { PayloadBuilder as PayloadBuilder3 } from "@xyo-network/payload-builder";
264
- import { intraBoundwitnessSchemaCombinations as intraBoundwitnessSchemaCombinations2 } from "@xyo-network/payload-utils";
265
- import { TimestampSchema } from "@xyo-network/witness-timestamp";
266
- var order = "asc";
267
- var moduleName2 = "TemporalIndexingDivinerStateToIndexCandidateDiviner";
268
- var TemporalIndexingDivinerStateToIndexCandidateDiviner = class extends AbstractDiviner4 {
269
- static {
270
- __name(this, "TemporalIndexingDivinerStateToIndexCandidateDiviner");
271
- }
272
- static configSchemas = [
273
- ...super.configSchemas,
274
- TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema
275
- ];
276
- static defaultConfigSchema = TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema;
277
- static labels = {
278
- ...super.labels,
279
- "network.xyo.diviner.stage": "stateToIndexCandidateDiviner"
280
- };
281
- get payloadDivinerLimit() {
282
- return this.config.payloadDivinerLimit ?? 1e3;
283
- }
284
- /**
285
- * The required payload_schemas within BoundWitnesses to identify index candidates
286
- */
287
- get payload_schemas() {
288
- const schemas = this.config.filter?.payload_schemas;
289
- return [
290
- TimestampSchema,
291
- ...schemas ?? []
292
- ];
293
- }
294
- async divineHandler(payloads = []) {
295
- const lastState = payloads.find(isModuleState);
296
- if (!lastState) return [
297
- {
298
- schema: ModuleStateSchema,
299
- state: {
300
- offset: 0
301
- }
302
- }
303
- ];
304
- const { offset } = lastState.state;
305
- const boundWitnessDiviner = await this.getBoundWitnessDivinerForStore();
306
- if (!boundWitnessDiviner) return [
307
- lastState
308
- ];
309
- const query = await new PayloadBuilder3({
310
- schema: BoundWitnessDivinerQuerySchema
311
- }).fields({
312
- limit: this.payloadDivinerLimit,
313
- offset,
314
- order,
315
- payload_schemas: this.payload_schemas
316
- }).build();
317
- const batch = await boundWitnessDiviner.divine([
318
- query
319
- ]);
320
- if (batch.length === 0) return [
321
- lastState
322
- ];
323
- const sourceArchivist = await this.getArchivistForStore();
324
- if (!sourceArchivist) return [
325
- lastState
326
- ];
327
- const bws = batch.filter(isBoundWitnessWithMeta2);
328
- const indexCandidates = (await Promise.all(bws.map((bw) => this.getPayloadsInBoundWitness(bw, sourceArchivist)))).filter(exists2).flat();
329
- const nextState = {
330
- schema: ModuleStateSchema,
331
- state: {
332
- ...lastState.state,
333
- offset: offset + batch.length
334
- }
335
- };
336
- return [
337
- nextState,
338
- ...indexCandidates
339
- ];
340
- }
341
- /**
342
- * Retrieves the archivist for the payloadStore
343
- * @returns The archivist for the payloadStore or undefined if not resolvable
344
- */
345
- async getArchivistForStore() {
346
- const name = assertEx2(this.config?.payloadStore?.archivist, () => `${moduleName2}: Config for payloadStore.archivist not specified`);
347
- const mod = await this.resolve(name);
348
- if (!mod) return void 0;
349
- return ArchivistWrapper.wrap(mod, this.account);
350
- }
351
- /**
352
- * Retrieves the BoundWitness Diviner for the payloadStore
353
- * @returns The BoundWitness Diviner for the payloadStore or undefined if not resolvable
354
- */
355
- async getBoundWitnessDivinerForStore() {
356
- const name = assertEx2(this.config?.payloadStore?.boundWitnessDiviner, () => `${moduleName2}: Config for payloadStore.boundWitnessDiviner not specified`);
357
- const mod = await this.resolve(name);
358
- if (!mod) return;
359
- return DivinerWrapper.wrap(mod, this.account);
360
- }
361
- async getPayloadsInBoundWitness(bw, archivist) {
362
- const combinations = intraBoundwitnessSchemaCombinations2(bw, this.payload_schemas).flat();
363
- if (combinations.length === 0) return void 0;
364
- const hashes = new Set(combinations);
365
- const indexCandidates = await archivist.get([
366
- ...hashes
367
- ]);
368
- return [
369
- bw,
370
- ...indexCandidates
371
- ];
372
- }
373
- };
374
- export {
375
- TemporalIndexingDiviner,
376
- TemporalIndexingDivinerDivinerQueryToIndexQueryDiviner,
377
- TemporalIndexingDivinerIndexCandidateToIndexDiviner,
378
- TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDiviner,
379
- TemporalIndexingDivinerStateToIndexCandidateDiviner
380
- };
1
+ var F=Object.defineProperty;var s=(o,e)=>F(o,"name",{value:e,configurable:!0});import{IndexingDiviner as H}from"@xyo-network/diviner-indexing-memory";import{TemporalIndexingDivinerConfigSchema as S}from"@xyo-network/diviner-temporal-indexing-model";var g=class extends H{static{s(this,"TemporalIndexingDiviner")}static configSchemas=[...super.configSchemas,S];static defaultConfigSchema=S;async startHandler(){return await super.startHandler(),!0}};import{AbstractDiviner as M}from"@xyo-network/diviner-abstract";import{jsonPathToTransformersDictionary as j,reducePayloads as k}from"@xyo-network/diviner-jsonpath-aggregate-memory";import{PayloadDivinerQuerySchema as b}from"@xyo-network/diviner-payload-model";import{TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema as v,TemporalIndexingDivinerResultIndexSchema as $}from"@xyo-network/diviner-temporal-indexing-model";import{PayloadBuilder as E}from"@xyo-network/payload-builder";import{isPayloadOfSchemaType as O}from"@xyo-network/payload-model";var T=class extends M{static{s(this,"TemporalIndexingDivinerDivinerQueryToIndexQueryDiviner")}static configSchemas=[...super.configSchemas,v];static defaultConfigSchema=v;static labels={...super.labels,"network.xyo.diviner.stage":"divinerQueryToIndexQueryDiviner"};_indexableSchemas;_payloadTransformers;get divinerQuerySchema(){return this.config.divinerQuerySchema??b}get indexQuerySchema(){return this.config.indexQuerySchema??b}get indexSchema(){return this.config.indexSchema??$}get indexableSchemas(){return this._indexableSchemas||(this._indexableSchemas=Object.keys(this.schemaTransforms)),this._indexableSchemas}get payloadTransformers(){return this._payloadTransformers||(this._payloadTransformers=j(this.schemaTransforms)),this._payloadTransformers}get schemaTransforms(){return this.config?.schemaTransforms??{[this.divinerQuerySchema]:[{defaultValue:1,destinationField:"limit",sourcePathExpression:"$.limit"},{defaultValue:0,destinationField:"offset",sourcePathExpression:"$.offset"},{defaultValue:"desc",destinationField:"order",sourcePathExpression:"$.order"}]}}async divineHandler(e=[]){let i=e.filter(O(this.divinerQuerySchema));return i.length>0?await Promise.all(i.map(async r=>{let n=await k([r],this.payloadTransformers,this.indexQuerySchema);return n.schemas=[this.indexSchema],delete n.sources,await new E({schema:this.indexQuerySchema}).fields(n).build()})):[]}};import{containsAll as R}from"@xylabs/array";import{assertEx as L}from"@xylabs/assert";import{exists as V}from"@xylabs/exists";import{isBoundWitnessWithMeta as q}from"@xyo-network/boundwitness-model";import{AbstractDiviner as N}from"@xyo-network/diviner-abstract";import{jsonPathToTransformersDictionary as z}from"@xyo-network/diviner-jsonpath-aggregate-memory";import{TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema as D,TemporalIndexingDivinerResultIndexSchema as G}from"@xyo-network/diviner-temporal-indexing-model";import{PayloadBuilder as u}from"@xyo-network/payload-builder";import{isAnyPayload as J}from"@xyo-network/payload-model";import{intraBoundwitnessSchemaCombinations as K}from"@xyo-network/payload-utils";var U="TemporalIndexingDivinerIndexCandidateToIndexDiviner",w=class extends N{static{s(this,"TemporalIndexingDivinerIndexCandidateToIndexDiviner")}static configSchemas=[...super.configSchemas,D];static defaultConfigSchema=D;static labels={...super.labels,"network.xyo.diviner.stage":"indexCandidateToIndexDiviner"};_indexableSchemas;_payloadTransformers;get indexableSchemas(){return this._indexableSchemas||(this._indexableSchemas=Object.keys(this.schemaTransforms)),this._indexableSchemas}get payloadTransformers(){return this._payloadTransformers||(this._payloadTransformers=z(this.schemaTransforms)),this._payloadTransformers}get schemaTransforms(){return L(this.config?.schemaTransforms,()=>`${U}: Missing config.schemaTransforms section`)}async divineHandler(e=[]){let i=await Promise.all(e.map(t=>u.build(t))),a=i.filter(q).filter(t=>R(t.payload_schemas,this.indexableSchemas)),r=i.filter(t=>this.isIndexablePayload(t));if(a.length===0||r.length===0)return[];let[n,m]=await Promise.all([u.toDataHashMap(a),u.toDataHashMap(r)]),d=[];for(let[t,l]of Object.entries(n)){let f=K(l,this.indexableSchemas);for(let h of f)h.map(c=>m[c]).filter(V).length===this.indexableSchemas.length&&d.push([t,...h])}return(await Promise.all(d.map(async([t,...l])=>{let h=l.map(c=>m[c]).flatMap(c=>{let x=this.payloadTransformers[c.schema];return x?x.map(A=>A(c)):[]}),y=[t,...l];return await new u({schema:G}).fields(Object.assign({sources:y},...h)).build()}))).flat()}isIndexablePayload=s(e=>J(e)&&this.indexableSchemas.includes(e?.schema),"isIndexablePayload");isIndexableSchema=s(e=>typeof e=="string"?this.indexableSchemas.includes(e):!1,"isIndexableSchema")};import{AbstractDiviner as X}from"@xyo-network/diviner-abstract";import{isPayloadDivinerQueryPayload as Y}from"@xyo-network/diviner-payload-model";import{TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema as P}from"@xyo-network/diviner-temporal-indexing-model";var _=class extends X{static{s(this,"TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDiviner")}static configSchemas=[...super.configSchemas,P];static defaultConfigSchema=P;static labels={...super.labels,"network.xyo.diviner.stage":"indexQueryResponseToDivinerQueryResponseDiviner"};async divineHandler(e=[]){let i=e.filter(a=>!Y(a));return await Promise.resolve(i)}};import{assertEx as C}from"@xylabs/assert";import{exists as Z}from"@xylabs/exists";import{ArchivistWrapper as ee}from"@xyo-network/archivist-wrapper";import{isBoundWitnessWithMeta as ie}from"@xyo-network/boundwitness-model";import{AbstractDiviner as se}from"@xyo-network/diviner-abstract";import{BoundWitnessDivinerQuerySchema as ae}from"@xyo-network/diviner-boundwitness-model";import{TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema as I}from"@xyo-network/diviner-temporal-indexing-model";import{DivinerWrapper as te}from"@xyo-network/diviner-wrapper";import{isModuleState as re,ModuleStateSchema as Q}from"@xyo-network/module-model";import{PayloadBuilder as ne}from"@xyo-network/payload-builder";import{intraBoundwitnessSchemaCombinations as oe}from"@xyo-network/payload-utils";import{TimestampSchema as me}from"@xyo-network/witness-timestamp";var ce="asc",W="TemporalIndexingDivinerStateToIndexCandidateDiviner",B=class extends se{static{s(this,"TemporalIndexingDivinerStateToIndexCandidateDiviner")}static configSchemas=[...super.configSchemas,I];static defaultConfigSchema=I;static labels={...super.labels,"network.xyo.diviner.stage":"stateToIndexCandidateDiviner"};get payloadDivinerLimit(){return this.config.payloadDivinerLimit??1e3}get payload_schemas(){let e=this.config.filter?.payload_schemas;return[me,...e??[]]}async divineHandler(e=[]){let i=e.find(re);if(!i)return[{schema:Q,state:{offset:0}}];let{offset:a}=i.state,r=await this.getBoundWitnessDivinerForStore();if(!r)return[i];let n=await new ne({schema:ae}).fields({limit:this.payloadDivinerLimit,offset:a,order:ce,payload_schemas:this.payload_schemas}).build(),m=await r.divine([n]);if(m.length===0)return[i];let d=await this.getArchivistForStore();if(!d)return[i];let p=m.filter(ie),t=(await Promise.all(p.map(f=>this.getPayloadsInBoundWitness(f,d)))).filter(Z).flat();return[{schema:Q,state:{...i.state,offset:a+m.length}},...t]}async getArchivistForStore(){let e=C(this.config?.payloadStore?.archivist,()=>`${W}: Config for payloadStore.archivist not specified`),i=await this.resolve(e);if(i)return ee.wrap(i,this.account)}async getBoundWitnessDivinerForStore(){let e=C(this.config?.payloadStore?.boundWitnessDiviner,()=>`${W}: Config for payloadStore.boundWitnessDiviner not specified`),i=await this.resolve(e);if(i)return te.wrap(i,this.account)}async getPayloadsInBoundWitness(e,i){let a=oe(e,this.payload_schemas).flat();if(a.length===0)return;let r=new Set(a),n=await i.get([...r]);return[e,...n]}};export{g as TemporalIndexingDiviner,T as TemporalIndexingDivinerDivinerQueryToIndexQueryDiviner,w as TemporalIndexingDivinerIndexCandidateToIndexDiviner,_ as TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDiviner,B as TemporalIndexingDivinerStateToIndexCandidateDiviner};
381
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Diviner.ts","../../src/DivinerQueryToIndexQueryDiviner/Diviner.ts","../../src/IndexCandidateToIndexDiviner/Diviner.ts","../../src/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.ts","../../src/StateToIndexCandidateDiviner/Diviner.ts"],"sourcesContent":["import { IndexingDiviner } from '@xyo-network/diviner-indexing-memory'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { TemporalIndexingDivinerConfigSchema, TemporalIndexingDivinerParams } from '@xyo-network/diviner-temporal-indexing-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\n\nexport class TemporalIndexingDiviner<\n TParams extends TemporalIndexingDivinerParams = TemporalIndexingDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends IndexingDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, TemporalIndexingDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = TemporalIndexingDivinerConfigSchema\n\n protected override async startHandler(): Promise<boolean> {\n await super.startHandler()\n return true\n }\n}\n","import { Hash } from '@xylabs/hex'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { jsonPathToTransformersDictionary, reducePayloads } from '@xyo-network/diviner-jsonpath-aggregate-memory'\nimport { SchemaToJsonPathTransformExpressionsDictionary, SchemaToPayloadTransformersDictionary } from '@xyo-network/diviner-jsonpath-model'\nimport { PayloadDivinerQueryPayload, PayloadDivinerQuerySchema } from '@xyo-network/diviner-payload-model'\nimport {\n TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema,\n TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerParams,\n TemporalIndexingDivinerResultIndexSchema,\n} from '@xyo-network/diviner-temporal-indexing-model'\nimport { Labels } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isPayloadOfSchemaType, Payload } from '@xyo-network/payload-model'\n// TODO: Inherit from JsonPathAggregateDiviner\n/**\n * A diviner that converts diviner query to index query\n */\nexport class TemporalIndexingDivinerDivinerQueryToIndexQueryDiviner<\n TParams extends TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerParams = TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerParams,\n> extends AbstractDiviner<TParams> {\n static override readonly configSchemas = [...super.configSchemas, TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema]\n static override readonly defaultConfigSchema = TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema\n static override labels: Labels = {\n ...super.labels,\n 'network.xyo.diviner.stage': 'divinerQueryToIndexQueryDiviner',\n }\n\n private _indexableSchemas: string[] | undefined\n private _payloadTransformers: SchemaToPayloadTransformersDictionary | undefined\n\n /**\n * The schema of the diviner query payloads\n */\n protected get divinerQuerySchema(): string {\n return this.config.divinerQuerySchema ?? PayloadDivinerQuerySchema\n }\n\n /**\n * The schema of the index query payloads\n */\n protected get indexQuerySchema(): string {\n return this.config.indexQuerySchema ?? PayloadDivinerQuerySchema\n }\n\n /**\n * The schema of the index payloads\n */\n protected get indexSchema(): string {\n return this.config.indexSchema ?? TemporalIndexingDivinerResultIndexSchema\n }\n\n /**\n * List of indexable schemas for this diviner\n */\n protected get indexableSchemas(): string[] {\n if (!this._indexableSchemas) this._indexableSchemas = Object.keys(this.schemaTransforms)\n return this._indexableSchemas\n }\n\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get payloadTransformers(): SchemaToPayloadTransformersDictionary {\n if (!this._payloadTransformers) this._payloadTransformers = jsonPathToTransformersDictionary(this.schemaTransforms)\n return this._payloadTransformers\n }\n\n /**\n * The dictionary of schemas to JSON Path transform expressions for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get schemaTransforms(): SchemaToJsonPathTransformExpressionsDictionary {\n return (\n this.config?.schemaTransforms ?? {\n [this.divinerQuerySchema]: [\n {\n defaultValue: 1,\n destinationField: 'limit',\n sourcePathExpression: '$.limit',\n },\n {\n defaultValue: 0,\n destinationField: 'offset',\n sourcePathExpression: '$.offset',\n },\n {\n defaultValue: 'desc',\n destinationField: 'order',\n sourcePathExpression: '$.order',\n },\n ],\n }\n )\n }\n\n protected override async divineHandler(payloads: Payload[] = []): Promise<Payload[]> {\n const queries = payloads.filter(isPayloadOfSchemaType<PayloadDivinerQueryPayload>(this.divinerQuerySchema))\n if (queries.length > 0) {\n const results = await Promise.all(\n queries.map(async (query) => {\n const fields = await reducePayloads<PayloadDivinerQueryPayload & { sources?: Hash[] }>(\n [query],\n this.payloadTransformers,\n this.indexQuerySchema,\n )\n // TODO: Make index schema configurable\n fields.schemas = [this.indexSchema]\n // TODO: Make sources not need to be deleted\n delete fields.sources\n // TODO: Add support for additional filters\n return await new PayloadBuilder<Payload>({ schema: this.indexQuerySchema }).fields(fields).build()\n }),\n )\n return results\n }\n return []\n }\n}\n","import { containsAll } from '@xylabs/array'\nimport { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Hash } from '@xylabs/hex'\nimport { BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { jsonPathToTransformersDictionary } from '@xyo-network/diviner-jsonpath-aggregate-memory'\nimport { SchemaToJsonPathTransformExpressionsDictionary, SchemaToPayloadTransformersDictionary } from '@xyo-network/diviner-jsonpath-model'\nimport {\n TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema,\n TemporalIndexingDivinerIndexCandidateToIndexDivinerParams,\n TemporalIndexingDivinerResultIndex,\n TemporalIndexingDivinerResultIndexSchema,\n} from '@xyo-network/diviner-temporal-indexing-model'\nimport { Labels } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isAnyPayload, Payload, Schema } from '@xyo-network/payload-model'\nimport { intraBoundwitnessSchemaCombinations } from '@xyo-network/payload-utils'\n\ntype IndexableHashes = [Hash, ...Hash[]]\n\nconst moduleName = 'TemporalIndexingDivinerIndexCandidateToIndexDiviner'\n\n/**\n * Diviner which transforms index candidates to indexes using JSON Path to map\n * source properties in the supplied payloads to destination fields in the\n * resultant index\n */\nexport class TemporalIndexingDivinerIndexCandidateToIndexDiviner<\n TParams extends TemporalIndexingDivinerIndexCandidateToIndexDivinerParams = TemporalIndexingDivinerIndexCandidateToIndexDivinerParams,\n> extends AbstractDiviner<TParams> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema\n static override labels: Labels = {\n ...super.labels,\n 'network.xyo.diviner.stage': 'indexCandidateToIndexDiviner',\n }\n\n private _indexableSchemas: string[] | undefined\n private _payloadTransformers: SchemaToPayloadTransformersDictionary | undefined\n\n /**\n * List of indexable schemas for this diviner\n */\n protected get indexableSchemas(): string[] {\n if (!this._indexableSchemas) this._indexableSchemas = Object.keys(this.schemaTransforms)\n return this._indexableSchemas\n }\n\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get payloadTransformers(): SchemaToPayloadTransformersDictionary {\n if (!this._payloadTransformers) this._payloadTransformers = jsonPathToTransformersDictionary(this.schemaTransforms)\n return this._payloadTransformers\n }\n\n /**\n * The dictionary of schemas to JSON Path transform expressions for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get schemaTransforms(): SchemaToJsonPathTransformExpressionsDictionary {\n return assertEx(this.config?.schemaTransforms, () => `${moduleName}: Missing config.schemaTransforms section`)\n }\n\n protected override async divineHandler(payloads: Payload[] = []): Promise<Payload[]> {\n const builtPayloads = await Promise.all(payloads.map((payload) => PayloadBuilder.build(payload)))\n // If the Bound Witness does not contain all the required schemas do not index it\n const indexableBoundWitnesses = builtPayloads\n .filter(isBoundWitnessWithMeta)\n .filter((bw) => containsAll(bw.payload_schemas, this.indexableSchemas))\n // If the Payload is not one of the indexable schemas do not index it\n const indexablePayloads = builtPayloads.filter((p) => this.isIndexablePayload(p))\n // If there is nothing to index, return an empty array\n if (indexableBoundWitnesses.length === 0 || indexablePayloads.length === 0) return []\n // Hash all the indexable data once\n const [bwDictionary, payloadDictionary] = await Promise.all([\n PayloadBuilder.toDataHashMap(indexableBoundWitnesses),\n PayloadBuilder.toDataHashMap(indexablePayloads),\n ])\n\n // Initialize the array for validIndexableTuples outside of the loop\n const validIndexableTuples: IndexableHashes[] = []\n\n // Iterate over each entry in bwDictionary\n for (const [bwHash, bw] of Object.entries(bwDictionary) as [Hash, BoundWitness][]) {\n // Find the combinations of payloads that satisfy the required schemas\n const combinations = intraBoundwitnessSchemaCombinations(bw, this.indexableSchemas)\n\n // Iterate over each combination\n for (const combination of combinations) {\n const indexablePayloads = combination.map((hash) => payloadDictionary[hash]).filter(exists)\n\n // If we found the right amount of indexable payloads (of the correct schema as checked\n // above) in this BW, then index it\n if (indexablePayloads.length === this.indexableSchemas.length) {\n validIndexableTuples.push([bwHash, ...combination])\n }\n }\n }\n\n // Create the indexes from the tuples\n const indexes = await Promise.all(\n validIndexableTuples.map<Promise<TemporalIndexingDivinerResultIndex>>(async ([bwHash, ...sourcePayloadHashes]) => {\n const sourcePayloads = sourcePayloadHashes.map((hash) => payloadDictionary[hash])\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const indexFields = sourcePayloads.flatMap((payload) => {\n // Find the transformers for this payload\n const transformers = this.payloadTransformers[payload.schema]\n // If transformers exist, apply them to the payload otherwise return an empty array\n return transformers ? transformers.map((transform) => transform(payload)) : []\n })\n // Include all the sources for reference\n const sources: string[] = [bwHash, ...sourcePayloadHashes]\n // Build and return the index\n return await new PayloadBuilder<TemporalIndexingDivinerResultIndex>({ schema: TemporalIndexingDivinerResultIndexSchema })\n .fields(Object.assign({ sources }, ...indexFields))\n .build()\n }),\n )\n return indexes.flat()\n }\n\n /**\n * Identifies if a payload is one that is indexed by this diviner\n * @param x The candidate payload\n * @returns True if the payload is one indexed by this diviner, false otherwise\n */\n protected isIndexablePayload = (x: unknown) => {\n return isAnyPayload(x) && this.indexableSchemas.includes(x?.schema)\n }\n\n /**\n * Identifies if a schema is one that is indexed by this diviner\n * @param schema The candidate schema\n * @returns True if this schema is one indexed by this diviner, false otherwise\n */\n protected isIndexableSchema = (schema?: string | null) => {\n return typeof schema === 'string' ? this.indexableSchemas.includes(schema) : false\n }\n}\n","import { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { isPayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema } from '@xyo-network/diviner-temporal-indexing-model'\nimport { Labels } from '@xyo-network/module-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\n\n/**\n * Transforms an ImageThumbnailIndex response into an ImageThumbnailResponse response\n */\nexport class TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDiviner extends AbstractDiviner {\n static override readonly configSchemas: Schema[] = [\n ...super.configSchemas,\n TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema,\n ]\n static override readonly defaultConfigSchema: Schema = TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema\n static override labels: Labels = {\n ...super.labels,\n 'network.xyo.diviner.stage': 'indexQueryResponseToDivinerQueryResponseDiviner',\n }\n\n protected override async divineHandler(payloads: Payload[] = []): Promise<Payload[]> {\n // NOTE: We're not doing anything with the query payloads but some diviners\n // might want to use this to transform from the query to the response (for example\n // if we use a plaintext value in the query to generate a hash key in the index)\n // const queries = payloads.filter(isPayloadDivinerQueryPayload)\n const responses = payloads.filter((p) => !isPayloadDivinerQueryPayload(p))\n return await Promise.resolve(responses)\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { ArchivistWrapper } from '@xyo-network/archivist-wrapper'\nimport { BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { BoundWitnessDiviner } from '@xyo-network/diviner-boundwitness-abstract'\nimport { BoundWitnessDivinerParams, BoundWitnessDivinerQueryPayload, BoundWitnessDivinerQuerySchema } from '@xyo-network/diviner-boundwitness-model'\nimport { IndexingDivinerState } from '@xyo-network/diviner-indexing-model'\nimport {\n TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema,\n TemporalIndexingDivinerStateToIndexCandidateDivinerParams,\n} from '@xyo-network/diviner-temporal-indexing-model'\nimport { DivinerWrapper } from '@xyo-network/diviner-wrapper'\nimport { isModuleState, Labels, ModuleIdentifier, ModuleState, ModuleStateSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema } from '@xyo-network/payload-model'\nimport { intraBoundwitnessSchemaCombinations } from '@xyo-network/payload-utils'\nimport { TimeStamp, TimestampSchema } from '@xyo-network/witness-timestamp'\n\n/**\n * All Payload types involved in index candidates for indexing\n */\nexport type IndexCandidate = BoundWitness | Payload | TimeStamp\n\n/**\n * The response from the TemporalStateToIndexCandidateDiviner\n */\nexport type TemporalStateToIndexCandidateDivinerResponse = [\n /**\n * The next state of the diviner\n */\n nextState: ModuleState<IndexingDivinerState>,\n /**\n * The index candidates\n */\n ...IndexCandidate[],\n]\n\n/**\n * The default order to search Bound Witnesses to identify index candidates\n */\nconst order = 'asc'\n\n/**\n * The name of the module (for logging purposes)\n */\nconst moduleName = 'TemporalIndexingDivinerStateToIndexCandidateDiviner'\n\n/**\n * Transforms candidates for image thumbnail indexing into their indexed representation\n */\nexport class TemporalIndexingDivinerStateToIndexCandidateDiviner<\n TParams extends TemporalIndexingDivinerStateToIndexCandidateDivinerParams = TemporalIndexingDivinerStateToIndexCandidateDivinerParams,\n> extends AbstractDiviner<TParams, Payload, ModuleState | IndexCandidate> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema\n static override labels: Labels = {\n ...super.labels,\n 'network.xyo.diviner.stage': 'stateToIndexCandidateDiviner',\n }\n\n get payloadDivinerLimit() {\n return this.config.payloadDivinerLimit ?? 1000\n }\n\n /**\n * The required payload_schemas within BoundWitnesses to identify index candidates\n */\n protected get payload_schemas(): string[] {\n const schemas = this.config.filter?.payload_schemas\n return [TimestampSchema, ...(schemas ?? [])]\n }\n\n protected override async divineHandler(payloads: Payload[] = []): Promise<[ModuleState, ...IndexCandidate[]]> {\n // Retrieve the last state from what was passed in\n const lastState = payloads.find(isModuleState<IndexingDivinerState>)\n // If there is no last state, start from the beginning\n if (!lastState) return [{ schema: ModuleStateSchema, state: { offset: 0 } }]\n // Otherwise, get the last offset\n const { offset } = lastState.state\n // Get next batch of results starting from the offset\n const boundWitnessDiviner = await this.getBoundWitnessDivinerForStore()\n if (!boundWitnessDiviner) return [lastState]\n const query = await new PayloadBuilder<BoundWitnessDivinerQueryPayload>({ schema: BoundWitnessDivinerQuerySchema })\n .fields({ limit: this.payloadDivinerLimit, offset, order, payload_schemas: this.payload_schemas })\n .build()\n const batch = await boundWitnessDiviner.divine([query])\n if (batch.length === 0) return [lastState]\n // Get source data\n const sourceArchivist = await this.getArchivistForStore()\n if (!sourceArchivist) return [lastState]\n const bws = batch.filter(isBoundWitnessWithMeta)\n const indexCandidates: IndexCandidate[] = (await Promise.all(bws.map((bw) => this.getPayloadsInBoundWitness(bw, sourceArchivist))))\n .filter(exists)\n .flat()\n const nextState = { schema: ModuleStateSchema, state: { ...lastState.state, offset: offset + batch.length } }\n return [nextState, ...indexCandidates]\n }\n /**\n * Retrieves the archivist for the payloadStore\n * @returns The archivist for the payloadStore or undefined if not resolvable\n */\n protected async getArchivistForStore(): Promise<ArchivistWrapper | undefined> {\n // It should be defined, so we'll error if it's not\n const name: ModuleIdentifier = assertEx(\n this.config?.payloadStore?.archivist,\n () => `${moduleName}: Config for payloadStore.archivist not specified`,\n )\n // It might not be resolvable (yet), so we'll return undefined if it's not\n const mod = await this.resolve(name)\n if (!mod) return undefined\n // Return the wrapped archivist\n return ArchivistWrapper.wrap(mod, this.account)\n }\n\n /**\n * Retrieves the BoundWitness Diviner for the payloadStore\n * @returns The BoundWitness Diviner for the payloadStore or undefined if not resolvable\n */\n protected async getBoundWitnessDivinerForStore() {\n // It should be defined, so we'll error if it's not\n const name: ModuleIdentifier = assertEx(\n this.config?.payloadStore?.boundWitnessDiviner,\n () => `${moduleName}: Config for payloadStore.boundWitnessDiviner not specified`,\n )\n // It might not be resolvable (yet), so we'll return undefined if it's not\n const mod = await this.resolve(name)\n if (!mod) return\n // Return the wrapped diviner\n return DivinerWrapper.wrap<\n DivinerWrapper<\n BoundWitnessDiviner<BoundWitnessDivinerParams, BoundWitnessDivinerQueryPayload, BoundWitness>,\n BoundWitnessDivinerQueryPayload,\n BoundWitness\n >\n >(mod, this.account)\n }\n\n protected async getPayloadsInBoundWitness(bw: BoundWitness, archivist: ArchivistInstance): Promise<IndexCandidate[] | undefined> {\n const combinations = intraBoundwitnessSchemaCombinations(bw, this.payload_schemas).flat()\n if (combinations.length === 0) return undefined\n const hashes = new Set(combinations)\n const indexCandidates = await archivist.get([...hashes])\n return [bw, ...indexCandidates]\n }\n}\n"],"mappings":"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","names":["IndexingDiviner","TemporalIndexingDivinerConfigSchema","TemporalIndexingDiviner","IndexingDiviner","configSchemas","TemporalIndexingDivinerConfigSchema","defaultConfigSchema","startHandler","AbstractDiviner","jsonPathToTransformersDictionary","reducePayloads","PayloadDivinerQuerySchema","TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema","TemporalIndexingDivinerResultIndexSchema","PayloadBuilder","isPayloadOfSchemaType","TemporalIndexingDivinerDivinerQueryToIndexQueryDiviner","AbstractDiviner","configSchemas","TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema","defaultConfigSchema","labels","_indexableSchemas","_payloadTransformers","divinerQuerySchema","config","PayloadDivinerQuerySchema","indexQuerySchema","indexSchema","TemporalIndexingDivinerResultIndexSchema","indexableSchemas","Object","keys","schemaTransforms","payloadTransformers","jsonPathToTransformersDictionary","defaultValue","destinationField","sourcePathExpression","divineHandler","payloads","queries","filter","isPayloadOfSchemaType","length","results","Promise","all","map","query","fields","reducePayloads","schemas","sources","PayloadBuilder","schema","build","containsAll","assertEx","exists","isBoundWitnessWithMeta","AbstractDiviner","jsonPathToTransformersDictionary","TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema","TemporalIndexingDivinerResultIndexSchema","PayloadBuilder","isAnyPayload","intraBoundwitnessSchemaCombinations","moduleName","TemporalIndexingDivinerIndexCandidateToIndexDiviner","AbstractDiviner","configSchemas","TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema","defaultConfigSchema","labels","_indexableSchemas","_payloadTransformers","indexableSchemas","Object","keys","schemaTransforms","payloadTransformers","jsonPathToTransformersDictionary","assertEx","config","divineHandler","payloads","builtPayloads","Promise","all","map","payload","PayloadBuilder","build","indexableBoundWitnesses","filter","isBoundWitnessWithMeta","bw","containsAll","payload_schemas","indexablePayloads","p","isIndexablePayload","length","bwDictionary","payloadDictionary","toDataHashMap","validIndexableTuples","bwHash","entries","combinations","intraBoundwitnessSchemaCombinations","combination","hash","exists","push","indexes","sourcePayloadHashes","sourcePayloads","indexFields","flatMap","transformers","schema","transform","sources","TemporalIndexingDivinerResultIndexSchema","fields","assign","flat","x","isAnyPayload","includes","isIndexableSchema","AbstractDiviner","isPayloadDivinerQueryPayload","TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema","TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDiviner","AbstractDiviner","configSchemas","TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema","defaultConfigSchema","labels","divineHandler","payloads","responses","filter","p","isPayloadDivinerQueryPayload","Promise","resolve","assertEx","exists","ArchivistWrapper","isBoundWitnessWithMeta","AbstractDiviner","BoundWitnessDivinerQuerySchema","TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema","DivinerWrapper","isModuleState","ModuleStateSchema","PayloadBuilder","intraBoundwitnessSchemaCombinations","TimestampSchema","order","moduleName","TemporalIndexingDivinerStateToIndexCandidateDiviner","AbstractDiviner","configSchemas","TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema","defaultConfigSchema","labels","payloadDivinerLimit","config","payload_schemas","schemas","filter","TimestampSchema","divineHandler","payloads","lastState","find","isModuleState","schema","ModuleStateSchema","state","offset","boundWitnessDiviner","getBoundWitnessDivinerForStore","query","PayloadBuilder","BoundWitnessDivinerQuerySchema","fields","limit","build","batch","divine","length","sourceArchivist","getArchivistForStore","bws","isBoundWitnessWithMeta","indexCandidates","Promise","all","map","bw","getPayloadsInBoundWitness","exists","flat","nextState","name","assertEx","payloadStore","archivist","mod","resolve","undefined","ArchivistWrapper","wrap","account","DivinerWrapper","combinations","intraBoundwitnessSchemaCombinations","hashes","Set","get"]}
1
+ {"version":3,"sources":["../../src/Diviner.ts","../../src/DivinerQueryToIndexQueryDiviner/Diviner.ts","../../src/IndexCandidateToIndexDiviner/Diviner.ts","../../src/IndexQueryResponseToDivinerQueryResponseDiviner/Diviner.ts","../../src/StateToIndexCandidateDiviner/Diviner.ts"],"sourcesContent":["import { IndexingDiviner } from '@xyo-network/diviner-indexing-memory'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { TemporalIndexingDivinerConfigSchema, TemporalIndexingDivinerParams } from '@xyo-network/diviner-temporal-indexing-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\n\nexport class TemporalIndexingDiviner<\n TParams extends TemporalIndexingDivinerParams = TemporalIndexingDivinerParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends IndexingDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, TemporalIndexingDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = TemporalIndexingDivinerConfigSchema\n\n protected override async startHandler(): Promise<boolean> {\n await super.startHandler()\n return true\n }\n}\n","import { Hash } from '@xylabs/hex'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { jsonPathToTransformersDictionary, reducePayloads } from '@xyo-network/diviner-jsonpath-aggregate-memory'\nimport { SchemaToJsonPathTransformExpressionsDictionary, SchemaToPayloadTransformersDictionary } from '@xyo-network/diviner-jsonpath-model'\nimport { PayloadDivinerQueryPayload, PayloadDivinerQuerySchema } from '@xyo-network/diviner-payload-model'\nimport {\n TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema,\n TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerParams,\n TemporalIndexingDivinerResultIndexSchema,\n} from '@xyo-network/diviner-temporal-indexing-model'\nimport { Labels } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isPayloadOfSchemaType, Payload } from '@xyo-network/payload-model'\n// TODO: Inherit from JsonPathAggregateDiviner\n/**\n * A diviner that converts diviner query to index query\n */\nexport class TemporalIndexingDivinerDivinerQueryToIndexQueryDiviner<\n TParams extends TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerParams = TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerParams,\n> extends AbstractDiviner<TParams> {\n static override readonly configSchemas = [...super.configSchemas, TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema]\n static override readonly defaultConfigSchema = TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema\n static override labels: Labels = {\n ...super.labels,\n 'network.xyo.diviner.stage': 'divinerQueryToIndexQueryDiviner',\n }\n\n private _indexableSchemas: string[] | undefined\n private _payloadTransformers: SchemaToPayloadTransformersDictionary | undefined\n\n /**\n * The schema of the diviner query payloads\n */\n protected get divinerQuerySchema(): string {\n return this.config.divinerQuerySchema ?? PayloadDivinerQuerySchema\n }\n\n /**\n * The schema of the index query payloads\n */\n protected get indexQuerySchema(): string {\n return this.config.indexQuerySchema ?? PayloadDivinerQuerySchema\n }\n\n /**\n * The schema of the index payloads\n */\n protected get indexSchema(): string {\n return this.config.indexSchema ?? TemporalIndexingDivinerResultIndexSchema\n }\n\n /**\n * List of indexable schemas for this diviner\n */\n protected get indexableSchemas(): string[] {\n if (!this._indexableSchemas) this._indexableSchemas = Object.keys(this.schemaTransforms)\n return this._indexableSchemas\n }\n\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get payloadTransformers(): SchemaToPayloadTransformersDictionary {\n if (!this._payloadTransformers) this._payloadTransformers = jsonPathToTransformersDictionary(this.schemaTransforms)\n return this._payloadTransformers\n }\n\n /**\n * The dictionary of schemas to JSON Path transform expressions for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get schemaTransforms(): SchemaToJsonPathTransformExpressionsDictionary {\n return (\n this.config?.schemaTransforms ?? {\n [this.divinerQuerySchema]: [\n {\n defaultValue: 1,\n destinationField: 'limit',\n sourcePathExpression: '$.limit',\n },\n {\n defaultValue: 0,\n destinationField: 'offset',\n sourcePathExpression: '$.offset',\n },\n {\n defaultValue: 'desc',\n destinationField: 'order',\n sourcePathExpression: '$.order',\n },\n ],\n }\n )\n }\n\n protected override async divineHandler(payloads: Payload[] = []): Promise<Payload[]> {\n const queries = payloads.filter(isPayloadOfSchemaType<PayloadDivinerQueryPayload>(this.divinerQuerySchema))\n if (queries.length > 0) {\n const results = await Promise.all(\n queries.map(async (query) => {\n const fields = await reducePayloads<PayloadDivinerQueryPayload & { sources?: Hash[] }>(\n [query],\n this.payloadTransformers,\n this.indexQuerySchema,\n )\n // TODO: Make index schema configurable\n fields.schemas = [this.indexSchema]\n // TODO: Make sources not need to be deleted\n delete fields.sources\n // TODO: Add support for additional filters\n return await new PayloadBuilder<Payload>({ schema: this.indexQuerySchema }).fields(fields).build()\n }),\n )\n return results\n }\n return []\n }\n}\n","import { containsAll } from '@xylabs/array'\nimport { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Hash } from '@xylabs/hex'\nimport { BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { jsonPathToTransformersDictionary } from '@xyo-network/diviner-jsonpath-aggregate-memory'\nimport { SchemaToJsonPathTransformExpressionsDictionary, SchemaToPayloadTransformersDictionary } from '@xyo-network/diviner-jsonpath-model'\nimport {\n TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema,\n TemporalIndexingDivinerIndexCandidateToIndexDivinerParams,\n TemporalIndexingDivinerResultIndex,\n TemporalIndexingDivinerResultIndexSchema,\n} from '@xyo-network/diviner-temporal-indexing-model'\nimport { Labels } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isAnyPayload, Payload, Schema } from '@xyo-network/payload-model'\nimport { intraBoundwitnessSchemaCombinations } from '@xyo-network/payload-utils'\n\ntype IndexableHashes = [Hash, ...Hash[]]\n\nconst moduleName = 'TemporalIndexingDivinerIndexCandidateToIndexDiviner'\n\n/**\n * Diviner which transforms index candidates to indexes using JSON Path to map\n * source properties in the supplied payloads to destination fields in the\n * resultant index\n */\nexport class TemporalIndexingDivinerIndexCandidateToIndexDiviner<\n TParams extends TemporalIndexingDivinerIndexCandidateToIndexDivinerParams = TemporalIndexingDivinerIndexCandidateToIndexDivinerParams,\n> extends AbstractDiviner<TParams> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema\n static override labels: Labels = {\n ...super.labels,\n 'network.xyo.diviner.stage': 'indexCandidateToIndexDiviner',\n }\n\n private _indexableSchemas: string[] | undefined\n private _payloadTransformers: SchemaToPayloadTransformersDictionary | undefined\n\n /**\n * List of indexable schemas for this diviner\n */\n protected get indexableSchemas(): string[] {\n if (!this._indexableSchemas) this._indexableSchemas = Object.keys(this.schemaTransforms)\n return this._indexableSchemas\n }\n\n /**\n * Dictionary of schemas to payload transformers for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get payloadTransformers(): SchemaToPayloadTransformersDictionary {\n if (!this._payloadTransformers) this._payloadTransformers = jsonPathToTransformersDictionary(this.schemaTransforms)\n return this._payloadTransformers\n }\n\n /**\n * The dictionary of schemas to JSON Path transform expressions for creating indexes\n * from the payloads within a Bound Witness\n */\n protected get schemaTransforms(): SchemaToJsonPathTransformExpressionsDictionary {\n return assertEx(this.config?.schemaTransforms, () => `${moduleName}: Missing config.schemaTransforms section`)\n }\n\n protected override async divineHandler(payloads: Payload[] = []): Promise<Payload[]> {\n const builtPayloads = await Promise.all(payloads.map((payload) => PayloadBuilder.build(payload)))\n // If the Bound Witness does not contain all the required schemas do not index it\n const indexableBoundWitnesses = builtPayloads\n .filter(isBoundWitnessWithMeta)\n .filter((bw) => containsAll(bw.payload_schemas, this.indexableSchemas))\n // If the Payload is not one of the indexable schemas do not index it\n const indexablePayloads = builtPayloads.filter((p) => this.isIndexablePayload(p))\n // If there is nothing to index, return an empty array\n if (indexableBoundWitnesses.length === 0 || indexablePayloads.length === 0) return []\n // Hash all the indexable data once\n const [bwDictionary, payloadDictionary] = await Promise.all([\n PayloadBuilder.toDataHashMap(indexableBoundWitnesses),\n PayloadBuilder.toDataHashMap(indexablePayloads),\n ])\n\n // Initialize the array for validIndexableTuples outside of the loop\n const validIndexableTuples: IndexableHashes[] = []\n\n // Iterate over each entry in bwDictionary\n for (const [bwHash, bw] of Object.entries(bwDictionary) as [Hash, BoundWitness][]) {\n // Find the combinations of payloads that satisfy the required schemas\n const combinations = intraBoundwitnessSchemaCombinations(bw, this.indexableSchemas)\n\n // Iterate over each combination\n for (const combination of combinations) {\n const indexablePayloads = combination.map((hash) => payloadDictionary[hash]).filter(exists)\n\n // If we found the right amount of indexable payloads (of the correct schema as checked\n // above) in this BW, then index it\n if (indexablePayloads.length === this.indexableSchemas.length) {\n validIndexableTuples.push([bwHash, ...combination])\n }\n }\n }\n\n // Create the indexes from the tuples\n const indexes = await Promise.all(\n validIndexableTuples.map<Promise<TemporalIndexingDivinerResultIndex>>(async ([bwHash, ...sourcePayloadHashes]) => {\n const sourcePayloads = sourcePayloadHashes.map((hash) => payloadDictionary[hash])\n // Use the payload transformers to convert the fields from the source payloads to the destination fields\n const indexFields = sourcePayloads.flatMap((payload) => {\n // Find the transformers for this payload\n const transformers = this.payloadTransformers[payload.schema]\n // If transformers exist, apply them to the payload otherwise return an empty array\n return transformers ? transformers.map((transform) => transform(payload)) : []\n })\n // Include all the sources for reference\n const sources: string[] = [bwHash, ...sourcePayloadHashes]\n // Build and return the index\n return await new PayloadBuilder<TemporalIndexingDivinerResultIndex>({ schema: TemporalIndexingDivinerResultIndexSchema })\n .fields(Object.assign({ sources }, ...indexFields))\n .build()\n }),\n )\n return indexes.flat()\n }\n\n /**\n * Identifies if a payload is one that is indexed by this diviner\n * @param x The candidate payload\n * @returns True if the payload is one indexed by this diviner, false otherwise\n */\n protected isIndexablePayload = (x: unknown) => {\n return isAnyPayload(x) && this.indexableSchemas.includes(x?.schema)\n }\n\n /**\n * Identifies if a schema is one that is indexed by this diviner\n * @param schema The candidate schema\n * @returns True if this schema is one indexed by this diviner, false otherwise\n */\n protected isIndexableSchema = (schema?: string | null) => {\n return typeof schema === 'string' ? this.indexableSchemas.includes(schema) : false\n }\n}\n","import { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { isPayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema } from '@xyo-network/diviner-temporal-indexing-model'\nimport { Labels } from '@xyo-network/module-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\n\n/**\n * Transforms an ImageThumbnailIndex response into an ImageThumbnailResponse response\n */\nexport class TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDiviner extends AbstractDiviner {\n static override readonly configSchemas: Schema[] = [\n ...super.configSchemas,\n TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema,\n ]\n static override readonly defaultConfigSchema: Schema = TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema\n static override labels: Labels = {\n ...super.labels,\n 'network.xyo.diviner.stage': 'indexQueryResponseToDivinerQueryResponseDiviner',\n }\n\n protected override async divineHandler(payloads: Payload[] = []): Promise<Payload[]> {\n // NOTE: We're not doing anything with the query payloads but some diviners\n // might want to use this to transform from the query to the response (for example\n // if we use a plaintext value in the query to generate a hash key in the index)\n // const queries = payloads.filter(isPayloadDivinerQueryPayload)\n const responses = payloads.filter((p) => !isPayloadDivinerQueryPayload(p))\n return await Promise.resolve(responses)\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { ArchivistWrapper } from '@xyo-network/archivist-wrapper'\nimport { BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { BoundWitnessDiviner } from '@xyo-network/diviner-boundwitness-abstract'\nimport { BoundWitnessDivinerParams, BoundWitnessDivinerQueryPayload, BoundWitnessDivinerQuerySchema } from '@xyo-network/diviner-boundwitness-model'\nimport { IndexingDivinerState } from '@xyo-network/diviner-indexing-model'\nimport {\n TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema,\n TemporalIndexingDivinerStateToIndexCandidateDivinerParams,\n} from '@xyo-network/diviner-temporal-indexing-model'\nimport { DivinerWrapper } from '@xyo-network/diviner-wrapper'\nimport { isModuleState, Labels, ModuleIdentifier, ModuleState, ModuleStateSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema } from '@xyo-network/payload-model'\nimport { intraBoundwitnessSchemaCombinations } from '@xyo-network/payload-utils'\nimport { TimeStamp, TimestampSchema } from '@xyo-network/witness-timestamp'\n\n/**\n * All Payload types involved in index candidates for indexing\n */\nexport type IndexCandidate = BoundWitness | Payload | TimeStamp\n\n/**\n * The response from the TemporalStateToIndexCandidateDiviner\n */\nexport type TemporalStateToIndexCandidateDivinerResponse = [\n /**\n * The next state of the diviner\n */\n nextState: ModuleState<IndexingDivinerState>,\n /**\n * The index candidates\n */\n ...IndexCandidate[],\n]\n\n/**\n * The default order to search Bound Witnesses to identify index candidates\n */\nconst order = 'asc'\n\n/**\n * The name of the module (for logging purposes)\n */\nconst moduleName = 'TemporalIndexingDivinerStateToIndexCandidateDiviner'\n\n/**\n * Transforms candidates for image thumbnail indexing into their indexed representation\n */\nexport class TemporalIndexingDivinerStateToIndexCandidateDiviner<\n TParams extends TemporalIndexingDivinerStateToIndexCandidateDivinerParams = TemporalIndexingDivinerStateToIndexCandidateDivinerParams,\n> extends AbstractDiviner<TParams, Payload, ModuleState | IndexCandidate> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema\n static override labels: Labels = {\n ...super.labels,\n 'network.xyo.diviner.stage': 'stateToIndexCandidateDiviner',\n }\n\n get payloadDivinerLimit() {\n return this.config.payloadDivinerLimit ?? 1000\n }\n\n /**\n * The required payload_schemas within BoundWitnesses to identify index candidates\n */\n protected get payload_schemas(): string[] {\n const schemas = this.config.filter?.payload_schemas\n return [TimestampSchema, ...(schemas ?? [])]\n }\n\n protected override async divineHandler(payloads: Payload[] = []): Promise<[ModuleState, ...IndexCandidate[]]> {\n // Retrieve the last state from what was passed in\n const lastState = payloads.find(isModuleState<IndexingDivinerState>)\n // If there is no last state, start from the beginning\n if (!lastState) return [{ schema: ModuleStateSchema, state: { offset: 0 } }]\n // Otherwise, get the last offset\n const { offset } = lastState.state\n // Get next batch of results starting from the offset\n const boundWitnessDiviner = await this.getBoundWitnessDivinerForStore()\n if (!boundWitnessDiviner) return [lastState]\n const query = await new PayloadBuilder<BoundWitnessDivinerQueryPayload>({ schema: BoundWitnessDivinerQuerySchema })\n .fields({ limit: this.payloadDivinerLimit, offset, order, payload_schemas: this.payload_schemas })\n .build()\n const batch = await boundWitnessDiviner.divine([query])\n if (batch.length === 0) return [lastState]\n // Get source data\n const sourceArchivist = await this.getArchivistForStore()\n if (!sourceArchivist) return [lastState]\n const bws = batch.filter(isBoundWitnessWithMeta)\n const indexCandidates: IndexCandidate[] = (await Promise.all(bws.map((bw) => this.getPayloadsInBoundWitness(bw, sourceArchivist))))\n .filter(exists)\n .flat()\n const nextState = { schema: ModuleStateSchema, state: { ...lastState.state, offset: offset + batch.length } }\n return [nextState, ...indexCandidates]\n }\n /**\n * Retrieves the archivist for the payloadStore\n * @returns The archivist for the payloadStore or undefined if not resolvable\n */\n protected async getArchivistForStore(): Promise<ArchivistWrapper | undefined> {\n // It should be defined, so we'll error if it's not\n const name: ModuleIdentifier = assertEx(\n this.config?.payloadStore?.archivist,\n () => `${moduleName}: Config for payloadStore.archivist not specified`,\n )\n // It might not be resolvable (yet), so we'll return undefined if it's not\n const mod = await this.resolve(name)\n if (!mod) return undefined\n // Return the wrapped archivist\n return ArchivistWrapper.wrap(mod, this.account)\n }\n\n /**\n * Retrieves the BoundWitness Diviner for the payloadStore\n * @returns The BoundWitness Diviner for the payloadStore or undefined if not resolvable\n */\n protected async getBoundWitnessDivinerForStore() {\n // It should be defined, so we'll error if it's not\n const name: ModuleIdentifier = assertEx(\n this.config?.payloadStore?.boundWitnessDiviner,\n () => `${moduleName}: Config for payloadStore.boundWitnessDiviner not specified`,\n )\n // It might not be resolvable (yet), so we'll return undefined if it's not\n const mod = await this.resolve(name)\n if (!mod) return\n // Return the wrapped diviner\n return DivinerWrapper.wrap<\n DivinerWrapper<\n BoundWitnessDiviner<BoundWitnessDivinerParams, BoundWitnessDivinerQueryPayload, BoundWitness>,\n BoundWitnessDivinerQueryPayload,\n BoundWitness\n >\n >(mod, this.account)\n }\n\n protected async getPayloadsInBoundWitness(bw: BoundWitness, archivist: ArchivistInstance): Promise<IndexCandidate[] | undefined> {\n const combinations = intraBoundwitnessSchemaCombinations(bw, this.payload_schemas).flat()\n if (combinations.length === 0) return undefined\n const hashes = new Set(combinations)\n const indexCandidates = await archivist.get([...hashes])\n return [bw, ...indexCandidates]\n }\n}\n"],"mappings":"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","names":["IndexingDiviner","TemporalIndexingDivinerConfigSchema","TemporalIndexingDiviner","IndexingDiviner","configSchemas","TemporalIndexingDivinerConfigSchema","defaultConfigSchema","startHandler","AbstractDiviner","jsonPathToTransformersDictionary","reducePayloads","PayloadDivinerQuerySchema","TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema","TemporalIndexingDivinerResultIndexSchema","PayloadBuilder","isPayloadOfSchemaType","TemporalIndexingDivinerDivinerQueryToIndexQueryDiviner","AbstractDiviner","configSchemas","TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerConfigSchema","defaultConfigSchema","labels","_indexableSchemas","_payloadTransformers","divinerQuerySchema","config","PayloadDivinerQuerySchema","indexQuerySchema","indexSchema","TemporalIndexingDivinerResultIndexSchema","indexableSchemas","Object","keys","schemaTransforms","payloadTransformers","jsonPathToTransformersDictionary","defaultValue","destinationField","sourcePathExpression","divineHandler","payloads","queries","filter","isPayloadOfSchemaType","length","Promise","all","map","query","fields","reducePayloads","schemas","sources","PayloadBuilder","schema","build","containsAll","assertEx","exists","isBoundWitnessWithMeta","AbstractDiviner","jsonPathToTransformersDictionary","TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema","TemporalIndexingDivinerResultIndexSchema","PayloadBuilder","isAnyPayload","intraBoundwitnessSchemaCombinations","moduleName","TemporalIndexingDivinerIndexCandidateToIndexDiviner","AbstractDiviner","configSchemas","TemporalIndexingDivinerIndexCandidateToIndexDivinerConfigSchema","defaultConfigSchema","labels","_indexableSchemas","_payloadTransformers","indexableSchemas","Object","keys","schemaTransforms","payloadTransformers","jsonPathToTransformersDictionary","assertEx","config","divineHandler","payloads","builtPayloads","Promise","all","map","payload","PayloadBuilder","build","indexableBoundWitnesses","filter","isBoundWitnessWithMeta","bw","containsAll","payload_schemas","indexablePayloads","p","isIndexablePayload","length","bwDictionary","payloadDictionary","toDataHashMap","validIndexableTuples","bwHash","entries","combinations","intraBoundwitnessSchemaCombinations","combination","hash","exists","push","sourcePayloadHashes","indexFields","flatMap","transformers","schema","transform","sources","TemporalIndexingDivinerResultIndexSchema","fields","assign","flat","__name","x","isAnyPayload","includes","isIndexableSchema","AbstractDiviner","isPayloadDivinerQueryPayload","TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema","TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDiviner","AbstractDiviner","configSchemas","TemporalIndexingDivinerIndexQueryResponseToDivinerQueryResponseDivinerConfigSchema","defaultConfigSchema","labels","divineHandler","payloads","responses","filter","p","isPayloadDivinerQueryPayload","Promise","resolve","assertEx","exists","ArchivistWrapper","isBoundWitnessWithMeta","AbstractDiviner","BoundWitnessDivinerQuerySchema","TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema","DivinerWrapper","isModuleState","ModuleStateSchema","PayloadBuilder","intraBoundwitnessSchemaCombinations","TimestampSchema","order","moduleName","TemporalIndexingDivinerStateToIndexCandidateDiviner","AbstractDiviner","configSchemas","TemporalIndexingDivinerStateToIndexCandidateDivinerConfigSchema","defaultConfigSchema","labels","payloadDivinerLimit","config","payload_schemas","schemas","filter","TimestampSchema","divineHandler","payloads","lastState","find","isModuleState","schema","ModuleStateSchema","state","offset","boundWitnessDiviner","getBoundWitnessDivinerForStore","query","PayloadBuilder","BoundWitnessDivinerQuerySchema","fields","limit","build","batch","divine","length","sourceArchivist","getArchivistForStore","bws","isBoundWitnessWithMeta","indexCandidates","Promise","all","map","bw","getPayloadsInBoundWitness","exists","flat","name","assertEx","payloadStore","archivist","mod","resolve","ArchivistWrapper","wrap","account","DivinerWrapper","combinations","intraBoundwitnessSchemaCombinations","hashes","Set","get"]}
@@ -3,40 +3,17 @@ import { SchemaToJsonPathTransformExpressionsDictionary, SchemaToPayloadTransfor
3
3
  import { TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerParams } from '@xyo-network/diviner-temporal-indexing-model';
4
4
  import { Labels } from '@xyo-network/module-model';
5
5
  import { Payload } from '@xyo-network/payload-model';
6
- /**
7
- * A diviner that converts diviner query to index query
8
- */
9
6
  export declare class TemporalIndexingDivinerDivinerQueryToIndexQueryDiviner<TParams extends TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerParams = TemporalIndexingDivinerDivinerQueryToIndexQueryDivinerParams> extends AbstractDiviner<TParams> {
10
7
  static readonly configSchemas: string[];
11
8
  static readonly defaultConfigSchema: "network.xyo.diviner.indexing.temporal.stage.divinerQueryToIndexQueryDiviner.config";
12
9
  static labels: Labels;
13
10
  private _indexableSchemas;
14
11
  private _payloadTransformers;
15
- /**
16
- * The schema of the diviner query payloads
17
- */
18
12
  protected get divinerQuerySchema(): string;
19
- /**
20
- * The schema of the index query payloads
21
- */
22
13
  protected get indexQuerySchema(): string;
23
- /**
24
- * The schema of the index payloads
25
- */
26
14
  protected get indexSchema(): string;
27
- /**
28
- * List of indexable schemas for this diviner
29
- */
30
15
  protected get indexableSchemas(): string[];
31
- /**
32
- * Dictionary of schemas to payload transformers for creating indexes
33
- * from the payloads within a Bound Witness
34
- */
35
16
  protected get payloadTransformers(): SchemaToPayloadTransformersDictionary;
36
- /**
37
- * The dictionary of schemas to JSON Path transform expressions for creating indexes
38
- * from the payloads within a Bound Witness
39
- */
40
17
  protected get schemaTransforms(): SchemaToJsonPathTransformExpressionsDictionary;
41
18
  protected divineHandler(payloads?: Payload[]): Promise<Payload[]>;
42
19
  }
@@ -1 +1 @@
1
- {"version":3,"file":"Diviner.d.ts","sourceRoot":"","sources":["../../../src/DivinerQueryToIndexQueryDiviner/Diviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAE/D,OAAO,EAAE,8CAA8C,EAAE,qCAAqC,EAAE,MAAM,qCAAqC,CAAA;AAE3I,OAAO,EAEL,4DAA4D,EAE7D,MAAM,8CAA8C,CAAA;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,2BAA2B,CAAA;AAElD,OAAO,EAAyB,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAE3E;;GAEG;AACH,qBAAa,sDAAsD,CACjE,OAAO,SAAS,4DAA4D,GAAG,4DAA4D,CAC3I,SAAQ,eAAe,CAAC,OAAO,CAAC;IAChC,gBAAyB,aAAa,WAA+F;IACrI,gBAAyB,mBAAmB,uFAAqE;IACjH,OAAgB,MAAM,EAAE,MAAM,CAG7B;IAED,OAAO,CAAC,iBAAiB,CAAsB;IAC/C,OAAO,CAAC,oBAAoB,CAAmD;IAE/E;;OAEG;IACH,SAAS,KAAK,kBAAkB,IAAI,MAAM,CAEzC;IAED;;OAEG;IACH,SAAS,KAAK,gBAAgB,IAAI,MAAM,CAEvC;IAED;;OAEG;IACH,SAAS,KAAK,WAAW,IAAI,MAAM,CAElC;IAED;;OAEG;IACH,SAAS,KAAK,gBAAgB,IAAI,MAAM,EAAE,CAGzC;IAED;;;OAGG;IACH,SAAS,KAAK,mBAAmB,IAAI,qCAAqC,CAGzE;IAED;;;OAGG;IACH,SAAS,KAAK,gBAAgB,IAAI,8CAA8C,CAsB/E;cAEwB,aAAa,CAAC,QAAQ,GAAE,OAAO,EAAO,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CAsBrF"}
1
+ {"version":3,"file":"Diviner.d.ts","sourceRoot":"","sources":["../../../src/DivinerQueryToIndexQueryDiviner/Diviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAE/D,OAAO,EAAE,8CAA8C,EAAE,qCAAqC,EAAE,MAAM,qCAAqC,CAAA;AAE3I,OAAO,EAEL,4DAA4D,EAE7D,MAAM,8CAA8C,CAAA;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,2BAA2B,CAAA;AAElD,OAAO,EAAyB,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAK3E,qBAAa,sDAAsD,CACjE,OAAO,SAAS,4DAA4D,GAAG,4DAA4D,CAC3I,SAAQ,eAAe,CAAC,OAAO,CAAC;IAChC,gBAAyB,aAAa,WAA+F;IACrI,gBAAyB,mBAAmB,uFAAqE;IACjH,OAAgB,MAAM,EAAE,MAAM,CAG7B;IAED,OAAO,CAAC,iBAAiB,CAAsB;IAC/C,OAAO,CAAC,oBAAoB,CAAmD;IAK/E,SAAS,KAAK,kBAAkB,IAAI,MAAM,CAEzC;IAKD,SAAS,KAAK,gBAAgB,IAAI,MAAM,CAEvC;IAKD,SAAS,KAAK,WAAW,IAAI,MAAM,CAElC;IAKD,SAAS,KAAK,gBAAgB,IAAI,MAAM,EAAE,CAGzC;IAMD,SAAS,KAAK,mBAAmB,IAAI,qCAAqC,CAGzE;IAMD,SAAS,KAAK,gBAAgB,IAAI,8CAA8C,CAsB/E;cAEwB,aAAa,CAAC,QAAQ,GAAE,OAAO,EAAO,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CAsBrF"}