@xyo-network/diviner-payload-memory 2.106.0 → 2.107.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.
- package/dist/browser/index.cjs +1 -84
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +1 -63
- package/dist/browser/index.js.map +1 -1
- package/dist/neutral/index.cjs +1 -84
- package/dist/neutral/index.cjs.map +1 -1
- package/dist/neutral/index.js +1 -63
- package/dist/neutral/index.js.map +1 -1
- package/dist/node/index.cjs +1 -94
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +1 -69
- package/dist/node/index.js.map +1 -1
- package/package.json +13 -13
package/dist/browser/index.cjs
CHANGED
|
@@ -1,85 +1,2 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
7
|
-
var __export = (target, all) => {
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
11
|
-
var __copyProps = (to, from, except, desc) => {
|
|
12
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
-
for (let key of __getOwnPropNames(from))
|
|
14
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
19
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
20
|
-
|
|
21
|
-
// src/index.ts
|
|
22
|
-
var src_exports = {};
|
|
23
|
-
__export(src_exports, {
|
|
24
|
-
MemoryPayloadDiviner: () => MemoryPayloadDiviner
|
|
25
|
-
});
|
|
26
|
-
module.exports = __toCommonJS(src_exports);
|
|
27
|
-
|
|
28
|
-
// src/MemoryPayloadDiviner.ts
|
|
29
|
-
var import_assert = require("@xylabs/assert");
|
|
30
|
-
var import_object = require("@xylabs/object");
|
|
31
|
-
var import_diviner_payload_abstract = require("@xyo-network/diviner-payload-abstract");
|
|
32
|
-
var import_diviner_payload_model = require("@xyo-network/diviner-payload-model");
|
|
33
|
-
var import_payload_builder = require("@xyo-network/payload-builder");
|
|
34
|
-
var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.PayloadDiviner {
|
|
35
|
-
static {
|
|
36
|
-
__name(this, "MemoryPayloadDiviner");
|
|
37
|
-
}
|
|
38
|
-
static configSchemas = [
|
|
39
|
-
...super.configSchemas,
|
|
40
|
-
import_diviner_payload_model.PayloadDivinerConfigSchema
|
|
41
|
-
];
|
|
42
|
-
static defaultConfigSchema = import_diviner_payload_model.PayloadDivinerConfigSchema;
|
|
43
|
-
async divineHandler(payloads) {
|
|
44
|
-
const filter = (0, import_assert.assertEx)(payloads?.filter(import_diviner_payload_model.isPayloadDivinerQueryPayload)?.pop(), () => "Missing query payload");
|
|
45
|
-
if (!filter) return [];
|
|
46
|
-
const archivist = (0, import_assert.assertEx)(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
47
|
-
const { schemas, limit, offset, hash, order = "desc", ...props } = (0, import_object.removeFields)(filter, [
|
|
48
|
-
"schema",
|
|
49
|
-
"$meta",
|
|
50
|
-
"$hash"
|
|
51
|
-
]);
|
|
52
|
-
let all = await archivist.all?.();
|
|
53
|
-
if (all) {
|
|
54
|
-
if (order === "desc") all = all.reverse();
|
|
55
|
-
if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema));
|
|
56
|
-
if (Object.keys(props).length > 0) {
|
|
57
|
-
const additionalFilterCriteria = Object.entries(props);
|
|
58
|
-
for (const [prop, filter2] of additionalFilterCriteria) {
|
|
59
|
-
const property = prop;
|
|
60
|
-
all = Array.isArray(filter2) ? all.filter((payload) => filter2.every((value) => {
|
|
61
|
-
const prop2 = payload?.[property];
|
|
62
|
-
return Array.isArray(prop2) && prop2.includes?.(value);
|
|
63
|
-
})) : all.filter((payload) => payload?.[property] === filter2);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
const parsedLimit = limit ?? all.length;
|
|
67
|
-
const parsedOffset = offset || 0;
|
|
68
|
-
return offset === void 0 ? (async () => {
|
|
69
|
-
const allPairs = await import_payload_builder.PayloadBuilder.hashPairs(all);
|
|
70
|
-
if (hash) {
|
|
71
|
-
while (allPairs.length > 0 && allPairs[0][1] !== hash) {
|
|
72
|
-
allPairs.shift();
|
|
73
|
-
}
|
|
74
|
-
if (allPairs.length > 0 && allPairs[0][1] === hash) {
|
|
75
|
-
allPairs.shift();
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit);
|
|
79
|
-
})() : all.slice(parsedOffset, parsedOffset + parsedLimit);
|
|
80
|
-
} else {
|
|
81
|
-
throw new Error('Archivist does not support "all"');
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
};
|
|
1
|
+
"use strict";var c=Object.defineProperty;var D=Object.getOwnPropertyDescriptor;var E=Object.getOwnPropertyNames;var F=Object.prototype.hasOwnProperty;var A=(t,e)=>c(t,"name",{value:e,configurable:!0});var $=(t,e)=>{for(var a in e)c(t,a,{get:e[a],enumerable:!0})},k=(t,e,a,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of E(e))!F.call(t,s)&&s!==a&&c(t,s,{get:()=>e[s],enumerable:!(n=D(e,s))||n.enumerable});return t};var q=t=>k(c({},"__esModule",{value:!0}),t);var B={};$(B,{MemoryPayloadDiviner:()=>y});module.exports=q(B);var m=require("@xylabs/assert"),x=require("@xylabs/object"),S=require("@xyo-network/diviner-payload-abstract"),o=require("@xyo-network/diviner-payload-model"),b=require("@xyo-network/payload-builder");var y=class extends S.PayloadDiviner{static{A(this,"MemoryPayloadDiviner")}static configSchemas=[...super.configSchemas,o.PayloadDivinerConfigSchema];static defaultConfigSchema=o.PayloadDivinerConfigSchema;async divineHandler(e){let a=(0,m.assertEx)(e?.filter(o.isPayloadDivinerQueryPayload)?.pop(),()=>"Missing query payload");if(!a)return[];let n=(0,m.assertEx)(await this.archivistInstance(),()=>"Unable to resolve archivist"),{schemas:s,limit:C,offset:u,hash:f,order:O="desc",...v}=(0,x.removeFields)(a,["schema","$meta","$hash"]),r=await n.all?.();if(r){if(O==="desc"&&(r=r.reverse()),s?.length&&(r=r.filter(i=>s.includes(i.schema))),Object.keys(v).length>0){let i=Object.entries(v);for(let[h,p]of i){let w=h;r=Array.isArray(p)?r.filter(d=>p.every(j=>{let P=d?.[w];return Array.isArray(P)&&P.includes?.(j)})):r.filter(d=>d?.[w]===p)}}let g=C??r.length,l=u||0;return u===void 0?(async()=>{let i=await b.PayloadBuilder.hashPairs(r);if(f){for(;i.length>0&&i[0][1]!==f;)i.shift();i.length>0&&i[0][1]===f&&i.shift()}return i.map(([h])=>h).slice(l,l+g)})():r.slice(l,l+g)}else throw new Error('Archivist does not support "all"')}};
|
|
85
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -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 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":"
|
|
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":"4dAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,0BAAAE,IAAA,eAAAC,EAAAH,GCAA,IAAAI,EAAyB,0BACzBC,EAA6B,0BAE7BC,EAA+B,iDAC/BC,EAKO,8CACPC,EAA+B,wCAGxB,IAAMC,EAAN,cASGC,gBAAAA,CAtBV,MAsBUA,CAAAA,EAAAA,6BACR,OAAyBC,cAA0B,IAAI,MAAMA,cAAeC,8BAC5E,OAAyBC,oBAA8BD,6BAEvD,MAAyBE,cAAcC,EAA6C,CAClF,IAAMC,KAASC,YAASF,GAAUC,OAAOE,8BAAAA,GAA+BC,IAAAA,EAAO,IAAM,uBAAA,EACrF,GAAI,CAACH,EAAQ,MAAO,CAAA,EACpB,IAAMI,KAAYH,YAAS,MAAM,KAAKI,kBAAiB,EAAI,IAAM,6BAAA,EAC3D,CAAEC,QAAAA,EAASC,MAAAA,EAAOC,OAAAA,EAAQC,KAAAA,EAAMC,MAAAA,EAAQ,OAAQ,GAAGC,CAAAA,KAAUC,gBAAaZ,EAAyB,CAAC,SAAU,QAAS,QAAQ,EACjIa,EAAO,MAAMT,EAAUS,MAAG,EAC9B,GAAIA,EAAK,CAGP,GAFIH,IAAU,SAAQG,EAAMA,EAAIC,QAAO,GACnCR,GAASS,SAAQF,EAAMA,EAAIb,OAAQgB,GAAYV,EAAQW,SAASD,EAAQE,MAAM,CAAA,GAC9EC,OAAOC,KAAKT,CAAAA,EAAOI,OAAS,EAAG,CACjC,IAAMM,EAA2BF,OAAOG,QAAQX,CAAAA,EAChD,OAAW,CAACY,EAAMvB,CAAAA,IAAWqB,EAA0B,CACrD,IAAMG,EAAWD,EACjBV,EACEY,MAAMC,QAAQ1B,CAAAA,EACZa,EAAIb,OAAQgB,GACVhB,EAAO2B,MAAOC,GAAAA,CACZ,IAAML,EAAOP,IAAUQ,CAAAA,EAEvB,OAAOC,MAAMC,QAAQH,CAAAA,GAASA,EAAKN,WAAWW,CAAAA,CAChD,CAAA,CAAA,EAEFf,EAAIb,OAAQgB,GAAYA,IAAUQ,CAAAA,IAAcxB,CAAAA,CACtD,CACF,CACA,IAAM6B,EAActB,GAASM,EAAIE,OAC3Be,EAAetB,GAAU,EAC/B,OAAOA,IAAWuB,QACb,SAAA,CACC,IAAMC,EAAW,MAAMC,iBAAeC,UAAUrB,CAAAA,EAChD,GAAIJ,EAAM,CAER,KAAOuB,EAASjB,OAAS,GAAKiB,EAAS,CAAA,EAAG,CAAA,IAAOvB,GAC/CuB,EAASG,MAAK,EAGZH,EAASjB,OAAS,GAAKiB,EAAS,CAAA,EAAG,CAAA,IAAOvB,GAC5CuB,EAASG,MAAK,CAElB,CACA,OAAOH,EAASI,IAAI,CAAC,CAACpB,CAAAA,IAAaA,CAAAA,EAASqB,MAAMP,EAAcA,EAAeD,CAAAA,CACjF,GAAA,EACAhB,EAAIwB,MAAMP,EAAcA,EAAeD,CAAAA,CAC7C,KACE,OAAM,IAAIS,MAAM,kCAAA,CAEpB,CACF","names":["src_exports","__export","MemoryPayloadDiviner","__toCommonJS","import_assert","import_object","import_diviner_payload_abstract","import_diviner_payload_model","import_payload_builder","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
|
@@ -1,64 +1,2 @@
|
|
|
1
|
-
var
|
|
2
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
-
|
|
4
|
-
// src/MemoryPayloadDiviner.ts
|
|
5
|
-
import { assertEx } from "@xylabs/assert";
|
|
6
|
-
import { removeFields } from "@xylabs/object";
|
|
7
|
-
import { PayloadDiviner } from "@xyo-network/diviner-payload-abstract";
|
|
8
|
-
import { isPayloadDivinerQueryPayload, PayloadDivinerConfigSchema } from "@xyo-network/diviner-payload-model";
|
|
9
|
-
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
10
|
-
var MemoryPayloadDiviner = class extends PayloadDiviner {
|
|
11
|
-
static {
|
|
12
|
-
__name(this, "MemoryPayloadDiviner");
|
|
13
|
-
}
|
|
14
|
-
static configSchemas = [
|
|
15
|
-
...super.configSchemas,
|
|
16
|
-
PayloadDivinerConfigSchema
|
|
17
|
-
];
|
|
18
|
-
static defaultConfigSchema = PayloadDivinerConfigSchema;
|
|
19
|
-
async divineHandler(payloads) {
|
|
20
|
-
const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => "Missing query payload");
|
|
21
|
-
if (!filter) return [];
|
|
22
|
-
const archivist = assertEx(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
23
|
-
const { schemas, limit, offset, hash, order = "desc", ...props } = removeFields(filter, [
|
|
24
|
-
"schema",
|
|
25
|
-
"$meta",
|
|
26
|
-
"$hash"
|
|
27
|
-
]);
|
|
28
|
-
let all = await archivist.all?.();
|
|
29
|
-
if (all) {
|
|
30
|
-
if (order === "desc") all = all.reverse();
|
|
31
|
-
if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema));
|
|
32
|
-
if (Object.keys(props).length > 0) {
|
|
33
|
-
const additionalFilterCriteria = Object.entries(props);
|
|
34
|
-
for (const [prop, filter2] of additionalFilterCriteria) {
|
|
35
|
-
const property = prop;
|
|
36
|
-
all = Array.isArray(filter2) ? all.filter((payload) => filter2.every((value) => {
|
|
37
|
-
const prop2 = payload?.[property];
|
|
38
|
-
return Array.isArray(prop2) && prop2.includes?.(value);
|
|
39
|
-
})) : all.filter((payload) => payload?.[property] === filter2);
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
const parsedLimit = limit ?? all.length;
|
|
43
|
-
const parsedOffset = offset || 0;
|
|
44
|
-
return offset === void 0 ? (async () => {
|
|
45
|
-
const allPairs = await PayloadBuilder.hashPairs(all);
|
|
46
|
-
if (hash) {
|
|
47
|
-
while (allPairs.length > 0 && allPairs[0][1] !== hash) {
|
|
48
|
-
allPairs.shift();
|
|
49
|
-
}
|
|
50
|
-
if (allPairs.length > 0 && allPairs[0][1] === hash) {
|
|
51
|
-
allPairs.shift();
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit);
|
|
55
|
-
})() : all.slice(parsedOffset, parsedOffset + parsedLimit);
|
|
56
|
-
} else {
|
|
57
|
-
throw new Error('Archivist does not support "all"');
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
export {
|
|
62
|
-
MemoryPayloadDiviner
|
|
63
|
-
};
|
|
1
|
+
var b=Object.defineProperty;var u=(l,t)=>b(l,"name",{value:t,configurable:!0});import{assertEx as v}from"@xylabs/assert";import{removeFields as C}from"@xylabs/object";import{PayloadDiviner as O}from"@xyo-network/diviner-payload-abstract";import{isPayloadDivinerQueryPayload as j,PayloadDivinerConfigSchema as g}from"@xyo-network/diviner-payload-model";import{PayloadBuilder as D}from"@xyo-network/payload-builder";var w=class extends O{static{u(this,"MemoryPayloadDiviner")}static configSchemas=[...super.configSchemas,g];static defaultConfigSchema=g;async divineHandler(t){let c=v(t?.filter(j)?.pop(),()=>"Missing query payload");if(!c)return[];let P=v(await this.archivistInstance(),()=>"Unable to resolve archivist"),{schemas:f,limit:A,offset:h,hash:s,order:x="desc",...p}=C(c,["schema","$meta","$hash"]),e=await P.all?.();if(e){if(x==="desc"&&(e=e.reverse()),f?.length&&(e=e.filter(r=>f.includes(r.schema))),Object.keys(p).length>0){let r=Object.entries(p);for(let[a,o]of r){let m=a;e=Array.isArray(o)?e.filter(n=>o.every(S=>{let y=n?.[m];return Array.isArray(y)&&y.includes?.(S)})):e.filter(n=>n?.[m]===o)}}let d=A??e.length,i=h||0;return h===void 0?(async()=>{let r=await D.hashPairs(e);if(s){for(;r.length>0&&r[0][1]!==s;)r.shift();r.length>0&&r[0][1]===s&&r.shift()}return r.map(([a])=>a).slice(i,i+d)})():e.slice(i,i+d)}else throw new Error('Archivist does not support "all"')}};export{w as MemoryPayloadDiviner};
|
|
64
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":"
|
|
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":"+EAAA,OAASA,YAAAA,MAAgB,iBACzB,OAASC,gBAAAA,MAAoB,iBAE7B,OAASC,kBAAAA,MAAsB,wCAC/B,OACEC,gCAAAA,EACAC,8BAAAA,MAGK,qCACP,OAASC,kBAAAA,MAAsB,+BAGxB,IAAMC,EAAN,cASGC,CAAAA,CAtBV,MAsBUA,CAAAA,EAAAA,6BACR,OAAyBC,cAA0B,IAAI,MAAMA,cAAeC,GAC5E,OAAyBC,oBAA8BD,EAEvD,MAAyBE,cAAcC,EAA6C,CAClF,IAAMC,EAASC,EAASF,GAAUC,OAAOE,CAAAA,GAA+BC,IAAAA,EAAO,IAAM,uBAAA,EACrF,GAAI,CAACH,EAAQ,MAAO,CAAA,EACpB,IAAMI,EAAYH,EAAS,MAAM,KAAKI,kBAAiB,EAAI,IAAM,6BAAA,EAC3D,CAAEC,QAAAA,EAASC,MAAAA,EAAOC,OAAAA,EAAQC,KAAAA,EAAMC,MAAAA,EAAQ,OAAQ,GAAGC,CAAAA,EAAUC,EAAaZ,EAAyB,CAAC,SAAU,QAAS,QAAQ,EACjIa,EAAO,MAAMT,EAAUS,MAAG,EAC9B,GAAIA,EAAK,CAGP,GAFIH,IAAU,SAAQG,EAAMA,EAAIC,QAAO,GACnCR,GAASS,SAAQF,EAAMA,EAAIb,OAAQgB,GAAYV,EAAQW,SAASD,EAAQE,MAAM,CAAA,GAC9EC,OAAOC,KAAKT,CAAAA,EAAOI,OAAS,EAAG,CACjC,IAAMM,EAA2BF,OAAOG,QAAQX,CAAAA,EAChD,OAAW,CAACY,EAAMvB,CAAAA,IAAWqB,EAA0B,CACrD,IAAMG,EAAWD,EACjBV,EACEY,MAAMC,QAAQ1B,CAAAA,EACZa,EAAIb,OAAQgB,GACVhB,EAAO2B,MAAOC,GAAAA,CACZ,IAAML,EAAOP,IAAUQ,CAAAA,EAEvB,OAAOC,MAAMC,QAAQH,CAAAA,GAASA,EAAKN,WAAWW,CAAAA,CAChD,CAAA,CAAA,EAEFf,EAAIb,OAAQgB,GAAYA,IAAUQ,CAAAA,IAAcxB,CAAAA,CACtD,CACF,CACA,IAAM6B,EAActB,GAASM,EAAIE,OAC3Be,EAAetB,GAAU,EAC/B,OAAOA,IAAWuB,QACb,SAAA,CACC,IAAMC,EAAW,MAAMC,EAAeC,UAAUrB,CAAAA,EAChD,GAAIJ,EAAM,CAER,KAAOuB,EAASjB,OAAS,GAAKiB,EAAS,CAAA,EAAG,CAAA,IAAOvB,GAC/CuB,EAASG,MAAK,EAGZH,EAASjB,OAAS,GAAKiB,EAAS,CAAA,EAAG,CAAA,IAAOvB,GAC5CuB,EAASG,MAAK,CAElB,CACA,OAAOH,EAASI,IAAI,CAAC,CAACpB,CAAAA,IAAaA,CAAAA,EAASqB,MAAMP,EAAcA,EAAeD,CAAAA,CACjF,GAAA,EACAhB,EAAIwB,MAAMP,EAAcA,EAAeD,CAAAA,CAC7C,KACE,OAAM,IAAIS,MAAM,kCAAA,CAEpB,CACF","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"]}
|
package/dist/neutral/index.cjs
CHANGED
|
@@ -1,85 +1,2 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
7
|
-
var __export = (target, all) => {
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
11
|
-
var __copyProps = (to, from, except, desc) => {
|
|
12
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
-
for (let key of __getOwnPropNames(from))
|
|
14
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
19
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
20
|
-
|
|
21
|
-
// src/index.ts
|
|
22
|
-
var src_exports = {};
|
|
23
|
-
__export(src_exports, {
|
|
24
|
-
MemoryPayloadDiviner: () => MemoryPayloadDiviner
|
|
25
|
-
});
|
|
26
|
-
module.exports = __toCommonJS(src_exports);
|
|
27
|
-
|
|
28
|
-
// src/MemoryPayloadDiviner.ts
|
|
29
|
-
var import_assert = require("@xylabs/assert");
|
|
30
|
-
var import_object = require("@xylabs/object");
|
|
31
|
-
var import_diviner_payload_abstract = require("@xyo-network/diviner-payload-abstract");
|
|
32
|
-
var import_diviner_payload_model = require("@xyo-network/diviner-payload-model");
|
|
33
|
-
var import_payload_builder = require("@xyo-network/payload-builder");
|
|
34
|
-
var MemoryPayloadDiviner = class extends import_diviner_payload_abstract.PayloadDiviner {
|
|
35
|
-
static {
|
|
36
|
-
__name(this, "MemoryPayloadDiviner");
|
|
37
|
-
}
|
|
38
|
-
static configSchemas = [
|
|
39
|
-
...super.configSchemas,
|
|
40
|
-
import_diviner_payload_model.PayloadDivinerConfigSchema
|
|
41
|
-
];
|
|
42
|
-
static defaultConfigSchema = import_diviner_payload_model.PayloadDivinerConfigSchema;
|
|
43
|
-
async divineHandler(payloads) {
|
|
44
|
-
const filter = (0, import_assert.assertEx)(payloads?.filter(import_diviner_payload_model.isPayloadDivinerQueryPayload)?.pop(), () => "Missing query payload");
|
|
45
|
-
if (!filter) return [];
|
|
46
|
-
const archivist = (0, import_assert.assertEx)(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
47
|
-
const { schemas, limit, offset, hash, order = "desc", ...props } = (0, import_object.removeFields)(filter, [
|
|
48
|
-
"schema",
|
|
49
|
-
"$meta",
|
|
50
|
-
"$hash"
|
|
51
|
-
]);
|
|
52
|
-
let all = await archivist.all?.();
|
|
53
|
-
if (all) {
|
|
54
|
-
if (order === "desc") all = all.reverse();
|
|
55
|
-
if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema));
|
|
56
|
-
if (Object.keys(props).length > 0) {
|
|
57
|
-
const additionalFilterCriteria = Object.entries(props);
|
|
58
|
-
for (const [prop, filter2] of additionalFilterCriteria) {
|
|
59
|
-
const property = prop;
|
|
60
|
-
all = Array.isArray(filter2) ? all.filter((payload) => filter2.every((value) => {
|
|
61
|
-
const prop2 = payload?.[property];
|
|
62
|
-
return Array.isArray(prop2) && prop2.includes?.(value);
|
|
63
|
-
})) : all.filter((payload) => payload?.[property] === filter2);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
const parsedLimit = limit ?? all.length;
|
|
67
|
-
const parsedOffset = offset || 0;
|
|
68
|
-
return offset === void 0 ? (async () => {
|
|
69
|
-
const allPairs = await import_payload_builder.PayloadBuilder.hashPairs(all);
|
|
70
|
-
if (hash) {
|
|
71
|
-
while (allPairs.length > 0 && allPairs[0][1] !== hash) {
|
|
72
|
-
allPairs.shift();
|
|
73
|
-
}
|
|
74
|
-
if (allPairs.length > 0 && allPairs[0][1] === hash) {
|
|
75
|
-
allPairs.shift();
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit);
|
|
79
|
-
})() : all.slice(parsedOffset, parsedOffset + parsedLimit);
|
|
80
|
-
} else {
|
|
81
|
-
throw new Error('Archivist does not support "all"');
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
};
|
|
1
|
+
"use strict";var c=Object.defineProperty;var D=Object.getOwnPropertyDescriptor;var E=Object.getOwnPropertyNames;var F=Object.prototype.hasOwnProperty;var A=(t,e)=>c(t,"name",{value:e,configurable:!0});var $=(t,e)=>{for(var a in e)c(t,a,{get:e[a],enumerable:!0})},k=(t,e,a,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of E(e))!F.call(t,s)&&s!==a&&c(t,s,{get:()=>e[s],enumerable:!(n=D(e,s))||n.enumerable});return t};var q=t=>k(c({},"__esModule",{value:!0}),t);var B={};$(B,{MemoryPayloadDiviner:()=>y});module.exports=q(B);var m=require("@xylabs/assert"),x=require("@xylabs/object"),S=require("@xyo-network/diviner-payload-abstract"),o=require("@xyo-network/diviner-payload-model"),b=require("@xyo-network/payload-builder");var y=class extends S.PayloadDiviner{static{A(this,"MemoryPayloadDiviner")}static configSchemas=[...super.configSchemas,o.PayloadDivinerConfigSchema];static defaultConfigSchema=o.PayloadDivinerConfigSchema;async divineHandler(e){let a=(0,m.assertEx)(e?.filter(o.isPayloadDivinerQueryPayload)?.pop(),()=>"Missing query payload");if(!a)return[];let n=(0,m.assertEx)(await this.archivistInstance(),()=>"Unable to resolve archivist"),{schemas:s,limit:C,offset:u,hash:f,order:O="desc",...v}=(0,x.removeFields)(a,["schema","$meta","$hash"]),r=await n.all?.();if(r){if(O==="desc"&&(r=r.reverse()),s?.length&&(r=r.filter(i=>s.includes(i.schema))),Object.keys(v).length>0){let i=Object.entries(v);for(let[h,p]of i){let w=h;r=Array.isArray(p)?r.filter(d=>p.every(j=>{let P=d?.[w];return Array.isArray(P)&&P.includes?.(j)})):r.filter(d=>d?.[w]===p)}}let g=C??r.length,l=u||0;return u===void 0?(async()=>{let i=await b.PayloadBuilder.hashPairs(r);if(f){for(;i.length>0&&i[0][1]!==f;)i.shift();i.length>0&&i[0][1]===f&&i.shift()}return i.map(([h])=>h).slice(l,l+g)})():r.slice(l,l+g)}else throw new Error('Archivist does not support "all"')}};
|
|
85
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -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 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":"
|
|
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":"4dAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,0BAAAE,IAAA,eAAAC,EAAAH,GCAA,IAAAI,EAAyB,0BACzBC,EAA6B,0BAE7BC,EAA+B,iDAC/BC,EAKO,8CACPC,EAA+B,wCAGxB,IAAMC,EAAN,cASGC,gBAAAA,CAtBV,MAsBUA,CAAAA,EAAAA,6BACR,OAAyBC,cAA0B,IAAI,MAAMA,cAAeC,8BAC5E,OAAyBC,oBAA8BD,6BAEvD,MAAyBE,cAAcC,EAA6C,CAClF,IAAMC,KAASC,YAASF,GAAUC,OAAOE,8BAAAA,GAA+BC,IAAAA,EAAO,IAAM,uBAAA,EACrF,GAAI,CAACH,EAAQ,MAAO,CAAA,EACpB,IAAMI,KAAYH,YAAS,MAAM,KAAKI,kBAAiB,EAAI,IAAM,6BAAA,EAC3D,CAAEC,QAAAA,EAASC,MAAAA,EAAOC,OAAAA,EAAQC,KAAAA,EAAMC,MAAAA,EAAQ,OAAQ,GAAGC,CAAAA,KAAUC,gBAAaZ,EAAyB,CAAC,SAAU,QAAS,QAAQ,EACjIa,EAAO,MAAMT,EAAUS,MAAG,EAC9B,GAAIA,EAAK,CAGP,GAFIH,IAAU,SAAQG,EAAMA,EAAIC,QAAO,GACnCR,GAASS,SAAQF,EAAMA,EAAIb,OAAQgB,GAAYV,EAAQW,SAASD,EAAQE,MAAM,CAAA,GAC9EC,OAAOC,KAAKT,CAAAA,EAAOI,OAAS,EAAG,CACjC,IAAMM,EAA2BF,OAAOG,QAAQX,CAAAA,EAChD,OAAW,CAACY,EAAMvB,CAAAA,IAAWqB,EAA0B,CACrD,IAAMG,EAAWD,EACjBV,EACEY,MAAMC,QAAQ1B,CAAAA,EACZa,EAAIb,OAAQgB,GACVhB,EAAO2B,MAAOC,GAAAA,CACZ,IAAML,EAAOP,IAAUQ,CAAAA,EAEvB,OAAOC,MAAMC,QAAQH,CAAAA,GAASA,EAAKN,WAAWW,CAAAA,CAChD,CAAA,CAAA,EAEFf,EAAIb,OAAQgB,GAAYA,IAAUQ,CAAAA,IAAcxB,CAAAA,CACtD,CACF,CACA,IAAM6B,EAActB,GAASM,EAAIE,OAC3Be,EAAetB,GAAU,EAC/B,OAAOA,IAAWuB,QACb,SAAA,CACC,IAAMC,EAAW,MAAMC,iBAAeC,UAAUrB,CAAAA,EAChD,GAAIJ,EAAM,CAER,KAAOuB,EAASjB,OAAS,GAAKiB,EAAS,CAAA,EAAG,CAAA,IAAOvB,GAC/CuB,EAASG,MAAK,EAGZH,EAASjB,OAAS,GAAKiB,EAAS,CAAA,EAAG,CAAA,IAAOvB,GAC5CuB,EAASG,MAAK,CAElB,CACA,OAAOH,EAASI,IAAI,CAAC,CAACpB,CAAAA,IAAaA,CAAAA,EAASqB,MAAMP,EAAcA,EAAeD,CAAAA,CACjF,GAAA,EACAhB,EAAIwB,MAAMP,EAAcA,EAAeD,CAAAA,CAC7C,KACE,OAAM,IAAIS,MAAM,kCAAA,CAEpB,CACF","names":["src_exports","__export","MemoryPayloadDiviner","__toCommonJS","import_assert","import_object","import_diviner_payload_abstract","import_diviner_payload_model","import_payload_builder","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/neutral/index.js
CHANGED
|
@@ -1,64 +1,2 @@
|
|
|
1
|
-
var
|
|
2
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
-
|
|
4
|
-
// src/MemoryPayloadDiviner.ts
|
|
5
|
-
import { assertEx } from "@xylabs/assert";
|
|
6
|
-
import { removeFields } from "@xylabs/object";
|
|
7
|
-
import { PayloadDiviner } from "@xyo-network/diviner-payload-abstract";
|
|
8
|
-
import { isPayloadDivinerQueryPayload, PayloadDivinerConfigSchema } from "@xyo-network/diviner-payload-model";
|
|
9
|
-
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
10
|
-
var MemoryPayloadDiviner = class extends PayloadDiviner {
|
|
11
|
-
static {
|
|
12
|
-
__name(this, "MemoryPayloadDiviner");
|
|
13
|
-
}
|
|
14
|
-
static configSchemas = [
|
|
15
|
-
...super.configSchemas,
|
|
16
|
-
PayloadDivinerConfigSchema
|
|
17
|
-
];
|
|
18
|
-
static defaultConfigSchema = PayloadDivinerConfigSchema;
|
|
19
|
-
async divineHandler(payloads) {
|
|
20
|
-
const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => "Missing query payload");
|
|
21
|
-
if (!filter) return [];
|
|
22
|
-
const archivist = assertEx(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
23
|
-
const { schemas, limit, offset, hash, order = "desc", ...props } = removeFields(filter, [
|
|
24
|
-
"schema",
|
|
25
|
-
"$meta",
|
|
26
|
-
"$hash"
|
|
27
|
-
]);
|
|
28
|
-
let all = await archivist.all?.();
|
|
29
|
-
if (all) {
|
|
30
|
-
if (order === "desc") all = all.reverse();
|
|
31
|
-
if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema));
|
|
32
|
-
if (Object.keys(props).length > 0) {
|
|
33
|
-
const additionalFilterCriteria = Object.entries(props);
|
|
34
|
-
for (const [prop, filter2] of additionalFilterCriteria) {
|
|
35
|
-
const property = prop;
|
|
36
|
-
all = Array.isArray(filter2) ? all.filter((payload) => filter2.every((value) => {
|
|
37
|
-
const prop2 = payload?.[property];
|
|
38
|
-
return Array.isArray(prop2) && prop2.includes?.(value);
|
|
39
|
-
})) : all.filter((payload) => payload?.[property] === filter2);
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
const parsedLimit = limit ?? all.length;
|
|
43
|
-
const parsedOffset = offset || 0;
|
|
44
|
-
return offset === void 0 ? (async () => {
|
|
45
|
-
const allPairs = await PayloadBuilder.hashPairs(all);
|
|
46
|
-
if (hash) {
|
|
47
|
-
while (allPairs.length > 0 && allPairs[0][1] !== hash) {
|
|
48
|
-
allPairs.shift();
|
|
49
|
-
}
|
|
50
|
-
if (allPairs.length > 0 && allPairs[0][1] === hash) {
|
|
51
|
-
allPairs.shift();
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit);
|
|
55
|
-
})() : all.slice(parsedOffset, parsedOffset + parsedLimit);
|
|
56
|
-
} else {
|
|
57
|
-
throw new Error('Archivist does not support "all"');
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
export {
|
|
62
|
-
MemoryPayloadDiviner
|
|
63
|
-
};
|
|
1
|
+
var b=Object.defineProperty;var u=(l,t)=>b(l,"name",{value:t,configurable:!0});import{assertEx as v}from"@xylabs/assert";import{removeFields as C}from"@xylabs/object";import{PayloadDiviner as O}from"@xyo-network/diviner-payload-abstract";import{isPayloadDivinerQueryPayload as j,PayloadDivinerConfigSchema as g}from"@xyo-network/diviner-payload-model";import{PayloadBuilder as D}from"@xyo-network/payload-builder";var w=class extends O{static{u(this,"MemoryPayloadDiviner")}static configSchemas=[...super.configSchemas,g];static defaultConfigSchema=g;async divineHandler(t){let c=v(t?.filter(j)?.pop(),()=>"Missing query payload");if(!c)return[];let P=v(await this.archivistInstance(),()=>"Unable to resolve archivist"),{schemas:f,limit:A,offset:h,hash:s,order:x="desc",...p}=C(c,["schema","$meta","$hash"]),e=await P.all?.();if(e){if(x==="desc"&&(e=e.reverse()),f?.length&&(e=e.filter(r=>f.includes(r.schema))),Object.keys(p).length>0){let r=Object.entries(p);for(let[a,o]of r){let m=a;e=Array.isArray(o)?e.filter(n=>o.every(S=>{let y=n?.[m];return Array.isArray(y)&&y.includes?.(S)})):e.filter(n=>n?.[m]===o)}}let d=A??e.length,i=h||0;return h===void 0?(async()=>{let r=await D.hashPairs(e);if(s){for(;r.length>0&&r[0][1]!==s;)r.shift();r.length>0&&r[0][1]===s&&r.shift()}return r.map(([a])=>a).slice(i,i+d)})():e.slice(i,i+d)}else throw new Error('Archivist does not support "all"')}};export{w as MemoryPayloadDiviner};
|
|
64
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/MemoryPayloadDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { removeFields } from '@xylabs/object'\nimport { DivinerInstance, DivinerModuleEventData } from '@xyo-network/diviner-model'\nimport { PayloadDiviner } from '@xyo-network/diviner-payload-abstract'\nimport {\n isPayloadDivinerQueryPayload,\n PayloadDivinerConfigSchema,\n PayloadDivinerParams,\n PayloadDivinerQueryPayload,\n} from '@xyo-network/diviner-payload-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload, Schema, WithMeta } from '@xyo-network/payload-model'\n\nexport class MemoryPayloadDiviner<\n TParams extends PayloadDivinerParams = PayloadDivinerParams,\n TIn extends PayloadDivinerQueryPayload = PayloadDivinerQueryPayload,\n TOut extends Payload = Payload,\n TEventData extends DivinerModuleEventData<DivinerInstance<TParams, TIn, TOut>, TIn, TOut> = DivinerModuleEventData<\n DivinerInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n> extends PayloadDiviner<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, PayloadDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = PayloadDivinerConfigSchema\n\n protected override async divineHandler(payloads?: TIn[]): Promise<WithMeta<TOut>[]> {\n const filter = assertEx(payloads?.filter(isPayloadDivinerQueryPayload)?.pop(), () => 'Missing query payload')\n if (!filter) return []\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const { schemas, limit, offset, hash, order = 'desc', ...props } = removeFields(filter as WithMeta<TIn>, ['schema', '$meta', '$hash'])\n let all = (await archivist.all?.()) as WithMeta<TOut>[]\n if (all) {\n if (order === 'desc') all = all.reverse()\n if (schemas?.length) all = all.filter((payload) => schemas.includes(payload.schema))\n if (Object.keys(props).length > 0) {\n const additionalFilterCriteria = Object.entries(props)\n for (const [prop, filter] of additionalFilterCriteria) {\n const property = prop as keyof TOut\n all =\n Array.isArray(filter) ?\n all.filter((payload) =>\n filter.every((value) => {\n const prop = payload?.[property]\n //TODO: This seems to be written just to check arrays, and now that $meta is there, need to check type?\n return Array.isArray(prop) && prop.includes?.(value)\n }),\n )\n : all.filter((payload) => payload?.[property] === filter)\n }\n }\n const parsedLimit = limit ?? all.length\n const parsedOffset = offset || 0\n return offset === undefined ?\n (async () => {\n const allPairs = await PayloadBuilder.hashPairs(all)\n if (hash) {\n //remove all until found\n while (allPairs.length > 0 && allPairs[0][1] !== hash) {\n allPairs.shift()\n }\n //remove it if found\n if (allPairs.length > 0 && allPairs[0][1] === hash) {\n allPairs.shift()\n }\n }\n return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit)\n })()\n : all.slice(parsedOffset, parsedOffset + parsedLimit)\n } else {\n throw new Error('Archivist does not support \"all\"')\n }\n }\n}\n"],"mappings":"
|
|
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":"+EAAA,OAASA,YAAAA,MAAgB,iBACzB,OAASC,gBAAAA,MAAoB,iBAE7B,OAASC,kBAAAA,MAAsB,wCAC/B,OACEC,gCAAAA,EACAC,8BAAAA,MAGK,qCACP,OAASC,kBAAAA,MAAsB,+BAGxB,IAAMC,EAAN,cASGC,CAAAA,CAtBV,MAsBUA,CAAAA,EAAAA,6BACR,OAAyBC,cAA0B,IAAI,MAAMA,cAAeC,GAC5E,OAAyBC,oBAA8BD,EAEvD,MAAyBE,cAAcC,EAA6C,CAClF,IAAMC,EAASC,EAASF,GAAUC,OAAOE,CAAAA,GAA+BC,IAAAA,EAAO,IAAM,uBAAA,EACrF,GAAI,CAACH,EAAQ,MAAO,CAAA,EACpB,IAAMI,EAAYH,EAAS,MAAM,KAAKI,kBAAiB,EAAI,IAAM,6BAAA,EAC3D,CAAEC,QAAAA,EAASC,MAAAA,EAAOC,OAAAA,EAAQC,KAAAA,EAAMC,MAAAA,EAAQ,OAAQ,GAAGC,CAAAA,EAAUC,EAAaZ,EAAyB,CAAC,SAAU,QAAS,QAAQ,EACjIa,EAAO,MAAMT,EAAUS,MAAG,EAC9B,GAAIA,EAAK,CAGP,GAFIH,IAAU,SAAQG,EAAMA,EAAIC,QAAO,GACnCR,GAASS,SAAQF,EAAMA,EAAIb,OAAQgB,GAAYV,EAAQW,SAASD,EAAQE,MAAM,CAAA,GAC9EC,OAAOC,KAAKT,CAAAA,EAAOI,OAAS,EAAG,CACjC,IAAMM,EAA2BF,OAAOG,QAAQX,CAAAA,EAChD,OAAW,CAACY,EAAMvB,CAAAA,IAAWqB,EAA0B,CACrD,IAAMG,EAAWD,EACjBV,EACEY,MAAMC,QAAQ1B,CAAAA,EACZa,EAAIb,OAAQgB,GACVhB,EAAO2B,MAAOC,GAAAA,CACZ,IAAML,EAAOP,IAAUQ,CAAAA,EAEvB,OAAOC,MAAMC,QAAQH,CAAAA,GAASA,EAAKN,WAAWW,CAAAA,CAChD,CAAA,CAAA,EAEFf,EAAIb,OAAQgB,GAAYA,IAAUQ,CAAAA,IAAcxB,CAAAA,CACtD,CACF,CACA,IAAM6B,EAActB,GAASM,EAAIE,OAC3Be,EAAetB,GAAU,EAC/B,OAAOA,IAAWuB,QACb,SAAA,CACC,IAAMC,EAAW,MAAMC,EAAeC,UAAUrB,CAAAA,EAChD,GAAIJ,EAAM,CAER,KAAOuB,EAASjB,OAAS,GAAKiB,EAAS,CAAA,EAAG,CAAA,IAAOvB,GAC/CuB,EAASG,MAAK,EAGZH,EAASjB,OAAS,GAAKiB,EAAS,CAAA,EAAG,CAAA,IAAOvB,GAC5CuB,EAASG,MAAK,CAElB,CACA,OAAOH,EAASI,IAAI,CAAC,CAACpB,CAAAA,IAAaA,CAAAA,EAASqB,MAAMP,EAAcA,EAAeD,CAAAA,CACjF,GAAA,EACAhB,EAAIwB,MAAMP,EAAcA,EAAeD,CAAAA,CAC7C,KACE,OAAM,IAAIS,MAAM,kCAAA,CAEpB,CACF","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"]}
|
package/dist/node/index.cjs
CHANGED
|
@@ -1,95 +1,2 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
-
var __reflectGet = Reflect.get;
|
|
8
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
9
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
10
|
-
var __export = (target, all) => {
|
|
11
|
-
for (var name in all)
|
|
12
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
13
|
-
};
|
|
14
|
-
var __copyProps = (to, from, except, desc) => {
|
|
15
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
16
|
-
for (let key of __getOwnPropNames(from))
|
|
17
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
18
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
19
|
-
}
|
|
20
|
-
return to;
|
|
21
|
-
};
|
|
22
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
23
|
-
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
24
|
-
var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
|
|
25
|
-
|
|
26
|
-
// src/index.ts
|
|
27
|
-
var src_exports = {};
|
|
28
|
-
__export(src_exports, {
|
|
29
|
-
MemoryPayloadDiviner: () => MemoryPayloadDiviner
|
|
30
|
-
});
|
|
31
|
-
module.exports = __toCommonJS(src_exports);
|
|
32
|
-
|
|
33
|
-
// src/MemoryPayloadDiviner.ts
|
|
34
|
-
var import_assert = require("@xylabs/assert");
|
|
35
|
-
var import_object = require("@xylabs/object");
|
|
36
|
-
var import_diviner_payload_abstract = require("@xyo-network/diviner-payload-abstract");
|
|
37
|
-
var import_diviner_payload_model = require("@xyo-network/diviner-payload-model");
|
|
38
|
-
var import_payload_builder = require("@xyo-network/payload-builder");
|
|
39
|
-
var _MemoryPayloadDiviner = class _MemoryPayloadDiviner extends import_diviner_payload_abstract.PayloadDiviner {
|
|
40
|
-
async divineHandler(payloads) {
|
|
41
|
-
var _a, _b;
|
|
42
|
-
const filter = (0, import_assert.assertEx)((_a = payloads == null ? void 0 : payloads.filter(import_diviner_payload_model.isPayloadDivinerQueryPayload)) == null ? void 0 : _a.pop(), () => "Missing query payload");
|
|
43
|
-
if (!filter) return [];
|
|
44
|
-
const archivist = (0, import_assert.assertEx)(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
45
|
-
const { schemas, limit, offset, hash, order = "desc", ...props } = (0, import_object.removeFields)(filter, [
|
|
46
|
-
"schema",
|
|
47
|
-
"$meta",
|
|
48
|
-
"$hash"
|
|
49
|
-
]);
|
|
50
|
-
let all = await ((_b = archivist.all) == null ? void 0 : _b.call(archivist));
|
|
51
|
-
if (all) {
|
|
52
|
-
if (order === "desc") all = all.reverse();
|
|
53
|
-
if (schemas == null ? void 0 : schemas.length) all = all.filter((payload) => schemas.includes(payload.schema));
|
|
54
|
-
if (Object.keys(props).length > 0) {
|
|
55
|
-
const additionalFilterCriteria = Object.entries(props);
|
|
56
|
-
for (const [prop, filter2] of additionalFilterCriteria) {
|
|
57
|
-
const property = prop;
|
|
58
|
-
all = Array.isArray(filter2) ? all.filter((payload) => filter2.every((value) => {
|
|
59
|
-
var _a2;
|
|
60
|
-
const prop2 = payload == null ? void 0 : payload[property];
|
|
61
|
-
return Array.isArray(prop2) && ((_a2 = prop2.includes) == null ? void 0 : _a2.call(prop2, value));
|
|
62
|
-
})) : all.filter((payload) => (payload == null ? void 0 : payload[property]) === filter2);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
const parsedLimit = limit ?? all.length;
|
|
66
|
-
const parsedOffset = offset || 0;
|
|
67
|
-
return offset === void 0 ? (async () => {
|
|
68
|
-
const allPairs = await import_payload_builder.PayloadBuilder.hashPairs(all);
|
|
69
|
-
if (hash) {
|
|
70
|
-
while (allPairs.length > 0 && allPairs[0][1] !== hash) {
|
|
71
|
-
allPairs.shift();
|
|
72
|
-
}
|
|
73
|
-
if (allPairs.length > 0 && allPairs[0][1] === hash) {
|
|
74
|
-
allPairs.shift();
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit);
|
|
78
|
-
})() : all.slice(parsedOffset, parsedOffset + parsedLimit);
|
|
79
|
-
} else {
|
|
80
|
-
throw new Error('Archivist does not support "all"');
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
};
|
|
84
|
-
__name(_MemoryPayloadDiviner, "MemoryPayloadDiviner");
|
|
85
|
-
__publicField(_MemoryPayloadDiviner, "configSchemas", [
|
|
86
|
-
...__superGet(_MemoryPayloadDiviner, _MemoryPayloadDiviner, "configSchemas"),
|
|
87
|
-
import_diviner_payload_model.PayloadDivinerConfigSchema
|
|
88
|
-
]);
|
|
89
|
-
__publicField(_MemoryPayloadDiviner, "defaultConfigSchema", import_diviner_payload_model.PayloadDivinerConfigSchema);
|
|
90
|
-
var MemoryPayloadDiviner = _MemoryPayloadDiviner;
|
|
91
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
92
|
-
0 && (module.exports = {
|
|
93
|
-
MemoryPayloadDiviner
|
|
94
|
-
});
|
|
1
|
+
"use strict";var l=Object.defineProperty;var L=Object.getOwnPropertyDescriptor;var P=Object.getOwnPropertyNames;var Q=Object.getPrototypeOf,U=Object.prototype.hasOwnProperty;var z=Reflect.get;var G=(e,t,r)=>t in e?l(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r;var E=(e,t)=>l(e,"name",{value:t,configurable:!0});var J=(e,t)=>{for(var r in t)l(e,r,{get:t[r],enumerable:!0})},K=(e,t,r,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of P(t))!U.call(e,n)&&n!==r&&l(e,n,{get:()=>t[n],enumerable:!(o=L(t,n))||o.enumerable});return e};var N=e=>K(l({},"__esModule",{value:!0}),e);var d=(e,t,r)=>G(e,typeof t!="symbol"?t+"":t,r);var F=(e,t,r)=>z(Q(e),r,t);var R={};J(R,{MemoryPayloadDiviner:()=>A});module.exports=N(R);var w=require("@xylabs/assert"),$=require("@xylabs/object"),k=require("@xyo-network/diviner-payload-abstract"),h=require("@xyo-network/diviner-payload-model"),q=require("@xyo-network/payload-builder");var f=class f extends k.PayloadDiviner{async divineHandler(t){var S,b;let r=(0,w.assertEx)((S=t==null?void 0:t.filter(h.isPayloadDivinerQueryPayload))==null?void 0:S.pop(),()=>"Missing query payload");if(!r)return[];let o=(0,w.assertEx)(await this.archivistInstance(),()=>"Unable to resolve archivist"),{schemas:n,limit:B,offset:v,hash:u,order:H="desc",...x}=(0,$.removeFields)(r,["schema","$meta","$hash"]),i=await((b=o.all)==null?void 0:b.call(o));if(i){if(H==="desc"&&(i=i.reverse()),n!=null&&n.length&&(i=i.filter(s=>n.includes(s.schema))),Object.keys(x).length>0){let s=Object.entries(x);for(let[g,p]of s){let O=g;i=Array.isArray(p)?i.filter(c=>p.every(I=>{var j;let m=c==null?void 0:c[O];return Array.isArray(m)&&((j=m.includes)==null?void 0:j.call(m,I))})):i.filter(c=>(c==null?void 0:c[O])===p)}}let C=B??i.length,a=v||0;return v===void 0?(async()=>{let s=await q.PayloadBuilder.hashPairs(i);if(u){for(;s.length>0&&s[0][1]!==u;)s.shift();s.length>0&&s[0][1]===u&&s.shift()}return s.map(([g])=>g).slice(a,a+C)})():i.slice(a,a+C)}else throw new Error('Archivist does not support "all"')}};E(f,"MemoryPayloadDiviner"),d(f,"configSchemas",[...F(f,f,"configSchemas"),h.PayloadDivinerConfigSchema]),d(f,"defaultConfigSchema",h.PayloadDivinerConfigSchema);var A=f;0&&(module.exports={MemoryPayloadDiviner});
|
|
95
2
|
//# sourceMappingURL=index.cjs.map
|
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 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":"
|
|
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":"yqBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,0BAAAE,IAAA,eAAAC,EAAAH,GCAA,IAAAI,EAAyB,0BACzBC,EAA6B,0BAE7BC,EAA+B,iDAC/BC,EAKO,8CACPC,EAA+B,wCAGxB,IAAMC,EAAN,MAAMA,UASHC,gBAAAA,CAIR,MAAyBC,cAAcC,EAA6C,CA1BtF,IAAAC,EAAAC,EA2BI,IAAMC,KAASC,aAASJ,EAAAA,GAAAA,YAAAA,EAAUG,OAAOE,kCAAjBL,YAAAA,EAAgDM,MAAO,IAAM,uBAAA,EACrF,GAAI,CAACH,EAAQ,MAAO,CAAA,EACpB,IAAMI,KAAYH,YAAS,MAAM,KAAKI,kBAAiB,EAAI,IAAM,6BAAA,EAC3D,CAAEC,QAAAA,EAASC,MAAAA,EAAOC,OAAAA,EAAQC,KAAAA,EAAMC,MAAAA,EAAQ,OAAQ,GAAGC,CAAAA,KAAUC,gBAAaZ,EAAyB,CAAC,SAAU,QAAS,QAAQ,EACjIa,EAAO,OAAMT,EAAAA,EAAUS,MAAVT,YAAAA,EAAAA,KAAAA,IACjB,GAAIS,EAAK,CAGP,GAFIH,IAAU,SAAQG,EAAMA,EAAIC,QAAO,GACnCR,GAAAA,MAAAA,EAASS,SAAQF,EAAMA,EAAIb,OAAQgB,GAAYV,EAAQW,SAASD,EAAQE,MAAM,CAAA,GAC9EC,OAAOC,KAAKT,CAAAA,EAAOI,OAAS,EAAG,CACjC,IAAMM,EAA2BF,OAAOG,QAAQX,CAAAA,EAChD,OAAW,CAACY,EAAMvB,CAAAA,IAAWqB,EAA0B,CACrD,IAAMG,EAAWD,EACjBV,EACEY,MAAMC,QAAQ1B,CAAAA,EACZa,EAAIb,OAAQgB,GACVhB,EAAO2B,MAAOC,GAAAA,CA1C9B,IAAA9B,EA2CkB,IAAMyB,EAAOP,GAAAA,YAAAA,EAAUQ,GAEvB,OAAOC,MAAMC,QAAQH,CAAAA,KAASA,EAAAA,EAAKN,WAALM,YAAAA,EAAAA,KAAAA,EAAgBK,GAChD,CAAA,CAAA,EAEFf,EAAIb,OAAQgB,IAAYA,GAAAA,YAAAA,EAAUQ,MAAcxB,CAAAA,CACtD,CACF,CACA,IAAM6B,EAActB,GAASM,EAAIE,OAC3Be,EAAetB,GAAU,EAC/B,OAAOA,IAAWuB,QACb,SAAA,CACC,IAAMC,EAAW,MAAMC,iBAAeC,UAAUrB,CAAAA,EAChD,GAAIJ,EAAM,CAER,KAAOuB,EAASjB,OAAS,GAAKiB,EAAS,CAAA,EAAG,CAAA,IAAOvB,GAC/CuB,EAASG,MAAK,EAGZH,EAASjB,OAAS,GAAKiB,EAAS,CAAA,EAAG,CAAA,IAAOvB,GAC5CuB,EAASG,MAAK,CAElB,CACA,OAAOH,EAASI,IAAI,CAAC,CAACpB,CAAAA,IAAaA,CAAAA,EAASqB,MAAMP,EAAcA,EAAeD,CAAAA,CACjF,GAAA,EACAhB,EAAIwB,MAAMP,EAAcA,EAAeD,CAAAA,CAC7C,KACE,OAAM,IAAIS,MAAM,kCAAA,CAEpB,CACF,EAnDU3C,EAAAA,EAAAA,wBACR4C,EAVW7C,EAUc8C,gBAA0B,IAAIC,EAAAC,IAAMF,iBAAeG,+BAC5EJ,EAXW7C,EAWckD,sBAA8BD,8BAXlD,IAAMjD,EAANgD","names":["src_exports","__export","MemoryPayloadDiviner","__toCommonJS","import_assert","import_object","import_diviner_payload_abstract","import_diviner_payload_model","import_payload_builder","MemoryPayloadDiviner","PayloadDiviner","divineHandler","payloads","_a","_b","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","__publicField","configSchemas","__superGet","_MemoryPayloadDiviner","PayloadDivinerConfigSchema","defaultConfigSchema"]}
|
package/dist/node/index.js
CHANGED
|
@@ -1,70 +1,2 @@
|
|
|
1
|
-
var
|
|
2
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
3
|
-
var __reflectGet = Reflect.get;
|
|
4
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
5
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
|
-
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
7
|
-
var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
|
|
8
|
-
|
|
9
|
-
// src/MemoryPayloadDiviner.ts
|
|
10
|
-
import { assertEx } from "@xylabs/assert";
|
|
11
|
-
import { removeFields } from "@xylabs/object";
|
|
12
|
-
import { PayloadDiviner } from "@xyo-network/diviner-payload-abstract";
|
|
13
|
-
import { isPayloadDivinerQueryPayload, PayloadDivinerConfigSchema } from "@xyo-network/diviner-payload-model";
|
|
14
|
-
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
15
|
-
var _MemoryPayloadDiviner = class _MemoryPayloadDiviner extends PayloadDiviner {
|
|
16
|
-
async divineHandler(payloads) {
|
|
17
|
-
var _a, _b;
|
|
18
|
-
const filter = assertEx((_a = payloads == null ? void 0 : payloads.filter(isPayloadDivinerQueryPayload)) == null ? void 0 : _a.pop(), () => "Missing query payload");
|
|
19
|
-
if (!filter) return [];
|
|
20
|
-
const archivist = assertEx(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
21
|
-
const { schemas, limit, offset, hash, order = "desc", ...props } = removeFields(filter, [
|
|
22
|
-
"schema",
|
|
23
|
-
"$meta",
|
|
24
|
-
"$hash"
|
|
25
|
-
]);
|
|
26
|
-
let all = await ((_b = archivist.all) == null ? void 0 : _b.call(archivist));
|
|
27
|
-
if (all) {
|
|
28
|
-
if (order === "desc") all = all.reverse();
|
|
29
|
-
if (schemas == null ? void 0 : schemas.length) all = all.filter((payload) => schemas.includes(payload.schema));
|
|
30
|
-
if (Object.keys(props).length > 0) {
|
|
31
|
-
const additionalFilterCriteria = Object.entries(props);
|
|
32
|
-
for (const [prop, filter2] of additionalFilterCriteria) {
|
|
33
|
-
const property = prop;
|
|
34
|
-
all = Array.isArray(filter2) ? all.filter((payload) => filter2.every((value) => {
|
|
35
|
-
var _a2;
|
|
36
|
-
const prop2 = payload == null ? void 0 : payload[property];
|
|
37
|
-
return Array.isArray(prop2) && ((_a2 = prop2.includes) == null ? void 0 : _a2.call(prop2, value));
|
|
38
|
-
})) : all.filter((payload) => (payload == null ? void 0 : payload[property]) === filter2);
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
const parsedLimit = limit ?? all.length;
|
|
42
|
-
const parsedOffset = offset || 0;
|
|
43
|
-
return offset === void 0 ? (async () => {
|
|
44
|
-
const allPairs = await PayloadBuilder.hashPairs(all);
|
|
45
|
-
if (hash) {
|
|
46
|
-
while (allPairs.length > 0 && allPairs[0][1] !== hash) {
|
|
47
|
-
allPairs.shift();
|
|
48
|
-
}
|
|
49
|
-
if (allPairs.length > 0 && allPairs[0][1] === hash) {
|
|
50
|
-
allPairs.shift();
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
return allPairs.map(([payload]) => payload).slice(parsedOffset, parsedOffset + parsedLimit);
|
|
54
|
-
})() : all.slice(parsedOffset, parsedOffset + parsedLimit);
|
|
55
|
-
} else {
|
|
56
|
-
throw new Error('Archivist does not support "all"');
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
};
|
|
60
|
-
__name(_MemoryPayloadDiviner, "MemoryPayloadDiviner");
|
|
61
|
-
__publicField(_MemoryPayloadDiviner, "configSchemas", [
|
|
62
|
-
...__superGet(_MemoryPayloadDiviner, _MemoryPayloadDiviner, "configSchemas"),
|
|
63
|
-
PayloadDivinerConfigSchema
|
|
64
|
-
]);
|
|
65
|
-
__publicField(_MemoryPayloadDiviner, "defaultConfigSchema", PayloadDivinerConfigSchema);
|
|
66
|
-
var MemoryPayloadDiviner = _MemoryPayloadDiviner;
|
|
67
|
-
export {
|
|
68
|
-
MemoryPayloadDiviner
|
|
69
|
-
};
|
|
1
|
+
var b=Object.defineProperty;var B=Object.getPrototypeOf;var H=Reflect.get;var I=(i,t,s)=>t in i?b(i,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):i[t]=s;var C=(i,t)=>b(i,"name",{value:t,configurable:!0});var g=(i,t,s)=>I(i,typeof t!="symbol"?t+"":t,s);var O=(i,t,s)=>H(B(i),s,t);import{assertEx as j}from"@xylabs/assert";import{removeFields as L}from"@xylabs/object";import{PayloadDiviner as P}from"@xyo-network/diviner-payload-abstract";import{isPayloadDivinerQueryPayload as Q,PayloadDivinerConfigSchema as E}from"@xyo-network/diviner-payload-model";import{PayloadBuilder as U}from"@xyo-network/payload-builder";var c=class c extends P{async divineHandler(t){var w,A;let s=j((w=t==null?void 0:t.filter(Q))==null?void 0:w.pop(),()=>"Missing query payload");if(!s)return[];let h=j(await this.archivistInstance(),()=>"Unable to resolve archivist"),{schemas:f,limit:$,offset:p,hash:a,order:k="desc",...d}=L(s,["schema","$meta","$hash"]),e=await((A=h.all)==null?void 0:A.call(h));if(e){if(k==="desc"&&(e=e.reverse()),f!=null&&f.length&&(e=e.filter(r=>f.includes(r.schema))),Object.keys(d).length>0){let r=Object.entries(d);for(let[m,u]of r){let x=m;e=Array.isArray(u)?e.filter(n=>u.every(q=>{var S;let l=n==null?void 0:n[x];return Array.isArray(l)&&((S=l.includes)==null?void 0:S.call(l,q))})):e.filter(n=>(n==null?void 0:n[x])===u)}}let v=$??e.length,o=p||0;return p===void 0?(async()=>{let r=await U.hashPairs(e);if(a){for(;r.length>0&&r[0][1]!==a;)r.shift();r.length>0&&r[0][1]===a&&r.shift()}return r.map(([m])=>m).slice(o,o+v)})():e.slice(o,o+v)}else throw new Error('Archivist does not support "all"')}};C(c,"MemoryPayloadDiviner"),g(c,"configSchemas",[...O(c,c,"configSchemas"),E]),g(c,"defaultConfigSchema",E);var F=c;export{F as MemoryPayloadDiviner};
|
|
70
2
|
//# sourceMappingURL=index.js.map
|
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 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":"
|
|
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":"gSAAA,OAASA,YAAAA,MAAgB,iBACzB,OAASC,gBAAAA,MAAoB,iBAE7B,OAASC,kBAAAA,MAAsB,wCAC/B,OACEC,gCAAAA,EACAC,8BAAAA,MAGK,qCACP,OAASC,kBAAAA,MAAsB,+BAGxB,IAAMC,EAAN,MAAMA,UASHC,CAAAA,CAIR,MAAyBC,cAAcC,EAA6C,CA1BtF,IAAAC,EAAAC,EA2BI,IAAMC,EAASC,GAASJ,EAAAA,GAAAA,YAAAA,EAAUG,OAAOE,KAAjBL,YAAAA,EAAgDM,MAAO,IAAM,uBAAA,EACrF,GAAI,CAACH,EAAQ,MAAO,CAAA,EACpB,IAAMI,EAAYH,EAAS,MAAM,KAAKI,kBAAiB,EAAI,IAAM,6BAAA,EAC3D,CAAEC,QAAAA,EAASC,MAAAA,EAAOC,OAAAA,EAAQC,KAAAA,EAAMC,MAAAA,EAAQ,OAAQ,GAAGC,CAAAA,EAAUC,EAAaZ,EAAyB,CAAC,SAAU,QAAS,QAAQ,EACjIa,EAAO,OAAMT,EAAAA,EAAUS,MAAVT,YAAAA,EAAAA,KAAAA,IACjB,GAAIS,EAAK,CAGP,GAFIH,IAAU,SAAQG,EAAMA,EAAIC,QAAO,GACnCR,GAAAA,MAAAA,EAASS,SAAQF,EAAMA,EAAIb,OAAQgB,GAAYV,EAAQW,SAASD,EAAQE,MAAM,CAAA,GAC9EC,OAAOC,KAAKT,CAAAA,EAAOI,OAAS,EAAG,CACjC,IAAMM,EAA2BF,OAAOG,QAAQX,CAAAA,EAChD,OAAW,CAACY,EAAMvB,CAAAA,IAAWqB,EAA0B,CACrD,IAAMG,EAAWD,EACjBV,EACEY,MAAMC,QAAQ1B,CAAAA,EACZa,EAAIb,OAAQgB,GACVhB,EAAO2B,MAAOC,GAAAA,CA1C9B,IAAA9B,EA2CkB,IAAMyB,EAAOP,GAAAA,YAAAA,EAAUQ,GAEvB,OAAOC,MAAMC,QAAQH,CAAAA,KAASA,EAAAA,EAAKN,WAALM,YAAAA,EAAAA,KAAAA,EAAgBK,GAChD,CAAA,CAAA,EAEFf,EAAIb,OAAQgB,IAAYA,GAAAA,YAAAA,EAAUQ,MAAcxB,CAAAA,CACtD,CACF,CACA,IAAM6B,EAActB,GAASM,EAAIE,OAC3Be,EAAetB,GAAU,EAC/B,OAAOA,IAAWuB,QACb,SAAA,CACC,IAAMC,EAAW,MAAMC,EAAeC,UAAUrB,CAAAA,EAChD,GAAIJ,EAAM,CAER,KAAOuB,EAASjB,OAAS,GAAKiB,EAAS,CAAA,EAAG,CAAA,IAAOvB,GAC/CuB,EAASG,MAAK,EAGZH,EAASjB,OAAS,GAAKiB,EAAS,CAAA,EAAG,CAAA,IAAOvB,GAC5CuB,EAASG,MAAK,CAElB,CACA,OAAOH,EAASI,IAAI,CAAC,CAACpB,CAAAA,IAAaA,CAAAA,EAASqB,MAAMP,EAAcA,EAAeD,CAAAA,CACjF,GAAA,EACAhB,EAAIwB,MAAMP,EAAcA,EAAeD,CAAAA,CAC7C,KACE,OAAM,IAAIS,MAAM,kCAAA,CAEpB,CACF,EAnDU3C,EAAAA,EAAAA,wBACR4C,EAVW7C,EAUc8C,gBAA0B,IAAIC,EAAAC,IAAMF,iBAAeG,IAC5EJ,EAXW7C,EAWckD,sBAA8BD,GAXlD,IAAMjD,EAANgD","names":["assertEx","removeFields","PayloadDiviner","isPayloadDivinerQueryPayload","PayloadDivinerConfigSchema","PayloadBuilder","MemoryPayloadDiviner","PayloadDiviner","divineHandler","payloads","_a","_b","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","__publicField","configSchemas","__superGet","_MemoryPayloadDiviner","PayloadDivinerConfigSchema","defaultConfigSchema"]}
|
package/package.json
CHANGED
|
@@ -12,20 +12,20 @@
|
|
|
12
12
|
"dependencies": {
|
|
13
13
|
"@xylabs/assert": "^3.5.1",
|
|
14
14
|
"@xylabs/object": "^3.5.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.
|
|
15
|
+
"@xyo-network/diviner-model": "~2.107.0",
|
|
16
|
+
"@xyo-network/diviner-payload-abstract": "~2.107.0",
|
|
17
|
+
"@xyo-network/diviner-payload-model": "~2.107.0",
|
|
18
|
+
"@xyo-network/payload-builder": "~2.107.0",
|
|
19
|
+
"@xyo-network/payload-model": "~2.107.0"
|
|
20
20
|
},
|
|
21
21
|
"devDependencies": {
|
|
22
|
-
"@xylabs/ts-scripts-yarn3": "^3.11.
|
|
23
|
-
"@xylabs/tsconfig": "^3.11.
|
|
24
|
-
"@xyo-network/account": "~2.
|
|
25
|
-
"@xyo-network/archivist-memory": "~2.
|
|
26
|
-
"@xyo-network/node-memory": "~2.
|
|
27
|
-
"@xyo-network/payload-builder": "~2.
|
|
28
|
-
"typescript": "^5.
|
|
22
|
+
"@xylabs/ts-scripts-yarn3": "^3.11.8",
|
|
23
|
+
"@xylabs/tsconfig": "^3.11.8",
|
|
24
|
+
"@xyo-network/account": "~2.107.0",
|
|
25
|
+
"@xyo-network/archivist-memory": "~2.107.0",
|
|
26
|
+
"@xyo-network/node-memory": "~2.107.0",
|
|
27
|
+
"@xyo-network/payload-builder": "~2.107.0",
|
|
28
|
+
"typescript": "^5.5.2"
|
|
29
29
|
},
|
|
30
30
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
31
31
|
"types": "dist/node/index.d.ts",
|
|
@@ -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.107.0",
|
|
70
70
|
"type": "module"
|
|
71
71
|
}
|