@xyo-network/diviner-payload-memory 2.110.11 → 2.110.13

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 (42) hide show
  1. package/dist/browser/MemoryPayloadDiviner.d.cts.map +1 -1
  2. package/dist/browser/MemoryPayloadDiviner.d.mts.map +1 -1
  3. package/dist/browser/MemoryPayloadDiviner.d.ts.map +1 -1
  4. package/dist/browser/hasTimestamp.d.cts +8 -0
  5. package/dist/browser/hasTimestamp.d.cts.map +1 -0
  6. package/dist/browser/hasTimestamp.d.mts +8 -0
  7. package/dist/browser/hasTimestamp.d.mts.map +1 -0
  8. package/dist/browser/hasTimestamp.d.ts +8 -0
  9. package/dist/browser/hasTimestamp.d.ts.map +1 -0
  10. package/dist/browser/index.cjs +15 -1
  11. package/dist/browser/index.cjs.map +1 -1
  12. package/dist/browser/index.js +15 -1
  13. package/dist/browser/index.js.map +1 -1
  14. package/dist/neutral/MemoryPayloadDiviner.d.cts.map +1 -1
  15. package/dist/neutral/MemoryPayloadDiviner.d.mts.map +1 -1
  16. package/dist/neutral/MemoryPayloadDiviner.d.ts.map +1 -1
  17. package/dist/neutral/hasTimestamp.d.cts +8 -0
  18. package/dist/neutral/hasTimestamp.d.cts.map +1 -0
  19. package/dist/neutral/hasTimestamp.d.mts +8 -0
  20. package/dist/neutral/hasTimestamp.d.mts.map +1 -0
  21. package/dist/neutral/hasTimestamp.d.ts +8 -0
  22. package/dist/neutral/hasTimestamp.d.ts.map +1 -0
  23. package/dist/neutral/index.cjs +15 -1
  24. package/dist/neutral/index.cjs.map +1 -1
  25. package/dist/neutral/index.js +15 -1
  26. package/dist/neutral/index.js.map +1 -1
  27. package/dist/node/MemoryPayloadDiviner.d.cts.map +1 -1
  28. package/dist/node/MemoryPayloadDiviner.d.mts.map +1 -1
  29. package/dist/node/MemoryPayloadDiviner.d.ts.map +1 -1
  30. package/dist/node/hasTimestamp.d.cts +8 -0
  31. package/dist/node/hasTimestamp.d.cts.map +1 -0
  32. package/dist/node/hasTimestamp.d.mts +8 -0
  33. package/dist/node/hasTimestamp.d.mts.map +1 -0
  34. package/dist/node/hasTimestamp.d.ts +8 -0
  35. package/dist/node/hasTimestamp.d.ts.map +1 -0
  36. package/dist/node/index.cjs +15 -1
  37. package/dist/node/index.cjs.map +1 -1
  38. package/dist/node/index.js +15 -1
  39. package/dist/node/index.js.map +1 -1
  40. package/package.json +12 -11
  41. package/src/MemoryPayloadDiviner.ts +17 -1
  42. package/src/hasTimestamp.ts +6 -0
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAItE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA4DpF"}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAItE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA4DpF"}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAItE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA4DpF"}
@@ -0,0 +1,8 @@
1
+ import { AnyObject } from '@xylabs/object';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export declare const hasTimestamp: <T extends Payload = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & AnyObject & {
4
+ schema: import("@xyo-network/payload-model").Schema;
5
+ }>(payload: T) => payload is T & {
6
+ timestamp: number;
7
+ };
8
+ //# sourceMappingURL=hasTimestamp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hasTimestamp.d.ts","sourceRoot":"","sources":["../../src/hasTimestamp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,OAAO;;YAAgC,CAAC,KAAG,OAAO,IAAI,CAAC,GAAG;IAAE,SAAS,EAAE,MAAM,CAAA;CAEnH,CAAA"}
@@ -0,0 +1,8 @@
1
+ import { AnyObject } from '@xylabs/object';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export declare const hasTimestamp: <T extends Payload = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & AnyObject & {
4
+ schema: import("@xyo-network/payload-model").Schema;
5
+ }>(payload: T) => payload is T & {
6
+ timestamp: number;
7
+ };
8
+ //# sourceMappingURL=hasTimestamp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hasTimestamp.d.ts","sourceRoot":"","sources":["../../src/hasTimestamp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,OAAO;;YAAgC,CAAC,KAAG,OAAO,IAAI,CAAC,GAAG;IAAE,SAAS,EAAE,MAAM,CAAA;CAEnH,CAAA"}
@@ -0,0 +1,8 @@
1
+ import { AnyObject } from '@xylabs/object';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export declare const hasTimestamp: <T extends Payload = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & AnyObject & {
4
+ schema: import("@xyo-network/payload-model").Schema;
5
+ }>(payload: T) => payload is T & {
6
+ timestamp: number;
7
+ };
8
+ //# sourceMappingURL=hasTimestamp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hasTimestamp.d.ts","sourceRoot":"","sources":["../../src/hasTimestamp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,OAAO;;YAAgC,CAAC,KAAG,OAAO,IAAI,CAAC,GAAG;IAAE,SAAS,EAAE,MAAM,CAAA;CAEnH,CAAA"}
@@ -31,6 +31,13 @@ var import_object = require("@xylabs/object");
31
31
  var import_diviner_payload_abstract = require("@xyo-network/diviner-payload-abstract");
32
32
  var import_diviner_payload_model = require("@xyo-network/diviner-payload-model");
33
33
  var import_payload_builder = require("@xyo-network/payload-builder");
34
+
35
+ // src/hasTimestamp.ts
36
+ var hasTimestamp = /* @__PURE__ */ __name((payload) => {
37
+ return payload.timestamp !== void 0;
38
+ }, "hasTimestamp");
39
+
40
+ // src/MemoryPayloadDiviner.ts
34
41
  var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.PayloadDiviner {
35
42
  static {
36
43
  __name(this, "MemoryPayloadDiviner");
@@ -44,7 +51,7 @@ var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.Payload
44
51
  const filter = (0, import_assert.assertEx)(payloads?.filter(import_diviner_payload_model.isPayloadDivinerQueryPayload)?.pop(), () => "Missing query payload");
45
52
  if (!filter) return [];
46
53
  const archivist = (0, import_assert.assertEx)(await this.archivistInstance(), () => "Unable to resolve archivist");
47
- const { schemas, limit, offset, hash, order = "desc", ...props } = (0, import_object.removeFields)(filter, [
54
+ const { schemas, limit, offset, hash, order = "desc", timestamp, ...props } = (0, import_object.removeFields)(filter, [
48
55
  "schema",
49
56
  "$meta",
50
57
  "$hash"
@@ -53,6 +60,13 @@ var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.Payload
53
60
  if (all) {
54
61
  if (order === "desc") all = all.reverse();
55
62
  if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema));
63
+ if (timestamp !== void 0) {
64
+ if (filter.order === void 0) {
65
+ all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp);
66
+ } else {
67
+ all = order === "asc" ? all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp) : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp);
68
+ }
69
+ }
56
70
  if (Object.keys(props).length > 0) {
57
71
  const additionalFilterCriteria = Object.entries(props);
58
72
  for (const [prop, filter2] of additionalFilterCriteria) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner.js'\n","import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\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 PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\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 TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,oBAA6B;AAE7B,sCAA+B;AAC/B,mCAKO;AACP,6BAA+B;AAGxB,IAAMA,uBAAN,cASGC,+CAAAA;EAtBV,OAsBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAyBE,cAAcC,UAA6C;AAClF,UAAMC,aAASC,wBAASF,UAAUC,OAAOE,yDAAAA,GAA+BC,IAAAA,GAAO,MAAM,uBAAA;AACrF,QAAI,CAACH,OAAQ,QAAO,CAAA;AACpB,UAAMI,gBAAYH,wBAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQ,GAAGC,MAAAA,QAAUC,4BAAaZ,QAAyB;MAAC;MAAU;MAAS;KAAQ;AACrI,QAAIa,MAAO,MAAMT,UAAUS,MAAG;AAC9B,QAAIA,KAAK;AACP,UAAIH,UAAU,OAAQG,OAAMA,IAAIC,QAAO;AACvC,UAAIR,SAASS,OAAQF,OAAMA,IAAIb,OAAO,CAACgB,YAAYV,QAAQW,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIC,OAAOC,KAAKT,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMM,2BAA2BF,OAAOG,QAAQX,KAAAA;AAChD,mBAAW,CAACY,MAAMvB,OAAAA,KAAWqB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBV,gBACEY,MAAMC,QAAQ1B,OAAAA,IACZa,IAAIb,OAAO,CAACgB,YACVhB,QAAO2B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOP,UAAUQ,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKN,WAAWW,KAAAA;UAChD,CAAA,CAAA,IAEFf,IAAIb,OAAO,CAACgB,YAAYA,UAAUQ,QAAAA,MAAcxB,OAAAA;QACtD;MACF;AACA,YAAM6B,cAActB,SAASM,IAAIE;AACjC,YAAMe,eAAetB,UAAU;AAC/B,aAAOA,WAAWuB,UACb,YAAA;AACC,cAAMC,WAAW,MAAMC,sCAAeC,UAAUrB,GAAAA;AAChD,YAAIJ,MAAM;AAER,iBAAOuB,SAASjB,SAAS,KAAKiB,SAAS,CAAA,EAAG,CAAA,MAAOvB,MAAM;AACrDuB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASjB,SAAS,KAAKiB,SAAS,CAAA,EAAG,CAAA,MAAOvB,MAAM;AAClDuB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACpB,OAAAA,MAAaA,OAAAA,EAASqB,MAAMP,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAhB,IAAIwB,MAAMP,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIS,MAAM,kCAAA;IAClB;EACF;AACF;","names":["MemoryPayloadDiviner","PayloadDiviner","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","props","removeFields","all","reverse","length","payload","includes","schema","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","parsedLimit","parsedOffset","undefined","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts","../../src/hasTimestamp.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner.js'\n","/* eslint-disable complexity */\nimport { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.js'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\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 PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', timestamp, ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (timestamp !== undefined) {\n // If there was no order supplied with the original\n if (filter.order === undefined) {\n // filter for timestamp equality\n all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp)\n } else {\n // filter for greater than/less than or equal to\n all =\n order === 'asc' ?\n all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp)\n : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp)\n }\n }\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 TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n","import { AnyObject } from '@xylabs/object'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport const hasTimestamp = <T extends Payload = Payload<AnyObject>>(payload: T): payload is T & { timestamp: number } => {\n return (payload as unknown as { timestamp: number }).timestamp !== undefined\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACCA,oBAAyB;AACzB,oBAA6B;AAE7B,sCAA+B;AAC/B,mCAKO;AACP,6BAA+B;;;ACRxB,IAAMA,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADarB,IAAMC,uBAAN,cASGC,+CAAAA;EAzBV,OAyBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAyBE,cAAcC,UAA6C;AAClF,UAAMC,aAASC,wBAASF,UAAUC,OAAOE,yDAAAA,GAA+BC,IAAAA,GAAO,MAAM,uBAAA;AACrF,QAAI,CAACH,OAAQ,QAAO,CAAA;AACpB,UAAMI,gBAAYH,wBAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQC,WAAW,GAAGC,MAAAA,QAAUC,4BAAab,QAAyB;MAAC;MAAU;MAAS;KAAQ;AAChJ,QAAIc,MAAO,MAAMV,UAAUU,MAAG;AAC9B,QAAIA,KAAK;AACP,UAAIJ,UAAU,OAAQI,OAAMA,IAAIC,QAAO;AACvC,UAAIT,SAASU,OAAQF,OAAMA,IAAId,OAAO,CAACiB,YAAYX,QAAQY,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIR,cAAcS,QAAW;AAE3B,YAAIpB,OAAOU,UAAUU,QAAW;AAE9BN,gBAAMA,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,cAAcA,SAAAA;QAC3E,OAAO;AAELG,gBACEJ,UAAU,QACRI,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,aAAaA,SAAAA,IAClEG,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,aAAaA,SAAAA;QACxE;MACF;AACA,UAAIW,OAAOC,KAAKX,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMQ,2BAA2BF,OAAOG,QAAQb,KAAAA;AAChD,mBAAW,CAACc,MAAM1B,OAAAA,KAAWwB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBZ,gBACEc,MAAMC,QAAQ7B,OAAAA,IACZc,IAAId,OAAO,CAACiB,YACVjB,QAAO8B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOT,UAAUU,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKR,WAAWa,KAAAA;UAChD,CAAA,CAAA,IAEFjB,IAAId,OAAO,CAACiB,YAAYA,UAAUU,QAAAA,MAAc3B,OAAAA;QACtD;MACF;AACA,YAAMgC,cAAczB,SAASO,IAAIE;AACjC,YAAMiB,eAAezB,UAAU;AAC/B,aAAOA,WAAWY,UACb,YAAA;AACC,cAAMc,WAAW,MAAMC,sCAAeC,UAAUtB,GAAAA;AAChD,YAAIL,MAAM;AAER,iBAAOyB,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOzB,MAAM;AACrDyB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOzB,MAAM;AAClDyB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACrB,OAAAA,MAAaA,OAAAA,EAASsB,MAAMN,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAlB,IAAIyB,MAAMN,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIQ,MAAM,kCAAA;IAClB;EACF;AACF;","names":["hasTimestamp","payload","timestamp","undefined","MemoryPayloadDiviner","PayloadDiviner","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","timestamp","props","removeFields","all","reverse","length","payload","includes","schema","undefined","hasTimestamp","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","parsedLimit","parsedOffset","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
@@ -7,6 +7,13 @@ import { removeFields } from "@xylabs/object";
7
7
  import { PayloadDiviner } from "@xyo-network/diviner-payload-abstract";
8
8
  import { isPayloadDivinerQueryPayload, PayloadDivinerConfigSchema } from "@xyo-network/diviner-payload-model";
9
9
  import { PayloadBuilder } from "@xyo-network/payload-builder";
10
+
11
+ // src/hasTimestamp.ts
12
+ var hasTimestamp = /* @__PURE__ */ __name((payload) => {
13
+ return payload.timestamp !== void 0;
14
+ }, "hasTimestamp");
15
+
16
+ // src/MemoryPayloadDiviner.ts
10
17
  var MemoryPayloadDiviner = class extends PayloadDiviner {
11
18
  static {
12
19
  __name(this, "MemoryPayloadDiviner");
@@ -20,7 +27,7 @@ var MemoryPayloadDiviner = class extends PayloadDiviner {
20
27
  const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => "Missing query payload");
21
28
  if (!filter) return [];
22
29
  const archivist = assertEx(await this.archivistInstance(), () => "Unable to resolve archivist");
23
- const { schemas, limit, offset, hash, order = "desc", ...props } = removeFields(filter, [
30
+ const { schemas, limit, offset, hash, order = "desc", timestamp, ...props } = removeFields(filter, [
24
31
  "schema",
25
32
  "$meta",
26
33
  "$hash"
@@ -29,6 +36,13 @@ var MemoryPayloadDiviner = class extends PayloadDiviner {
29
36
  if (all) {
30
37
  if (order === "desc") all = all.reverse();
31
38
  if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema));
39
+ if (timestamp !== void 0) {
40
+ if (filter.order === void 0) {
41
+ all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp);
42
+ } else {
43
+ all = order === "asc" ? all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp) : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp);
44
+ }
45
+ }
32
46
  if (Object.keys(props).length > 0) {
33
47
  const additionalFilterCriteria = Object.entries(props);
34
48
  for (const [prop, filter2] of additionalFilterCriteria) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\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 PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\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 TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,oBAAoB;AAE7B,SAASC,sBAAsB;AAC/B,SACEC,8BACAC,kCAGK;AACP,SAASC,sBAAsB;AAGxB,IAAMC,uBAAN,cASGC,eAAAA;EAtBV,OAsBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAyBE,cAAcC,UAA6C;AAClF,UAAMC,SAASC,SAASF,UAAUC,OAAOE,4BAAAA,GAA+BC,IAAAA,GAAO,MAAM,uBAAA;AACrF,QAAI,CAACH,OAAQ,QAAO,CAAA;AACpB,UAAMI,YAAYH,SAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQ,GAAGC,MAAAA,IAAUC,aAAaZ,QAAyB;MAAC;MAAU;MAAS;KAAQ;AACrI,QAAIa,MAAO,MAAMT,UAAUS,MAAG;AAC9B,QAAIA,KAAK;AACP,UAAIH,UAAU,OAAQG,OAAMA,IAAIC,QAAO;AACvC,UAAIR,SAASS,OAAQF,OAAMA,IAAIb,OAAO,CAACgB,YAAYV,QAAQW,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIC,OAAOC,KAAKT,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMM,2BAA2BF,OAAOG,QAAQX,KAAAA;AAChD,mBAAW,CAACY,MAAMvB,OAAAA,KAAWqB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBV,gBACEY,MAAMC,QAAQ1B,OAAAA,IACZa,IAAIb,OAAO,CAACgB,YACVhB,QAAO2B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOP,UAAUQ,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKN,WAAWW,KAAAA;UAChD,CAAA,CAAA,IAEFf,IAAIb,OAAO,CAACgB,YAAYA,UAAUQ,QAAAA,MAAcxB,OAAAA;QACtD;MACF;AACA,YAAM6B,cAActB,SAASM,IAAIE;AACjC,YAAMe,eAAetB,UAAU;AAC/B,aAAOA,WAAWuB,UACb,YAAA;AACC,cAAMC,WAAW,MAAMC,eAAeC,UAAUrB,GAAAA;AAChD,YAAIJ,MAAM;AAER,iBAAOuB,SAASjB,SAAS,KAAKiB,SAAS,CAAA,EAAG,CAAA,MAAOvB,MAAM;AACrDuB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASjB,SAAS,KAAKiB,SAAS,CAAA,EAAG,CAAA,MAAOvB,MAAM;AAClDuB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACpB,OAAAA,MAAaA,OAAAA,EAASqB,MAAMP,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAhB,IAAIwB,MAAMP,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIS,MAAM,kCAAA;IAClB;EACF;AACF;","names":["assertEx","removeFields","PayloadDiviner","isPayloadDivinerQueryPayload","PayloadDivinerConfigSchema","PayloadBuilder","MemoryPayloadDiviner","PayloadDiviner","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","props","removeFields","all","reverse","length","payload","includes","schema","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","parsedLimit","parsedOffset","undefined","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
1
+ {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts","../../src/hasTimestamp.ts"],"sourcesContent":["/* eslint-disable complexity */\nimport { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.js'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\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 PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', timestamp, ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (timestamp !== undefined) {\n // If there was no order supplied with the original\n if (filter.order === undefined) {\n // filter for timestamp equality\n all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp)\n } else {\n // filter for greater than/less than or equal to\n all =\n order === 'asc' ?\n all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp)\n : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp)\n }\n }\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 TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n","import { AnyObject } from '@xylabs/object'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport const hasTimestamp = <T extends Payload = Payload<AnyObject>>(payload: T): payload is T & { timestamp: number } => {\n return (payload as unknown as { timestamp: number }).timestamp !== undefined\n}\n"],"mappings":";;;;AACA,SAASA,gBAAgB;AACzB,SAASC,oBAAoB;AAE7B,SAASC,sBAAsB;AAC/B,SACEC,8BACAC,kCAGK;AACP,SAASC,sBAAsB;;;ACRxB,IAAMC,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADarB,IAAMC,uBAAN,cASGC,eAAAA;EAzBV,OAyBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAyBE,cAAcC,UAA6C;AAClF,UAAMC,SAASC,SAASF,UAAUC,OAAOE,4BAAAA,GAA+BC,IAAAA,GAAO,MAAM,uBAAA;AACrF,QAAI,CAACH,OAAQ,QAAO,CAAA;AACpB,UAAMI,YAAYH,SAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQC,WAAW,GAAGC,MAAAA,IAAUC,aAAab,QAAyB;MAAC;MAAU;MAAS;KAAQ;AAChJ,QAAIc,MAAO,MAAMV,UAAUU,MAAG;AAC9B,QAAIA,KAAK;AACP,UAAIJ,UAAU,OAAQI,OAAMA,IAAIC,QAAO;AACvC,UAAIT,SAASU,OAAQF,OAAMA,IAAId,OAAO,CAACiB,YAAYX,QAAQY,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIR,cAAcS,QAAW;AAE3B,YAAIpB,OAAOU,UAAUU,QAAW;AAE9BN,gBAAMA,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,cAAcA,SAAAA;QAC3E,OAAO;AAELG,gBACEJ,UAAU,QACRI,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,aAAaA,SAAAA,IAClEG,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,aAAaA,SAAAA;QACxE;MACF;AACA,UAAIW,OAAOC,KAAKX,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMQ,2BAA2BF,OAAOG,QAAQb,KAAAA;AAChD,mBAAW,CAACc,MAAM1B,OAAAA,KAAWwB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBZ,gBACEc,MAAMC,QAAQ7B,OAAAA,IACZc,IAAId,OAAO,CAACiB,YACVjB,QAAO8B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOT,UAAUU,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKR,WAAWa,KAAAA;UAChD,CAAA,CAAA,IAEFjB,IAAId,OAAO,CAACiB,YAAYA,UAAUU,QAAAA,MAAc3B,OAAAA;QACtD;MACF;AACA,YAAMgC,cAAczB,SAASO,IAAIE;AACjC,YAAMiB,eAAezB,UAAU;AAC/B,aAAOA,WAAWY,UACb,YAAA;AACC,cAAMc,WAAW,MAAMC,eAAeC,UAAUtB,GAAAA;AAChD,YAAIL,MAAM;AAER,iBAAOyB,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOzB,MAAM;AACrDyB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOzB,MAAM;AAClDyB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACrB,OAAAA,MAAaA,OAAAA,EAASsB,MAAMN,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAlB,IAAIyB,MAAMN,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIQ,MAAM,kCAAA;IAClB;EACF;AACF;","names":["assertEx","removeFields","PayloadDiviner","isPayloadDivinerQueryPayload","PayloadDivinerConfigSchema","PayloadBuilder","hasTimestamp","payload","timestamp","undefined","MemoryPayloadDiviner","PayloadDiviner","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","timestamp","props","removeFields","all","reverse","length","payload","includes","schema","undefined","hasTimestamp","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","parsedLimit","parsedOffset","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAItE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA4DpF"}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAItE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA4DpF"}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAItE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA4DpF"}
@@ -0,0 +1,8 @@
1
+ import { AnyObject } from '@xylabs/object';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export declare const hasTimestamp: <T extends Payload = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & AnyObject & {
4
+ schema: import("@xyo-network/payload-model").Schema;
5
+ }>(payload: T) => payload is T & {
6
+ timestamp: number;
7
+ };
8
+ //# sourceMappingURL=hasTimestamp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hasTimestamp.d.ts","sourceRoot":"","sources":["../../src/hasTimestamp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,OAAO;;YAAgC,CAAC,KAAG,OAAO,IAAI,CAAC,GAAG;IAAE,SAAS,EAAE,MAAM,CAAA;CAEnH,CAAA"}
@@ -0,0 +1,8 @@
1
+ import { AnyObject } from '@xylabs/object';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export declare const hasTimestamp: <T extends Payload = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & AnyObject & {
4
+ schema: import("@xyo-network/payload-model").Schema;
5
+ }>(payload: T) => payload is T & {
6
+ timestamp: number;
7
+ };
8
+ //# sourceMappingURL=hasTimestamp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hasTimestamp.d.ts","sourceRoot":"","sources":["../../src/hasTimestamp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,OAAO;;YAAgC,CAAC,KAAG,OAAO,IAAI,CAAC,GAAG;IAAE,SAAS,EAAE,MAAM,CAAA;CAEnH,CAAA"}
@@ -0,0 +1,8 @@
1
+ import { AnyObject } from '@xylabs/object';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export declare const hasTimestamp: <T extends Payload = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & AnyObject & {
4
+ schema: import("@xyo-network/payload-model").Schema;
5
+ }>(payload: T) => payload is T & {
6
+ timestamp: number;
7
+ };
8
+ //# sourceMappingURL=hasTimestamp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hasTimestamp.d.ts","sourceRoot":"","sources":["../../src/hasTimestamp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,OAAO;;YAAgC,CAAC,KAAG,OAAO,IAAI,CAAC,GAAG;IAAE,SAAS,EAAE,MAAM,CAAA;CAEnH,CAAA"}
@@ -31,6 +31,13 @@ var import_object = require("@xylabs/object");
31
31
  var import_diviner_payload_abstract = require("@xyo-network/diviner-payload-abstract");
32
32
  var import_diviner_payload_model = require("@xyo-network/diviner-payload-model");
33
33
  var import_payload_builder = require("@xyo-network/payload-builder");
34
+
35
+ // src/hasTimestamp.ts
36
+ var hasTimestamp = /* @__PURE__ */ __name((payload) => {
37
+ return payload.timestamp !== void 0;
38
+ }, "hasTimestamp");
39
+
40
+ // src/MemoryPayloadDiviner.ts
34
41
  var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.PayloadDiviner {
35
42
  static {
36
43
  __name(this, "MemoryPayloadDiviner");
@@ -44,7 +51,7 @@ var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.Payload
44
51
  const filter = (0, import_assert.assertEx)(payloads?.filter(import_diviner_payload_model.isPayloadDivinerQueryPayload)?.pop(), () => "Missing query payload");
45
52
  if (!filter) return [];
46
53
  const archivist = (0, import_assert.assertEx)(await this.archivistInstance(), () => "Unable to resolve archivist");
47
- const { schemas, limit, offset, hash, order = "desc", ...props } = (0, import_object.removeFields)(filter, [
54
+ const { schemas, limit, offset, hash, order = "desc", timestamp, ...props } = (0, import_object.removeFields)(filter, [
48
55
  "schema",
49
56
  "$meta",
50
57
  "$hash"
@@ -53,6 +60,13 @@ var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.Payload
53
60
  if (all) {
54
61
  if (order === "desc") all = all.reverse();
55
62
  if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema));
63
+ if (timestamp !== void 0) {
64
+ if (filter.order === void 0) {
65
+ all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp);
66
+ } else {
67
+ all = order === "asc" ? all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp) : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp);
68
+ }
69
+ }
56
70
  if (Object.keys(props).length > 0) {
57
71
  const additionalFilterCriteria = Object.entries(props);
58
72
  for (const [prop, filter2] of additionalFilterCriteria) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner.js'\n","import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\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 PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\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 TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,oBAA6B;AAE7B,sCAA+B;AAC/B,mCAKO;AACP,6BAA+B;AAGxB,IAAMA,uBAAN,cASGC,+CAAAA;EAtBV,OAsBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAyBE,cAAcC,UAA6C;AAClF,UAAMC,aAASC,wBAASF,UAAUC,OAAOE,yDAAAA,GAA+BC,IAAAA,GAAO,MAAM,uBAAA;AACrF,QAAI,CAACH,OAAQ,QAAO,CAAA;AACpB,UAAMI,gBAAYH,wBAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQ,GAAGC,MAAAA,QAAUC,4BAAaZ,QAAyB;MAAC;MAAU;MAAS;KAAQ;AACrI,QAAIa,MAAO,MAAMT,UAAUS,MAAG;AAC9B,QAAIA,KAAK;AACP,UAAIH,UAAU,OAAQG,OAAMA,IAAIC,QAAO;AACvC,UAAIR,SAASS,OAAQF,OAAMA,IAAIb,OAAO,CAACgB,YAAYV,QAAQW,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIC,OAAOC,KAAKT,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMM,2BAA2BF,OAAOG,QAAQX,KAAAA;AAChD,mBAAW,CAACY,MAAMvB,OAAAA,KAAWqB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBV,gBACEY,MAAMC,QAAQ1B,OAAAA,IACZa,IAAIb,OAAO,CAACgB,YACVhB,QAAO2B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOP,UAAUQ,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKN,WAAWW,KAAAA;UAChD,CAAA,CAAA,IAEFf,IAAIb,OAAO,CAACgB,YAAYA,UAAUQ,QAAAA,MAAcxB,OAAAA;QACtD;MACF;AACA,YAAM6B,cAActB,SAASM,IAAIE;AACjC,YAAMe,eAAetB,UAAU;AAC/B,aAAOA,WAAWuB,UACb,YAAA;AACC,cAAMC,WAAW,MAAMC,sCAAeC,UAAUrB,GAAAA;AAChD,YAAIJ,MAAM;AAER,iBAAOuB,SAASjB,SAAS,KAAKiB,SAAS,CAAA,EAAG,CAAA,MAAOvB,MAAM;AACrDuB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASjB,SAAS,KAAKiB,SAAS,CAAA,EAAG,CAAA,MAAOvB,MAAM;AAClDuB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACpB,OAAAA,MAAaA,OAAAA,EAASqB,MAAMP,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAhB,IAAIwB,MAAMP,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIS,MAAM,kCAAA;IAClB;EACF;AACF;","names":["MemoryPayloadDiviner","PayloadDiviner","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","props","removeFields","all","reverse","length","payload","includes","schema","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","parsedLimit","parsedOffset","undefined","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts","../../src/hasTimestamp.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner.js'\n","/* eslint-disable complexity */\nimport { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.js'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\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 PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', timestamp, ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (timestamp !== undefined) {\n // If there was no order supplied with the original\n if (filter.order === undefined) {\n // filter for timestamp equality\n all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp)\n } else {\n // filter for greater than/less than or equal to\n all =\n order === 'asc' ?\n all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp)\n : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp)\n }\n }\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 TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n","import { AnyObject } from '@xylabs/object'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport const hasTimestamp = <T extends Payload = Payload<AnyObject>>(payload: T): payload is T & { timestamp: number } => {\n return (payload as unknown as { timestamp: number }).timestamp !== undefined\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACCA,oBAAyB;AACzB,oBAA6B;AAE7B,sCAA+B;AAC/B,mCAKO;AACP,6BAA+B;;;ACRxB,IAAMA,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADarB,IAAMC,uBAAN,cASGC,+CAAAA;EAzBV,OAyBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAyBE,cAAcC,UAA6C;AAClF,UAAMC,aAASC,wBAASF,UAAUC,OAAOE,yDAAAA,GAA+BC,IAAAA,GAAO,MAAM,uBAAA;AACrF,QAAI,CAACH,OAAQ,QAAO,CAAA;AACpB,UAAMI,gBAAYH,wBAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQC,WAAW,GAAGC,MAAAA,QAAUC,4BAAab,QAAyB;MAAC;MAAU;MAAS;KAAQ;AAChJ,QAAIc,MAAO,MAAMV,UAAUU,MAAG;AAC9B,QAAIA,KAAK;AACP,UAAIJ,UAAU,OAAQI,OAAMA,IAAIC,QAAO;AACvC,UAAIT,SAASU,OAAQF,OAAMA,IAAId,OAAO,CAACiB,YAAYX,QAAQY,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIR,cAAcS,QAAW;AAE3B,YAAIpB,OAAOU,UAAUU,QAAW;AAE9BN,gBAAMA,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,cAAcA,SAAAA;QAC3E,OAAO;AAELG,gBACEJ,UAAU,QACRI,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,aAAaA,SAAAA,IAClEG,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,aAAaA,SAAAA;QACxE;MACF;AACA,UAAIW,OAAOC,KAAKX,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMQ,2BAA2BF,OAAOG,QAAQb,KAAAA;AAChD,mBAAW,CAACc,MAAM1B,OAAAA,KAAWwB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBZ,gBACEc,MAAMC,QAAQ7B,OAAAA,IACZc,IAAId,OAAO,CAACiB,YACVjB,QAAO8B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOT,UAAUU,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKR,WAAWa,KAAAA;UAChD,CAAA,CAAA,IAEFjB,IAAId,OAAO,CAACiB,YAAYA,UAAUU,QAAAA,MAAc3B,OAAAA;QACtD;MACF;AACA,YAAMgC,cAAczB,SAASO,IAAIE;AACjC,YAAMiB,eAAezB,UAAU;AAC/B,aAAOA,WAAWY,UACb,YAAA;AACC,cAAMc,WAAW,MAAMC,sCAAeC,UAAUtB,GAAAA;AAChD,YAAIL,MAAM;AAER,iBAAOyB,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOzB,MAAM;AACrDyB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOzB,MAAM;AAClDyB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACrB,OAAAA,MAAaA,OAAAA,EAASsB,MAAMN,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAlB,IAAIyB,MAAMN,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIQ,MAAM,kCAAA;IAClB;EACF;AACF;","names":["hasTimestamp","payload","timestamp","undefined","MemoryPayloadDiviner","PayloadDiviner","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","timestamp","props","removeFields","all","reverse","length","payload","includes","schema","undefined","hasTimestamp","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","parsedLimit","parsedOffset","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
@@ -7,6 +7,13 @@ import { removeFields } from "@xylabs/object";
7
7
  import { PayloadDiviner } from "@xyo-network/diviner-payload-abstract";
8
8
  import { isPayloadDivinerQueryPayload, PayloadDivinerConfigSchema } from "@xyo-network/diviner-payload-model";
9
9
  import { PayloadBuilder } from "@xyo-network/payload-builder";
10
+
11
+ // src/hasTimestamp.ts
12
+ var hasTimestamp = /* @__PURE__ */ __name((payload) => {
13
+ return payload.timestamp !== void 0;
14
+ }, "hasTimestamp");
15
+
16
+ // src/MemoryPayloadDiviner.ts
10
17
  var MemoryPayloadDiviner = class extends PayloadDiviner {
11
18
  static {
12
19
  __name(this, "MemoryPayloadDiviner");
@@ -20,7 +27,7 @@ var MemoryPayloadDiviner = class extends PayloadDiviner {
20
27
  const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => "Missing query payload");
21
28
  if (!filter) return [];
22
29
  const archivist = assertEx(await this.archivistInstance(), () => "Unable to resolve archivist");
23
- const { schemas, limit, offset, hash, order = "desc", ...props } = removeFields(filter, [
30
+ const { schemas, limit, offset, hash, order = "desc", timestamp, ...props } = removeFields(filter, [
24
31
  "schema",
25
32
  "$meta",
26
33
  "$hash"
@@ -29,6 +36,13 @@ var MemoryPayloadDiviner = class extends PayloadDiviner {
29
36
  if (all) {
30
37
  if (order === "desc") all = all.reverse();
31
38
  if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema));
39
+ if (timestamp !== void 0) {
40
+ if (filter.order === void 0) {
41
+ all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp);
42
+ } else {
43
+ all = order === "asc" ? all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp) : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp);
44
+ }
45
+ }
32
46
  if (Object.keys(props).length > 0) {
33
47
  const additionalFilterCriteria = Object.entries(props);
34
48
  for (const [prop, filter2] of additionalFilterCriteria) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\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 PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\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 TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,oBAAoB;AAE7B,SAASC,sBAAsB;AAC/B,SACEC,8BACAC,kCAGK;AACP,SAASC,sBAAsB;AAGxB,IAAMC,uBAAN,cASGC,eAAAA;EAtBV,OAsBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAyBE,cAAcC,UAA6C;AAClF,UAAMC,SAASC,SAASF,UAAUC,OAAOE,4BAAAA,GAA+BC,IAAAA,GAAO,MAAM,uBAAA;AACrF,QAAI,CAACH,OAAQ,QAAO,CAAA;AACpB,UAAMI,YAAYH,SAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQ,GAAGC,MAAAA,IAAUC,aAAaZ,QAAyB;MAAC;MAAU;MAAS;KAAQ;AACrI,QAAIa,MAAO,MAAMT,UAAUS,MAAG;AAC9B,QAAIA,KAAK;AACP,UAAIH,UAAU,OAAQG,OAAMA,IAAIC,QAAO;AACvC,UAAIR,SAASS,OAAQF,OAAMA,IAAIb,OAAO,CAACgB,YAAYV,QAAQW,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIC,OAAOC,KAAKT,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMM,2BAA2BF,OAAOG,QAAQX,KAAAA;AAChD,mBAAW,CAACY,MAAMvB,OAAAA,KAAWqB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBV,gBACEY,MAAMC,QAAQ1B,OAAAA,IACZa,IAAIb,OAAO,CAACgB,YACVhB,QAAO2B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOP,UAAUQ,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKN,WAAWW,KAAAA;UAChD,CAAA,CAAA,IAEFf,IAAIb,OAAO,CAACgB,YAAYA,UAAUQ,QAAAA,MAAcxB,OAAAA;QACtD;MACF;AACA,YAAM6B,cAActB,SAASM,IAAIE;AACjC,YAAMe,eAAetB,UAAU;AAC/B,aAAOA,WAAWuB,UACb,YAAA;AACC,cAAMC,WAAW,MAAMC,eAAeC,UAAUrB,GAAAA;AAChD,YAAIJ,MAAM;AAER,iBAAOuB,SAASjB,SAAS,KAAKiB,SAAS,CAAA,EAAG,CAAA,MAAOvB,MAAM;AACrDuB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASjB,SAAS,KAAKiB,SAAS,CAAA,EAAG,CAAA,MAAOvB,MAAM;AAClDuB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACpB,OAAAA,MAAaA,OAAAA,EAASqB,MAAMP,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAhB,IAAIwB,MAAMP,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIS,MAAM,kCAAA;IAClB;EACF;AACF;","names":["assertEx","removeFields","PayloadDiviner","isPayloadDivinerQueryPayload","PayloadDivinerConfigSchema","PayloadBuilder","MemoryPayloadDiviner","PayloadDiviner","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","props","removeFields","all","reverse","length","payload","includes","schema","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","parsedLimit","parsedOffset","undefined","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
1
+ {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts","../../src/hasTimestamp.ts"],"sourcesContent":["/* eslint-disable complexity */\nimport { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.js'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\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 PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', timestamp, ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (timestamp !== undefined) {\n // If there was no order supplied with the original\n if (filter.order === undefined) {\n // filter for timestamp equality\n all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp)\n } else {\n // filter for greater than/less than or equal to\n all =\n order === 'asc' ?\n all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp)\n : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp)\n }\n }\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 TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n","import { AnyObject } from '@xylabs/object'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport const hasTimestamp = <T extends Payload = Payload<AnyObject>>(payload: T): payload is T & { timestamp: number } => {\n return (payload as unknown as { timestamp: number }).timestamp !== undefined\n}\n"],"mappings":";;;;AACA,SAASA,gBAAgB;AACzB,SAASC,oBAAoB;AAE7B,SAASC,sBAAsB;AAC/B,SACEC,8BACAC,kCAGK;AACP,SAASC,sBAAsB;;;ACRxB,IAAMC,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADarB,IAAMC,uBAAN,cASGC,eAAAA;EAzBV,OAyBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAyBE,cAAcC,UAA6C;AAClF,UAAMC,SAASC,SAASF,UAAUC,OAAOE,4BAAAA,GAA+BC,IAAAA,GAAO,MAAM,uBAAA;AACrF,QAAI,CAACH,OAAQ,QAAO,CAAA;AACpB,UAAMI,YAAYH,SAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQC,WAAW,GAAGC,MAAAA,IAAUC,aAAab,QAAyB;MAAC;MAAU;MAAS;KAAQ;AAChJ,QAAIc,MAAO,MAAMV,UAAUU,MAAG;AAC9B,QAAIA,KAAK;AACP,UAAIJ,UAAU,OAAQI,OAAMA,IAAIC,QAAO;AACvC,UAAIT,SAASU,OAAQF,OAAMA,IAAId,OAAO,CAACiB,YAAYX,QAAQY,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIR,cAAcS,QAAW;AAE3B,YAAIpB,OAAOU,UAAUU,QAAW;AAE9BN,gBAAMA,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,cAAcA,SAAAA;QAC3E,OAAO;AAELG,gBACEJ,UAAU,QACRI,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,aAAaA,SAAAA,IAClEG,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,aAAaA,SAAAA;QACxE;MACF;AACA,UAAIW,OAAOC,KAAKX,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMQ,2BAA2BF,OAAOG,QAAQb,KAAAA;AAChD,mBAAW,CAACc,MAAM1B,OAAAA,KAAWwB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBZ,gBACEc,MAAMC,QAAQ7B,OAAAA,IACZc,IAAId,OAAO,CAACiB,YACVjB,QAAO8B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOT,UAAUU,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKR,WAAWa,KAAAA;UAChD,CAAA,CAAA,IAEFjB,IAAId,OAAO,CAACiB,YAAYA,UAAUU,QAAAA,MAAc3B,OAAAA;QACtD;MACF;AACA,YAAMgC,cAAczB,SAASO,IAAIE;AACjC,YAAMiB,eAAezB,UAAU;AAC/B,aAAOA,WAAWY,UACb,YAAA;AACC,cAAMc,WAAW,MAAMC,eAAeC,UAAUtB,GAAAA;AAChD,YAAIL,MAAM;AAER,iBAAOyB,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOzB,MAAM;AACrDyB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOzB,MAAM;AAClDyB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACrB,OAAAA,MAAaA,OAAAA,EAASsB,MAAMN,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAlB,IAAIyB,MAAMN,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIQ,MAAM,kCAAA;IAClB;EACF;AACF;","names":["assertEx","removeFields","PayloadDiviner","isPayloadDivinerQueryPayload","PayloadDivinerConfigSchema","PayloadBuilder","hasTimestamp","payload","timestamp","undefined","MemoryPayloadDiviner","PayloadDiviner","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","timestamp","props","removeFields","all","reverse","length","payload","includes","schema","undefined","hasTimestamp","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","parsedLimit","parsedOffset","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAItE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA4DpF"}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAItE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA4DpF"}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAItE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA4DpF"}
@@ -0,0 +1,8 @@
1
+ import { AnyObject } from '@xylabs/object';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export declare const hasTimestamp: <T extends Payload = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & AnyObject & {
4
+ schema: import("@xyo-network/payload-model").Schema;
5
+ }>(payload: T) => payload is T & {
6
+ timestamp: number;
7
+ };
8
+ //# sourceMappingURL=hasTimestamp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hasTimestamp.d.ts","sourceRoot":"","sources":["../../src/hasTimestamp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,OAAO;;YAAgC,CAAC,KAAG,OAAO,IAAI,CAAC,GAAG;IAAE,SAAS,EAAE,MAAM,CAAA;CAEnH,CAAA"}
@@ -0,0 +1,8 @@
1
+ import { AnyObject } from '@xylabs/object';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export declare const hasTimestamp: <T extends Payload = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & AnyObject & {
4
+ schema: import("@xyo-network/payload-model").Schema;
5
+ }>(payload: T) => payload is T & {
6
+ timestamp: number;
7
+ };
8
+ //# sourceMappingURL=hasTimestamp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hasTimestamp.d.ts","sourceRoot":"","sources":["../../src/hasTimestamp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,OAAO;;YAAgC,CAAC,KAAG,OAAO,IAAI,CAAC,GAAG;IAAE,SAAS,EAAE,MAAM,CAAA;CAEnH,CAAA"}
@@ -0,0 +1,8 @@
1
+ import { AnyObject } from '@xylabs/object';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export declare const hasTimestamp: <T extends Payload = import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & AnyObject & {
4
+ schema: import("@xyo-network/payload-model").Schema;
5
+ }>(payload: T) => payload is T & {
6
+ timestamp: number;
7
+ };
8
+ //# sourceMappingURL=hasTimestamp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hasTimestamp.d.ts","sourceRoot":"","sources":["../../src/hasTimestamp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,OAAO;;YAAgC,CAAC,KAAG,OAAO,IAAI,CAAC,GAAG;IAAE,SAAS,EAAE,MAAM,CAAA;CAEnH,CAAA"}
@@ -36,13 +36,20 @@ var import_object = require("@xylabs/object");
36
36
  var import_diviner_payload_abstract = require("@xyo-network/diviner-payload-abstract");
37
37
  var import_diviner_payload_model = require("@xyo-network/diviner-payload-model");
38
38
  var import_payload_builder = require("@xyo-network/payload-builder");
39
+
40
+ // src/hasTimestamp.ts
41
+ var hasTimestamp = /* @__PURE__ */ __name((payload) => {
42
+ return payload.timestamp !== void 0;
43
+ }, "hasTimestamp");
44
+
45
+ // src/MemoryPayloadDiviner.ts
39
46
  var _MemoryPayloadDiviner = class _MemoryPayloadDiviner extends import_diviner_payload_abstract.PayloadDiviner {
40
47
  async divineHandler(payloads) {
41
48
  var _a, _b;
42
49
  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");
43
50
  if (!filter) return [];
44
51
  const archivist = (0, import_assert.assertEx)(await this.archivistInstance(), () => "Unable to resolve archivist");
45
- const { schemas, limit, offset, hash, order = "desc", ...props } = (0, import_object.removeFields)(filter, [
52
+ const { schemas, limit, offset, hash, order = "desc", timestamp, ...props } = (0, import_object.removeFields)(filter, [
46
53
  "schema",
47
54
  "$meta",
48
55
  "$hash"
@@ -51,6 +58,13 @@ var _MemoryPayloadDiviner = class _MemoryPayloadDiviner extends import_diviner_p
51
58
  if (all) {
52
59
  if (order === "desc") all = all.reverse();
53
60
  if (schemas == null ? void 0 : schemas.length) all = all.filter((payload) => schemas.includes(payload.schema));
61
+ if (timestamp !== void 0) {
62
+ if (filter.order === void 0) {
63
+ all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp);
64
+ } else {
65
+ all = order === "asc" ? all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp) : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp);
66
+ }
67
+ }
54
68
  if (Object.keys(props).length > 0) {
55
69
  const additionalFilterCriteria = Object.entries(props);
56
70
  for (const [prop, filter2] of additionalFilterCriteria) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner.js'\n","import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\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 PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\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 TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,oBAA6B;AAE7B,sCAA+B;AAC/B,mCAKO;AACP,6BAA+B;AAGxB,IAAMA,wBAAN,MAAMA,8BASHC,+CAAAA;EAIR,MAAyBC,cAAcC,UAA6C;AA1BtF;AA2BI,UAAMC,aAASC,yBAASF,0CAAUC,OAAOE,+DAAjBH,mBAAgDI,OAAO,MAAM,uBAAA;AACrF,QAAI,CAACH,OAAQ,QAAO,CAAA;AACpB,UAAMI,gBAAYH,wBAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQ,GAAGC,MAAAA,QAAUC,4BAAaZ,QAAyB;MAAC;MAAU;MAAS;KAAQ;AACrI,QAAIa,MAAO,QAAMT,eAAUS,QAAVT;AACjB,QAAIS,KAAK;AACP,UAAIH,UAAU,OAAQG,OAAMA,IAAIC,QAAO;AACvC,UAAIR,mCAASS,OAAQF,OAAMA,IAAIb,OAAO,CAACgB,YAAYV,QAAQW,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIC,OAAOC,KAAKT,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMM,2BAA2BF,OAAOG,QAAQX,KAAAA;AAChD,mBAAW,CAACY,MAAMvB,OAAAA,KAAWqB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBV,gBACEY,MAAMC,QAAQ1B,OAAAA,IACZa,IAAIb,OAAO,CAACgB,YACVhB,QAAO2B,MAAM,CAACC,UAAAA;AA1C9B,gBAAAC;AA2CkB,kBAAMN,QAAOP,mCAAUQ;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,OAASA,MAAAA,MAAKN,aAALM,gBAAAA,IAAAA,KAAAA,OAAgBK;UAChD,CAAA,CAAA,IAEFf,IAAIb,OAAO,CAACgB,aAAYA,mCAAUQ,eAAcxB,OAAAA;QACtD;MACF;AACA,YAAM8B,cAAcvB,SAASM,IAAIE;AACjC,YAAMgB,eAAevB,UAAU;AAC/B,aAAOA,WAAWwB,UACb,YAAA;AACC,cAAMC,WAAW,MAAMC,sCAAeC,UAAUtB,GAAAA;AAChD,YAAIJ,MAAM;AAER,iBAAOwB,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOxB,MAAM;AACrDwB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOxB,MAAM;AAClDwB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACrB,OAAAA,MAAaA,OAAAA,EAASsB,MAAMP,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAjB,IAAIyB,MAAMP,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIS,MAAM,kCAAA;IAClB;EACF;AACF;AAnDU1C;AACR,cAVWD,uBAUc4C,iBAA0B;KAAI,yDAAMA;EAAeC;;AAC5E,cAXW7C,uBAWc8C,uBAA8BD;AAXlD,IAAM7C,uBAAN;","names":["MemoryPayloadDiviner","PayloadDiviner","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","props","removeFields","all","reverse","length","payload","includes","schema","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","_a","parsedLimit","parsedOffset","undefined","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts","../../src/hasTimestamp.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner.js'\n","/* eslint-disable complexity */\nimport { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.js'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\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 PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', timestamp, ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (timestamp !== undefined) {\n // If there was no order supplied with the original\n if (filter.order === undefined) {\n // filter for timestamp equality\n all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp)\n } else {\n // filter for greater than/less than or equal to\n all =\n order === 'asc' ?\n all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp)\n : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp)\n }\n }\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 TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n","import { AnyObject } from '@xylabs/object'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport const hasTimestamp = <T extends Payload = Payload<AnyObject>>(payload: T): payload is T & { timestamp: number } => {\n return (payload as unknown as { timestamp: number }).timestamp !== undefined\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACCA,oBAAyB;AACzB,oBAA6B;AAE7B,sCAA+B;AAC/B,mCAKO;AACP,6BAA+B;;;ACRxB,IAAMA,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADarB,IAAMC,wBAAN,MAAMA,8BASHC,+CAAAA;EAIR,MAAyBC,cAAcC,UAA6C;AA7BtF;AA8BI,UAAMC,aAASC,yBAASF,0CAAUC,OAAOE,+DAAjBH,mBAAgDI,OAAO,MAAM,uBAAA;AACrF,QAAI,CAACH,OAAQ,QAAO,CAAA;AACpB,UAAMI,gBAAYH,wBAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQC,WAAW,GAAGC,MAAAA,QAAUC,4BAAab,QAAyB;MAAC;MAAU;MAAS;KAAQ;AAChJ,QAAIc,MAAO,QAAMV,eAAUU,QAAVV;AACjB,QAAIU,KAAK;AACP,UAAIJ,UAAU,OAAQI,OAAMA,IAAIC,QAAO;AACvC,UAAIT,mCAASU,OAAQF,OAAMA,IAAId,OAAO,CAACiB,YAAYX,QAAQY,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIR,cAAcS,QAAW;AAE3B,YAAIpB,OAAOU,UAAUU,QAAW;AAE9BN,gBAAMA,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,cAAcA,SAAAA;QAC3E,OAAO;AAELG,gBACEJ,UAAU,QACRI,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,aAAaA,SAAAA,IAClEG,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,aAAaA,SAAAA;QACxE;MACF;AACA,UAAIW,OAAOC,KAAKX,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMQ,2BAA2BF,OAAOG,QAAQb,KAAAA;AAChD,mBAAW,CAACc,MAAM1B,OAAAA,KAAWwB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBZ,gBACEc,MAAMC,QAAQ7B,OAAAA,IACZc,IAAId,OAAO,CAACiB,YACVjB,QAAO8B,MAAM,CAACC,UAAAA;AA1D9B,gBAAAC;AA2DkB,kBAAMN,QAAOT,mCAAUU;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,OAASA,MAAAA,MAAKR,aAALQ,gBAAAA,IAAAA,KAAAA,OAAgBK;UAChD,CAAA,CAAA,IAEFjB,IAAId,OAAO,CAACiB,aAAYA,mCAAUU,eAAc3B,OAAAA;QACtD;MACF;AACA,YAAMiC,cAAc1B,SAASO,IAAIE;AACjC,YAAMkB,eAAe1B,UAAU;AAC/B,aAAOA,WAAWY,UACb,YAAA;AACC,cAAMe,WAAW,MAAMC,sCAAeC,UAAUvB,GAAAA;AAChD,YAAIL,MAAM;AAER,iBAAO0B,SAASnB,SAAS,KAAKmB,SAAS,CAAA,EAAG,CAAA,MAAO1B,MAAM;AACrD0B,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASnB,SAAS,KAAKmB,SAAS,CAAA,EAAG,CAAA,MAAO1B,MAAM;AAClD0B,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACtB,OAAAA,MAAaA,OAAAA,EAASuB,MAAMN,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAnB,IAAI0B,MAAMN,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIQ,MAAM,kCAAA;IAClB;EACF;AACF;AAhEU5C;AACR,cAVWD,uBAUc8C,iBAA0B;KAAI,yDAAMA;EAAeC;;AAC5E,cAXW/C,uBAWcgD,uBAA8BD;AAXlD,IAAM/C,uBAAN;","names":["hasTimestamp","payload","timestamp","undefined","MemoryPayloadDiviner","PayloadDiviner","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","timestamp","props","removeFields","all","reverse","length","payload","includes","schema","undefined","hasTimestamp","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","_a","parsedLimit","parsedOffset","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema"]}
@@ -12,13 +12,20 @@ import { removeFields } from "@xylabs/object";
12
12
  import { PayloadDiviner } from "@xyo-network/diviner-payload-abstract";
13
13
  import { isPayloadDivinerQueryPayload, PayloadDivinerConfigSchema } from "@xyo-network/diviner-payload-model";
14
14
  import { PayloadBuilder } from "@xyo-network/payload-builder";
15
+
16
+ // src/hasTimestamp.ts
17
+ var hasTimestamp = /* @__PURE__ */ __name((payload) => {
18
+ return payload.timestamp !== void 0;
19
+ }, "hasTimestamp");
20
+
21
+ // src/MemoryPayloadDiviner.ts
15
22
  var _MemoryPayloadDiviner = class _MemoryPayloadDiviner extends PayloadDiviner {
16
23
  async divineHandler(payloads) {
17
24
  var _a, _b;
18
25
  const filter = assertEx((_a = payloads == null ? void 0 : payloads.filter(isPayloadDivinerQueryPayload)) == null ? void 0 : _a.pop(), () => "Missing query payload");
19
26
  if (!filter) return [];
20
27
  const archivist = assertEx(await this.archivistInstance(), () => "Unable to resolve archivist");
21
- const { schemas, limit, offset, hash, order = "desc", ...props } = removeFields(filter, [
28
+ const { schemas, limit, offset, hash, order = "desc", timestamp, ...props } = removeFields(filter, [
22
29
  "schema",
23
30
  "$meta",
24
31
  "$hash"
@@ -27,6 +34,13 @@ var _MemoryPayloadDiviner = class _MemoryPayloadDiviner extends PayloadDiviner {
27
34
  if (all) {
28
35
  if (order === "desc") all = all.reverse();
29
36
  if (schemas == null ? void 0 : schemas.length) all = all.filter((payload) => schemas.includes(payload.schema));
37
+ if (timestamp !== void 0) {
38
+ if (filter.order === void 0) {
39
+ all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp);
40
+ } else {
41
+ all = order === "asc" ? all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp) : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp);
42
+ }
43
+ }
30
44
  if (Object.keys(props).length > 0) {
31
45
  const additionalFilterCriteria = Object.entries(props);
32
46
  for (const [prop, filter2] of additionalFilterCriteria) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\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 PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\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 TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,oBAAoB;AAE7B,SAASC,sBAAsB;AAC/B,SACEC,8BACAC,kCAGK;AACP,SAASC,sBAAsB;AAGxB,IAAMC,wBAAN,MAAMA,8BASHC,eAAAA;EAIR,MAAyBC,cAAcC,UAA6C;AA1BtF;AA2BI,UAAMC,SAASC,UAASF,0CAAUC,OAAOE,kCAAjBH,mBAAgDI,OAAO,MAAM,uBAAA;AACrF,QAAI,CAACH,OAAQ,QAAO,CAAA;AACpB,UAAMI,YAAYH,SAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQ,GAAGC,MAAAA,IAAUC,aAAaZ,QAAyB;MAAC;MAAU;MAAS;KAAQ;AACrI,QAAIa,MAAO,QAAMT,eAAUS,QAAVT;AACjB,QAAIS,KAAK;AACP,UAAIH,UAAU,OAAQG,OAAMA,IAAIC,QAAO;AACvC,UAAIR,mCAASS,OAAQF,OAAMA,IAAIb,OAAO,CAACgB,YAAYV,QAAQW,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIC,OAAOC,KAAKT,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMM,2BAA2BF,OAAOG,QAAQX,KAAAA;AAChD,mBAAW,CAACY,MAAMvB,OAAAA,KAAWqB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBV,gBACEY,MAAMC,QAAQ1B,OAAAA,IACZa,IAAIb,OAAO,CAACgB,YACVhB,QAAO2B,MAAM,CAACC,UAAAA;AA1C9B,gBAAAC;AA2CkB,kBAAMN,QAAOP,mCAAUQ;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,OAASA,MAAAA,MAAKN,aAALM,gBAAAA,IAAAA,KAAAA,OAAgBK;UAChD,CAAA,CAAA,IAEFf,IAAIb,OAAO,CAACgB,aAAYA,mCAAUQ,eAAcxB,OAAAA;QACtD;MACF;AACA,YAAM8B,cAAcvB,SAASM,IAAIE;AACjC,YAAMgB,eAAevB,UAAU;AAC/B,aAAOA,WAAWwB,UACb,YAAA;AACC,cAAMC,WAAW,MAAMC,eAAeC,UAAUtB,GAAAA;AAChD,YAAIJ,MAAM;AAER,iBAAOwB,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOxB,MAAM;AACrDwB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOxB,MAAM;AAClDwB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACrB,OAAAA,MAAaA,OAAAA,EAASsB,MAAMP,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAjB,IAAIyB,MAAMP,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIS,MAAM,kCAAA;IAClB;EACF;AACF;AAnDU1C;AACR,cAVWD,uBAUc4C,iBAA0B;KAAI,yDAAMA;EAAeC;;AAC5E,cAXW7C,uBAWc8C,uBAA8BD;AAXlD,IAAM7C,uBAAN;","names":["assertEx","removeFields","PayloadDiviner","isPayloadDivinerQueryPayload","PayloadDivinerConfigSchema","PayloadBuilder","MemoryPayloadDiviner","PayloadDiviner","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","props","removeFields","all","reverse","length","payload","includes","schema","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","_a","parsedLimit","parsedOffset","undefined","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema"]}
1
+ {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts","../../src/hasTimestamp.ts"],"sourcesContent":["/* eslint-disable complexity */\nimport { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.js'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\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 PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', timestamp, ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (timestamp !== undefined) {\n // If there was no order supplied with the original\n if (filter.order === undefined) {\n // filter for timestamp equality\n all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp)\n } else {\n // filter for greater than/less than or equal to\n all =\n order === 'asc' ?\n all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp)\n : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp)\n }\n }\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 TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n","import { AnyObject } from '@xylabs/object'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport const hasTimestamp = <T extends Payload = Payload<AnyObject>>(payload: T): payload is T & { timestamp: number } => {\n return (payload as unknown as { timestamp: number }).timestamp !== undefined\n}\n"],"mappings":";;;;;;;;;AACA,SAASA,gBAAgB;AACzB,SAASC,oBAAoB;AAE7B,SAASC,sBAAsB;AAC/B,SACEC,8BACAC,kCAGK;AACP,SAASC,sBAAsB;;;ACRxB,IAAMC,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADarB,IAAMC,wBAAN,MAAMA,8BASHC,eAAAA;EAIR,MAAyBC,cAAcC,UAA6C;AA7BtF;AA8BI,UAAMC,SAASC,UAASF,0CAAUC,OAAOE,kCAAjBH,mBAAgDI,OAAO,MAAM,uBAAA;AACrF,QAAI,CAACH,OAAQ,QAAO,CAAA;AACpB,UAAMI,YAAYH,SAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQC,WAAW,GAAGC,MAAAA,IAAUC,aAAab,QAAyB;MAAC;MAAU;MAAS;KAAQ;AAChJ,QAAIc,MAAO,QAAMV,eAAUU,QAAVV;AACjB,QAAIU,KAAK;AACP,UAAIJ,UAAU,OAAQI,OAAMA,IAAIC,QAAO;AACvC,UAAIT,mCAASU,OAAQF,OAAMA,IAAId,OAAO,CAACiB,YAAYX,QAAQY,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIR,cAAcS,QAAW;AAE3B,YAAIpB,OAAOU,UAAUU,QAAW;AAE9BN,gBAAMA,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,cAAcA,SAAAA;QAC3E,OAAO;AAELG,gBACEJ,UAAU,QACRI,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,aAAaA,SAAAA,IAClEG,IAAId,OAAOqB,YAAAA,EAAcrB,OAAO,CAACiB,YAAYA,QAAQN,aAAaA,SAAAA;QACxE;MACF;AACA,UAAIW,OAAOC,KAAKX,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMQ,2BAA2BF,OAAOG,QAAQb,KAAAA;AAChD,mBAAW,CAACc,MAAM1B,OAAAA,KAAWwB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBZ,gBACEc,MAAMC,QAAQ7B,OAAAA,IACZc,IAAId,OAAO,CAACiB,YACVjB,QAAO8B,MAAM,CAACC,UAAAA;AA1D9B,gBAAAC;AA2DkB,kBAAMN,QAAOT,mCAAUU;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,OAASA,MAAAA,MAAKR,aAALQ,gBAAAA,IAAAA,KAAAA,OAAgBK;UAChD,CAAA,CAAA,IAEFjB,IAAId,OAAO,CAACiB,aAAYA,mCAAUU,eAAc3B,OAAAA;QACtD;MACF;AACA,YAAMiC,cAAc1B,SAASO,IAAIE;AACjC,YAAMkB,eAAe1B,UAAU;AAC/B,aAAOA,WAAWY,UACb,YAAA;AACC,cAAMe,WAAW,MAAMC,eAAeC,UAAUvB,GAAAA;AAChD,YAAIL,MAAM;AAER,iBAAO0B,SAASnB,SAAS,KAAKmB,SAAS,CAAA,EAAG,CAAA,MAAO1B,MAAM;AACrD0B,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASnB,SAAS,KAAKmB,SAAS,CAAA,EAAG,CAAA,MAAO1B,MAAM;AAClD0B,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACtB,OAAAA,MAAaA,OAAAA,EAASuB,MAAMN,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAnB,IAAI0B,MAAMN,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIQ,MAAM,kCAAA;IAClB;EACF;AACF;AAhEU5C;AACR,cAVWD,uBAUc8C,iBAA0B;KAAI,yDAAMA;EAAeC;;AAC5E,cAXW/C,uBAWcgD,uBAA8BD;AAXlD,IAAM/C,uBAAN;","names":["assertEx","removeFields","PayloadDiviner","isPayloadDivinerQueryPayload","PayloadDivinerConfigSchema","PayloadBuilder","hasTimestamp","payload","timestamp","undefined","MemoryPayloadDiviner","PayloadDiviner","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","timestamp","props","removeFields","all","reverse","length","payload","includes","schema","undefined","hasTimestamp","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","_a","parsedLimit","parsedOffset","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema"]}
package/package.json CHANGED
@@ -12,18 +12,19 @@
12
12
  "dependencies": {
13
13
  "@xylabs/assert": "^3.6.5",
14
14
  "@xylabs/object": "^3.6.5",
15
- "@xyo-network/diviner-model": "^2.110.11",
16
- "@xyo-network/diviner-payload-abstract": "^2.110.11",
17
- "@xyo-network/diviner-payload-model": "^2.110.11",
18
- "@xyo-network/payload-builder": "^2.110.11",
19
- "@xyo-network/payload-model": "^2.110.11"
15
+ "@xyo-network/diviner-model": "^2.110.13",
16
+ "@xyo-network/diviner-payload-abstract": "^2.110.13",
17
+ "@xyo-network/diviner-payload-model": "^2.110.13",
18
+ "@xyo-network/payload-builder": "^2.110.13",
19
+ "@xyo-network/payload-model": "^2.110.13"
20
20
  },
21
21
  "devDependencies": {
22
- "@xylabs/ts-scripts-yarn3": "^3.13.3",
23
- "@xylabs/tsconfig": "^3.13.3",
24
- "@xyo-network/archivist-memory": "^2.110.11",
25
- "@xyo-network/node-memory": "^2.110.11",
26
- "@xyo-network/payload-builder": "^2.110.11",
22
+ "@xylabs/delay": "^3.6.5",
23
+ "@xylabs/ts-scripts-yarn3": "^3.13.9",
24
+ "@xylabs/tsconfig": "^3.13.9",
25
+ "@xyo-network/archivist-memory": "^2.110.13",
26
+ "@xyo-network/node-memory": "^2.110.13",
27
+ "@xyo-network/payload-builder": "^2.110.13",
27
28
  "typescript": "^5.5.4"
28
29
  },
29
30
  "description": "Primary SDK for using XYO Protocol 2.0",
@@ -65,6 +66,6 @@
65
66
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
66
67
  },
67
68
  "sideEffects": false,
68
- "version": "2.110.11",
69
+ "version": "2.110.13",
69
70
  "type": "module"
70
71
  }
@@ -1,3 +1,4 @@
1
+ /* eslint-disable complexity */
1
2
  import { assertEx } from '@xylabs/assert'
2
3
  import { removeFields } from '@xylabs/object'
3
4
  import { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'
@@ -11,6 +12,8 @@ import {
11
12
  import { PayloadBuilder } from '@xyo-network/payload-builder'
12
13
  import { Payload, Schema, WithMeta } from '@xyo-network/payload-model'
13
14
 
15
+ import { hasTimestamp } from './hasTimestamp.js'
16
+
14
17
  export class MemoryPayloadDiviner<
15
18
  TParams extends PayloadDivinerParams = PayloadDivinerParams,
16
19
  TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,
@@ -28,11 +31,24 @@ export class MemoryPayloadDiviner<
28
31
  const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')
29
32
  if (!filter) return []
30
33
  const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')
31
- const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])
34
+ const { schemas, limit, offset, hash, order = 'desc', timestamp, ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])
32
35
  let all = (await archivist.all?.()) as WithMeta<TOut>[]
33
36
  if (all) {
34
37
  if (order === 'desc') all = all.reverse()
35
38
  if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))
39
+ if (timestamp !== undefined) {
40
+ // If there was no order supplied with the original
41
+ if (filter.order === undefined) {
42
+ // filter for timestamp equality
43
+ all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp)
44
+ } else {
45
+ // filter for greater than/less than or equal to
46
+ all =
47
+ order === 'asc' ?
48
+ all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp)
49
+ : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp)
50
+ }
51
+ }
36
52
  if (Object.keys(props).length > 0) {
37
53
  const additionalFilterCriteria = Object.entries(props)
38
54
  for (const [prop, filter] of additionalFilterCriteria) {
@@ -0,0 +1,6 @@
1
+ import { AnyObject } from '@xylabs/object'
2
+ import { Payload } from '@xyo-network/payload-model'
3
+
4
+ export const hasTimestamp = <T extends Payload = Payload<AnyObject>>(payload: T): payload is T & { timestamp: number } => {
5
+ return (payload as unknown as { timestamp: number }).timestamp !== undefined
6
+ }