@xyo-network/diviner-payload-memory 2.98.5 → 2.99.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/MemoryPayloadDiviner.d.cts +2 -2
- package/dist/browser/MemoryPayloadDiviner.d.cts.map +1 -1
- package/dist/browser/MemoryPayloadDiviner.d.mts +2 -2
- package/dist/browser/MemoryPayloadDiviner.d.mts.map +1 -1
- package/dist/browser/MemoryPayloadDiviner.d.ts +2 -2
- package/dist/browser/MemoryPayloadDiviner.d.ts.map +1 -1
- package/dist/browser/index.cjs +3 -3
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +3 -3
- package/dist/browser/index.js.map +1 -1
- package/dist/node/MemoryPayloadDiviner.d.cts +2 -2
- package/dist/node/MemoryPayloadDiviner.d.cts.map +1 -1
- package/dist/node/MemoryPayloadDiviner.d.mts +2 -2
- package/dist/node/MemoryPayloadDiviner.d.mts.map +1 -1
- package/dist/node/MemoryPayloadDiviner.d.ts +2 -2
- package/dist/node/MemoryPayloadDiviner.d.ts.map +1 -1
- package/dist/node/index.cjs +3 -3
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +3 -3
- package/dist/node/index.js.map +1 -1
- package/package.json +12 -12
- package/src/MemoryPayloadDiviner.ts +5 -5
|
@@ -3,8 +3,8 @@ import { PayloadDiviner } from '@xyo-network/diviner-payload-abstract';
|
|
|
3
3
|
import { PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model';
|
|
4
4
|
import { Payload, Schema, WithMeta } from '@xyo-network/payload-model';
|
|
5
5
|
export declare class MemoryPayloadDiviner<TParams extends PayloadDivinerParams = PayloadDivinerParams, TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload, TOut extends Payload = Payload, TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut>> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {
|
|
6
|
-
static configSchemas: Schema[];
|
|
7
|
-
static defaultConfigSchema: Schema;
|
|
6
|
+
static readonly configSchemas: Schema[];
|
|
7
|
+
static readonly defaultConfigSchema: Schema;
|
|
8
8
|
protected divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]>;
|
|
9
9
|
}
|
|
10
10
|
//# sourceMappingURL=MemoryPayloadDiviner.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,
|
|
1
|
+
{"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
|
|
@@ -3,8 +3,8 @@ import { PayloadDiviner } from '@xyo-network/diviner-payload-abstract';
|
|
|
3
3
|
import { PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model';
|
|
4
4
|
import { Payload, Schema, WithMeta } from '@xyo-network/payload-model';
|
|
5
5
|
export declare class MemoryPayloadDiviner<TParams extends PayloadDivinerParams = PayloadDivinerParams, TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload, TOut extends Payload = Payload, TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut>> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {
|
|
6
|
-
static configSchemas: Schema[];
|
|
7
|
-
static defaultConfigSchema: Schema;
|
|
6
|
+
static readonly configSchemas: Schema[];
|
|
7
|
+
static readonly defaultConfigSchema: Schema;
|
|
8
8
|
protected divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]>;
|
|
9
9
|
}
|
|
10
10
|
//# sourceMappingURL=MemoryPayloadDiviner.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,
|
|
1
|
+
{"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
|
|
@@ -3,8 +3,8 @@ import { PayloadDiviner } from '@xyo-network/diviner-payload-abstract';
|
|
|
3
3
|
import { PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model';
|
|
4
4
|
import { Payload, Schema, WithMeta } from '@xyo-network/payload-model';
|
|
5
5
|
export declare class MemoryPayloadDiviner<TParams extends PayloadDivinerParams = PayloadDivinerParams, TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload, TOut extends Payload = Payload, TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut>> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {
|
|
6
|
-
static configSchemas: Schema[];
|
|
7
|
-
static defaultConfigSchema: Schema;
|
|
6
|
+
static readonly configSchemas: Schema[];
|
|
7
|
+
static readonly defaultConfigSchema: Schema;
|
|
8
8
|
protected divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]>;
|
|
9
9
|
}
|
|
10
10
|
//# sourceMappingURL=MemoryPayloadDiviner.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,
|
|
1
|
+
{"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
|
package/dist/browser/index.cjs
CHANGED
|
@@ -45,7 +45,7 @@ var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.Payload
|
|
|
45
45
|
if (!filter)
|
|
46
46
|
return [];
|
|
47
47
|
const archivist = (0, import_assert.assertEx)(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
48
|
-
const { schemas, limit, offset, hash, order, ...props } = (0, import_object.removeFields)(filter, [
|
|
48
|
+
const { schemas, limit, offset, hash, order = "desc", ...props } = (0, import_object.removeFields)(filter, [
|
|
49
49
|
"schema",
|
|
50
50
|
"$meta",
|
|
51
51
|
"$hash"
|
|
@@ -78,8 +78,8 @@ var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.Payload
|
|
|
78
78
|
allPairs.shift();
|
|
79
79
|
}
|
|
80
80
|
}
|
|
81
|
-
return allPairs.map(([payload]) => payload);
|
|
82
|
-
})() : all.slice(parsedOffset, parsedLimit);
|
|
81
|
+
return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit);
|
|
82
|
+
})() : all.slice(parsedOffset, parsedOffset + parsedLimit);
|
|
83
83
|
} else {
|
|
84
84
|
throw new Error('Archivist does not support "all"');
|
|
85
85
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order, ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload)\n })()\n : all.slice(parsedOffset, parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,oBAA6B;AAE7B,sCAA+B;AAC/B,mCAKO;AACP,6BAA+B;AAGxB,IAAMA,uBAAN,cASGC,+CAAAA;EAtBV,OAsBUA;;;EACR,
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,oBAA6B;AAE7B,sCAA+B;AAC/B,mCAKO;AACP,6BAA+B;AAGxB,IAAMA,uBAAN,cASGC,+CAAAA;EAtBV,OAsBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAyBE,cAAcC,UAA6C;AAClF,UAAMC,aAASC,wBAASF,UAAUC,OAAOE,yDAAAA,GAA+BC,IAAAA,GAAO,MAAM,uBAAA;AACrF,QAAI,CAACH;AAAQ,aAAO,CAAA;AACpB,UAAMI,gBAAYH,wBAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQ,GAAGC,MAAAA,QAAUC,4BAAaZ,QAAyB;MAAC;MAAU;MAAS;KAAQ;AACrI,QAAIa,MAAO,MAAMT,UAAUS,MAAG;AAC9B,QAAIA,KAAK;AACP,UAAIH,UAAU;AAAQG,cAAMA,IAAIC,QAAO;AACvC,UAAIR,SAASS;AAAQF,cAAMA,IAAIb,OAAO,CAACgB,YAAYV,QAAQW,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIC,OAAOC,KAAKT,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMM,2BAA2BF,OAAOG,QAAQX,KAAAA;AAChD,mBAAW,CAACY,MAAMvB,OAAAA,KAAWqB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBV,gBACEY,MAAMC,QAAQ1B,OAAAA,IACZa,IAAIb,OAAO,CAACgB,YACVhB,QAAO2B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOP,UAAUQ,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKN,WAAWW,KAAAA;UAChD,CAAA,CAAA,IAEFf,IAAIb,OAAO,CAACgB,YAAYA,UAAUQ,QAAAA,MAAcxB,OAAAA;QACtD;MACF;AACA,YAAM6B,cAActB,SAASM,IAAIE;AACjC,YAAMe,eAAetB,UAAU;AAC/B,aAAOA,WAAWuB,UACb,YAAA;AACC,cAAMC,WAAW,MAAMC,sCAAeC,UAAUrB,GAAAA;AAChD,YAAIJ,MAAM;AAER,iBAAOuB,SAASjB,SAAS,KAAKiB,SAAS,CAAA,EAAG,CAAA,MAAOvB,MAAM;AACrDuB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASjB,SAAS,KAAKiB,SAAS,CAAA,EAAG,CAAA,MAAOvB,MAAM;AAClDuB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACpB,OAAAA,MAAaA,OAAAA,EAASqB,MAAMP,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAhB,IAAIwB,MAAMP,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIS,MAAM,kCAAA;IAClB;EACF;AACF;","names":["MemoryPayloadDiviner","PayloadDiviner","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","props","removeFields","all","reverse","length","payload","includes","schema","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","parsedLimit","parsedOffset","undefined","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
|
package/dist/browser/index.js
CHANGED
|
@@ -21,7 +21,7 @@ var MemoryPayloadDiviner = class extends PayloadDiviner {
|
|
|
21
21
|
if (!filter)
|
|
22
22
|
return [];
|
|
23
23
|
const archivist = assertEx(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
24
|
-
const { schemas, limit, offset, hash, order, ...props } = removeFields(filter, [
|
|
24
|
+
const { schemas, limit, offset, hash, order = "desc", ...props } = removeFields(filter, [
|
|
25
25
|
"schema",
|
|
26
26
|
"$meta",
|
|
27
27
|
"$hash"
|
|
@@ -54,8 +54,8 @@ var MemoryPayloadDiviner = class extends PayloadDiviner {
|
|
|
54
54
|
allPairs.shift();
|
|
55
55
|
}
|
|
56
56
|
}
|
|
57
|
-
return allPairs.map(([payload]) => payload);
|
|
58
|
-
})() : all.slice(parsedOffset, parsedLimit);
|
|
57
|
+
return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit);
|
|
58
|
+
})() : all.slice(parsedOffset, parsedOffset + parsedLimit);
|
|
59
59
|
} else {
|
|
60
60
|
throw new Error('Archivist does not support "all"');
|
|
61
61
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order, ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload)\n })()\n : all.slice(parsedOffset, parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,oBAAoB;AAE7B,SAASC,sBAAsB;AAC/B,SACEC,8BACAC,kCAGK;AACP,SAASC,sBAAsB;AAGxB,IAAMC,uBAAN,cASGC,eAAAA;EAtBV,OAsBUA;;;EACR,
|
|
1
|
+
{"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,oBAAoB;AAE7B,SAASC,sBAAsB;AAC/B,SACEC,8BACAC,kCAGK;AACP,SAASC,sBAAsB;AAGxB,IAAMC,uBAAN,cASGC,eAAAA;EAtBV,OAsBUA;;;EACR,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAyBE,cAAcC,UAA6C;AAClF,UAAMC,SAASC,SAASF,UAAUC,OAAOE,4BAAAA,GAA+BC,IAAAA,GAAO,MAAM,uBAAA;AACrF,QAAI,CAACH;AAAQ,aAAO,CAAA;AACpB,UAAMI,YAAYH,SAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQ,GAAGC,MAAAA,IAAUC,aAAaZ,QAAyB;MAAC;MAAU;MAAS;KAAQ;AACrI,QAAIa,MAAO,MAAMT,UAAUS,MAAG;AAC9B,QAAIA,KAAK;AACP,UAAIH,UAAU;AAAQG,cAAMA,IAAIC,QAAO;AACvC,UAAIR,SAASS;AAAQF,cAAMA,IAAIb,OAAO,CAACgB,YAAYV,QAAQW,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIC,OAAOC,KAAKT,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMM,2BAA2BF,OAAOG,QAAQX,KAAAA;AAChD,mBAAW,CAACY,MAAMvB,OAAAA,KAAWqB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBV,gBACEY,MAAMC,QAAQ1B,OAAAA,IACZa,IAAIb,OAAO,CAACgB,YACVhB,QAAO2B,MAAM,CAACC,UAAAA;AACZ,kBAAML,QAAOP,UAAUQ,QAAAA;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,KAASA,MAAKN,WAAWW,KAAAA;UAChD,CAAA,CAAA,IAEFf,IAAIb,OAAO,CAACgB,YAAYA,UAAUQ,QAAAA,MAAcxB,OAAAA;QACtD;MACF;AACA,YAAM6B,cAActB,SAASM,IAAIE;AACjC,YAAMe,eAAetB,UAAU;AAC/B,aAAOA,WAAWuB,UACb,YAAA;AACC,cAAMC,WAAW,MAAMC,eAAeC,UAAUrB,GAAAA;AAChD,YAAIJ,MAAM;AAER,iBAAOuB,SAASjB,SAAS,KAAKiB,SAAS,CAAA,EAAG,CAAA,MAAOvB,MAAM;AACrDuB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASjB,SAAS,KAAKiB,SAAS,CAAA,EAAG,CAAA,MAAOvB,MAAM;AAClDuB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACpB,OAAAA,MAAaA,OAAAA,EAASqB,MAAMP,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAhB,IAAIwB,MAAMP,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIS,MAAM,kCAAA;IAClB;EACF;AACF;","names":["assertEx","removeFields","PayloadDiviner","isPayloadDivinerQueryPayload","PayloadDivinerConfigSchema","PayloadBuilder","MemoryPayloadDiviner","PayloadDiviner","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","props","removeFields","all","reverse","length","payload","includes","schema","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","parsedLimit","parsedOffset","undefined","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error"]}
|
|
@@ -3,8 +3,8 @@ import { PayloadDiviner } from '@xyo-network/diviner-payload-abstract';
|
|
|
3
3
|
import { PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model';
|
|
4
4
|
import { Payload, Schema, WithMeta } from '@xyo-network/payload-model';
|
|
5
5
|
export declare class MemoryPayloadDiviner<TParams extends PayloadDivinerParams = PayloadDivinerParams, TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload, TOut extends Payload = Payload, TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut>> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {
|
|
6
|
-
static configSchemas: Schema[];
|
|
7
|
-
static defaultConfigSchema: Schema;
|
|
6
|
+
static readonly configSchemas: Schema[];
|
|
7
|
+
static readonly defaultConfigSchema: Schema;
|
|
8
8
|
protected divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]>;
|
|
9
9
|
}
|
|
10
10
|
//# sourceMappingURL=MemoryPayloadDiviner.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,
|
|
1
|
+
{"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
|
|
@@ -3,8 +3,8 @@ import { PayloadDiviner } from '@xyo-network/diviner-payload-abstract';
|
|
|
3
3
|
import { PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model';
|
|
4
4
|
import { Payload, Schema, WithMeta } from '@xyo-network/payload-model';
|
|
5
5
|
export declare class MemoryPayloadDiviner<TParams extends PayloadDivinerParams = PayloadDivinerParams, TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload, TOut extends Payload = Payload, TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut>> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {
|
|
6
|
-
static configSchemas: Schema[];
|
|
7
|
-
static defaultConfigSchema: Schema;
|
|
6
|
+
static readonly configSchemas: Schema[];
|
|
7
|
+
static readonly defaultConfigSchema: Schema;
|
|
8
8
|
protected divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]>;
|
|
9
9
|
}
|
|
10
10
|
//# sourceMappingURL=MemoryPayloadDiviner.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,
|
|
1
|
+
{"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
|
|
@@ -3,8 +3,8 @@ import { PayloadDiviner } from '@xyo-network/diviner-payload-abstract';
|
|
|
3
3
|
import { PayloadDivinerParams, PayloadDivinerQueryPayload } from '@xyo-network/diviner-payload-model';
|
|
4
4
|
import { Payload, Schema, WithMeta } from '@xyo-network/payload-model';
|
|
5
5
|
export declare class MemoryPayloadDiviner<TParams extends PayloadDivinerParams = PayloadDivinerParams, TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload, TOut extends Payload = Payload, TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut>> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {
|
|
6
|
-
static configSchemas: Schema[];
|
|
7
|
-
static defaultConfigSchema: Schema;
|
|
6
|
+
static readonly configSchemas: Schema[];
|
|
7
|
+
static readonly defaultConfigSchema: Schema;
|
|
8
8
|
protected divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]>;
|
|
9
9
|
}
|
|
10
10
|
//# sourceMappingURL=MemoryPayloadDiviner.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,
|
|
1
|
+
{"version":3,"file":"MemoryPayloadDiviner.d.ts","sourceRoot":"","sources":["../../src/MemoryPayloadDiviner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAA;AACtE,OAAO,EAGL,oBAAoB,EACpB,0BAA0B,EAC3B,MAAM,oCAAoC,CAAA;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEtE,qBAAa,oBAAoB,CAC/B,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,GAAG,SAAS,0BAA0B,GAAG,0BAA0B,EACnE,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CACD,SAAQ,cAAc,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAuD;IACvG,gBAAyB,mBAAmB,EAAE,MAAM,CAA6B;cAExD,aAAa,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CA+CpF"}
|
package/dist/node/index.cjs
CHANGED
|
@@ -46,7 +46,7 @@ var _MemoryPayloadDiviner = class _MemoryPayloadDiviner extends import_diviner_p
|
|
|
46
46
|
if (!filter)
|
|
47
47
|
return [];
|
|
48
48
|
const archivist = (0, import_assert.assertEx)(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
49
|
-
const { schemas, limit, offset, hash, order, ...props } = (0, import_object.removeFields)(filter, [
|
|
49
|
+
const { schemas, limit, offset, hash, order = "desc", ...props } = (0, import_object.removeFields)(filter, [
|
|
50
50
|
"schema",
|
|
51
51
|
"$meta",
|
|
52
52
|
"$hash"
|
|
@@ -80,8 +80,8 @@ var _MemoryPayloadDiviner = class _MemoryPayloadDiviner extends import_diviner_p
|
|
|
80
80
|
allPairs.shift();
|
|
81
81
|
}
|
|
82
82
|
}
|
|
83
|
-
return allPairs.map(([payload]) => payload);
|
|
84
|
-
})() : all.slice(parsedOffset, parsedLimit);
|
|
83
|
+
return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit);
|
|
84
|
+
})() : all.slice(parsedOffset, parsedOffset + parsedLimit);
|
|
85
85
|
} else {
|
|
86
86
|
throw new Error('Archivist does not support "all"');
|
|
87
87
|
}
|
package/dist/node/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order, ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload)\n })()\n : all.slice(parsedOffset, parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,oBAA6B;AAE7B,sCAA+B;AAC/B,mCAKO;AACP,6BAA+B;AAGxB,IAAMA,wBAAN,MAAMA,8BASHC,+CAAAA;EAIR,MAAyBC,cAAcC,UAA6C;AA1BtF;AA2BI,UAAMC,aAASC,yBAASF,0CAAUC,OAAOE,+DAAjBH,mBAAgDI,OAAO,MAAM,uBAAA;AACrF,QAAI,CAACH;AAAQ,aAAO,CAAA;AACpB,UAAMI,gBAAYH,wBAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["export * from './MemoryPayloadDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,oBAA6B;AAE7B,sCAA+B;AAC/B,mCAKO;AACP,6BAA+B;AAGxB,IAAMA,wBAAN,MAAMA,8BASHC,+CAAAA;EAIR,MAAyBC,cAAcC,UAA6C;AA1BtF;AA2BI,UAAMC,aAASC,yBAASF,0CAAUC,OAAOE,+DAAjBH,mBAAgDI,OAAO,MAAM,uBAAA;AACrF,QAAI,CAACH;AAAQ,aAAO,CAAA;AACpB,UAAMI,gBAAYH,wBAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQ,GAAGC,MAAAA,QAAUC,4BAAaZ,QAAyB;MAAC;MAAU;MAAS;KAAQ;AACrI,QAAIa,MAAO,QAAMT,eAAUS,QAAVT;AACjB,QAAIS,KAAK;AACP,UAAIH,UAAU;AAAQG,cAAMA,IAAIC,QAAO;AACvC,UAAIR,mCAASS;AAAQF,cAAMA,IAAIb,OAAO,CAACgB,YAAYV,QAAQW,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIC,OAAOC,KAAKT,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMM,2BAA2BF,OAAOG,QAAQX,KAAAA;AAChD,mBAAW,CAACY,MAAMvB,OAAAA,KAAWqB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBV,gBACEY,MAAMC,QAAQ1B,OAAAA,IACZa,IAAIb,OAAO,CAACgB,YACVhB,QAAO2B,MAAM,CAACC,UAAAA;AA1C9B,gBAAAC;AA2CkB,kBAAMN,QAAOP,mCAAUQ;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,OAASA,MAAAA,MAAKN,aAALM,gBAAAA,IAAAA,KAAAA,OAAgBK;UAChD,CAAA,CAAA,IAEFf,IAAIb,OAAO,CAACgB,aAAYA,mCAAUQ,eAAcxB,OAAAA;QACtD;MACF;AACA,YAAM8B,cAAcvB,SAASM,IAAIE;AACjC,YAAMgB,eAAevB,UAAU;AAC/B,aAAOA,WAAWwB,UACb,YAAA;AACC,cAAMC,WAAW,MAAMC,sCAAeC,UAAUtB,GAAAA;AAChD,YAAIJ,MAAM;AAER,iBAAOwB,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOxB,MAAM;AACrDwB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOxB,MAAM;AAClDwB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACrB,OAAAA,MAAaA,OAAAA,EAASsB,MAAMP,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAjB,IAAIyB,MAAMP,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIS,MAAM,kCAAA;IAClB;EACF;AACF;AAnDU1C;AACR,cAVWD,uBAUc4C,iBAA0B;KAAI,yDAAMA;EAAeC;;AAC5E,cAXW7C,uBAWc8C,uBAA8BD;AAXlD,IAAM7C,uBAAN;","names":["MemoryPayloadDiviner","PayloadDiviner","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","props","removeFields","all","reverse","length","payload","includes","schema","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","_a","parsedLimit","parsedOffset","undefined","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema"]}
|
package/dist/node/index.js
CHANGED
|
@@ -22,7 +22,7 @@ var _MemoryPayloadDiviner = class _MemoryPayloadDiviner extends PayloadDiviner {
|
|
|
22
22
|
if (!filter)
|
|
23
23
|
return [];
|
|
24
24
|
const archivist = assertEx(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
25
|
-
const { schemas, limit, offset, hash, order, ...props } = removeFields(filter, [
|
|
25
|
+
const { schemas, limit, offset, hash, order = "desc", ...props } = removeFields(filter, [
|
|
26
26
|
"schema",
|
|
27
27
|
"$meta",
|
|
28
28
|
"$hash"
|
|
@@ -56,8 +56,8 @@ var _MemoryPayloadDiviner = class _MemoryPayloadDiviner extends PayloadDiviner {
|
|
|
56
56
|
allPairs.shift();
|
|
57
57
|
}
|
|
58
58
|
}
|
|
59
|
-
return allPairs.map(([payload]) => payload);
|
|
60
|
-
})() : all.slice(parsedOffset, parsedLimit);
|
|
59
|
+
return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit);
|
|
60
|
+
})() : all.slice(parsedOffset, parsedOffset + parsedLimit);
|
|
61
61
|
} else {
|
|
62
62
|
throw new Error('Archivist does not support "all"');
|
|
63
63
|
}
|
package/dist/node/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order, ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload)\n })()\n : all.slice(parsedOffset, parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,oBAAoB;AAE7B,SAASC,sBAAsB;AAC/B,SACEC,8BACAC,kCAGK;AACP,SAASC,sBAAsB;AAGxB,IAAMC,wBAAN,MAAMA,8BASHC,eAAAA;EAIR,MAAyBC,cAAcC,UAA6C;AA1BtF;AA2BI,UAAMC,SAASC,UAASF,0CAAUC,OAAOE,kCAAjBH,mBAAgDI,OAAO,MAAM,uBAAA;AACrF,QAAI,CAACH;AAAQ,aAAO,CAAA;AACpB,UAAMI,YAAYH,SAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,
|
|
1
|
+
{"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,oBAAoB;AAE7B,SAASC,sBAAsB;AAC/B,SACEC,8BACAC,kCAGK;AACP,SAASC,sBAAsB;AAGxB,IAAMC,wBAAN,MAAMA,8BASHC,eAAAA;EAIR,MAAyBC,cAAcC,UAA6C;AA1BtF;AA2BI,UAAMC,SAASC,UAASF,0CAAUC,OAAOE,kCAAjBH,mBAAgDI,OAAO,MAAM,uBAAA;AACrF,QAAI,CAACH;AAAQ,aAAO,CAAA;AACpB,UAAMI,YAAYH,SAAS,MAAM,KAAKI,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAM,EAAEC,SAASC,OAAOC,QAAQC,MAAMC,QAAQ,QAAQ,GAAGC,MAAAA,IAAUC,aAAaZ,QAAyB;MAAC;MAAU;MAAS;KAAQ;AACrI,QAAIa,MAAO,QAAMT,eAAUS,QAAVT;AACjB,QAAIS,KAAK;AACP,UAAIH,UAAU;AAAQG,cAAMA,IAAIC,QAAO;AACvC,UAAIR,mCAASS;AAAQF,cAAMA,IAAIb,OAAO,CAACgB,YAAYV,QAAQW,SAASD,QAAQE,MAAM,CAAA;AAClF,UAAIC,OAAOC,KAAKT,KAAAA,EAAOI,SAAS,GAAG;AACjC,cAAMM,2BAA2BF,OAAOG,QAAQX,KAAAA;AAChD,mBAAW,CAACY,MAAMvB,OAAAA,KAAWqB,0BAA0B;AACrD,gBAAMG,WAAWD;AACjBV,gBACEY,MAAMC,QAAQ1B,OAAAA,IACZa,IAAIb,OAAO,CAACgB,YACVhB,QAAO2B,MAAM,CAACC,UAAAA;AA1C9B,gBAAAC;AA2CkB,kBAAMN,QAAOP,mCAAUQ;AAEvB,mBAAOC,MAAMC,QAAQH,KAAAA,OAASA,MAAAA,MAAKN,aAALM,gBAAAA,IAAAA,KAAAA,OAAgBK;UAChD,CAAA,CAAA,IAEFf,IAAIb,OAAO,CAACgB,aAAYA,mCAAUQ,eAAcxB,OAAAA;QACtD;MACF;AACA,YAAM8B,cAAcvB,SAASM,IAAIE;AACjC,YAAMgB,eAAevB,UAAU;AAC/B,aAAOA,WAAWwB,UACb,YAAA;AACC,cAAMC,WAAW,MAAMC,eAAeC,UAAUtB,GAAAA;AAChD,YAAIJ,MAAM;AAER,iBAAOwB,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOxB,MAAM;AACrDwB,qBAASG,MAAK;UAChB;AAEA,cAAIH,SAASlB,SAAS,KAAKkB,SAAS,CAAA,EAAG,CAAA,MAAOxB,MAAM;AAClDwB,qBAASG,MAAK;UAChB;QACF;AACA,eAAOH,SAASI,IAAI,CAAC,CAACrB,OAAAA,MAAaA,OAAAA,EAASsB,MAAMP,cAAcA,eAAeD,WAAAA;MACjF,GAAA,IACAjB,IAAIyB,MAAMP,cAAcA,eAAeD,WAAAA;IAC7C,OAAO;AACL,YAAM,IAAIS,MAAM,kCAAA;IAClB;EACF;AACF;AAnDU1C;AACR,cAVWD,uBAUc4C,iBAA0B;KAAI,yDAAMA;EAAeC;;AAC5E,cAXW7C,uBAWc8C,uBAA8BD;AAXlD,IAAM7C,uBAAN;","names":["assertEx","removeFields","PayloadDiviner","isPayloadDivinerQueryPayload","PayloadDivinerConfigSchema","PayloadBuilder","MemoryPayloadDiviner","PayloadDiviner","divineHandler","payloads","filter","assertEx","isPayloadDivinerQueryPayload","pop","archivist","archivistInstance","schemas","limit","offset","hash","order","props","removeFields","all","reverse","length","payload","includes","schema","Object","keys","additionalFilterCriteria","entries","prop","property","Array","isArray","every","value","_a","parsedLimit","parsedOffset","undefined","allPairs","PayloadBuilder","hashPairs","shift","map","slice","Error","configSchemas","PayloadDivinerConfigSchema","defaultConfigSchema"]}
|
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.1.
|
|
14
|
-
"@xylabs/object": "^3.1.
|
|
15
|
-
"@xyo-network/diviner-model": "~2.
|
|
16
|
-
"@xyo-network/diviner-payload-abstract": "~2.
|
|
17
|
-
"@xyo-network/diviner-payload-model": "~2.
|
|
18
|
-
"@xyo-network/payload-builder": "~2.
|
|
19
|
-
"@xyo-network/payload-model": "~2.
|
|
13
|
+
"@xylabs/assert": "^3.1.11",
|
|
14
|
+
"@xylabs/object": "^3.1.11",
|
|
15
|
+
"@xyo-network/diviner-model": "~2.99.1",
|
|
16
|
+
"@xyo-network/diviner-payload-abstract": "~2.99.1",
|
|
17
|
+
"@xyo-network/diviner-payload-model": "~2.99.1",
|
|
18
|
+
"@xyo-network/payload-builder": "~2.99.1",
|
|
19
|
+
"@xyo-network/payload-model": "~2.99.1"
|
|
20
20
|
},
|
|
21
21
|
"devDependencies": {
|
|
22
22
|
"@xylabs/ts-scripts-yarn3": "^3.9.1",
|
|
23
23
|
"@xylabs/tsconfig": "^3.9.1",
|
|
24
|
-
"@xyo-network/account": "~2.
|
|
25
|
-
"@xyo-network/archivist-memory": "~2.
|
|
26
|
-
"@xyo-network/node-memory": "~2.
|
|
27
|
-
"@xyo-network/payload-builder": "~2.
|
|
24
|
+
"@xyo-network/account": "~2.99.1",
|
|
25
|
+
"@xyo-network/archivist-memory": "~2.99.1",
|
|
26
|
+
"@xyo-network/node-memory": "~2.99.1",
|
|
27
|
+
"@xyo-network/payload-builder": "~2.99.1",
|
|
28
28
|
"typescript": "^5.4.5"
|
|
29
29
|
},
|
|
30
30
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
@@ -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.
|
|
69
|
+
"version": "2.99.1",
|
|
70
70
|
"type": "module"
|
|
71
71
|
}
|
|
@@ -21,14 +21,14 @@ export class MemoryPayloadDiviner<
|
|
|
21
21
|
TOut
|
|
22
22
|
>,
|
|
23
23
|
> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {
|
|
24
|
-
static override configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]
|
|
25
|
-
static override defaultConfigSchema: Schema = PayloadDivinerConfigSchema
|
|
24
|
+
static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]
|
|
25
|
+
static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema
|
|
26
26
|
|
|
27
27
|
protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {
|
|
28
28
|
const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')
|
|
29
29
|
if (!filter) return []
|
|
30
30
|
const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')
|
|
31
|
-
const { schemas, limit, offset, hash, order, ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])
|
|
31
|
+
const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])
|
|
32
32
|
let all = (await archivist.all?.()) as WithMeta<TOut>[]
|
|
33
33
|
if (all) {
|
|
34
34
|
if (order === 'desc') all = all.reverse()
|
|
@@ -64,9 +64,9 @@ export class MemoryPayloadDiviner<
|
|
|
64
64
|
allPairs.shift()
|
|
65
65
|
}
|
|
66
66
|
}
|
|
67
|
-
return allPairs.map(([payload]) => payload)
|
|
67
|
+
return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)
|
|
68
68
|
})()
|
|
69
|
-
: all.slice(parsedOffset, parsedLimit)
|
|
69
|
+
: all.slice(parsedOffset, parsedOffset + parsedLimit)
|
|
70
70
|
} else {
|
|
71
71
|
throw new Error('Archivist does not support "all"')
|
|
72
72
|
}
|