@xyo-network/diviner-payload-memory 2.75.15 → 2.75.17

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/docs.json CHANGED
@@ -4252,7 +4252,7 @@
4252
4252
  "fileName": "modules/packages/diviner/packages/payload/packages/memory/src/MemoryPayloadDiviner.ts",
4253
4253
  "line": 8,
4254
4254
  "character": 18,
4255
- "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/blob/329e1cefafe53/packages/modules/packages/diviner/packages/payload/packages/memory/src/MemoryPayloadDiviner.ts#L8"
4255
+ "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/blob/88daee906ba30/packages/modules/packages/diviner/packages/payload/packages/memory/src/MemoryPayloadDiviner.ts#L8"
4256
4256
  }
4257
4257
  ],
4258
4258
  "type": {
@@ -7904,7 +7904,7 @@
7904
7904
  "fileName": "modules/packages/diviner/packages/payload/packages/memory/src/MemoryPayloadDiviner.ts",
7905
7905
  "line": 10,
7906
7906
  "character": 27,
7907
- "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/blob/329e1cefafe53/packages/modules/packages/diviner/packages/payload/packages/memory/src/MemoryPayloadDiviner.ts#L10"
7907
+ "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/blob/88daee906ba30/packages/modules/packages/diviner/packages/payload/packages/memory/src/MemoryPayloadDiviner.ts#L10"
7908
7908
  }
7909
7909
  ],
7910
7910
  "signatures": [
@@ -7919,7 +7919,7 @@
7919
7919
  "fileName": "modules/packages/diviner/packages/payload/packages/memory/src/MemoryPayloadDiviner.ts",
7920
7920
  "line": 10,
7921
7921
  "character": 27,
7922
- "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/blob/329e1cefafe53/packages/modules/packages/diviner/packages/payload/packages/memory/src/MemoryPayloadDiviner.ts#L10"
7922
+ "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/blob/88daee906ba30/packages/modules/packages/diviner/packages/payload/packages/memory/src/MemoryPayloadDiviner.ts#L10"
7923
7923
  }
7924
7924
  ],
7925
7925
  "parameters": [
@@ -17613,7 +17613,7 @@
17613
17613
  "fileName": "modules/packages/diviner/packages/payload/packages/memory/src/MemoryPayloadDiviner.ts",
17614
17614
  "line": 7,
17615
17615
  "character": 13,
17616
- "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/blob/329e1cefafe53/packages/modules/packages/diviner/packages/payload/packages/memory/src/MemoryPayloadDiviner.ts#L7"
17616
+ "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/blob/88daee906ba30/packages/modules/packages/diviner/packages/payload/packages/memory/src/MemoryPayloadDiviner.ts#L7"
17617
17617
  }
17618
17618
  ],
17619
17619
  "typeParameters": [
package/package.json CHANGED
@@ -10,19 +10,19 @@
10
10
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
11
11
  },
12
12
  "dependencies": {
13
- "@xylabs/assert": "^2.12.22",
14
- "@xyo-network/core": "~2.75.15",
15
- "@xyo-network/diviner-payload-abstract": "~2.75.15",
16
- "@xyo-network/diviner-payload-model": "~2.75.15",
17
- "@xyo-network/payload-model": "~2.75.15"
13
+ "@xylabs/assert": "^2.12.24",
14
+ "@xyo-network/core": "~2.75.17",
15
+ "@xyo-network/diviner-payload-abstract": "~2.75.17",
16
+ "@xyo-network/diviner-payload-model": "~2.75.17",
17
+ "@xyo-network/payload-model": "~2.75.17"
18
18
  },
19
19
  "devDependencies": {
20
- "@xylabs/ts-scripts-yarn3": "^3.0.88",
21
- "@xylabs/tsconfig": "^3.0.88",
22
- "@xyo-network/account": "~2.75.15",
23
- "@xyo-network/memory-archivist": "~2.75.15",
24
- "@xyo-network/node-memory": "~2.75.15",
25
- "@xyo-network/payload-builder": "~2.75.15",
20
+ "@xylabs/ts-scripts-yarn3": "^3.1.9",
21
+ "@xylabs/tsconfig": "^3.1.9",
22
+ "@xyo-network/account": "~2.75.17",
23
+ "@xyo-network/memory-archivist": "~2.75.17",
24
+ "@xyo-network/node-memory": "~2.75.17",
25
+ "@xyo-network/payload-builder": "~2.75.17",
26
26
  "typescript": "^5.2.2"
27
27
  },
28
28
  "description": "Primary SDK for using XYO Protocol 2.0",
@@ -68,5 +68,5 @@
68
68
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
69
69
  },
70
70
  "sideEffects": false,
71
- "version": "2.75.15"
71
+ "version": "2.75.17"
72
72
  }
@@ -1,76 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
-
20
- // src/MemoryPayloadDiviner.ts
21
- var MemoryPayloadDiviner_exports = {};
22
- __export(MemoryPayloadDiviner_exports, {
23
- MemoryPayloadDiviner: () => MemoryPayloadDiviner
24
- });
25
- module.exports = __toCommonJS(MemoryPayloadDiviner_exports);
26
- var import_assert = require("@xylabs/assert");
27
- var import_core = require("@xyo-network/core");
28
- var import_diviner_payload_abstract = require("@xyo-network/diviner-payload-abstract");
29
- var import_diviner_payload_model = require("@xyo-network/diviner-payload-model");
30
- var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.PayloadDiviner {
31
- static configSchemas = [import_diviner_payload_model.PayloadDivinerConfigSchema];
32
- async divineHandler(payloads) {
33
- const filter = (0, import_assert.assertEx)(payloads?.filter(import_diviner_payload_model.isPayloadDivinerQueryPayload)?.pop(), "Missing query payload");
34
- if (!filter)
35
- return [];
36
- const archivist = (0, import_assert.assertEx)(await this.readArchivist(), "Unable to resolve archivist");
37
- const { schemas, limit, offset, hash, order, schema, ...props } = filter;
38
- let all = await archivist.all?.();
39
- if (all) {
40
- if (order === "desc")
41
- all = all.reverse();
42
- if (schemas?.length)
43
- all = all.filter((payload) => schemas.includes(payload.schema));
44
- if (Object.keys(props).length > 0) {
45
- const additionalFilterCriteria = Object.entries(props);
46
- for (const [prop, filter2] of additionalFilterCriteria) {
47
- const property = prop;
48
- if (Array.isArray(filter2)) {
49
- all = all.filter((payload) => filter2.every((value) => payload?.[property]?.includes(value)));
50
- } else {
51
- all = all.filter((payload) => payload?.[property] === filter2);
52
- }
53
- }
54
- }
55
- const parsedLimit = limit || all.length;
56
- const parsedOffset = offset || 0;
57
- return offset !== void 0 ? all.slice(parsedOffset, parsedLimit) : (async () => {
58
- const allPairs = await Promise.all(
59
- all.map(async (payload) => [await import_core.PayloadHasher.hashAsync(payload), payload])
60
- );
61
- if (hash) {
62
- while (allPairs.length > 0 && allPairs[0][0] !== hash) {
63
- allPairs.shift();
64
- }
65
- if (allPairs.length > 0 && allPairs[0][0] === hash) {
66
- allPairs.shift();
67
- }
68
- }
69
- return allPairs.map(([, payload]) => payload);
70
- })();
71
- } else {
72
- throw Error('Archivist does not support "all"');
73
- }
74
- }
75
- };
76
- //# sourceMappingURL=MemoryPayloadDiviner.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport { isPayloadDivinerQueryPayload, PayloadDivinerConfigSchema, PayloadDivinerParams } from '@xyo-network/diviner-payload-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<TParams extends PayloadDivinerParams = PayloadDivinerParams> extends PayloadDiviner<TParams> {\n static override configSchemas = [PayloadDivinerConfigSchema]\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.readArchivist(), 'Unable to resolve archivist')\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schemas, limit, offset, hash, order, schema, ...props } = filter\n let all = await archivist.all?.()\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof Payload\n if (Array.isArray(filter)) {\n all = all.filter((payload) => filter.every((value) => payload?.[property]?.includes(value)))\n } else {\n all = all.filter((payload) => payload?.[property] === filter)\n }\n }\n }\n const parsedLimit = limit || all.length\n const parsedOffset = offset || 0\n return offset !== undefined\n ? all.slice(parsedOffset, parsedLimit)\n : (async () => {\n const allPairs = await Promise.all(\n all.map<Promise<[string, Payload]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]),\n )\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][0] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][0] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([, payload]) => payload)\n })()\n } else {\n throw Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAyB;AACzB,kBAA8B;AAC9B,sCAA+B;AAC/B,mCAA+F;AAGxF,IAAM,uBAAN,cAAgG,+CAAwB;AAAA,EAC7H,OAAgB,gBAAgB,CAAC,uDAA0B;AAAA,EAE3D,MAAyB,cAAc,UAA0C;AAC/E,UAAM,aAAS,wBAAS,UAAU,OAAO,yDAA4B,GAAG,IAAI,GAAG,uBAAuB;AACtG,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,UAAM,gBAAY,wBAAS,MAAM,KAAK,cAAc,GAAG,6BAA6B;AAEpF,UAAM,EAAE,SAAS,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,MAAM,IAAI;AAClE,QAAI,MAAM,MAAM,UAAU,MAAM;AAChC,QAAI,KAAK;AACP,UAAI,UAAU;AAAQ,cAAM,IAAI,QAAQ;AACxC,UAAI,SAAS;AAAQ,cAAM,IAAI,OAAO,CAAC,YAAY,QAAQ,SAAS,QAAQ,MAAM,CAAC;AACnF,UAAI,OAAO,KAAK,KAAK,EAAE,SAAS,GAAG;AACjC,cAAM,2BAA2B,OAAO,QAAQ,KAAK;AACrD,mBAAW,CAAC,MAAMA,OAAM,KAAK,0BAA0B;AACrD,gBAAM,WAAW;AACjB,cAAI,MAAM,QAAQA,OAAM,GAAG;AACzB,kBAAM,IAAI,OAAO,CAAC,YAAYA,QAAO,MAAM,CAAC,UAAU,UAAU,QAAQ,GAAG,SAAS,KAAK,CAAC,CAAC;AAAA,UAC7F,OAAO;AACL,kBAAM,IAAI,OAAO,CAAC,YAAY,UAAU,QAAQ,MAAMA,OAAM;AAAA,UAC9D;AAAA,QACF;AAAA,MACF;AACA,YAAM,cAAc,SAAS,IAAI;AACjC,YAAM,eAAe,UAAU;AAC/B,aAAO,WAAW,SACd,IAAI,MAAM,cAAc,WAAW,KAClC,YAAY;AACX,cAAM,WAAW,MAAM,QAAQ;AAAA,UAC7B,IAAI,IAAgC,OAAO,YAAY,CAAC,MAAM,0BAAc,UAAU,OAAO,GAAG,OAAO,CAAC;AAAA,QAC1G;AACA,YAAI,MAAM;AAER,iBAAO,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AACrD,qBAAS,MAAM;AAAA,UACjB;AAEA,cAAI,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AAClD,qBAAS,MAAM;AAAA,UACjB;AAAA,QACF;AACA,eAAO,SAAS,IAAI,CAAC,CAAC,EAAE,OAAO,MAAM,OAAO;AAAA,MAC9C,GAAG;AAAA,IACT,OAAO;AACL,YAAM,MAAM,kCAAkC;AAAA,IAChD;AAAA,EACF;AACF;","names":["filter"]}
@@ -1,55 +0,0 @@
1
- // src/MemoryPayloadDiviner.ts
2
- import { assertEx } from "@xylabs/assert";
3
- import { PayloadHasher } from "@xyo-network/core";
4
- import { PayloadDiviner } from "@xyo-network/diviner-payload-abstract";
5
- import { isPayloadDivinerQueryPayload, PayloadDivinerConfigSchema } from "@xyo-network/diviner-payload-model";
6
- var MemoryPayloadDiviner = class extends PayloadDiviner {
7
- static configSchemas = [PayloadDivinerConfigSchema];
8
- async divineHandler(payloads) {
9
- const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), "Missing query payload");
10
- if (!filter)
11
- return [];
12
- const archivist = assertEx(await this.readArchivist(), "Unable to resolve archivist");
13
- const { schemas, limit, offset, hash, order, schema, ...props } = filter;
14
- let all = await archivist.all?.();
15
- if (all) {
16
- if (order === "desc")
17
- all = all.reverse();
18
- if (schemas?.length)
19
- all = all.filter((payload) => schemas.includes(payload.schema));
20
- if (Object.keys(props).length > 0) {
21
- const additionalFilterCriteria = Object.entries(props);
22
- for (const [prop, filter2] of additionalFilterCriteria) {
23
- const property = prop;
24
- if (Array.isArray(filter2)) {
25
- all = all.filter((payload) => filter2.every((value) => payload?.[property]?.includes(value)));
26
- } else {
27
- all = all.filter((payload) => payload?.[property] === filter2);
28
- }
29
- }
30
- }
31
- const parsedLimit = limit || all.length;
32
- const parsedOffset = offset || 0;
33
- return offset !== void 0 ? all.slice(parsedOffset, parsedLimit) : (async () => {
34
- const allPairs = await Promise.all(
35
- all.map(async (payload) => [await PayloadHasher.hashAsync(payload), payload])
36
- );
37
- if (hash) {
38
- while (allPairs.length > 0 && allPairs[0][0] !== hash) {
39
- allPairs.shift();
40
- }
41
- if (allPairs.length > 0 && allPairs[0][0] === hash) {
42
- allPairs.shift();
43
- }
44
- }
45
- return allPairs.map(([, payload]) => payload);
46
- })();
47
- } else {
48
- throw Error('Archivist does not support "all"');
49
- }
50
- }
51
- };
52
- export {
53
- MemoryPayloadDiviner
54
- };
55
- //# sourceMappingURL=MemoryPayloadDiviner.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport { isPayloadDivinerQueryPayload, PayloadDivinerConfigSchema, PayloadDivinerParams } from '@xyo-network/diviner-payload-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<TParams extends PayloadDivinerParams = PayloadDivinerParams> extends PayloadDiviner<TParams> {\n static override configSchemas = [PayloadDivinerConfigSchema]\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.readArchivist(), 'Unable to resolve archivist')\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schemas, limit, offset, hash, order, schema, ...props } = filter\n let all = await archivist.all?.()\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof Payload\n if (Array.isArray(filter)) {\n all = all.filter((payload) => filter.every((value) => payload?.[property]?.includes(value)))\n } else {\n all = all.filter((payload) => payload?.[property] === filter)\n }\n }\n }\n const parsedLimit = limit || all.length\n const parsedOffset = offset || 0\n return offset !== undefined\n ? all.slice(parsedOffset, parsedLimit)\n : (async () => {\n const allPairs = await Promise.all(\n all.map<Promise<[string, Payload]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]),\n )\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][0] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][0] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([, payload]) => payload)\n })()\n } else {\n throw Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";AAAA,SAAS,gBAAgB;AACzB,SAAS,qBAAqB;AAC9B,SAAS,sBAAsB;AAC/B,SAAS,8BAA8B,kCAAwD;AAGxF,IAAM,uBAAN,cAAgG,eAAwB;AAAA,EAC7H,OAAgB,gBAAgB,CAAC,0BAA0B;AAAA,EAE3D,MAAyB,cAAc,UAA0C;AAC/E,UAAM,SAAS,SAAS,UAAU,OAAO,4BAA4B,GAAG,IAAI,GAAG,uBAAuB;AACtG,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,UAAM,YAAY,SAAS,MAAM,KAAK,cAAc,GAAG,6BAA6B;AAEpF,UAAM,EAAE,SAAS,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,MAAM,IAAI;AAClE,QAAI,MAAM,MAAM,UAAU,MAAM;AAChC,QAAI,KAAK;AACP,UAAI,UAAU;AAAQ,cAAM,IAAI,QAAQ;AACxC,UAAI,SAAS;AAAQ,cAAM,IAAI,OAAO,CAAC,YAAY,QAAQ,SAAS,QAAQ,MAAM,CAAC;AACnF,UAAI,OAAO,KAAK,KAAK,EAAE,SAAS,GAAG;AACjC,cAAM,2BAA2B,OAAO,QAAQ,KAAK;AACrD,mBAAW,CAAC,MAAMA,OAAM,KAAK,0BAA0B;AACrD,gBAAM,WAAW;AACjB,cAAI,MAAM,QAAQA,OAAM,GAAG;AACzB,kBAAM,IAAI,OAAO,CAAC,YAAYA,QAAO,MAAM,CAAC,UAAU,UAAU,QAAQ,GAAG,SAAS,KAAK,CAAC,CAAC;AAAA,UAC7F,OAAO;AACL,kBAAM,IAAI,OAAO,CAAC,YAAY,UAAU,QAAQ,MAAMA,OAAM;AAAA,UAC9D;AAAA,QACF;AAAA,MACF;AACA,YAAM,cAAc,SAAS,IAAI;AACjC,YAAM,eAAe,UAAU;AAC/B,aAAO,WAAW,SACd,IAAI,MAAM,cAAc,WAAW,KAClC,YAAY;AACX,cAAM,WAAW,MAAM,QAAQ;AAAA,UAC7B,IAAI,IAAgC,OAAO,YAAY,CAAC,MAAM,cAAc,UAAU,OAAO,GAAG,OAAO,CAAC;AAAA,QAC1G;AACA,YAAI,MAAM;AAER,iBAAO,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AACrD,qBAAS,MAAM;AAAA,UACjB;AAEA,cAAI,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AAClD,qBAAS,MAAM;AAAA,UACjB;AAAA,QACF;AACA,eAAO,SAAS,IAAI,CAAC,CAAC,EAAE,OAAO,MAAM,OAAO;AAAA,MAC9C,GAAG;AAAA,IACT,OAAO;AACL,YAAM,MAAM,kCAAkC;AAAA,IAChD;AAAA,EACF;AACF;","names":["filter"]}
@@ -1,84 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
-
20
- // src/MemoryPayloadDiviner.ts
21
- var MemoryPayloadDiviner_exports = {};
22
- __export(MemoryPayloadDiviner_exports, {
23
- MemoryPayloadDiviner: () => MemoryPayloadDiviner
24
- });
25
- module.exports = __toCommonJS(MemoryPayloadDiviner_exports);
26
- var import_assert = require("@xylabs/assert");
27
- var import_core = require("@xyo-network/core");
28
- var import_diviner_payload_abstract = require("@xyo-network/diviner-payload-abstract");
29
- var import_diviner_payload_model = require("@xyo-network/diviner-payload-model");
30
- var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.PayloadDiviner {
31
- static configSchemas = [import_diviner_payload_model.PayloadDivinerConfigSchema];
32
- async divineHandler(payloads) {
33
- var _a, _b;
34
- const filter = (0, import_assert.assertEx)((_a = payloads == null ? void 0 : payloads.filter(import_diviner_payload_model.isPayloadDivinerQueryPayload)) == null ? void 0 : _a.pop(), "Missing query payload");
35
- if (!filter)
36
- return [];
37
- const archivist = (0, import_assert.assertEx)(await this.readArchivist(), "Unable to resolve archivist");
38
- const { schemas, limit, offset, hash, order, schema, ...props } = filter;
39
- let all = await ((_b = archivist.all) == null ? void 0 : _b.call(archivist));
40
- if (all) {
41
- if (order === "desc")
42
- all = all.reverse();
43
- if (schemas == null ? void 0 : schemas.length)
44
- all = all.filter((payload) => schemas.includes(payload.schema));
45
- if (Object.keys(props).length > 0) {
46
- const additionalFilterCriteria = Object.entries(props);
47
- for (const [prop, filter2] of additionalFilterCriteria) {
48
- const property = prop;
49
- if (Array.isArray(filter2)) {
50
- all = all.filter((payload) => filter2.every((value) => {
51
- var _a2;
52
- return (_a2 = payload == null ? void 0 : payload[property]) == null ? void 0 : _a2.includes(value);
53
- }));
54
- } else {
55
- all = all.filter((payload) => (payload == null ? void 0 : payload[property]) === filter2);
56
- }
57
- }
58
- }
59
- const parsedLimit = limit || all.length;
60
- const parsedOffset = offset || 0;
61
- return offset !== void 0 ? all.slice(parsedOffset, parsedLimit) : (async () => {
62
- const allPairs = await Promise.all(
63
- all.map(async (payload) => [await import_core.PayloadHasher.hashAsync(payload), payload])
64
- );
65
- if (hash) {
66
- while (allPairs.length > 0 && allPairs[0][0] !== hash) {
67
- allPairs.shift();
68
- }
69
- if (allPairs.length > 0 && allPairs[0][0] === hash) {
70
- allPairs.shift();
71
- }
72
- }
73
- return allPairs.map(([, payload]) => payload);
74
- })();
75
- } else {
76
- throw Error('Archivist does not support "all"');
77
- }
78
- }
79
- };
80
- // Annotate the CommonJS export names for ESM import in node:
81
- 0 && (module.exports = {
82
- MemoryPayloadDiviner
83
- });
84
- //# sourceMappingURL=MemoryPayloadDiviner.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport { isPayloadDivinerQueryPayload, PayloadDivinerConfigSchema, PayloadDivinerParams } from '@xyo-network/diviner-payload-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<TParams extends PayloadDivinerParams = PayloadDivinerParams> extends PayloadDiviner<TParams> {\n static override configSchemas = [PayloadDivinerConfigSchema]\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.readArchivist(), 'Unable to resolve archivist')\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schemas, limit, offset, hash, order, schema, ...props } = filter\n let all = await archivist.all?.()\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof Payload\n if (Array.isArray(filter)) {\n all = all.filter((payload) => filter.every((value) => payload?.[property]?.includes(value)))\n } else {\n all = all.filter((payload) => payload?.[property] === filter)\n }\n }\n }\n const parsedLimit = limit || all.length\n const parsedOffset = offset || 0\n return offset !== undefined\n ? all.slice(parsedOffset, parsedLimit)\n : (async () => {\n const allPairs = await Promise.all(\n all.map<Promise<[string, Payload]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]),\n )\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][0] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][0] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([, payload]) => payload)\n })()\n } else {\n throw Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAyB;AACzB,kBAA8B;AAC9B,sCAA+B;AAC/B,mCAA+F;AAGxF,IAAM,uBAAN,cAAgG,+CAAwB;AAAA,EAC7H,OAAgB,gBAAgB,CAAC,uDAA0B;AAAA,EAE3D,MAAyB,cAAc,UAA0C;AATnF;AAUI,UAAM,aAAS,yBAAS,0CAAU,OAAO,+DAAjB,mBAAgD,OAAO,uBAAuB;AACtG,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,UAAM,gBAAY,wBAAS,MAAM,KAAK,cAAc,GAAG,6BAA6B;AAEpF,UAAM,EAAE,SAAS,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,MAAM,IAAI;AAClE,QAAI,MAAM,QAAM,eAAU,QAAV;AAChB,QAAI,KAAK;AACP,UAAI,UAAU;AAAQ,cAAM,IAAI,QAAQ;AACxC,UAAI,mCAAS;AAAQ,cAAM,IAAI,OAAO,CAAC,YAAY,QAAQ,SAAS,QAAQ,MAAM,CAAC;AACnF,UAAI,OAAO,KAAK,KAAK,EAAE,SAAS,GAAG;AACjC,cAAM,2BAA2B,OAAO,QAAQ,KAAK;AACrD,mBAAW,CAAC,MAAMA,OAAM,KAAK,0BAA0B;AACrD,gBAAM,WAAW;AACjB,cAAI,MAAM,QAAQA,OAAM,GAAG;AACzB,kBAAM,IAAI,OAAO,CAAC,YAAYA,QAAO,MAAM,CAAC,UAAO;AAxB/D,kBAAAC;AAwBkE,sBAAAA,MAAA,mCAAU,cAAV,gBAAAA,IAAqB,SAAS;AAAA,aAAM,CAAC;AAAA,UAC7F,OAAO;AACL,kBAAM,IAAI,OAAO,CAAC,aAAY,mCAAU,eAAcD,OAAM;AAAA,UAC9D;AAAA,QACF;AAAA,MACF;AACA,YAAM,cAAc,SAAS,IAAI;AACjC,YAAM,eAAe,UAAU;AAC/B,aAAO,WAAW,SACd,IAAI,MAAM,cAAc,WAAW,KAClC,YAAY;AACX,cAAM,WAAW,MAAM,QAAQ;AAAA,UAC7B,IAAI,IAAgC,OAAO,YAAY,CAAC,MAAM,0BAAc,UAAU,OAAO,GAAG,OAAO,CAAC;AAAA,QAC1G;AACA,YAAI,MAAM;AAER,iBAAO,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AACrD,qBAAS,MAAM;AAAA,UACjB;AAEA,cAAI,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AAClD,qBAAS,MAAM;AAAA,UACjB;AAAA,QACF;AACA,eAAO,SAAS,IAAI,CAAC,CAAC,EAAE,OAAO,MAAM,OAAO;AAAA,MAC9C,GAAG;AAAA,IACT,OAAO;AACL,YAAM,MAAM,kCAAkC;AAAA,IAChD;AAAA,EACF;AACF;","names":["filter","_a"]}
@@ -1,59 +0,0 @@
1
- // src/MemoryPayloadDiviner.ts
2
- import { assertEx } from "@xylabs/assert";
3
- import { PayloadHasher } from "@xyo-network/core";
4
- import { PayloadDiviner } from "@xyo-network/diviner-payload-abstract";
5
- import { isPayloadDivinerQueryPayload, PayloadDivinerConfigSchema } from "@xyo-network/diviner-payload-model";
6
- var MemoryPayloadDiviner = class extends PayloadDiviner {
7
- static configSchemas = [PayloadDivinerConfigSchema];
8
- async divineHandler(payloads) {
9
- var _a, _b;
10
- const filter = assertEx((_a = payloads == null ? void 0 : payloads.filter(isPayloadDivinerQueryPayload)) == null ? void 0 : _a.pop(), "Missing query payload");
11
- if (!filter)
12
- return [];
13
- const archivist = assertEx(await this.readArchivist(), "Unable to resolve archivist");
14
- const { schemas, limit, offset, hash, order, schema, ...props } = filter;
15
- let all = await ((_b = archivist.all) == null ? void 0 : _b.call(archivist));
16
- if (all) {
17
- if (order === "desc")
18
- all = all.reverse();
19
- if (schemas == null ? void 0 : schemas.length)
20
- all = all.filter((payload) => schemas.includes(payload.schema));
21
- if (Object.keys(props).length > 0) {
22
- const additionalFilterCriteria = Object.entries(props);
23
- for (const [prop, filter2] of additionalFilterCriteria) {
24
- const property = prop;
25
- if (Array.isArray(filter2)) {
26
- all = all.filter((payload) => filter2.every((value) => {
27
- var _a2;
28
- return (_a2 = payload == null ? void 0 : payload[property]) == null ? void 0 : _a2.includes(value);
29
- }));
30
- } else {
31
- all = all.filter((payload) => (payload == null ? void 0 : payload[property]) === filter2);
32
- }
33
- }
34
- }
35
- const parsedLimit = limit || all.length;
36
- const parsedOffset = offset || 0;
37
- return offset !== void 0 ? all.slice(parsedOffset, parsedLimit) : (async () => {
38
- const allPairs = await Promise.all(
39
- all.map(async (payload) => [await PayloadHasher.hashAsync(payload), payload])
40
- );
41
- if (hash) {
42
- while (allPairs.length > 0 && allPairs[0][0] !== hash) {
43
- allPairs.shift();
44
- }
45
- if (allPairs.length > 0 && allPairs[0][0] === hash) {
46
- allPairs.shift();
47
- }
48
- }
49
- return allPairs.map(([, payload]) => payload);
50
- })();
51
- } else {
52
- throw Error('Archivist does not support "all"');
53
- }
54
- }
55
- };
56
- export {
57
- MemoryPayloadDiviner
58
- };
59
- //# sourceMappingURL=MemoryPayloadDiviner.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport { isPayloadDivinerQueryPayload, PayloadDivinerConfigSchema, PayloadDivinerParams } from '@xyo-network/diviner-payload-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<TParams extends PayloadDivinerParams = PayloadDivinerParams> extends PayloadDiviner<TParams> {\n static override configSchemas = [PayloadDivinerConfigSchema]\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.readArchivist(), 'Unable to resolve archivist')\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schemas, limit, offset, hash, order, schema, ...props } = filter\n let all = await archivist.all?.()\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof Payload\n if (Array.isArray(filter)) {\n all = all.filter((payload) => filter.every((value) => payload?.[property]?.includes(value)))\n } else {\n all = all.filter((payload) => payload?.[property] === filter)\n }\n }\n }\n const parsedLimit = limit || all.length\n const parsedOffset = offset || 0\n return offset !== undefined\n ? all.slice(parsedOffset, parsedLimit)\n : (async () => {\n const allPairs = await Promise.all(\n all.map<Promise<[string, Payload]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]),\n )\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][0] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][0] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([, payload]) => payload)\n })()\n } else {\n throw Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";AAAA,SAAS,gBAAgB;AACzB,SAAS,qBAAqB;AAC9B,SAAS,sBAAsB;AAC/B,SAAS,8BAA8B,kCAAwD;AAGxF,IAAM,uBAAN,cAAgG,eAAwB;AAAA,EAC7H,OAAgB,gBAAgB,CAAC,0BAA0B;AAAA,EAE3D,MAAyB,cAAc,UAA0C;AATnF;AAUI,UAAM,SAAS,UAAS,0CAAU,OAAO,kCAAjB,mBAAgD,OAAO,uBAAuB;AACtG,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,UAAM,YAAY,SAAS,MAAM,KAAK,cAAc,GAAG,6BAA6B;AAEpF,UAAM,EAAE,SAAS,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,MAAM,IAAI;AAClE,QAAI,MAAM,QAAM,eAAU,QAAV;AAChB,QAAI,KAAK;AACP,UAAI,UAAU;AAAQ,cAAM,IAAI,QAAQ;AACxC,UAAI,mCAAS;AAAQ,cAAM,IAAI,OAAO,CAAC,YAAY,QAAQ,SAAS,QAAQ,MAAM,CAAC;AACnF,UAAI,OAAO,KAAK,KAAK,EAAE,SAAS,GAAG;AACjC,cAAM,2BAA2B,OAAO,QAAQ,KAAK;AACrD,mBAAW,CAAC,MAAMA,OAAM,KAAK,0BAA0B;AACrD,gBAAM,WAAW;AACjB,cAAI,MAAM,QAAQA,OAAM,GAAG;AACzB,kBAAM,IAAI,OAAO,CAAC,YAAYA,QAAO,MAAM,CAAC,UAAO;AAxB/D,kBAAAC;AAwBkE,sBAAAA,MAAA,mCAAU,cAAV,gBAAAA,IAAqB,SAAS;AAAA,aAAM,CAAC;AAAA,UAC7F,OAAO;AACL,kBAAM,IAAI,OAAO,CAAC,aAAY,mCAAU,eAAcD,OAAM;AAAA,UAC9D;AAAA,QACF;AAAA,MACF;AACA,YAAM,cAAc,SAAS,IAAI;AACjC,YAAM,eAAe,UAAU;AAC/B,aAAO,WAAW,SACd,IAAI,MAAM,cAAc,WAAW,KAClC,YAAY;AACX,cAAM,WAAW,MAAM,QAAQ;AAAA,UAC7B,IAAI,IAAgC,OAAO,YAAY,CAAC,MAAM,cAAc,UAAU,OAAO,GAAG,OAAO,CAAC;AAAA,QAC1G;AACA,YAAI,MAAM;AAER,iBAAO,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AACrD,qBAAS,MAAM;AAAA,UACjB;AAEA,cAAI,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AAClD,qBAAS,MAAM;AAAA,UACjB;AAAA,QACF;AACA,eAAO,SAAS,IAAI,CAAC,CAAC,EAAE,OAAO,MAAM,OAAO;AAAA,MAC9C,GAAG;AAAA,IACT,OAAO;AACL,YAAM,MAAM,kCAAkC;AAAA,IAChD;AAAA,EACF;AACF;","names":["filter","_a"]}