@xyo-network/diviner-payload-memory 2.110.18 → 2.111.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts","../../src/hasTimestamp.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner.ts'\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 { isPayloadDivinerQueryPayload, PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.ts'\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 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,mCAA+F;AAC/F,6BAA+B;;;ACHxB,IAAMA,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADQrB,IAAMC,uBAAN,cASGC,+CAAAA;EApBV,OAoBUA;;;EACR,MAAyBC,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","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
+ {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts","../../src/hasTimestamp.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner.ts'\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 { isPayloadDivinerQueryPayload, PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.ts'\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 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,mCAA+F;AAC/F,6BAA+B;;;ACHxB,IAAMA,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADQrB,IAAMC,uBAAN,cASGC,+CAAAA;EApBV,OAoBUA;;;EACR,MAAyBC,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,OAAOiB,CAAAA,YAAWX,QAAQY,SAASD,QAAQE,MAAM,CAAA;AAChF,UAAIR,cAAcS,QAAW;AAE3B,YAAIpB,OAAOU,UAAUU,QAAW;AAE9BN,gBAAMA,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,QAAQN,cAAcA,SAAAA;QACzE,OAAO;AAELG,gBACIJ,UAAU,QACRI,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,QAAQN,aAAaA,SAAAA,IAChEG,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,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,gBACIc,MAAMC,QAAQ7B,OAAAA,IACZc,IAAId,OAAOiB,CAAAA,YACXjB,QAAO8B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOT,UAAUU,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKR,WAAWa,KAAAA;UAChD,CAAA,CAAA,IAEAjB,IAAId,OAAOiB,CAAAA,YAAWA,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","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"]}
@@ -70,4 +70,4 @@ var MemoryPayloadDiviner = class extends PayloadDiviner {
70
70
  export {
71
71
  MemoryPayloadDiviner
72
72
  };
73
- //# sourceMappingURL=index.js.map
73
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
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 { isPayloadDivinerQueryPayload, PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.ts'\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 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,SAASC,oCAAsF;AAC/F,SAASC,sBAAsB;;;ACHxB,IAAMC,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADQrB,IAAMC,uBAAN,cASGC,eAAAA;EApBV,OAoBUA;;;EACR,MAAyBC,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,OAAOiB,CAAAA,YAAWX,QAAQY,SAASD,QAAQE,MAAM,CAAA;AAChF,UAAIR,cAAcS,QAAW;AAE3B,YAAIpB,OAAOU,UAAUU,QAAW;AAE9BN,gBAAMA,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,QAAQN,cAAcA,SAAAA;QACzE,OAAO;AAELG,gBACIJ,UAAU,QACRI,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,QAAQN,aAAaA,SAAAA,IAChEG,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,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,gBACIc,MAAMC,QAAQ7B,OAAAA,IACZc,IAAId,OAAOiB,CAAAA,YACXjB,QAAO8B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOT,UAAUU,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKR,WAAWa,KAAAA;UAChD,CAAA,CAAA,IAEAjB,IAAId,OAAOiB,CAAAA,YAAWA,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","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","parsedLimit","parsedOffset","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts","../../src/hasTimestamp.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner.ts'\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 { isPayloadDivinerQueryPayload, PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.ts'\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 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,mCAA+F;AAC/F,6BAA+B;;;ACHxB,IAAMA,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADQrB,IAAMC,uBAAN,cASGC,+CAAAA;EApBV,OAoBUA;;;EACR,MAAyBC,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","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
+ {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts","../../src/hasTimestamp.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner.ts'\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 { isPayloadDivinerQueryPayload, PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.ts'\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 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,mCAA+F;AAC/F,6BAA+B;;;ACHxB,IAAMA,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADQrB,IAAMC,uBAAN,cASGC,+CAAAA;EApBV,OAoBUA;;;EACR,MAAyBC,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,OAAOiB,CAAAA,YAAWX,QAAQY,SAASD,QAAQE,MAAM,CAAA;AAChF,UAAIR,cAAcS,QAAW;AAE3B,YAAIpB,OAAOU,UAAUU,QAAW;AAE9BN,gBAAMA,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,QAAQN,cAAcA,SAAAA;QACzE,OAAO;AAELG,gBACIJ,UAAU,QACRI,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,QAAQN,aAAaA,SAAAA,IAChEG,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,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,gBACIc,MAAMC,QAAQ7B,OAAAA,IACZc,IAAId,OAAOiB,CAAAA,YACXjB,QAAO8B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOT,UAAUU,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKR,WAAWa,KAAAA;UAChD,CAAA,CAAA,IAEAjB,IAAId,OAAOiB,CAAAA,YAAWA,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","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"]}
@@ -70,4 +70,4 @@ var MemoryPayloadDiviner = class extends PayloadDiviner {
70
70
  export {
71
71
  MemoryPayloadDiviner
72
72
  };
73
- //# sourceMappingURL=index.js.map
73
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
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 { isPayloadDivinerQueryPayload, PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.ts'\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 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,SAASC,oCAAsF;AAC/F,SAASC,sBAAsB;;;ACHxB,IAAMC,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADQrB,IAAMC,uBAAN,cASGC,eAAAA;EApBV,OAoBUA;;;EACR,MAAyBC,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,OAAOiB,CAAAA,YAAWX,QAAQY,SAASD,QAAQE,MAAM,CAAA;AAChF,UAAIR,cAAcS,QAAW;AAE3B,YAAIpB,OAAOU,UAAUU,QAAW;AAE9BN,gBAAMA,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,QAAQN,cAAcA,SAAAA;QACzE,OAAO;AAELG,gBACIJ,UAAU,QACRI,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,QAAQN,aAAaA,SAAAA,IAChEG,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,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,gBACIc,MAAMC,QAAQ7B,OAAAA,IACZc,IAAId,OAAOiB,CAAAA,YACXjB,QAAO8B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOT,UAAUU,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKR,WAAWa,KAAAA;UAChD,CAAA,CAAA,IAEAjB,IAAId,OAAOiB,CAAAA,YAAWA,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","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","parsedLimit","parsedOffset","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts","../../src/hasTimestamp.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner.ts'\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 { isPayloadDivinerQueryPayload, PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.ts'\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 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,mCAA+F;AAC/F,6BAA+B;;;ACHxB,IAAMA,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADQrB,IAAMC,wBAAN,MAAMA,8BASHC,+CAAAA;EACR,MAAyBC,cAAcC,UAA6C;AArBtF;AAsBI,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;AAlD9B,gBAAAC;AAmDkB,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;AA7DU5C;AATH,IAAMD,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"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts","../../src/hasTimestamp.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner.ts'\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 { isPayloadDivinerQueryPayload, PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.ts'\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 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,mCAA+F;AAC/F,6BAA+B;;;ACHxB,IAAMA,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADQrB,IAAMC,wBAAN,MAAMA,8BASHC,+CAAAA;EACR,MAAyBC,cAAcC,UAA6C;AArBtF;AAsBI,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,OAAOiB,CAAAA,YAAWX,QAAQY,SAASD,QAAQE,MAAM,CAAA;AAChF,UAAIR,cAAcS,QAAW;AAE3B,YAAIpB,OAAOU,UAAUU,QAAW;AAE9BN,gBAAMA,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,QAAQN,cAAcA,SAAAA;QACzE,OAAO;AAELG,gBACIJ,UAAU,QACRI,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,QAAQN,aAAaA,SAAAA,IAChEG,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,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,gBACIc,MAAMC,QAAQ7B,OAAAA,IACZc,IAAId,OAAOiB,CAAAA,YACXjB,QAAO8B,MAAM,CAACC,UAAAA;AAlD9B,gBAAAC;AAmDkB,kBAAMN,QAAOT,mCAAUU;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,OAASA,MAAAA,MAAKR,aAALQ,gBAAAA,IAAAA,KAAAA,OAAgBK;UAChD,CAAA,CAAA,IAEAjB,IAAId,OAAOiB,CAAAA,aAAWA,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;AA7DU5C;AATH,IAAMD,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"]}
@@ -71,4 +71,4 @@ var MemoryPayloadDiviner = _MemoryPayloadDiviner;
71
71
  export {
72
72
  MemoryPayloadDiviner
73
73
  };
74
- //# sourceMappingURL=index.js.map
74
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
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 { isPayloadDivinerQueryPayload, PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.ts'\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 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,SAASC,oCAAsF;AAC/F,SAASC,sBAAsB;;;ACHxB,IAAMC,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADQrB,IAAMC,wBAAN,MAAMA,8BASHC,eAAAA;EACR,MAAyBC,cAAcC,UAA6C;AArBtF;AAsBI,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,OAAOiB,CAAAA,YAAWX,QAAQY,SAASD,QAAQE,MAAM,CAAA;AAChF,UAAIR,cAAcS,QAAW;AAE3B,YAAIpB,OAAOU,UAAUU,QAAW;AAE9BN,gBAAMA,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,QAAQN,cAAcA,SAAAA;QACzE,OAAO;AAELG,gBACIJ,UAAU,QACRI,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,QAAQN,aAAaA,SAAAA,IAChEG,IAAId,OAAOqB,YAAAA,EAAcrB,OAAOiB,CAAAA,YAAWA,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,gBACIc,MAAMC,QAAQ7B,OAAAA,IACZc,IAAId,OAAOiB,CAAAA,YACXjB,QAAO8B,MAAM,CAACC,UAAAA;AAlD9B,gBAAAC;AAmDkB,kBAAMN,QAAOT,mCAAUU;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,OAASA,MAAAA,MAAKR,aAALQ,gBAAAA,IAAAA,KAAAA,OAAgBK;UAChD,CAAA,CAAA,IAEAjB,IAAId,OAAOiB,CAAAA,aAAWA,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;AA7DU5C;AATH,IAAMD,uBAAN;","names":["assertEx","removeFields","PayloadDiviner","isPayloadDivinerQueryPayload","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"]}
package/package.json CHANGED
@@ -10,21 +10,21 @@
10
10
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
11
11
  },
12
12
  "dependencies": {
13
- "@xylabs/assert": "^3.6.6",
14
- "@xylabs/object": "^3.6.6",
15
- "@xyo-network/diviner-model": "^2.110.18",
16
- "@xyo-network/diviner-payload-abstract": "^2.110.18",
17
- "@xyo-network/diviner-payload-model": "^2.110.18",
18
- "@xyo-network/payload-builder": "^2.110.18",
19
- "@xyo-network/payload-model": "^2.110.18"
13
+ "@xylabs/assert": "^3.6.8",
14
+ "@xylabs/object": "^3.6.8",
15
+ "@xyo-network/diviner-model": "^2.111.0",
16
+ "@xyo-network/diviner-payload-abstract": "^2.111.0",
17
+ "@xyo-network/diviner-payload-model": "^2.111.0",
18
+ "@xyo-network/payload-builder": "^2.111.0",
19
+ "@xyo-network/payload-model": "^2.111.0"
20
20
  },
21
21
  "devDependencies": {
22
- "@xylabs/delay": "^3.6.6",
23
- "@xylabs/ts-scripts-yarn3": "^3.14.1",
24
- "@xylabs/tsconfig": "^3.14.1",
25
- "@xyo-network/archivist-memory": "^2.110.18",
26
- "@xyo-network/node-memory": "^2.110.18",
27
- "@xyo-network/payload-builder": "^2.110.18",
22
+ "@xylabs/delay": "^3.6.8",
23
+ "@xylabs/ts-scripts-yarn3": "^3.15.5",
24
+ "@xylabs/tsconfig": "^3.15.5",
25
+ "@xyo-network/archivist-memory": "^2.111.0",
26
+ "@xyo-network/node-memory": "^2.111.0",
27
+ "@xyo-network/payload-builder": "^2.111.0",
28
28
  "typescript": "^5.5.4"
29
29
  },
30
30
  "description": "Primary SDK for using XYO Protocol 2.0",
@@ -38,7 +38,7 @@
38
38
  },
39
39
  "import": {
40
40
  "types": "./dist/browser/index.d.mts",
41
- "default": "./dist/browser/index.js"
41
+ "default": "./dist/browser/index.mjs"
42
42
  }
43
43
  },
44
44
  "node": {
@@ -48,14 +48,14 @@
48
48
  },
49
49
  "import": {
50
50
  "types": "./dist/node/index.d.mts",
51
- "default": "./dist/node/index.js"
51
+ "default": "./dist/node/index.mjs"
52
52
  }
53
53
  }
54
54
  },
55
55
  "./package.json": "./package.json"
56
56
  },
57
57
  "main": "dist/node/index.cjs",
58
- "module": "dist/node/index.js",
58
+ "module": "dist/node/index.mjs",
59
59
  "homepage": "https://xyo.network",
60
60
  "license": "LGPL-3.0-only",
61
61
  "publishConfig": {
@@ -66,6 +66,6 @@
66
66
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
67
67
  },
68
68
  "sideEffects": false,
69
- "version": "2.110.18",
69
+ "version": "2.111.0",
70
70
  "type": "module"
71
71
  }
@@ -27,47 +27,47 @@ export class MemoryPayloadDiviner<
27
27
  let all = (await archivist.all?.()) as WithMeta<TOut>[]
28
28
  if (all) {
29
29
  if (order === 'desc') all = all.reverse()
30
- if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))
30
+ if (schemas?.length) all = all.filter(payload => schemas.includes(payload.schema))
31
31
  if (timestamp !== undefined) {
32
32
  // If there was no order supplied with the original
33
33
  if (filter.order === undefined) {
34
34
  // filter for timestamp equality
35
- all = all.filter(hasTimestamp).filter((payload) => payload.timestamp === timestamp)
35
+ all = all.filter(hasTimestamp).filter(payload => payload.timestamp === timestamp)
36
36
  } else {
37
37
  // filter for greater than/less than or equal to
38
- all =
39
- order === 'asc' ?
40
- all.filter(hasTimestamp).filter((payload) => payload.timestamp >= timestamp)
41
- : all.filter(hasTimestamp).filter((payload) => payload.timestamp <= timestamp)
38
+ all
39
+ = order === 'asc'
40
+ ? all.filter(hasTimestamp).filter(payload => payload.timestamp >= timestamp)
41
+ : all.filter(hasTimestamp).filter(payload => payload.timestamp <= timestamp)
42
42
  }
43
43
  }
44
44
  if (Object.keys(props).length > 0) {
45
45
  const additionalFilterCriteria = Object.entries(props)
46
46
  for (const [prop, filter] of additionalFilterCriteria) {
47
47
  const property = prop as keyof TOut
48
- all =
49
- Array.isArray(filter) ?
50
- all.filter((payload) =>
48
+ all
49
+ = Array.isArray(filter)
50
+ ? all.filter(payload =>
51
51
  filter.every((value) => {
52
52
  const prop = payload?.[property]
53
- //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?
53
+ // TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?
54
54
  return Array.isArray(prop) && prop.includes?.(value)
55
55
  }),
56
56
  )
57
- : all.filter((payload) => payload?.[property] === filter)
57
+ : all.filter(payload => payload?.[property] === filter)
58
58
  }
59
59
  }
60
60
  const parsedLimit = limit ?? all.length
61
61
  const parsedOffset = offset || 0
62
- return offset === undefined ?
63
- (async () => {
62
+ return offset === undefined
63
+ ? (async () => {
64
64
  const allPairs = await PayloadBuilder.hashPairs(all)
65
65
  if (hash) {
66
- //remove all until found
66
+ // remove all until found
67
67
  while (allPairs.length > 0 && allPairs[0][1] !== hash) {
68
68
  allPairs.shift()
69
69
  }
70
- //remove it if found
70
+ // remove it if found
71
71
  if (allPairs.length > 0 && allPairs[0][1] === hash) {
72
72
  allPairs.shift()
73
73
  }
@@ -1 +0,0 @@
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 { isPayloadDivinerQueryPayload, PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.ts'\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 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,SAASC,oCAAsF;AAC/F,SAASC,sBAAsB;;;ACHxB,IAAMC,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADQrB,IAAMC,uBAAN,cASGC,eAAAA;EApBV,OAoBUA;;;EACR,MAAyBC,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","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","parsedLimit","parsedOffset","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
@@ -1 +0,0 @@
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 { isPayloadDivinerQueryPayload, PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.ts'\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 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,SAASC,oCAAsF;AAC/F,SAASC,sBAAsB;;;ACHxB,IAAMC,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADQrB,IAAMC,uBAAN,cASGC,eAAAA;EApBV,OAoBUA;;;EACR,MAAyBC,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","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","parsedLimit","parsedOffset","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
@@ -1 +0,0 @@
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 { isPayloadDivinerQueryPayload, PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport { hasTimestamp } from './hasTimestamp.ts'\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 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,SAASC,oCAAsF;AAC/F,SAASC,sBAAsB;;;ACHxB,IAAMC,eAAe,wBAAyCC,YAAAA;AACnE,SAAQA,QAA6CC,cAAcC;AACrE,GAF4B;;;ADQrB,IAAMC,wBAAN,MAAMA,8BASHC,eAAAA;EACR,MAAyBC,cAAcC,UAA6C;AArBtF;AAsBI,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;AAlD9B,gBAAAC;AAmDkB,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;AA7DU5C;AATH,IAAMD,uBAAN;","names":["assertEx","removeFields","PayloadDiviner","isPayloadDivinerQueryPayload","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"]}