@xyo-network/diviner-image-thumbnail 2.83.0 → 2.84.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.
@@ -1,7 +1,7 @@
1
1
  import { AbstractDiviner } from '@xyo-network/abstract-diviner'
2
2
  import { BoundWitness, isBoundWitness } from '@xyo-network/boundwitness-model'
3
- import { PayloadHasher } from '@xyo-network/core'
4
3
  import { DivinerConfigSchema } from '@xyo-network/diviner-model'
4
+ import { PayloadHasher } from '@xyo-network/hash'
5
5
  import {
6
6
  ImageThumbnail,
7
7
  ImageThumbnailResultIndex,
@@ -57,7 +57,7 @@ export class ImageThumbnailIndexCandidateToImageThumbnailIndexDiviner extends Ab
57
57
  const key = await PayloadHasher.hashAsync(urlPayload)
58
58
  const fields: ImageThumbnailResultIndexFields = { key, sources, success, timestamp }
59
59
  if (status) fields.status = status
60
- const result: ImageThumbnailResultIndex = new PayloadBuilder<ImageThumbnailResultIndex>({ schema: ImageThumbnailResultIndexSchema })
60
+ const result: ImageThumbnailResultIndex = await new PayloadBuilder<ImageThumbnailResultIndex>({ schema: ImageThumbnailResultIndexSchema })
61
61
  .fields(fields)
62
62
  .build()
63
63
  return [result]
@@ -1,7 +1,7 @@
1
1
  import { exists } from '@xylabs/exists'
2
2
  import { AbstractDiviner } from '@xyo-network/abstract-diviner'
3
- import { PayloadHasher } from '@xyo-network/core'
4
3
  import { DivinerConfigSchema } from '@xyo-network/diviner-model'
4
+ import { PayloadHasher } from '@xyo-network/hash'
5
5
  import {
6
6
  ImageThumbnailResult,
7
7
  ImageThumbnailResultFields,
@@ -37,24 +37,26 @@ export class ImageThumbnailIndexQueryResponseToImageThumbnailQueryResponseDivine
37
37
  await Promise.all(
38
38
  imageThumbnailDivinerQueries.map(async (imageThumbnailDivinerQuery) => {
39
39
  const { url } = imageThumbnailDivinerQuery
40
- const urlPayload = new PayloadBuilder<ImageThumbnailResult>({ schema: UrlSchema }).fields({ url }).build()
40
+ const urlPayload = await new PayloadBuilder<ImageThumbnailResult>({ schema: UrlSchema }).fields({ url }).build()
41
41
  const key = await PayloadHasher.hashAsync(urlPayload)
42
42
  return [key, url] as const
43
43
  }),
44
44
  ),
45
45
  )
46
46
  // Map the indexes to responses using the dictionary
47
- return imageThumbnailResultIndexes
48
- .map((imageThumbnailResultIndex) => {
49
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
50
- const { key, schema, ...commonFields } = imageThumbnailResultIndex
51
- const url = keyToUrlDictionary?.[key]
52
- if (url) {
53
- const fields: ImageThumbnailResultFields = { ...commonFields, url }
54
- return new PayloadBuilder<ImageThumbnailResult>({ schema: ImageThumbnailResultSchema }).fields(fields).build()
55
- }
56
- })
57
- .filter(exists)
47
+ return (
48
+ await Promise.all(
49
+ imageThumbnailResultIndexes.map(async (imageThumbnailResultIndex) => {
50
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
51
+ const { key, schema, ...commonFields } = imageThumbnailResultIndex
52
+ const url = keyToUrlDictionary?.[key]
53
+ if (url) {
54
+ const fields: ImageThumbnailResultFields = { ...commonFields, url }
55
+ return await new PayloadBuilder<ImageThumbnailResult>({ schema: ImageThumbnailResultSchema }).fields(fields).build()
56
+ }
57
+ }),
58
+ )
59
+ ).filter(exists)
58
60
  }
59
61
  return []
60
62
  }
@@ -1,7 +1,7 @@
1
1
  import { AbstractDiviner } from '@xyo-network/abstract-diviner'
2
- import { PayloadHasher } from '@xyo-network/core'
3
2
  import { DivinerConfigSchema } from '@xyo-network/diviner-model'
4
3
  import { PayloadDivinerQuerySchema } from '@xyo-network/diviner-payload-model'
4
+ import { PayloadHasher } from '@xyo-network/hash'
5
5
  import { isImageThumbnailDivinerQuery } from '@xyo-network/image-thumbnail-payload-plugin'
6
6
  import { PayloadBuilder } from '@xyo-network/payload-builder'
7
7
  import { Payload } from '@xyo-network/payload-model'
@@ -33,7 +33,7 @@ export class ImageThumbnailQueryToImageThumbnailIndexQueryDiviner extends Abstra
33
33
  const fields: Partial<ImageThumbnailResultQuery> = { key, limit, offset, order }
34
34
  if (payloadSuccess !== undefined) fields.success = payloadSuccess
35
35
  if (payloadStatus !== undefined) fields.status = payloadStatus
36
- return new PayloadBuilder<ImageThumbnailResultQuery>({ schema: PayloadDivinerQuerySchema }).fields(fields).build()
36
+ return await new PayloadBuilder<ImageThumbnailResultQuery>({ schema: PayloadDivinerQuerySchema }).fields(fields).build()
37
37
  }),
38
38
  )
39
39
  return results
@@ -92,7 +92,7 @@ export class ImageThumbnailStateToIndexCandidateDiviner<
92
92
  const { offset } = lastState.state
93
93
  // Get next batch of results starting from the offset
94
94
  const boundWitnessDiviner = await this.getBoundWitnessDivinerForStore()
95
- const query = new PayloadBuilder<BoundWitnessDivinerQueryPayload>({ schema: BoundWitnessDivinerQuerySchema })
95
+ const query = await new PayloadBuilder<BoundWitnessDivinerQueryPayload>({ schema: BoundWitnessDivinerQuerySchema })
96
96
  .fields({ limit: this.payloadDivinerLimit, offset, order, payload_schemas })
97
97
  .build()
98
98
  const batch = await boundWitnessDiviner.divine([query])
@@ -1,267 +0,0 @@
1
- // src/Diviner/Diviner.ts
2
- import { IndexingDiviner } from "@xyo-network/diviner-indexing";
3
-
4
- // src/Diviner/ImageThumbnailDivinerLabels.ts
5
- var ImageThumbnailDivinerLabels = {
6
- "network.xyo.image.thumbnail": "diviner"
7
- };
8
-
9
- // src/Diviner/Diviner.ts
10
- var ImageThumbnailDiviner = class extends IndexingDiviner {
11
- static labels = ImageThumbnailDivinerLabels;
12
- };
13
-
14
- // src/Diviner/ImageThumbnailIndexCandidateToImageThumbnailIndexDiviner.ts
15
- import { AbstractDiviner } from "@xyo-network/abstract-diviner";
16
- import { isBoundWitness } from "@xyo-network/boundwitness-model";
17
- import { PayloadHasher } from "@xyo-network/core";
18
- import { DivinerConfigSchema } from "@xyo-network/diviner-model";
19
- import {
20
- ImageThumbnailResultIndexSchema,
21
- ImageThumbnailSchema,
22
- isImageThumbnail
23
- } from "@xyo-network/image-thumbnail-payload-plugin";
24
- import { PayloadBuilder } from "@xyo-network/payload-builder";
25
- import { UrlSchema } from "@xyo-network/url-payload-plugin";
26
- import { isTimestamp, TimestampSchema } from "@xyo-network/witness-timestamp";
27
- var ImageThumbnailIndexCandidateToImageThumbnailIndexDiviner = class extends AbstractDiviner {
28
- static configSchemas = [DivinerConfigSchema];
29
- static labels = {
30
- ...ImageThumbnailDivinerLabels,
31
- "network.xyo.diviner.stage": "indexCandidateToIndexDiviner"
32
- };
33
- async divineHandler(payloads = []) {
34
- const bws = payloads.filter(isBoundWitness);
35
- const imageThumbnailPayloads = payloads.filter(isImageThumbnail);
36
- const timestampPayloads = payloads.filter(isTimestamp);
37
- if (bws.length && imageThumbnailPayloads.length && timestampPayloads.length) {
38
- const payloadDictionary = await PayloadHasher.toMap(payloads);
39
- const tuples = bws.reduce(
40
- (acc, curr) => {
41
- var _a, _b, _c, _d;
42
- const imageThumbnailIndex = (_a = curr.payload_schemas) == null ? void 0 : _a.findIndex((schema) => schema === ImageThumbnailSchema);
43
- const timestampIndex = (_b = curr.payload_schemas) == null ? void 0 : _b.findIndex((schema) => schema === TimestampSchema);
44
- const imageThumbnailHash = (_c = curr.payload_hashes) == null ? void 0 : _c[imageThumbnailIndex];
45
- const timestampHash = (_d = curr.payload_hashes) == null ? void 0 : _d[timestampIndex];
46
- const imageThumbnailPayload = [payloadDictionary[imageThumbnailHash]].find(isImageThumbnail);
47
- const timestampPayload = [payloadDictionary[timestampHash]].find(isTimestamp);
48
- if (imageThumbnailPayload && timestampPayload)
49
- acc.push([curr, imageThumbnailPayload, timestampPayload]);
50
- return acc;
51
- },
52
- []
53
- );
54
- const indexes = await Promise.all(
55
- tuples.map(async ([bw, imageThumbnailPayload, timestampPayload]) => {
56
- var _a;
57
- const { sourceUrl: url } = imageThumbnailPayload;
58
- const { timestamp } = timestampPayload;
59
- const status = (_a = imageThumbnailPayload.http) == null ? void 0 : _a.status;
60
- const success = !!imageThumbnailPayload.url;
61
- const sources = (await PayloadHasher.hashPairs([bw, imageThumbnailPayload, timestampPayload])).map(([, hash]) => hash);
62
- const urlPayload = { schema: UrlSchema, url };
63
- const key = await PayloadHasher.hashAsync(urlPayload);
64
- const fields = { key, sources, success, timestamp };
65
- if (status)
66
- fields.status = status;
67
- const result = new PayloadBuilder({ schema: ImageThumbnailResultIndexSchema }).fields(fields).build();
68
- return [result];
69
- })
70
- );
71
- return indexes.flat();
72
- }
73
- return Promise.resolve([]);
74
- }
75
- };
76
-
77
- // src/Diviner/ImageThumbnailIndexQueryResponseToImageThumbnailQueryResponseDiviner.ts
78
- import { exists } from "@xylabs/exists";
79
- import { AbstractDiviner as AbstractDiviner2 } from "@xyo-network/abstract-diviner";
80
- import { PayloadHasher as PayloadHasher2 } from "@xyo-network/core";
81
- import { DivinerConfigSchema as DivinerConfigSchema2 } from "@xyo-network/diviner-model";
82
- import {
83
- ImageThumbnailResultSchema,
84
- isImageThumbnailDivinerQuery,
85
- isImageThumbnailResultIndex
86
- } from "@xyo-network/image-thumbnail-payload-plugin";
87
- import { PayloadBuilder as PayloadBuilder2 } from "@xyo-network/payload-builder";
88
- import { UrlSchema as UrlSchema2 } from "@xyo-network/url-payload-plugin";
89
- var ImageThumbnailIndexQueryResponseToImageThumbnailQueryResponseDiviner = class extends AbstractDiviner2 {
90
- static configSchemas = [DivinerConfigSchema2];
91
- static labels = {
92
- ...ImageThumbnailDivinerLabels,
93
- "network.xyo.diviner.stage": "indexQueryResponseToDivinerQueryResponseDiviner"
94
- };
95
- async divineHandler(payloads = []) {
96
- const imageThumbnailDivinerQueries = payloads.filter(isImageThumbnailDivinerQuery);
97
- const imageThumbnailResultIndexes = payloads.filter(isImageThumbnailResultIndex);
98
- if (imageThumbnailDivinerQueries.length && imageThumbnailResultIndexes.length) {
99
- const keyToUrlDictionary = Object.fromEntries(
100
- await Promise.all(
101
- imageThumbnailDivinerQueries.map(async (imageThumbnailDivinerQuery) => {
102
- const { url } = imageThumbnailDivinerQuery;
103
- const urlPayload = new PayloadBuilder2({ schema: UrlSchema2 }).fields({ url }).build();
104
- const key = await PayloadHasher2.hashAsync(urlPayload);
105
- return [key, url];
106
- })
107
- )
108
- );
109
- return imageThumbnailResultIndexes.map((imageThumbnailResultIndex) => {
110
- const { key, schema, ...commonFields } = imageThumbnailResultIndex;
111
- const url = keyToUrlDictionary == null ? void 0 : keyToUrlDictionary[key];
112
- if (url) {
113
- const fields = { ...commonFields, url };
114
- return new PayloadBuilder2({ schema: ImageThumbnailResultSchema }).fields(fields).build();
115
- }
116
- }).filter(exists);
117
- }
118
- return [];
119
- }
120
- };
121
-
122
- // src/Diviner/ImageThumbnailQueryToImageThumbnailIndexQueryDiviner.ts
123
- import { AbstractDiviner as AbstractDiviner3 } from "@xyo-network/abstract-diviner";
124
- import { PayloadHasher as PayloadHasher3 } from "@xyo-network/core";
125
- import { DivinerConfigSchema as DivinerConfigSchema3 } from "@xyo-network/diviner-model";
126
- import { PayloadDivinerQuerySchema } from "@xyo-network/diviner-payload-model";
127
- import { isImageThumbnailDivinerQuery as isImageThumbnailDivinerQuery2 } from "@xyo-network/image-thumbnail-payload-plugin";
128
- import { PayloadBuilder as PayloadBuilder3 } from "@xyo-network/payload-builder";
129
- import { UrlSchema as UrlSchema3 } from "@xyo-network/url-payload-plugin";
130
- var ImageThumbnailQueryToImageThumbnailIndexQueryDiviner = class extends AbstractDiviner3 {
131
- static configSchemas = [DivinerConfigSchema3];
132
- static labels = {
133
- ...ImageThumbnailDivinerLabels,
134
- "network.xyo.diviner.stage": "divinerQueryToIndexQueryDiviner"
135
- };
136
- async divineHandler(payloads = []) {
137
- const queries = payloads.filter(isImageThumbnailDivinerQuery2);
138
- if (queries.length) {
139
- const results = await Promise.all(
140
- queries.map(async (query) => {
141
- const { limit: payloadLimit, offset: payloadOffset, order: payloadOrder, status: payloadStatus, success: payloadSuccess, url } = query;
142
- const limit = payloadLimit ?? 1;
143
- const order2 = payloadOrder ?? "desc";
144
- const offset = payloadOffset ?? 0;
145
- const urlPayload = { schema: UrlSchema3, url };
146
- const key = await PayloadHasher3.hashAsync(urlPayload);
147
- const fields = { key, limit, offset, order: order2 };
148
- if (payloadSuccess !== void 0)
149
- fields.success = payloadSuccess;
150
- if (payloadStatus !== void 0)
151
- fields.status = payloadStatus;
152
- return new PayloadBuilder3({ schema: PayloadDivinerQuerySchema }).fields(fields).build();
153
- })
154
- );
155
- return results;
156
- }
157
- return Promise.resolve([]);
158
- }
159
- };
160
-
161
- // src/Diviner/ImageThumbnailResultQuery.ts
162
- import { PayloadDivinerQuerySchema as PayloadDivinerQuerySchema2 } from "@xyo-network/diviner-payload-model";
163
- import { isPayloadOfSchemaType } from "@xyo-network/payload-model";
164
- var isImageThumbnailResultQuery = isPayloadOfSchemaType(PayloadDivinerQuerySchema2);
165
-
166
- // src/Diviner/ImageThumbnailStateToIndexCandidateDiviner/Schema.ts
167
- import { ImageThumbnailDivinerSchema } from "@xyo-network/image-thumbnail-payload-plugin";
168
- var ImageThumbnailStateToIndexCandidateDivinerSchema = `${ImageThumbnailDivinerSchema}.stage.stateToIndexCandidateDiviner`;
169
-
170
- // src/Diviner/ImageThumbnailStateToIndexCandidateDiviner/Config.ts
171
- var ImageThumbnailStateToIndexCandidateDivinerConfigSchema = `${ImageThumbnailStateToIndexCandidateDivinerSchema}.config`;
172
-
173
- // src/Diviner/ImageThumbnailStateToIndexCandidateDiviner/Diviner.ts
174
- import { assertEx } from "@xylabs/assert";
175
- import { exists as exists2 } from "@xylabs/exists";
176
- import { AbstractDiviner as AbstractDiviner4 } from "@xyo-network/abstract-diviner";
177
- import { ArchivistWrapper } from "@xyo-network/archivist-wrapper";
178
- import { isBoundWitness as isBoundWitness2 } from "@xyo-network/boundwitness-model";
179
- import { BoundWitnessDivinerQuerySchema } from "@xyo-network/diviner-boundwitness-model";
180
- import { DivinerConfigSchema as DivinerConfigSchema4 } from "@xyo-network/diviner-model";
181
- import { DivinerWrapper } from "@xyo-network/diviner-wrapper";
182
- import { ImageThumbnailSchema as ImageThumbnailSchema2, isImageThumbnail as isImageThumbnail2 } from "@xyo-network/image-thumbnail-payload-plugin";
183
- import { isModuleState, ModuleStateSchema } from "@xyo-network/module-model";
184
- import { PayloadBuilder as PayloadBuilder4 } from "@xyo-network/payload-builder";
185
- import { isTimestamp as isTimestamp2, TimestampSchema as TimestampSchema2 } from "@xyo-network/witness-timestamp";
186
- var payload_schemas = [ImageThumbnailSchema2, TimestampSchema2];
187
- var indexCandidateIdentityFunctions = [isImageThumbnail2, isTimestamp2];
188
- var order = "asc";
189
- var moduleName = "ImageThumbnailStateToIndexCandidateDiviner";
190
- var ImageThumbnailStateToIndexCandidateDiviner = class _ImageThumbnailStateToIndexCandidateDiviner extends AbstractDiviner4 {
191
- static configSchemas = [DivinerConfigSchema4, ImageThumbnailStateToIndexCandidateDivinerConfigSchema];
192
- static labels = {
193
- ...ImageThumbnailDivinerLabels,
194
- "network.xyo.diviner.stage": "stateToIndexCandidateDiviner"
195
- };
196
- get payloadDivinerLimit() {
197
- return this.config.payloadDivinerLimit ?? 1e3;
198
- }
199
- static async getPayloadsInBoundWitness(bw, archivist) {
200
- const indexes = payload_schemas.map((schema) => {
201
- var _a;
202
- return (_a = bw.payload_schemas) == null ? void 0 : _a.findIndex((s) => s === schema);
203
- });
204
- const hashes = indexes.map((index) => {
205
- var _a;
206
- return (_a = bw.payload_hashes) == null ? void 0 : _a[index];
207
- });
208
- const results = await archivist.get(hashes);
209
- const filteredResults = indexCandidateIdentityFunctions.map((is) => results.find(is));
210
- if (filteredResults.some((f) => f === void 0))
211
- return void 0;
212
- const indexCandidates = filteredResults.filter(exists2);
213
- return [bw, ...indexCandidates];
214
- }
215
- async divineHandler(payloads = []) {
216
- const lastState = payloads.find(isModuleState);
217
- if (!lastState)
218
- return [{ schema: ModuleStateSchema, state: { offset: 0 } }];
219
- const { offset } = lastState.state;
220
- const boundWitnessDiviner = await this.getBoundWitnessDivinerForStore();
221
- const query = new PayloadBuilder4({ schema: BoundWitnessDivinerQuerySchema }).fields({ limit: this.payloadDivinerLimit, offset, order, payload_schemas }).build();
222
- const batch = await boundWitnessDiviner.divine([query]);
223
- if (batch.length === 0)
224
- return [lastState];
225
- const sourceArchivist = await this.getArchivistForStore();
226
- const indexCandidates = (await Promise.all(
227
- batch.filter(isBoundWitness2).map((bw) => _ImageThumbnailStateToIndexCandidateDiviner.getPayloadsInBoundWitness(bw, sourceArchivist))
228
- )).filter(exists2).flat();
229
- const nextState = { schema: ModuleStateSchema, state: { ...lastState.state, offset: offset + batch.length } };
230
- return [nextState, ...indexCandidates];
231
- }
232
- /**
233
- * Retrieves the archivist for the payloadStore
234
- * @returns The archivist for the payloadStore
235
- */
236
- async getArchivistForStore() {
237
- var _a, _b;
238
- const name = assertEx((_b = (_a = this.config) == null ? void 0 : _a.payloadStore) == null ? void 0 : _b.archivist, () => `${moduleName}: Config for payloadStore.archivist not specified`);
239
- const mod = assertEx(await this.resolve(name), () => `${moduleName}: Failed to resolve payloadStore.archivist`);
240
- return ArchivistWrapper.wrap(mod, this.account);
241
- }
242
- /**
243
- * Retrieves the BoundWitness Diviner for the payloadStore
244
- * @returns The BoundWitness Diviner for the payloadStore
245
- */
246
- async getBoundWitnessDivinerForStore() {
247
- var _a, _b;
248
- const name = assertEx(
249
- (_b = (_a = this.config) == null ? void 0 : _a.payloadStore) == null ? void 0 : _b.boundWitnessDiviner,
250
- () => `${moduleName}: Config for payloadStore.boundWitnessDiviner not specified`
251
- );
252
- const mod = assertEx(await this.resolve(name), () => `${moduleName}: Failed to resolve payloadStore.boundWitnessDiviner`);
253
- return DivinerWrapper.wrap(mod, this.account);
254
- }
255
- };
256
- export {
257
- ImageThumbnailDiviner,
258
- ImageThumbnailDivinerLabels,
259
- ImageThumbnailIndexCandidateToImageThumbnailIndexDiviner,
260
- ImageThumbnailIndexQueryResponseToImageThumbnailQueryResponseDiviner,
261
- ImageThumbnailQueryToImageThumbnailIndexQueryDiviner,
262
- ImageThumbnailStateToIndexCandidateDiviner,
263
- ImageThumbnailStateToIndexCandidateDivinerConfigSchema,
264
- ImageThumbnailStateToIndexCandidateDivinerSchema,
265
- isImageThumbnailResultQuery
266
- };
267
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/Diviner/Diviner.ts","../../src/Diviner/ImageThumbnailDivinerLabels.ts","../../src/Diviner/ImageThumbnailIndexCandidateToImageThumbnailIndexDiviner.ts","../../src/Diviner/ImageThumbnailIndexQueryResponseToImageThumbnailQueryResponseDiviner.ts","../../src/Diviner/ImageThumbnailQueryToImageThumbnailIndexQueryDiviner.ts","../../src/Diviner/ImageThumbnailResultQuery.ts","../../src/Diviner/ImageThumbnailStateToIndexCandidateDiviner/Schema.ts","../../src/Diviner/ImageThumbnailStateToIndexCandidateDiviner/Config.ts","../../src/Diviner/ImageThumbnailStateToIndexCandidateDiviner/Diviner.ts"],"sourcesContent":["import { IndexingDiviner } from '@xyo-network/diviner-indexing'\n\nimport { ImageThumbnailDivinerLabels } from './ImageThumbnailDivinerLabels'\n\nexport class ImageThumbnailDiviner extends IndexingDiviner {\n static labels: ImageThumbnailDivinerLabels = ImageThumbnailDivinerLabels\n}\n","import { DivinerStageSchema, IndexingDivinerStage } from '@xyo-network/diviner-indexing'\nimport { Labels } from '@xyo-network/module-model'\n\n/**\n * Labels for Image Thumbnail Diviner components\n */\nexport interface ImageThumbnailDivinerLabels extends Labels {\n 'network.xyo.image.thumbnail': 'diviner'\n}\n\n/**\n * Labels for Image Thumbnail Diviner components\n */\nexport const ImageThumbnailDivinerLabels: ImageThumbnailDivinerLabels = {\n 'network.xyo.image.thumbnail': 'diviner',\n}\n\n/**\n * Labels for Image Thumbnail Diviner Stage Diviners\n */\nexport type ImageThumbnailDivinerStageLabels = ImageThumbnailDivinerLabels & {\n /**\n * Labels for the stage of the Image Thumbnail Diviner Stage Diviner\n */\n [key in DivinerStageSchema]: IndexingDivinerStage\n}\n","import { AbstractDiviner } from '@xyo-network/abstract-diviner'\nimport { BoundWitness, isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { DivinerConfigSchema } from '@xyo-network/diviner-model'\nimport {\n ImageThumbnail,\n ImageThumbnailResultIndex,\n ImageThumbnailResultIndexFields,\n ImageThumbnailResultIndexSchema,\n ImageThumbnailSchema,\n isImageThumbnail,\n} from '@xyo-network/image-thumbnail-payload-plugin'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { UrlSchema } from '@xyo-network/url-payload-plugin'\nimport { isTimestamp, TimeStamp, TimestampSchema } from '@xyo-network/witness-timestamp'\n\nimport { ImageThumbnailDivinerLabels, ImageThumbnailDivinerStageLabels } from './ImageThumbnailDivinerLabels'\n\n/**\n * Transforms candidates for image thumbnail indexing into their indexed representation\n */\nexport class ImageThumbnailIndexCandidateToImageThumbnailIndexDiviner extends AbstractDiviner {\n static override configSchemas = [DivinerConfigSchema]\n static labels: ImageThumbnailDivinerStageLabels = {\n ...ImageThumbnailDivinerLabels,\n 'network.xyo.diviner.stage': 'indexCandidateToIndexDiviner',\n }\n\n protected override async divineHandler(payloads: Payload[] = []): Promise<ImageThumbnailResultIndex[]> {\n const bws: BoundWitness[] = payloads.filter(isBoundWitness)\n const imageThumbnailPayloads: ImageThumbnail[] = payloads.filter(isImageThumbnail)\n const timestampPayloads: TimeStamp[] = payloads.filter(isTimestamp)\n if (bws.length && imageThumbnailPayloads.length && timestampPayloads.length) {\n const payloadDictionary = await PayloadHasher.toMap(payloads)\n const tuples: [BoundWitness, ImageThumbnail, TimeStamp][] = bws.reduce<[BoundWitness, ImageThumbnail, TimeStamp][]>(\n (acc, curr) => {\n const imageThumbnailIndex = curr.payload_schemas?.findIndex((schema) => schema === ImageThumbnailSchema)\n const timestampIndex = curr.payload_schemas?.findIndex((schema) => schema === TimestampSchema)\n const imageThumbnailHash = curr.payload_hashes?.[imageThumbnailIndex]\n const timestampHash = curr.payload_hashes?.[timestampIndex]\n const imageThumbnailPayload = [payloadDictionary[imageThumbnailHash]].find(isImageThumbnail)\n const timestampPayload = [payloadDictionary[timestampHash]].find(isTimestamp)\n if (imageThumbnailPayload && timestampPayload) acc.push([curr, imageThumbnailPayload, timestampPayload])\n return acc\n },\n [] as [BoundWitness, ImageThumbnail, TimeStamp][],\n )\n const indexes = await Promise.all(\n tuples.map(async ([bw, imageThumbnailPayload, timestampPayload]) => {\n const { sourceUrl: url } = imageThumbnailPayload\n const { timestamp } = timestampPayload\n const status = imageThumbnailPayload.http?.status\n const success = !!imageThumbnailPayload.url // Call anything with a thumbnail url a success\n const sources = (await PayloadHasher.hashPairs([bw, imageThumbnailPayload, timestampPayload])).map(([, hash]) => hash)\n const urlPayload = { schema: UrlSchema, url }\n const key = await PayloadHasher.hashAsync(urlPayload)\n const fields: ImageThumbnailResultIndexFields = { key, sources, success, timestamp }\n if (status) fields.status = status\n const result: ImageThumbnailResultIndex = new PayloadBuilder<ImageThumbnailResultIndex>({ schema: ImageThumbnailResultIndexSchema })\n .fields(fields)\n .build()\n return [result]\n }),\n )\n return indexes.flat()\n }\n return Promise.resolve([])\n }\n}\n","import { exists } from '@xylabs/exists'\nimport { AbstractDiviner } from '@xyo-network/abstract-diviner'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { DivinerConfigSchema } from '@xyo-network/diviner-model'\nimport {\n ImageThumbnailResult,\n ImageThumbnailResultFields,\n ImageThumbnailResultSchema,\n isImageThumbnailDivinerQuery,\n isImageThumbnailResultIndex,\n} from '@xyo-network/image-thumbnail-payload-plugin'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { UrlSchema } from '@xyo-network/url-payload-plugin'\n\nimport { ImageThumbnailDivinerLabels, ImageThumbnailDivinerStageLabels } from './ImageThumbnailDivinerLabels'\n\n/**\n * Transforms an ImageThumbnailIndex response into an ImageThumbnailResponse response\n */\nexport class ImageThumbnailIndexQueryResponseToImageThumbnailQueryResponseDiviner extends AbstractDiviner {\n static override configSchemas = [DivinerConfigSchema]\n static labels: ImageThumbnailDivinerStageLabels = {\n ...ImageThumbnailDivinerLabels,\n 'network.xyo.diviner.stage': 'indexQueryResponseToDivinerQueryResponseDiviner',\n }\n\n protected override async divineHandler(payloads: Payload[] = []): Promise<ImageThumbnailResult[]> {\n // Filter out the two operands\n const imageThumbnailDivinerQueries = payloads.filter(isImageThumbnailDivinerQuery)\n const imageThumbnailResultIndexes = payloads.filter(isImageThumbnailResultIndex)\n\n // If we have operands\n if (imageThumbnailDivinerQueries.length && imageThumbnailResultIndexes.length) {\n // Create a dictionary to translate index keys to the urls that represent them\n const keyToUrlDictionary = Object.fromEntries(\n await Promise.all(\n imageThumbnailDivinerQueries.map(async (imageThumbnailDivinerQuery) => {\n const { url } = imageThumbnailDivinerQuery\n const urlPayload = new PayloadBuilder<ImageThumbnailResult>({ schema: UrlSchema }).fields({ url }).build()\n const key = await PayloadHasher.hashAsync(urlPayload)\n return [key, url] as const\n }),\n ),\n )\n // Map the indexes to responses using the dictionary\n return imageThumbnailResultIndexes\n .map((imageThumbnailResultIndex) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { key, schema, ...commonFields } = imageThumbnailResultIndex\n const url = keyToUrlDictionary?.[key]\n if (url) {\n const fields: ImageThumbnailResultFields = { ...commonFields, url }\n return new PayloadBuilder<ImageThumbnailResult>({ schema: ImageThumbnailResultSchema }).fields(fields).build()\n }\n })\n .filter(exists)\n }\n return []\n }\n}\n","import { AbstractDiviner } from '@xyo-network/abstract-diviner'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { DivinerConfigSchema } from '@xyo-network/diviner-model'\nimport { PayloadDivinerQuerySchema } from '@xyo-network/diviner-payload-model'\nimport { isImageThumbnailDivinerQuery } from '@xyo-network/image-thumbnail-payload-plugin'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { UrlSchema } from '@xyo-network/url-payload-plugin'\n\nimport { ImageThumbnailDivinerLabels, ImageThumbnailDivinerStageLabels } from './ImageThumbnailDivinerLabels'\nimport { ImageThumbnailResultQuery } from './ImageThumbnailResultQuery'\n\n/**\n * A diviner that converts ImageThumbnailDivinerQuery to ImageThumbnailResultQuery\n */\nexport class ImageThumbnailQueryToImageThumbnailIndexQueryDiviner extends AbstractDiviner {\n static override configSchemas = [DivinerConfigSchema]\n static labels: ImageThumbnailDivinerStageLabels = {\n ...ImageThumbnailDivinerLabels,\n 'network.xyo.diviner.stage': 'divinerQueryToIndexQueryDiviner',\n }\n protected override async divineHandler(payloads: Payload[] = []): Promise<ImageThumbnailResultQuery[]> {\n const queries = payloads.filter(isImageThumbnailDivinerQuery)\n if (queries.length) {\n const results = await Promise.all(\n queries.map(async (query) => {\n const { limit: payloadLimit, offset: payloadOffset, order: payloadOrder, status: payloadStatus, success: payloadSuccess, url } = query\n const limit = payloadLimit ?? 1\n const order = payloadOrder ?? 'desc'\n const offset = payloadOffset ?? 0\n const urlPayload = { schema: UrlSchema, url }\n const key = await PayloadHasher.hashAsync(urlPayload)\n const fields: Partial<ImageThumbnailResultQuery> = { key, limit, offset, order }\n if (payloadSuccess !== undefined) fields.success = payloadSuccess\n if (payloadStatus !== undefined) fields.status = payloadStatus\n return new PayloadBuilder<ImageThumbnailResultQuery>({ schema: PayloadDivinerQuerySchema }).fields(fields).build()\n }),\n )\n return results\n }\n return Promise.resolve([])\n }\n}\n","import { PayloadDivinerQueryPayload, PayloadDivinerQuerySchema } from '@xyo-network/diviner-payload-model'\nimport { ImageThumbnailResultIndex } from '@xyo-network/image-thumbnail-payload-plugin'\nimport { isPayloadOfSchemaType } from '@xyo-network/payload-model'\n\n/**\n * The fields that will need to be indexed on in the underlying store\n */\nexport type QueryableImageThumbnailResultProperties = Extract<keyof ImageThumbnailResultIndex, 'status' | 'success' | 'timestamp' | 'key'>\n\n/**\n * The query that will be used to retrieve the results from the underlying store\n */\nexport type ImageThumbnailResultQuery = PayloadDivinerQueryPayload & Pick<ImageThumbnailResultIndex, QueryableImageThumbnailResultProperties>\n\n/**\n * A type guard for ImageThumbnailResultQuery\n */\n// TODO: Use a more derived schema than PayloadDivinerQuerySchema\nexport const isImageThumbnailResultQuery = isPayloadOfSchemaType<ImageThumbnailResultQuery>(PayloadDivinerQuerySchema)\n","import { ImageThumbnailDivinerSchema } from '@xyo-network/image-thumbnail-payload-plugin'\n\nexport type ImageThumbnailStateToIndexCandidateDivinerSchema = `${ImageThumbnailDivinerSchema}.stage.stateToIndexCandidateDiviner`\nexport const ImageThumbnailStateToIndexCandidateDivinerSchema: ImageThumbnailStateToIndexCandidateDivinerSchema = `${ImageThumbnailDivinerSchema}.stage.stateToIndexCandidateDiviner`\n","import { DivinerConfig } from '@xyo-network/diviner-model'\nimport { SearchableStorage } from '@xyo-network/image-thumbnail-payload-plugin'\n\nimport { ImageThumbnailStateToIndexCandidateDivinerSchema } from './Schema'\n\nexport type ImageThumbnailStateToIndexCandidateDivinerConfigSchema = `${ImageThumbnailStateToIndexCandidateDivinerSchema}.config`\nexport const ImageThumbnailStateToIndexCandidateDivinerConfigSchema: ImageThumbnailStateToIndexCandidateDivinerConfigSchema = `${ImageThumbnailStateToIndexCandidateDivinerSchema}.config`\n\nexport type ImageThumbnailStateToIndexCandidateDivinerConfig = DivinerConfig<{\n payloadDivinerLimit?: number\n /**\n * Where the diviner should look for stored thumbnails\n */\n payloadStore?: SearchableStorage\n schema: ImageThumbnailStateToIndexCandidateDivinerConfigSchema\n}>\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { AbstractDiviner } from '@xyo-network/abstract-diviner'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { ArchivistWrapper } from '@xyo-network/archivist-wrapper'\nimport { BoundWitness, isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessDivinerQueryPayload, BoundWitnessDivinerQuerySchema } from '@xyo-network/diviner-boundwitness-model'\nimport { DivinerConfigSchema } from '@xyo-network/diviner-model'\nimport { DivinerWrapper } from '@xyo-network/diviner-wrapper'\nimport { ImageThumbnail, ImageThumbnailSchema, isImageThumbnail } from '@xyo-network/image-thumbnail-payload-plugin'\nimport { isModuleState, ModuleState, ModuleStateSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport { isTimestamp, TimeStamp, TimestampSchema } from '@xyo-network/witness-timestamp'\n\nimport { ImageThumbnailDivinerLabels, ImageThumbnailDivinerStageLabels } from '../ImageThumbnailDivinerLabels'\nimport { ImageThumbnailDivinerState } from '../ImageThumbnailDivinerState'\nimport { ImageThumbnailStateToIndexCandidateDivinerConfigSchema } from './Config'\nimport { ImageThumbnailStateToIndexCandidateDivinerParams } from './Params'\n\n/**\n * All Payload types involved in index candidates for indexing\n */\nexport type IndexCandidate = BoundWitness | ImageThumbnail | TimeStamp\n\n/**\n * The response from the ImageThumbnailStateToIndexCandidateDiviner\n */\nexport type ImageThumbnailStateToIndexCandidateDivinerResponse = [\n /**\n * The next state of the diviner\n */\n nextState: ModuleState<ImageThumbnailDivinerState>,\n /**\n * The index candidates\n */\n ...IndexCandidate[],\n]\n\n/**\n * The required payload_schemas within BoundWitnesses to identify index candidates\n */\nconst payload_schemas = [ImageThumbnailSchema, TimestampSchema]\n\n/**\n * Index candidate identity functions\n */\nconst indexCandidateIdentityFunctions = [isImageThumbnail, isTimestamp] as const\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 = 'ImageThumbnailStateToIndexCandidateDiviner'\n\n/**\n * Transforms candidates for image thumbnail indexing into their indexed representation\n */\nexport class ImageThumbnailStateToIndexCandidateDiviner<\n TParams extends ImageThumbnailStateToIndexCandidateDivinerParams = ImageThumbnailStateToIndexCandidateDivinerParams,\n> extends AbstractDiviner<TParams> {\n static override configSchemas = [DivinerConfigSchema, ImageThumbnailStateToIndexCandidateDivinerConfigSchema]\n static labels: ImageThumbnailDivinerStageLabels = {\n ...ImageThumbnailDivinerLabels,\n 'network.xyo.diviner.stage': 'stateToIndexCandidateDiviner',\n }\n\n get payloadDivinerLimit() {\n return this.config.payloadDivinerLimit ?? 1_000\n }\n\n protected static async getPayloadsInBoundWitness(bw: BoundWitness, archivist: ArchivistInstance): Promise<IndexCandidate[] | undefined> {\n const indexes = payload_schemas.map((schema) => bw.payload_schemas?.findIndex((s) => s === schema))\n const hashes = indexes.map((index) => bw.payload_hashes?.[index])\n const results = await archivist.get(hashes)\n const filteredResults = indexCandidateIdentityFunctions.map((is) => results.find(is))\n if (filteredResults.some((f) => f === undefined)) return undefined\n const indexCandidates: IndexCandidate[] = filteredResults.filter(exists) as IndexCandidate[]\n return [bw, ...indexCandidates]\n }\n\n protected override async divineHandler(payloads: Payload[] = []): Promise<ImageThumbnailStateToIndexCandidateDivinerResponse> {\n // Retrieve the last state from what was passed in\n const lastState = payloads.find(isModuleState<ImageThumbnailDivinerState>)\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 const query = new PayloadBuilder<BoundWitnessDivinerQueryPayload>({ schema: BoundWitnessDivinerQuerySchema })\n .fields({ limit: this.payloadDivinerLimit, offset, order, 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 const indexCandidates: IndexCandidate[] = (\n await Promise.all(\n batch.filter(isBoundWitness).map((bw) => ImageThumbnailStateToIndexCandidateDiviner.getPayloadsInBoundWitness(bw, sourceArchivist)),\n )\n )\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\n */\n protected async getArchivistForStore() {\n const name = assertEx(this.config?.payloadStore?.archivist, () => `${moduleName}: Config for payloadStore.archivist not specified`)\n const mod = assertEx(await this.resolve(name), () => `${moduleName}: Failed to resolve payloadStore.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\n */\n protected async getBoundWitnessDivinerForStore() {\n const name = assertEx(\n this.config?.payloadStore?.boundWitnessDiviner,\n () => `${moduleName}: Config for payloadStore.boundWitnessDiviner not specified`,\n )\n const mod = assertEx(await this.resolve(name), () => `${moduleName}: Failed to resolve payloadStore.boundWitnessDiviner`)\n return DivinerWrapper.wrap(mod, this.account)\n }\n}\n"],"mappings":"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","names":["AbstractDiviner","PayloadHasher","DivinerConfigSchema","PayloadBuilder","UrlSchema","AbstractDiviner","DivinerConfigSchema","PayloadBuilder","UrlSchema","PayloadHasher","AbstractDiviner","PayloadHasher","DivinerConfigSchema","isImageThumbnailDivinerQuery","PayloadBuilder","UrlSchema","AbstractDiviner","DivinerConfigSchema","isImageThumbnailDivinerQuery","order","UrlSchema","PayloadHasher","PayloadBuilder","PayloadDivinerQuerySchema","exists","AbstractDiviner","isBoundWitness","DivinerConfigSchema","ImageThumbnailSchema","isImageThumbnail","PayloadBuilder","isTimestamp","TimestampSchema","ImageThumbnailSchema","TimestampSchema","isImageThumbnail","isTimestamp","AbstractDiviner","DivinerConfigSchema","exists","PayloadBuilder","isBoundWitness"]}