@xyo-network/diviner-payload-memory 2.84.5 → 2.84.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,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,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CACxI,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,OAAgB,aAAa,yCAA+B;cAEnC,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;CAiD1E"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,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,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CACxI,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,OAAgB,aAAa,yCAA+B;cAEnC,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;CA+C1E"}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,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,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CACxI,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,OAAgB,aAAa,yCAA+B;cAEnC,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;CAiD1E"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,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,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CACxI,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,OAAgB,aAAa,yCAA+B;cAEnC,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;CA+C1E"}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,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,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CACxI,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,OAAgB,aAAa,yCAA+B;cAEnC,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;CAiD1E"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,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,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CACxI,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,OAAgB,aAAa,yCAA+B;cAEnC,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;CA+C1E"}
@@ -47,21 +47,17 @@ var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.Payload
47
47
  const additionalFilterCriteria = Object.entries(props);
48
48
  for (const [prop, filter2] of additionalFilterCriteria) {
49
49
  const property = prop;
50
- if (Array.isArray(filter2)) {
51
- all = all.filter(
52
- (payload) => filter2.every((value) => {
53
- const prop2 = payload?.[property];
54
- return Array.isArray(prop2) && prop2.includes?.(value);
55
- })
56
- );
57
- } else {
58
- all = all.filter((payload) => payload?.[property] === filter2);
59
- }
50
+ all = Array.isArray(filter2) ? all.filter(
51
+ (payload) => filter2.every((value) => {
52
+ const prop2 = payload?.[property];
53
+ return Array.isArray(prop2) && prop2.includes?.(value);
54
+ })
55
+ ) : all.filter((payload) => payload?.[property] === filter2);
60
56
  }
61
57
  }
62
- const parsedLimit = limit || all.length;
58
+ const parsedLimit = limit ?? all.length;
63
59
  const parsedOffset = offset || 0;
64
- return offset !== void 0 ? all.slice(parsedOffset, parsedLimit) : (async () => {
60
+ return offset === void 0 ? (async () => {
65
61
  const allPairs = await Promise.all(all.map(async (payload) => [await import_hash.PayloadHasher.hashAsync(payload), payload]));
66
62
  if (hash) {
67
63
  while (allPairs.length > 0 && allPairs[0][0] !== hash) {
@@ -72,9 +68,9 @@ var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.Payload
72
68
  }
73
69
  }
74
70
  return allPairs.map(([, payload]) => payload);
75
- })();
71
+ })() : all.slice(parsedOffset, parsedLimit);
76
72
  } else {
77
- throw Error('Archivist does not support "all"');
73
+ throw new Error('Archivist does not support "all"');
78
74
  }
79
75
  }
80
76
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { DivinerModule, 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 { PayloadHasher } from '@xyo-network/hash'\nimport { Payload } 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<DivinerModule<TParams>, TIn, TOut> = DivinerModuleEventData<DivinerModule<TParams>, TIn, TOut>,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override configSchemas = [PayloadDivinerConfigSchema]\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.readArchivist(), 'Unable to resolve archivist')\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schemas, limit, offset, hash, order, schema, ...props } = filter\n let all = (await archivist.all?.()) as 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 if (Array.isArray(filter)) {\n all = 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 } else {\n all = all.filter((payload) => payload?.[property] === filter)\n }\n }\n }\n const parsedLimit = limit || all.length\n const parsedOffset = offset || 0\n return offset !== undefined\n ? all.slice(parsedOffset, parsedLimit)\n : (async () => {\n const allPairs = await Promise.all(all.map<Promise<[string, TOut]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]))\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][0] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][0] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([, payload]) => payload)\n })()\n } else {\n throw Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,oBAAyB;AAEzB,sCAA+B;AAC/B,mCAKO;AACP,kBAA8B;AAGvB,IAAM,uBAAN,cAKG,+CAA+C;AAAA,EACvD,OAAgB,gBAAgB,CAAC,uDAA0B;AAAA,EAE3D,MAAyB,cAAc,UAAmC;AACxE,UAAM,aAAS,wBAAS,UAAU,OAAO,yDAA4B,GAAG,IAAI,GAAG,uBAAuB;AACtG,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,UAAM,gBAAY,wBAAS,MAAM,KAAK,cAAc,GAAG,6BAA6B;AAEpF,UAAM,EAAE,SAAS,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,MAAM,IAAI;AAClE,QAAI,MAAO,MAAM,UAAU,MAAM;AACjC,QAAI,KAAK;AACP,UAAI,UAAU;AAAQ,cAAM,IAAI,QAAQ;AACxC,UAAI,SAAS;AAAQ,cAAM,IAAI,OAAO,CAAC,YAAY,QAAQ,SAAS,QAAQ,MAAM,CAAC;AACnF,UAAI,OAAO,KAAK,KAAK,EAAE,SAAS,GAAG;AACjC,cAAM,2BAA2B,OAAO,QAAQ,KAAK;AACrD,mBAAW,CAAC,MAAMA,OAAM,KAAK,0BAA0B;AACrD,gBAAM,WAAW;AACjB,cAAI,MAAM,QAAQA,OAAM,GAAG;AACzB,kBAAM,IAAI;AAAA,cAAO,CAAC,YAChBA,QAAO,MAAM,CAAC,UAAU;AACtB,sBAAMC,QAAO,UAAU,QAAQ;AAE/B,uBAAO,MAAM,QAAQA,KAAI,KAAKA,MAAK,WAAW,KAAK;AAAA,cACrD,CAAC;AAAA,YACH;AAAA,UACF,OAAO;AACL,kBAAM,IAAI,OAAO,CAAC,YAAY,UAAU,QAAQ,MAAMD,OAAM;AAAA,UAC9D;AAAA,QACF;AAAA,MACF;AACA,YAAM,cAAc,SAAS,IAAI;AACjC,YAAM,eAAe,UAAU;AAC/B,aAAO,WAAW,SACd,IAAI,MAAM,cAAc,WAAW,KAClC,YAAY;AACX,cAAM,WAAW,MAAM,QAAQ,IAAI,IAAI,IAA6B,OAAO,YAAY,CAAC,MAAM,0BAAc,UAAU,OAAO,GAAG,OAAO,CAAC,CAAC;AACzI,YAAI,MAAM;AAER,iBAAO,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AACrD,qBAAS,MAAM;AAAA,UACjB;AAEA,cAAI,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AAClD,qBAAS,MAAM;AAAA,UACjB;AAAA,QACF;AACA,eAAO,SAAS,IAAI,CAAC,CAAC,EAAE,OAAO,MAAM,OAAO;AAAA,MAC9C,GAAG;AAAA,IACT,OAAO;AACL,YAAM,MAAM,kCAAkC;AAAA,IAChD;AAAA,EACF;AACF;","names":["filter","prop"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { DivinerModule, 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 { PayloadHasher } from '@xyo-network/hash'\nimport { Payload } 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<DivinerModule<TParams>, TIn, TOut> = DivinerModuleEventData<DivinerModule<TParams>, TIn, TOut>,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override configSchemas = [PayloadDivinerConfigSchema]\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.readArchivist(), 'Unable to resolve archivist')\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schemas, limit, offset, hash, order, schema, ...props } = filter\n let all = (await archivist.all?.()) as 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 = 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 Promise.all(all.map<Promise<[string, TOut]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]))\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][0] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][0] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([, payload]) => payload)\n })()\n : all.slice(parsedOffset, parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,oBAAyB;AAEzB,sCAA+B;AAC/B,mCAKO;AACP,kBAA8B;AAGvB,IAAM,uBAAN,cAKG,+CAA+C;AAAA,EACvD,OAAgB,gBAAgB,CAAC,uDAA0B;AAAA,EAE3D,MAAyB,cAAc,UAAmC;AACxE,UAAM,aAAS,wBAAS,UAAU,OAAO,yDAA4B,GAAG,IAAI,GAAG,uBAAuB;AACtG,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,UAAM,gBAAY,wBAAS,MAAM,KAAK,cAAc,GAAG,6BAA6B;AAEpF,UAAM,EAAE,SAAS,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,MAAM,IAAI;AAClE,QAAI,MAAO,MAAM,UAAU,MAAM;AACjC,QAAI,KAAK;AACP,UAAI,UAAU;AAAQ,cAAM,IAAI,QAAQ;AACxC,UAAI,SAAS;AAAQ,cAAM,IAAI,OAAO,CAAC,YAAY,QAAQ,SAAS,QAAQ,MAAM,CAAC;AACnF,UAAI,OAAO,KAAK,KAAK,EAAE,SAAS,GAAG;AACjC,cAAM,2BAA2B,OAAO,QAAQ,KAAK;AACrD,mBAAW,CAAC,MAAMA,OAAM,KAAK,0BAA0B;AACrD,gBAAM,WAAW;AACjB,gBAAM,MAAM,QAAQA,OAAM,IACtB,IAAI;AAAA,YAAO,CAAC,YACVA,QAAO,MAAM,CAAC,UAAU;AACtB,oBAAMC,QAAO,UAAU,QAAQ;AAE/B,qBAAO,MAAM,QAAQA,KAAI,KAAKA,MAAK,WAAW,KAAK;AAAA,YACrD,CAAC;AAAA,UACH,IACA,IAAI,OAAO,CAAC,YAAY,UAAU,QAAQ,MAAMD,OAAM;AAAA,QAC5D;AAAA,MACF;AACA,YAAM,cAAc,SAAS,IAAI;AACjC,YAAM,eAAe,UAAU;AAC/B,aAAO,WAAW,UACb,YAAY;AACX,cAAM,WAAW,MAAM,QAAQ,IAAI,IAAI,IAA6B,OAAO,YAAY,CAAC,MAAM,0BAAc,UAAU,OAAO,GAAG,OAAO,CAAC,CAAC;AACzI,YAAI,MAAM;AAER,iBAAO,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AACrD,qBAAS,MAAM;AAAA,UACjB;AAEA,cAAI,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AAClD,qBAAS,MAAM;AAAA,UACjB;AAAA,QACF;AACA,eAAO,SAAS,IAAI,CAAC,CAAC,EAAE,OAAO,MAAM,OAAO;AAAA,MAC9C,GAAG,IACH,IAAI,MAAM,cAAc,WAAW;AAAA,IACzC,OAAO;AACL,YAAM,IAAI,MAAM,kCAAkC;AAAA,IACpD;AAAA,EACF;AACF;","names":["filter","prop"]}
@@ -24,21 +24,17 @@ var MemoryPayloadDiviner = class extends PayloadDiviner {
24
24
  const additionalFilterCriteria = Object.entries(props);
25
25
  for (const [prop, filter2] of additionalFilterCriteria) {
26
26
  const property = prop;
27
- if (Array.isArray(filter2)) {
28
- all = all.filter(
29
- (payload) => filter2.every((value) => {
30
- const prop2 = payload?.[property];
31
- return Array.isArray(prop2) && prop2.includes?.(value);
32
- })
33
- );
34
- } else {
35
- all = all.filter((payload) => payload?.[property] === filter2);
36
- }
27
+ all = Array.isArray(filter2) ? all.filter(
28
+ (payload) => filter2.every((value) => {
29
+ const prop2 = payload?.[property];
30
+ return Array.isArray(prop2) && prop2.includes?.(value);
31
+ })
32
+ ) : all.filter((payload) => payload?.[property] === filter2);
37
33
  }
38
34
  }
39
- const parsedLimit = limit || all.length;
35
+ const parsedLimit = limit ?? all.length;
40
36
  const parsedOffset = offset || 0;
41
- return offset !== void 0 ? all.slice(parsedOffset, parsedLimit) : (async () => {
37
+ return offset === void 0 ? (async () => {
42
38
  const allPairs = await Promise.all(all.map(async (payload) => [await PayloadHasher.hashAsync(payload), payload]));
43
39
  if (hash) {
44
40
  while (allPairs.length > 0 && allPairs[0][0] !== hash) {
@@ -49,9 +45,9 @@ var MemoryPayloadDiviner = class extends PayloadDiviner {
49
45
  }
50
46
  }
51
47
  return allPairs.map(([, payload]) => payload);
52
- })();
48
+ })() : all.slice(parsedOffset, parsedLimit);
53
49
  } else {
54
- throw Error('Archivist does not support "all"');
50
+ throw new Error('Archivist does not support "all"');
55
51
  }
56
52
  }
57
53
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { DivinerModule, 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 { PayloadHasher } from '@xyo-network/hash'\nimport { Payload } 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<DivinerModule<TParams>, TIn, TOut> = DivinerModuleEventData<DivinerModule<TParams>, TIn, TOut>,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override configSchemas = [PayloadDivinerConfigSchema]\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.readArchivist(), 'Unable to resolve archivist')\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schemas, limit, offset, hash, order, schema, ...props } = filter\n let all = (await archivist.all?.()) as 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 if (Array.isArray(filter)) {\n all = 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 } else {\n all = all.filter((payload) => payload?.[property] === filter)\n }\n }\n }\n const parsedLimit = limit || all.length\n const parsedOffset = offset || 0\n return offset !== undefined\n ? all.slice(parsedOffset, parsedLimit)\n : (async () => {\n const allPairs = await Promise.all(all.map<Promise<[string, TOut]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]))\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][0] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][0] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([, payload]) => payload)\n })()\n } else {\n throw Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";AAAA,SAAS,gBAAgB;AAEzB,SAAS,sBAAsB;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,OAGK;AACP,SAAS,qBAAqB;AAGvB,IAAM,uBAAN,cAKG,eAA+C;AAAA,EACvD,OAAgB,gBAAgB,CAAC,0BAA0B;AAAA,EAE3D,MAAyB,cAAc,UAAmC;AACxE,UAAM,SAAS,SAAS,UAAU,OAAO,4BAA4B,GAAG,IAAI,GAAG,uBAAuB;AACtG,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,UAAM,YAAY,SAAS,MAAM,KAAK,cAAc,GAAG,6BAA6B;AAEpF,UAAM,EAAE,SAAS,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,MAAM,IAAI;AAClE,QAAI,MAAO,MAAM,UAAU,MAAM;AACjC,QAAI,KAAK;AACP,UAAI,UAAU;AAAQ,cAAM,IAAI,QAAQ;AACxC,UAAI,SAAS;AAAQ,cAAM,IAAI,OAAO,CAAC,YAAY,QAAQ,SAAS,QAAQ,MAAM,CAAC;AACnF,UAAI,OAAO,KAAK,KAAK,EAAE,SAAS,GAAG;AACjC,cAAM,2BAA2B,OAAO,QAAQ,KAAK;AACrD,mBAAW,CAAC,MAAMA,OAAM,KAAK,0BAA0B;AACrD,gBAAM,WAAW;AACjB,cAAI,MAAM,QAAQA,OAAM,GAAG;AACzB,kBAAM,IAAI;AAAA,cAAO,CAAC,YAChBA,QAAO,MAAM,CAAC,UAAU;AACtB,sBAAMC,QAAO,UAAU,QAAQ;AAE/B,uBAAO,MAAM,QAAQA,KAAI,KAAKA,MAAK,WAAW,KAAK;AAAA,cACrD,CAAC;AAAA,YACH;AAAA,UACF,OAAO;AACL,kBAAM,IAAI,OAAO,CAAC,YAAY,UAAU,QAAQ,MAAMD,OAAM;AAAA,UAC9D;AAAA,QACF;AAAA,MACF;AACA,YAAM,cAAc,SAAS,IAAI;AACjC,YAAM,eAAe,UAAU;AAC/B,aAAO,WAAW,SACd,IAAI,MAAM,cAAc,WAAW,KAClC,YAAY;AACX,cAAM,WAAW,MAAM,QAAQ,IAAI,IAAI,IAA6B,OAAO,YAAY,CAAC,MAAM,cAAc,UAAU,OAAO,GAAG,OAAO,CAAC,CAAC;AACzI,YAAI,MAAM;AAER,iBAAO,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AACrD,qBAAS,MAAM;AAAA,UACjB;AAEA,cAAI,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AAClD,qBAAS,MAAM;AAAA,UACjB;AAAA,QACF;AACA,eAAO,SAAS,IAAI,CAAC,CAAC,EAAE,OAAO,MAAM,OAAO;AAAA,MAC9C,GAAG;AAAA,IACT,OAAO;AACL,YAAM,MAAM,kCAAkC;AAAA,IAChD;AAAA,EACF;AACF;","names":["filter","prop"]}
1
+ {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { DivinerModule, 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 { PayloadHasher } from '@xyo-network/hash'\nimport { Payload } 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<DivinerModule<TParams>, TIn, TOut> = DivinerModuleEventData<DivinerModule<TParams>, TIn, TOut>,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override configSchemas = [PayloadDivinerConfigSchema]\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.readArchivist(), 'Unable to resolve archivist')\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schemas, limit, offset, hash, order, schema, ...props } = filter\n let all = (await archivist.all?.()) as 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 = 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 Promise.all(all.map<Promise<[string, TOut]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]))\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][0] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][0] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([, payload]) => payload)\n })()\n : all.slice(parsedOffset, parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";AAAA,SAAS,gBAAgB;AAEzB,SAAS,sBAAsB;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,OAGK;AACP,SAAS,qBAAqB;AAGvB,IAAM,uBAAN,cAKG,eAA+C;AAAA,EACvD,OAAgB,gBAAgB,CAAC,0BAA0B;AAAA,EAE3D,MAAyB,cAAc,UAAmC;AACxE,UAAM,SAAS,SAAS,UAAU,OAAO,4BAA4B,GAAG,IAAI,GAAG,uBAAuB;AACtG,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,UAAM,YAAY,SAAS,MAAM,KAAK,cAAc,GAAG,6BAA6B;AAEpF,UAAM,EAAE,SAAS,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,MAAM,IAAI;AAClE,QAAI,MAAO,MAAM,UAAU,MAAM;AACjC,QAAI,KAAK;AACP,UAAI,UAAU;AAAQ,cAAM,IAAI,QAAQ;AACxC,UAAI,SAAS;AAAQ,cAAM,IAAI,OAAO,CAAC,YAAY,QAAQ,SAAS,QAAQ,MAAM,CAAC;AACnF,UAAI,OAAO,KAAK,KAAK,EAAE,SAAS,GAAG;AACjC,cAAM,2BAA2B,OAAO,QAAQ,KAAK;AACrD,mBAAW,CAAC,MAAMA,OAAM,KAAK,0BAA0B;AACrD,gBAAM,WAAW;AACjB,gBAAM,MAAM,QAAQA,OAAM,IACtB,IAAI;AAAA,YAAO,CAAC,YACVA,QAAO,MAAM,CAAC,UAAU;AACtB,oBAAMC,QAAO,UAAU,QAAQ;AAE/B,qBAAO,MAAM,QAAQA,KAAI,KAAKA,MAAK,WAAW,KAAK;AAAA,YACrD,CAAC;AAAA,UACH,IACA,IAAI,OAAO,CAAC,YAAY,UAAU,QAAQ,MAAMD,OAAM;AAAA,QAC5D;AAAA,MACF;AACA,YAAM,cAAc,SAAS,IAAI;AACjC,YAAM,eAAe,UAAU;AAC/B,aAAO,WAAW,UACb,YAAY;AACX,cAAM,WAAW,MAAM,QAAQ,IAAI,IAAI,IAA6B,OAAO,YAAY,CAAC,MAAM,cAAc,UAAU,OAAO,GAAG,OAAO,CAAC,CAAC;AACzI,YAAI,MAAM;AAER,iBAAO,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AACrD,qBAAS,MAAM;AAAA,UACjB;AAEA,cAAI,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AAClD,qBAAS,MAAM;AAAA,UACjB;AAAA,QACF;AACA,eAAO,SAAS,IAAI,CAAC,CAAC,EAAE,OAAO,MAAM,OAAO;AAAA,MAC9C,GAAG,IACH,IAAI,MAAM,cAAc,WAAW;AAAA,IACzC,OAAO;AACL,YAAM,IAAI,MAAM,kCAAkC;AAAA,IACpD;AAAA,EACF;AACF;","names":["filter","prop"]}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,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,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CACxI,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,OAAgB,aAAa,yCAA+B;cAEnC,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;CAiD1E"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,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,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CACxI,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,OAAgB,aAAa,yCAA+B;cAEnC,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;CA+C1E"}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,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,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CACxI,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,OAAgB,aAAa,yCAA+B;cAEnC,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;CAiD1E"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,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,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CACxI,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,OAAgB,aAAa,yCAA+B;cAEnC,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;CA+C1E"}
@@ -1 +1 @@
1
- {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,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,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CACxI,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,OAAgB,aAAa,yCAA+B;cAEnC,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;CAiD1E"}
1
+ {"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,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,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CACxI,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,OAAgB,aAAa,yCAA+B;cAEnC,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;CA+C1E"}
@@ -48,22 +48,18 @@ var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.Payload
48
48
  const additionalFilterCriteria = Object.entries(props);
49
49
  for (const [prop, filter2] of additionalFilterCriteria) {
50
50
  const property = prop;
51
- if (Array.isArray(filter2)) {
52
- all = all.filter(
53
- (payload) => filter2.every((value) => {
54
- var _a2;
55
- const prop2 = payload == null ? void 0 : payload[property];
56
- return Array.isArray(prop2) && ((_a2 = prop2.includes) == null ? void 0 : _a2.call(prop2, value));
57
- })
58
- );
59
- } else {
60
- all = all.filter((payload) => (payload == null ? void 0 : payload[property]) === filter2);
61
- }
51
+ all = Array.isArray(filter2) ? all.filter(
52
+ (payload) => filter2.every((value) => {
53
+ var _a2;
54
+ const prop2 = payload == null ? void 0 : payload[property];
55
+ return Array.isArray(prop2) && ((_a2 = prop2.includes) == null ? void 0 : _a2.call(prop2, value));
56
+ })
57
+ ) : all.filter((payload) => (payload == null ? void 0 : payload[property]) === filter2);
62
58
  }
63
59
  }
64
- const parsedLimit = limit || all.length;
60
+ const parsedLimit = limit ?? all.length;
65
61
  const parsedOffset = offset || 0;
66
- return offset !== void 0 ? all.slice(parsedOffset, parsedLimit) : (async () => {
62
+ return offset === void 0 ? (async () => {
67
63
  const allPairs = await Promise.all(all.map(async (payload) => [await import_hash.PayloadHasher.hashAsync(payload), payload]));
68
64
  if (hash) {
69
65
  while (allPairs.length > 0 && allPairs[0][0] !== hash) {
@@ -74,9 +70,9 @@ var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.Payload
74
70
  }
75
71
  }
76
72
  return allPairs.map(([, payload]) => payload);
77
- })();
73
+ })() : all.slice(parsedOffset, parsedLimit);
78
74
  } else {
79
- throw Error('Archivist does not support "all"');
75
+ throw new Error('Archivist does not support "all"');
80
76
  }
81
77
  }
82
78
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { DivinerModule, 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 { PayloadHasher } from '@xyo-network/hash'\nimport { Payload } 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<DivinerModule<TParams>, TIn, TOut> = DivinerModuleEventData<DivinerModule<TParams>, TIn, TOut>,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override configSchemas = [PayloadDivinerConfigSchema]\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.readArchivist(), 'Unable to resolve archivist')\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schemas, limit, offset, hash, order, schema, ...props } = filter\n let all = (await archivist.all?.()) as 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 if (Array.isArray(filter)) {\n all = 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 } else {\n all = all.filter((payload) => payload?.[property] === filter)\n }\n }\n }\n const parsedLimit = limit || all.length\n const parsedOffset = offset || 0\n return offset !== undefined\n ? all.slice(parsedOffset, parsedLimit)\n : (async () => {\n const allPairs = await Promise.all(all.map<Promise<[string, TOut]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]))\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][0] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][0] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([, payload]) => payload)\n })()\n } else {\n throw Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,oBAAyB;AAEzB,sCAA+B;AAC/B,mCAKO;AACP,kBAA8B;AAGvB,IAAM,uBAAN,cAKG,+CAA+C;AAAA,EACvD,OAAgB,gBAAgB,CAAC,uDAA0B;AAAA,EAE3D,MAAyB,cAAc,UAAmC;AApB5E;AAqBI,UAAM,aAAS,yBAAS,0CAAU,OAAO,+DAAjB,mBAAgD,OAAO,uBAAuB;AACtG,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,UAAM,gBAAY,wBAAS,MAAM,KAAK,cAAc,GAAG,6BAA6B;AAEpF,UAAM,EAAE,SAAS,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,MAAM,IAAI;AAClE,QAAI,MAAO,QAAM,eAAU,QAAV;AACjB,QAAI,KAAK;AACP,UAAI,UAAU;AAAQ,cAAM,IAAI,QAAQ;AACxC,UAAI,mCAAS;AAAQ,cAAM,IAAI,OAAO,CAAC,YAAY,QAAQ,SAAS,QAAQ,MAAM,CAAC;AACnF,UAAI,OAAO,KAAK,KAAK,EAAE,SAAS,GAAG;AACjC,cAAM,2BAA2B,OAAO,QAAQ,KAAK;AACrD,mBAAW,CAAC,MAAMA,OAAM,KAAK,0BAA0B;AACrD,gBAAM,WAAW;AACjB,cAAI,MAAM,QAAQA,OAAM,GAAG;AACzB,kBAAM,IAAI;AAAA,cAAO,CAAC,YAChBA,QAAO,MAAM,CAAC,UAAU;AApCtC,oBAAAC;AAqCgB,sBAAMC,QAAO,mCAAU;AAEvB,uBAAO,MAAM,QAAQA,KAAI,OAAKD,MAAAC,MAAK,aAAL,gBAAAD,IAAA,KAAAC,OAAgB;AAAA,cAChD,CAAC;AAAA,YACH;AAAA,UACF,OAAO;AACL,kBAAM,IAAI,OAAO,CAAC,aAAY,mCAAU,eAAcF,OAAM;AAAA,UAC9D;AAAA,QACF;AAAA,MACF;AACA,YAAM,cAAc,SAAS,IAAI;AACjC,YAAM,eAAe,UAAU;AAC/B,aAAO,WAAW,SACd,IAAI,MAAM,cAAc,WAAW,KAClC,YAAY;AACX,cAAM,WAAW,MAAM,QAAQ,IAAI,IAAI,IAA6B,OAAO,YAAY,CAAC,MAAM,0BAAc,UAAU,OAAO,GAAG,OAAO,CAAC,CAAC;AACzI,YAAI,MAAM;AAER,iBAAO,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AACrD,qBAAS,MAAM;AAAA,UACjB;AAEA,cAAI,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AAClD,qBAAS,MAAM;AAAA,UACjB;AAAA,QACF;AACA,eAAO,SAAS,IAAI,CAAC,CAAC,EAAE,OAAO,MAAM,OAAO;AAAA,MAC9C,GAAG;AAAA,IACT,OAAO;AACL,YAAM,MAAM,kCAAkC;AAAA,IAChD;AAAA,EACF;AACF;","names":["filter","_a","prop"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { DivinerModule, 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 { PayloadHasher } from '@xyo-network/hash'\nimport { Payload } 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<DivinerModule<TParams>, TIn, TOut> = DivinerModuleEventData<DivinerModule<TParams>, TIn, TOut>,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override configSchemas = [PayloadDivinerConfigSchema]\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.readArchivist(), 'Unable to resolve archivist')\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schemas, limit, offset, hash, order, schema, ...props } = filter\n let all = (await archivist.all?.()) as 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 = 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 Promise.all(all.map<Promise<[string, TOut]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]))\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][0] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][0] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([, payload]) => payload)\n })()\n : all.slice(parsedOffset, parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,oBAAyB;AAEzB,sCAA+B;AAC/B,mCAKO;AACP,kBAA8B;AAGvB,IAAM,uBAAN,cAKG,+CAA+C;AAAA,EACvD,OAAgB,gBAAgB,CAAC,uDAA0B;AAAA,EAE3D,MAAyB,cAAc,UAAmC;AApB5E;AAqBI,UAAM,aAAS,yBAAS,0CAAU,OAAO,+DAAjB,mBAAgD,OAAO,uBAAuB;AACtG,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,UAAM,gBAAY,wBAAS,MAAM,KAAK,cAAc,GAAG,6BAA6B;AAEpF,UAAM,EAAE,SAAS,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,MAAM,IAAI;AAClE,QAAI,MAAO,QAAM,eAAU,QAAV;AACjB,QAAI,KAAK;AACP,UAAI,UAAU;AAAQ,cAAM,IAAI,QAAQ;AACxC,UAAI,mCAAS;AAAQ,cAAM,IAAI,OAAO,CAAC,YAAY,QAAQ,SAAS,QAAQ,MAAM,CAAC;AACnF,UAAI,OAAO,KAAK,KAAK,EAAE,SAAS,GAAG;AACjC,cAAM,2BAA2B,OAAO,QAAQ,KAAK;AACrD,mBAAW,CAAC,MAAMA,OAAM,KAAK,0BAA0B;AACrD,gBAAM,WAAW;AACjB,gBAAM,MAAM,QAAQA,OAAM,IACtB,IAAI;AAAA,YAAO,CAAC,YACVA,QAAO,MAAM,CAAC,UAAU;AApCxC,kBAAAC;AAqCkB,oBAAMC,QAAO,mCAAU;AAEvB,qBAAO,MAAM,QAAQA,KAAI,OAAKD,MAAAC,MAAK,aAAL,gBAAAD,IAAA,KAAAC,OAAgB;AAAA,YAChD,CAAC;AAAA,UACH,IACA,IAAI,OAAO,CAAC,aAAY,mCAAU,eAAcF,OAAM;AAAA,QAC5D;AAAA,MACF;AACA,YAAM,cAAc,SAAS,IAAI;AACjC,YAAM,eAAe,UAAU;AAC/B,aAAO,WAAW,UACb,YAAY;AACX,cAAM,WAAW,MAAM,QAAQ,IAAI,IAAI,IAA6B,OAAO,YAAY,CAAC,MAAM,0BAAc,UAAU,OAAO,GAAG,OAAO,CAAC,CAAC;AACzI,YAAI,MAAM;AAER,iBAAO,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AACrD,qBAAS,MAAM;AAAA,UACjB;AAEA,cAAI,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AAClD,qBAAS,MAAM;AAAA,UACjB;AAAA,QACF;AACA,eAAO,SAAS,IAAI,CAAC,CAAC,EAAE,OAAO,MAAM,OAAO;AAAA,MAC9C,GAAG,IACH,IAAI,MAAM,cAAc,WAAW;AAAA,IACzC,OAAO;AACL,YAAM,IAAI,MAAM,kCAAkC;AAAA,IACpD;AAAA,EACF;AACF;","names":["filter","_a","prop"]}
@@ -25,22 +25,18 @@ var MemoryPayloadDiviner = class extends PayloadDiviner {
25
25
  const additionalFilterCriteria = Object.entries(props);
26
26
  for (const [prop, filter2] of additionalFilterCriteria) {
27
27
  const property = prop;
28
- if (Array.isArray(filter2)) {
29
- all = all.filter(
30
- (payload) => filter2.every((value) => {
31
- var _a2;
32
- const prop2 = payload == null ? void 0 : payload[property];
33
- return Array.isArray(prop2) && ((_a2 = prop2.includes) == null ? void 0 : _a2.call(prop2, value));
34
- })
35
- );
36
- } else {
37
- all = all.filter((payload) => (payload == null ? void 0 : payload[property]) === filter2);
38
- }
28
+ all = Array.isArray(filter2) ? all.filter(
29
+ (payload) => filter2.every((value) => {
30
+ var _a2;
31
+ const prop2 = payload == null ? void 0 : payload[property];
32
+ return Array.isArray(prop2) && ((_a2 = prop2.includes) == null ? void 0 : _a2.call(prop2, value));
33
+ })
34
+ ) : all.filter((payload) => (payload == null ? void 0 : payload[property]) === filter2);
39
35
  }
40
36
  }
41
- const parsedLimit = limit || all.length;
37
+ const parsedLimit = limit ?? all.length;
42
38
  const parsedOffset = offset || 0;
43
- return offset !== void 0 ? all.slice(parsedOffset, parsedLimit) : (async () => {
39
+ return offset === void 0 ? (async () => {
44
40
  const allPairs = await Promise.all(all.map(async (payload) => [await PayloadHasher.hashAsync(payload), payload]));
45
41
  if (hash) {
46
42
  while (allPairs.length > 0 && allPairs[0][0] !== hash) {
@@ -51,9 +47,9 @@ var MemoryPayloadDiviner = class extends PayloadDiviner {
51
47
  }
52
48
  }
53
49
  return allPairs.map(([, payload]) => payload);
54
- })();
50
+ })() : all.slice(parsedOffset, parsedLimit);
55
51
  } else {
56
- throw Error('Archivist does not support "all"');
52
+ throw new Error('Archivist does not support "all"');
57
53
  }
58
54
  }
59
55
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { DivinerModule, 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 { PayloadHasher } from '@xyo-network/hash'\nimport { Payload } 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<DivinerModule<TParams>, TIn, TOut> = DivinerModuleEventData<DivinerModule<TParams>, TIn, TOut>,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override configSchemas = [PayloadDivinerConfigSchema]\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.readArchivist(), 'Unable to resolve archivist')\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schemas, limit, offset, hash, order, schema, ...props } = filter\n let all = (await archivist.all?.()) as 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 if (Array.isArray(filter)) {\n all = 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 } else {\n all = all.filter((payload) => payload?.[property] === filter)\n }\n }\n }\n const parsedLimit = limit || all.length\n const parsedOffset = offset || 0\n return offset !== undefined\n ? all.slice(parsedOffset, parsedLimit)\n : (async () => {\n const allPairs = await Promise.all(all.map<Promise<[string, TOut]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]))\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][0] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][0] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([, payload]) => payload)\n })()\n } else {\n throw Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";AAAA,SAAS,gBAAgB;AAEzB,SAAS,sBAAsB;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,OAGK;AACP,SAAS,qBAAqB;AAGvB,IAAM,uBAAN,cAKG,eAA+C;AAAA,EACvD,OAAgB,gBAAgB,CAAC,0BAA0B;AAAA,EAE3D,MAAyB,cAAc,UAAmC;AApB5E;AAqBI,UAAM,SAAS,UAAS,0CAAU,OAAO,kCAAjB,mBAAgD,OAAO,uBAAuB;AACtG,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,UAAM,YAAY,SAAS,MAAM,KAAK,cAAc,GAAG,6BAA6B;AAEpF,UAAM,EAAE,SAAS,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,MAAM,IAAI;AAClE,QAAI,MAAO,QAAM,eAAU,QAAV;AACjB,QAAI,KAAK;AACP,UAAI,UAAU;AAAQ,cAAM,IAAI,QAAQ;AACxC,UAAI,mCAAS;AAAQ,cAAM,IAAI,OAAO,CAAC,YAAY,QAAQ,SAAS,QAAQ,MAAM,CAAC;AACnF,UAAI,OAAO,KAAK,KAAK,EAAE,SAAS,GAAG;AACjC,cAAM,2BAA2B,OAAO,QAAQ,KAAK;AACrD,mBAAW,CAAC,MAAMA,OAAM,KAAK,0BAA0B;AACrD,gBAAM,WAAW;AACjB,cAAI,MAAM,QAAQA,OAAM,GAAG;AACzB,kBAAM,IAAI;AAAA,cAAO,CAAC,YAChBA,QAAO,MAAM,CAAC,UAAU;AApCtC,oBAAAC;AAqCgB,sBAAMC,QAAO,mCAAU;AAEvB,uBAAO,MAAM,QAAQA,KAAI,OAAKD,MAAAC,MAAK,aAAL,gBAAAD,IAAA,KAAAC,OAAgB;AAAA,cAChD,CAAC;AAAA,YACH;AAAA,UACF,OAAO;AACL,kBAAM,IAAI,OAAO,CAAC,aAAY,mCAAU,eAAcF,OAAM;AAAA,UAC9D;AAAA,QACF;AAAA,MACF;AACA,YAAM,cAAc,SAAS,IAAI;AACjC,YAAM,eAAe,UAAU;AAC/B,aAAO,WAAW,SACd,IAAI,MAAM,cAAc,WAAW,KAClC,YAAY;AACX,cAAM,WAAW,MAAM,QAAQ,IAAI,IAAI,IAA6B,OAAO,YAAY,CAAC,MAAM,cAAc,UAAU,OAAO,GAAG,OAAO,CAAC,CAAC;AACzI,YAAI,MAAM;AAER,iBAAO,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AACrD,qBAAS,MAAM;AAAA,UACjB;AAEA,cAAI,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AAClD,qBAAS,MAAM;AAAA,UACjB;AAAA,QACF;AACA,eAAO,SAAS,IAAI,CAAC,CAAC,EAAE,OAAO,MAAM,OAAO;AAAA,MAC9C,GAAG;AAAA,IACT,OAAO;AACL,YAAM,MAAM,kCAAkC;AAAA,IAChD;AAAA,EACF;AACF;","names":["filter","_a","prop"]}
1
+ {"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { DivinerModule, 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 { PayloadHasher } from '@xyo-network/hash'\nimport { Payload } 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<DivinerModule<TParams>, TIn, TOut> = DivinerModuleEventData<DivinerModule<TParams>, TIn, TOut>,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override configSchemas = [PayloadDivinerConfigSchema]\n\n protected override async divineHandler(payloads?: TIn[]): Promise<TOut[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.readArchivist(), 'Unable to resolve archivist')\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { schemas, limit, offset, hash, order, schema, ...props } = filter\n let all = (await archivist.all?.()) as 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 = 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 Promise.all(all.map<Promise<[string, TOut]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]))\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][0] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][0] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([, payload]) => payload)\n })()\n : all.slice(parsedOffset, parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";AAAA,SAAS,gBAAgB;AAEzB,SAAS,sBAAsB;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,OAGK;AACP,SAAS,qBAAqB;AAGvB,IAAM,uBAAN,cAKG,eAA+C;AAAA,EACvD,OAAgB,gBAAgB,CAAC,0BAA0B;AAAA,EAE3D,MAAyB,cAAc,UAAmC;AApB5E;AAqBI,UAAM,SAAS,UAAS,0CAAU,OAAO,kCAAjB,mBAAgD,OAAO,uBAAuB;AACtG,QAAI,CAAC;AAAQ,aAAO,CAAC;AACrB,UAAM,YAAY,SAAS,MAAM,KAAK,cAAc,GAAG,6BAA6B;AAEpF,UAAM,EAAE,SAAS,OAAO,QAAQ,MAAM,OAAO,QAAQ,GAAG,MAAM,IAAI;AAClE,QAAI,MAAO,QAAM,eAAU,QAAV;AACjB,QAAI,KAAK;AACP,UAAI,UAAU;AAAQ,cAAM,IAAI,QAAQ;AACxC,UAAI,mCAAS;AAAQ,cAAM,IAAI,OAAO,CAAC,YAAY,QAAQ,SAAS,QAAQ,MAAM,CAAC;AACnF,UAAI,OAAO,KAAK,KAAK,EAAE,SAAS,GAAG;AACjC,cAAM,2BAA2B,OAAO,QAAQ,KAAK;AACrD,mBAAW,CAAC,MAAMA,OAAM,KAAK,0BAA0B;AACrD,gBAAM,WAAW;AACjB,gBAAM,MAAM,QAAQA,OAAM,IACtB,IAAI;AAAA,YAAO,CAAC,YACVA,QAAO,MAAM,CAAC,UAAU;AApCxC,kBAAAC;AAqCkB,oBAAMC,QAAO,mCAAU;AAEvB,qBAAO,MAAM,QAAQA,KAAI,OAAKD,MAAAC,MAAK,aAAL,gBAAAD,IAAA,KAAAC,OAAgB;AAAA,YAChD,CAAC;AAAA,UACH,IACA,IAAI,OAAO,CAAC,aAAY,mCAAU,eAAcF,OAAM;AAAA,QAC5D;AAAA,MACF;AACA,YAAM,cAAc,SAAS,IAAI;AACjC,YAAM,eAAe,UAAU;AAC/B,aAAO,WAAW,UACb,YAAY;AACX,cAAM,WAAW,MAAM,QAAQ,IAAI,IAAI,IAA6B,OAAO,YAAY,CAAC,MAAM,cAAc,UAAU,OAAO,GAAG,OAAO,CAAC,CAAC;AACzI,YAAI,MAAM;AAER,iBAAO,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AACrD,qBAAS,MAAM;AAAA,UACjB;AAEA,cAAI,SAAS,SAAS,KAAK,SAAS,CAAC,EAAE,CAAC,MAAM,MAAM;AAClD,qBAAS,MAAM;AAAA,UACjB;AAAA,QACF;AACA,eAAO,SAAS,IAAI,CAAC,CAAC,EAAE,OAAO,MAAM,OAAO;AAAA,MAC9C,GAAG,IACH,IAAI,MAAM,cAAc,WAAW;AAAA,IACzC,OAAO;AACL,YAAM,IAAI,MAAM,kCAAkC;AAAA,IACpD;AAAA,EACF;AACF;","names":["filter","_a","prop"]}
package/package.json CHANGED
@@ -11,19 +11,19 @@
11
11
  },
12
12
  "dependencies": {
13
13
  "@xylabs/assert": "^2.13.20",
14
- "@xyo-network/diviner-model": "~2.84.5",
15
- "@xyo-network/diviner-payload-abstract": "~2.84.5",
16
- "@xyo-network/diviner-payload-model": "~2.84.5",
17
- "@xyo-network/hash": "~2.84.5",
18
- "@xyo-network/payload-model": "~2.84.5"
14
+ "@xyo-network/diviner-model": "~2.84.7",
15
+ "@xyo-network/diviner-payload-abstract": "~2.84.7",
16
+ "@xyo-network/diviner-payload-model": "~2.84.7",
17
+ "@xyo-network/hash": "~2.84.7",
18
+ "@xyo-network/payload-model": "~2.84.7"
19
19
  },
20
20
  "devDependencies": {
21
- "@xylabs/ts-scripts-yarn3": "^3.2.19",
22
- "@xylabs/tsconfig": "^3.2.19",
23
- "@xyo-network/account": "~2.84.5",
24
- "@xyo-network/memory-archivist": "~2.84.5",
25
- "@xyo-network/node-memory": "~2.84.5",
26
- "@xyo-network/payload-builder": "~2.84.5",
21
+ "@xylabs/ts-scripts-yarn3": "^3.2.24",
22
+ "@xylabs/tsconfig": "^3.2.24",
23
+ "@xyo-network/account": "~2.84.7",
24
+ "@xyo-network/memory-archivist": "~2.84.7",
25
+ "@xyo-network/node-memory": "~2.84.7",
26
+ "@xyo-network/payload-builder": "~2.84.7",
27
27
  "typescript": "^5.3.3"
28
28
  },
29
29
  "description": "Primary SDK for using XYO Protocol 2.0",
@@ -65,6 +65,6 @@
65
65
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
66
66
  },
67
67
  "sideEffects": false,
68
- "version": "2.84.5",
68
+ "version": "2.84.7",
69
69
  "type": "module"
70
70
  }
@@ -32,24 +32,21 @@ export class MemoryPayloadDiviner<
32
32
  const additionalFilterCriteria = Object.entries(props)
33
33
  for (const [prop, filter] of additionalFilterCriteria) {
34
34
  const property = prop as keyof TOut
35
- if (Array.isArray(filter)) {
36
- all = all.filter((payload) =>
37
- filter.every((value) => {
38
- const prop = payload?.[property]
39
- //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?
40
- return Array.isArray(prop) && prop.includes?.(value)
41
- }),
42
- )
43
- } else {
44
- all = all.filter((payload) => payload?.[property] === filter)
45
- }
35
+ all = Array.isArray(filter)
36
+ ? all.filter((payload) =>
37
+ filter.every((value) => {
38
+ const prop = payload?.[property]
39
+ //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?
40
+ return Array.isArray(prop) && prop.includes?.(value)
41
+ }),
42
+ )
43
+ : all.filter((payload) => payload?.[property] === filter)
46
44
  }
47
45
  }
48
- const parsedLimit = limit || all.length
46
+ const parsedLimit = limit ?? all.length
49
47
  const parsedOffset = offset || 0
50
- return offset !== undefined
51
- ? all.slice(parsedOffset, parsedLimit)
52
- : (async () => {
48
+ return offset === undefined
49
+ ? (async () => {
53
50
  const allPairs = await Promise.all(all.map<Promise<[string, TOut]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]))
54
51
  if (hash) {
55
52
  //remove all until found
@@ -63,8 +60,9 @@ export class MemoryPayloadDiviner<
63
60
  }
64
61
  return allPairs.map(([, payload]) => payload)
65
62
  })()
63
+ : all.slice(parsedOffset, parsedLimit)
66
64
  } else {
67
- throw Error('Archivist does not support "all"')
65
+ throw new Error('Archivist does not support "all"')
68
66
  }
69
67
  }
70
68
  }