@xyo-network/diviner-schema-stats-memory 2.84.18 → 2.85.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 +26 -20
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +29 -25
- package/dist/browser/index.js.map +1 -1
- package/dist/node/index.cjs +31 -21
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +34 -26
- package/dist/node/index.js.map +1 -1
- package/package.json +6 -6
package/dist/browser/index.cjs
CHANGED
|
@@ -3,6 +3,7 @@ var __defProp = Object.defineProperty;
|
|
|
3
3
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
4
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
5
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
7
|
var __export = (target, all) => {
|
|
7
8
|
for (var name in all)
|
|
8
9
|
__defProp(target, name, { get: all[name], enumerable: true });
|
|
@@ -31,41 +32,46 @@ var import_diviner_schema_stats_abstract = require("@xyo-network/diviner-schema-
|
|
|
31
32
|
var import_diviner_schema_stats_model = require("@xyo-network/diviner-schema-stats-model");
|
|
32
33
|
var import_payload_builder = require("@xyo-network/payload-builder");
|
|
33
34
|
var MemorySchemaStatsDiviner = class extends import_diviner_schema_stats_abstract.SchemaStatsDiviner {
|
|
34
|
-
static
|
|
35
|
+
static {
|
|
36
|
+
__name(this, "MemorySchemaStatsDiviner");
|
|
37
|
+
}
|
|
38
|
+
static configSchemas = [
|
|
39
|
+
import_diviner_schema_stats_model.SchemaStatsDivinerConfigSchema
|
|
40
|
+
];
|
|
35
41
|
async divineAddress(address) {
|
|
36
42
|
const archivist = (0, import_assert.assertEx)(await this.getArchivist(), "Unable to resolve archivist");
|
|
37
43
|
const all = (0, import_assert.assertEx)(await archivist.all?.(), 'Archivist does not support "all"');
|
|
38
44
|
const filtered = all.filter(import_boundwitness_model.isBoundWitness).filter((bw) => bw.addresses.includes(address));
|
|
39
|
-
const counts = filtered.reduce(
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
},
|
|
44
|
-
{}
|
|
45
|
-
);
|
|
45
|
+
const counts = filtered.reduce((acc, payload) => {
|
|
46
|
+
acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1;
|
|
47
|
+
return acc;
|
|
48
|
+
}, {});
|
|
46
49
|
return counts;
|
|
47
50
|
}
|
|
48
51
|
async divineAllAddresses() {
|
|
49
52
|
const archivist = (0, import_assert.assertEx)(await this.getArchivist(), "Unable to resolve archivist");
|
|
50
53
|
const all = (0, import_assert.assertEx)(await archivist.all?.(), 'Archivist does not support "all"');
|
|
51
|
-
const counts = all.reduce(
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
},
|
|
56
|
-
{}
|
|
57
|
-
);
|
|
54
|
+
const counts = all.reduce((acc, payload) => {
|
|
55
|
+
acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1;
|
|
56
|
+
return acc;
|
|
57
|
+
}, {});
|
|
58
58
|
return counts;
|
|
59
59
|
}
|
|
60
60
|
async divineHandler(payloads) {
|
|
61
61
|
const query = payloads?.find(import_diviner_schema_stats_model.isSchemaStatsQueryPayload);
|
|
62
62
|
if (!query)
|
|
63
63
|
return [];
|
|
64
|
-
const addresses = query?.address ? Array.isArray(query?.address) ? query.address : [
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
64
|
+
const addresses = query?.address ? Array.isArray(query?.address) ? query.address : [
|
|
65
|
+
query.address
|
|
66
|
+
] : void 0;
|
|
67
|
+
const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [
|
|
68
|
+
await this.divineAllAddresses()
|
|
69
|
+
];
|
|
70
|
+
return await Promise.all(counts.map((count) => new import_payload_builder.PayloadBuilder({
|
|
71
|
+
schema: import_diviner_schema_stats_model.SchemaStatsDivinerSchema
|
|
72
|
+
}).fields({
|
|
73
|
+
count
|
|
74
|
+
}).build()));
|
|
69
75
|
}
|
|
70
76
|
};
|
|
71
77
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/MemorySchemaStatsDiviner.ts"],"sourcesContent":["export * from './MemorySchemaStatsDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { SchemaStatsDiviner } from '@xyo-network/diviner-schema-stats-abstract'\nimport {\n isSchemaStatsQueryPayload,\n SchemaStatsDivinerConfigSchema,\n SchemaStatsDivinerParams,\n SchemaStatsDivinerSchema,\n SchemaStatsPayload,\n SchemaStatsQueryPayload,\n} from '@xyo-network/diviner-schema-stats-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {\n static override configSchemas = [SchemaStatsDivinerConfigSchema]\n\n protected async divineAddress(address: string): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n const filtered = all.filter(isBoundWitness).filter((bw) => bw.addresses.includes(address))\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = filtered.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected async divineAllAddresses(): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = all.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n const query = payloads?.find<SchemaStatsQueryPayload>(isSchemaStatsQueryPayload)\n if (!query) return []\n const addresses = query?.address ? (Array.isArray(query?.address) ? query.address : [query.address]) : undefined\n const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [await this.divineAllAddresses()]\n return await Promise.all(\n counts.map((count) => new PayloadBuilder<SchemaStatsPayload>({ schema: SchemaStatsDivinerSchema }).fields({ count }).build()),\n )\n }\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/MemorySchemaStatsDiviner.ts"],"sourcesContent":["export * from './MemorySchemaStatsDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { SchemaStatsDiviner } from '@xyo-network/diviner-schema-stats-abstract'\nimport {\n isSchemaStatsQueryPayload,\n SchemaStatsDivinerConfigSchema,\n SchemaStatsDivinerParams,\n SchemaStatsDivinerSchema,\n SchemaStatsPayload,\n SchemaStatsQueryPayload,\n} from '@xyo-network/diviner-schema-stats-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {\n static override configSchemas = [SchemaStatsDivinerConfigSchema]\n\n protected async divineAddress(address: string): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n const filtered = all.filter(isBoundWitness).filter((bw) => bw.addresses.includes(address))\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = filtered.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected async divineAllAddresses(): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = all.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n const query = payloads?.find<SchemaStatsQueryPayload>(isSchemaStatsQueryPayload)\n if (!query) return []\n const addresses = query?.address ? (Array.isArray(query?.address) ? query.address : [query.address]) : undefined\n const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [await this.divineAllAddresses()]\n return await Promise.all(\n counts.map((count) => new PayloadBuilder<SchemaStatsPayload>({ schema: SchemaStatsDivinerSchema }).fields({ count }).build()),\n )\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,gCAA+B;AAC/B,2CAAmC;AACnC,wCAOO;AACP,6BAA+B;AAGxB,IAAMA,2BAAN,cAA4GC,wDAAAA;EAdnH,OAcmHA;;;EACjH,OAAgBC,gBAAgB;IAACC;;EAEjC,MAAgBC,cAAcC,SAAkD;AAC9E,UAAMC,gBAAYC,wBAAS,MAAM,KAAKC,aAAY,GAAI,6BAAA;AACtD,UAAMC,UAAMF,wBAAS,MAAMD,UAAUG,MAAG,GAAM,kCAAA;AAC9C,UAAMC,WAAWD,IAAIE,OAAOC,wCAAAA,EAAgBD,OAAO,CAACE,OAAOA,GAAGC,UAAUC,SAASV,OAAAA,CAAAA;AAEjF,UAAMW,SAAiCN,SAASO,OAC9C,CAACC,KAAKC,YAAAA;AACJD,UAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAI,IAAI;AACtE,aAAOF;IACT,GACA,CAAC,CAAA;AAEH,WAAOF;EACT;EAEA,MAAgBK,qBAAsD;AACpE,UAAMf,gBAAYC,wBAAS,MAAM,KAAKC,aAAY,GAAI,6BAAA;AACtD,UAAMC,UAAMF,wBAAS,MAAMD,UAAUG,MAAG,GAAM,kCAAA;AAE9C,UAAMO,SAAiCP,IAAIQ,OACzC,CAACC,KAAKC,YAAAA;AACJD,UAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAI,IAAI;AACtE,aAAOF;IACT,GACA,CAAC,CAAA;AAEH,WAAOF;EACT;EAEA,MAAyBM,cAAcC,UAA0C;AAC/E,UAAMC,QAAQD,UAAUE,KAA8BC,2DAAAA;AACtD,QAAI,CAACF;AAAO,aAAO,CAAA;AACnB,UAAMV,YAAYU,OAAOnB,UAAWsB,MAAMC,QAAQJ,OAAOnB,OAAAA,IAAWmB,MAAMnB,UAAU;MAACmB,MAAMnB;QAAYwB;AACvG,UAAMb,SAASF,YAAY,MAAMgB,QAAQrB,IAAIK,UAAUiB,IAAI,CAAC1B,YAAY,KAAKD,cAAcC,OAAAA,CAAAA,CAAAA,IAAa;MAAC,MAAM,KAAKgB,mBAAkB;;AACtI,WAAO,MAAMS,QAAQrB,IACnBO,OAAOe,IAAI,CAACC,UAAU,IAAIC,sCAAmC;MAAEb,QAAQc;IAAyB,CAAA,EAAGC,OAAO;MAAEH;IAAM,CAAA,EAAGI,MAAK,CAAA,CAAA;EAE9H;AACF;","names":["MemorySchemaStatsDiviner","SchemaStatsDiviner","configSchemas","SchemaStatsDivinerConfigSchema","divineAddress","address","archivist","assertEx","getArchivist","all","filtered","filter","isBoundWitness","bw","addresses","includes","counts","reduce","acc","payload","schema","divineAllAddresses","divineHandler","payloads","query","find","isSchemaStatsQueryPayload","Array","isArray","undefined","Promise","map","count","PayloadBuilder","SchemaStatsDivinerSchema","fields","build"]}
|
package/dist/browser/index.js
CHANGED
|
@@ -1,49 +1,53 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
+
|
|
1
4
|
// src/MemorySchemaStatsDiviner.ts
|
|
2
5
|
import { assertEx } from "@xylabs/assert";
|
|
3
6
|
import { isBoundWitness } from "@xyo-network/boundwitness-model";
|
|
4
7
|
import { SchemaStatsDiviner } from "@xyo-network/diviner-schema-stats-abstract";
|
|
5
|
-
import {
|
|
6
|
-
isSchemaStatsQueryPayload,
|
|
7
|
-
SchemaStatsDivinerConfigSchema,
|
|
8
|
-
SchemaStatsDivinerSchema
|
|
9
|
-
} from "@xyo-network/diviner-schema-stats-model";
|
|
8
|
+
import { isSchemaStatsQueryPayload, SchemaStatsDivinerConfigSchema, SchemaStatsDivinerSchema } from "@xyo-network/diviner-schema-stats-model";
|
|
10
9
|
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
11
10
|
var MemorySchemaStatsDiviner = class extends SchemaStatsDiviner {
|
|
12
|
-
static
|
|
11
|
+
static {
|
|
12
|
+
__name(this, "MemorySchemaStatsDiviner");
|
|
13
|
+
}
|
|
14
|
+
static configSchemas = [
|
|
15
|
+
SchemaStatsDivinerConfigSchema
|
|
16
|
+
];
|
|
13
17
|
async divineAddress(address) {
|
|
14
18
|
const archivist = assertEx(await this.getArchivist(), "Unable to resolve archivist");
|
|
15
19
|
const all = assertEx(await archivist.all?.(), 'Archivist does not support "all"');
|
|
16
20
|
const filtered = all.filter(isBoundWitness).filter((bw) => bw.addresses.includes(address));
|
|
17
|
-
const counts = filtered.reduce(
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
},
|
|
22
|
-
{}
|
|
23
|
-
);
|
|
21
|
+
const counts = filtered.reduce((acc, payload) => {
|
|
22
|
+
acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1;
|
|
23
|
+
return acc;
|
|
24
|
+
}, {});
|
|
24
25
|
return counts;
|
|
25
26
|
}
|
|
26
27
|
async divineAllAddresses() {
|
|
27
28
|
const archivist = assertEx(await this.getArchivist(), "Unable to resolve archivist");
|
|
28
29
|
const all = assertEx(await archivist.all?.(), 'Archivist does not support "all"');
|
|
29
|
-
const counts = all.reduce(
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
},
|
|
34
|
-
{}
|
|
35
|
-
);
|
|
30
|
+
const counts = all.reduce((acc, payload) => {
|
|
31
|
+
acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1;
|
|
32
|
+
return acc;
|
|
33
|
+
}, {});
|
|
36
34
|
return counts;
|
|
37
35
|
}
|
|
38
36
|
async divineHandler(payloads) {
|
|
39
37
|
const query = payloads?.find(isSchemaStatsQueryPayload);
|
|
40
38
|
if (!query)
|
|
41
39
|
return [];
|
|
42
|
-
const addresses = query?.address ? Array.isArray(query?.address) ? query.address : [
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
40
|
+
const addresses = query?.address ? Array.isArray(query?.address) ? query.address : [
|
|
41
|
+
query.address
|
|
42
|
+
] : void 0;
|
|
43
|
+
const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [
|
|
44
|
+
await this.divineAllAddresses()
|
|
45
|
+
];
|
|
46
|
+
return await Promise.all(counts.map((count) => new PayloadBuilder({
|
|
47
|
+
schema: SchemaStatsDivinerSchema
|
|
48
|
+
}).fields({
|
|
49
|
+
count
|
|
50
|
+
}).build()));
|
|
47
51
|
}
|
|
48
52
|
};
|
|
49
53
|
export {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/MemorySchemaStatsDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { SchemaStatsDiviner } from '@xyo-network/diviner-schema-stats-abstract'\nimport {\n isSchemaStatsQueryPayload,\n SchemaStatsDivinerConfigSchema,\n SchemaStatsDivinerParams,\n SchemaStatsDivinerSchema,\n SchemaStatsPayload,\n SchemaStatsQueryPayload,\n} from '@xyo-network/diviner-schema-stats-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {\n static override configSchemas = [SchemaStatsDivinerConfigSchema]\n\n protected async divineAddress(address: string): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n const filtered = all.filter(isBoundWitness).filter((bw) => bw.addresses.includes(address))\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = filtered.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected async divineAllAddresses(): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = all.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n const query = payloads?.find<SchemaStatsQueryPayload>(isSchemaStatsQueryPayload)\n if (!query) return []\n const addresses = query?.address ? (Array.isArray(query?.address) ? query.address : [query.address]) : undefined\n const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [await this.divineAllAddresses()]\n return await Promise.all(\n counts.map((count) => new PayloadBuilder<SchemaStatsPayload>({ schema: SchemaStatsDivinerSchema }).fields({ count }).build()),\n )\n }\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/MemorySchemaStatsDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { SchemaStatsDiviner } from '@xyo-network/diviner-schema-stats-abstract'\nimport {\n isSchemaStatsQueryPayload,\n SchemaStatsDivinerConfigSchema,\n SchemaStatsDivinerParams,\n SchemaStatsDivinerSchema,\n SchemaStatsPayload,\n SchemaStatsQueryPayload,\n} from '@xyo-network/diviner-schema-stats-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {\n static override configSchemas = [SchemaStatsDivinerConfigSchema]\n\n protected async divineAddress(address: string): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n const filtered = all.filter(isBoundWitness).filter((bw) => bw.addresses.includes(address))\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = filtered.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected async divineAllAddresses(): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = all.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n const query = payloads?.find<SchemaStatsQueryPayload>(isSchemaStatsQueryPayload)\n if (!query) return []\n const addresses = query?.address ? (Array.isArray(query?.address) ? query.address : [query.address]) : undefined\n const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [await this.divineAllAddresses()]\n return await Promise.all(\n counts.map((count) => new PayloadBuilder<SchemaStatsPayload>({ schema: SchemaStatsDivinerSchema }).fields({ count }).build()),\n )\n }\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,sBAAsB;AAC/B,SAASC,0BAA0B;AACnC,SACEC,2BACAC,gCAEAC,gCAGK;AACP,SAASC,sBAAsB;AAGxB,IAAMC,2BAAN,cAA4GC,mBAAAA;EAdnH,OAcmHA;;;EACjH,OAAgBC,gBAAgB;IAACC;;EAEjC,MAAgBC,cAAcC,SAAkD;AAC9E,UAAMC,YAAYC,SAAS,MAAM,KAAKC,aAAY,GAAI,6BAAA;AACtD,UAAMC,MAAMF,SAAS,MAAMD,UAAUG,MAAG,GAAM,kCAAA;AAC9C,UAAMC,WAAWD,IAAIE,OAAOC,cAAAA,EAAgBD,OAAO,CAACE,OAAOA,GAAGC,UAAUC,SAASV,OAAAA,CAAAA;AAEjF,UAAMW,SAAiCN,SAASO,OAC9C,CAACC,KAAKC,YAAAA;AACJD,UAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAI,IAAI;AACtE,aAAOF;IACT,GACA,CAAC,CAAA;AAEH,WAAOF;EACT;EAEA,MAAgBK,qBAAsD;AACpE,UAAMf,YAAYC,SAAS,MAAM,KAAKC,aAAY,GAAI,6BAAA;AACtD,UAAMC,MAAMF,SAAS,MAAMD,UAAUG,MAAG,GAAM,kCAAA;AAE9C,UAAMO,SAAiCP,IAAIQ,OACzC,CAACC,KAAKC,YAAAA;AACJD,UAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAI,IAAI;AACtE,aAAOF;IACT,GACA,CAAC,CAAA;AAEH,WAAOF;EACT;EAEA,MAAyBM,cAAcC,UAA0C;AAC/E,UAAMC,QAAQD,UAAUE,KAA8BC,yBAAAA;AACtD,QAAI,CAACF;AAAO,aAAO,CAAA;AACnB,UAAMV,YAAYU,OAAOnB,UAAWsB,MAAMC,QAAQJ,OAAOnB,OAAAA,IAAWmB,MAAMnB,UAAU;MAACmB,MAAMnB;QAAYwB;AACvG,UAAMb,SAASF,YAAY,MAAMgB,QAAQrB,IAAIK,UAAUiB,IAAI,CAAC1B,YAAY,KAAKD,cAAcC,OAAAA,CAAAA,CAAAA,IAAa;MAAC,MAAM,KAAKgB,mBAAkB;;AACtI,WAAO,MAAMS,QAAQrB,IACnBO,OAAOe,IAAI,CAACC,UAAU,IAAIC,eAAmC;MAAEb,QAAQc;IAAyB,CAAA,EAAGC,OAAO;MAAEH;IAAM,CAAA,EAAGI,MAAK,CAAA,CAAA;EAE9H;AACF;","names":["assertEx","isBoundWitness","SchemaStatsDiviner","isSchemaStatsQueryPayload","SchemaStatsDivinerConfigSchema","SchemaStatsDivinerSchema","PayloadBuilder","MemorySchemaStatsDiviner","SchemaStatsDiviner","configSchemas","SchemaStatsDivinerConfigSchema","divineAddress","address","archivist","assertEx","getArchivist","all","filtered","filter","isBoundWitness","bw","addresses","includes","counts","reduce","acc","payload","schema","divineAllAddresses","divineHandler","payloads","query","find","isSchemaStatsQueryPayload","Array","isArray","undefined","Promise","map","count","PayloadBuilder","SchemaStatsDivinerSchema","fields","build"]}
|
package/dist/node/index.cjs
CHANGED
|
@@ -3,6 +3,8 @@ var __defProp = Object.defineProperty;
|
|
|
3
3
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
4
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
5
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
7
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
8
|
var __export = (target, all) => {
|
|
7
9
|
for (var name in all)
|
|
8
10
|
__defProp(target, name, { get: all[name], enumerable: true });
|
|
@@ -16,6 +18,10 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
16
18
|
return to;
|
|
17
19
|
};
|
|
18
20
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
21
|
+
var __publicField = (obj, key, value) => {
|
|
22
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
23
|
+
return value;
|
|
24
|
+
};
|
|
19
25
|
|
|
20
26
|
// src/index.ts
|
|
21
27
|
var src_exports = {};
|
|
@@ -30,46 +36,50 @@ var import_boundwitness_model = require("@xyo-network/boundwitness-model");
|
|
|
30
36
|
var import_diviner_schema_stats_abstract = require("@xyo-network/diviner-schema-stats-abstract");
|
|
31
37
|
var import_diviner_schema_stats_model = require("@xyo-network/diviner-schema-stats-model");
|
|
32
38
|
var import_payload_builder = require("@xyo-network/payload-builder");
|
|
33
|
-
var
|
|
34
|
-
static configSchemas = [import_diviner_schema_stats_model.SchemaStatsDivinerConfigSchema];
|
|
39
|
+
var _MemorySchemaStatsDiviner = class _MemorySchemaStatsDiviner extends import_diviner_schema_stats_abstract.SchemaStatsDiviner {
|
|
35
40
|
async divineAddress(address) {
|
|
36
41
|
var _a;
|
|
37
42
|
const archivist = (0, import_assert.assertEx)(await this.getArchivist(), "Unable to resolve archivist");
|
|
38
43
|
const all = (0, import_assert.assertEx)(await ((_a = archivist.all) == null ? void 0 : _a.call(archivist)), 'Archivist does not support "all"');
|
|
39
44
|
const filtered = all.filter(import_boundwitness_model.isBoundWitness).filter((bw) => bw.addresses.includes(address));
|
|
40
|
-
const counts = filtered.reduce(
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
},
|
|
45
|
-
{}
|
|
46
|
-
);
|
|
45
|
+
const counts = filtered.reduce((acc, payload) => {
|
|
46
|
+
acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1;
|
|
47
|
+
return acc;
|
|
48
|
+
}, {});
|
|
47
49
|
return counts;
|
|
48
50
|
}
|
|
49
51
|
async divineAllAddresses() {
|
|
50
52
|
var _a;
|
|
51
53
|
const archivist = (0, import_assert.assertEx)(await this.getArchivist(), "Unable to resolve archivist");
|
|
52
54
|
const all = (0, import_assert.assertEx)(await ((_a = archivist.all) == null ? void 0 : _a.call(archivist)), 'Archivist does not support "all"');
|
|
53
|
-
const counts = all.reduce(
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
},
|
|
58
|
-
{}
|
|
59
|
-
);
|
|
55
|
+
const counts = all.reduce((acc, payload) => {
|
|
56
|
+
acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1;
|
|
57
|
+
return acc;
|
|
58
|
+
}, {});
|
|
60
59
|
return counts;
|
|
61
60
|
}
|
|
62
61
|
async divineHandler(payloads) {
|
|
63
62
|
const query = payloads == null ? void 0 : payloads.find(import_diviner_schema_stats_model.isSchemaStatsQueryPayload);
|
|
64
63
|
if (!query)
|
|
65
64
|
return [];
|
|
66
|
-
const addresses = (query == null ? void 0 : query.address) ? Array.isArray(query == null ? void 0 : query.address) ? query.address : [
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
65
|
+
const addresses = (query == null ? void 0 : query.address) ? Array.isArray(query == null ? void 0 : query.address) ? query.address : [
|
|
66
|
+
query.address
|
|
67
|
+
] : void 0;
|
|
68
|
+
const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [
|
|
69
|
+
await this.divineAllAddresses()
|
|
70
|
+
];
|
|
71
|
+
return await Promise.all(counts.map((count) => new import_payload_builder.PayloadBuilder({
|
|
72
|
+
schema: import_diviner_schema_stats_model.SchemaStatsDivinerSchema
|
|
73
|
+
}).fields({
|
|
74
|
+
count
|
|
75
|
+
}).build()));
|
|
71
76
|
}
|
|
72
77
|
};
|
|
78
|
+
__name(_MemorySchemaStatsDiviner, "MemorySchemaStatsDiviner");
|
|
79
|
+
__publicField(_MemorySchemaStatsDiviner, "configSchemas", [
|
|
80
|
+
import_diviner_schema_stats_model.SchemaStatsDivinerConfigSchema
|
|
81
|
+
]);
|
|
82
|
+
var MemorySchemaStatsDiviner = _MemorySchemaStatsDiviner;
|
|
73
83
|
// Annotate the CommonJS export names for ESM import in node:
|
|
74
84
|
0 && (module.exports = {
|
|
75
85
|
MemorySchemaStatsDiviner
|
package/dist/node/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/MemorySchemaStatsDiviner.ts"],"sourcesContent":["export * from './MemorySchemaStatsDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { SchemaStatsDiviner } from '@xyo-network/diviner-schema-stats-abstract'\nimport {\n isSchemaStatsQueryPayload,\n SchemaStatsDivinerConfigSchema,\n SchemaStatsDivinerParams,\n SchemaStatsDivinerSchema,\n SchemaStatsPayload,\n SchemaStatsQueryPayload,\n} from '@xyo-network/diviner-schema-stats-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {\n static override configSchemas = [SchemaStatsDivinerConfigSchema]\n\n protected async divineAddress(address: string): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n const filtered = all.filter(isBoundWitness).filter((bw) => bw.addresses.includes(address))\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = filtered.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected async divineAllAddresses(): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = all.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n const query = payloads?.find<SchemaStatsQueryPayload>(isSchemaStatsQueryPayload)\n if (!query) return []\n const addresses = query?.address ? (Array.isArray(query?.address) ? query.address : [query.address]) : undefined\n const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [await this.divineAllAddresses()]\n return await Promise.all(\n counts.map((count) => new PayloadBuilder<SchemaStatsPayload>({ schema: SchemaStatsDivinerSchema }).fields({ count }).build()),\n )\n }\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/MemorySchemaStatsDiviner.ts"],"sourcesContent":["export * from './MemorySchemaStatsDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { SchemaStatsDiviner } from '@xyo-network/diviner-schema-stats-abstract'\nimport {\n isSchemaStatsQueryPayload,\n SchemaStatsDivinerConfigSchema,\n SchemaStatsDivinerParams,\n SchemaStatsDivinerSchema,\n SchemaStatsPayload,\n SchemaStatsQueryPayload,\n} from '@xyo-network/diviner-schema-stats-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {\n static override configSchemas = [SchemaStatsDivinerConfigSchema]\n\n protected async divineAddress(address: string): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n const filtered = all.filter(isBoundWitness).filter((bw) => bw.addresses.includes(address))\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = filtered.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected async divineAllAddresses(): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = all.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n const query = payloads?.find<SchemaStatsQueryPayload>(isSchemaStatsQueryPayload)\n if (!query) return []\n const addresses = query?.address ? (Array.isArray(query?.address) ? query.address : [query.address]) : undefined\n const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [await this.divineAllAddresses()]\n return await Promise.all(\n counts.map((count) => new PayloadBuilder<SchemaStatsPayload>({ schema: SchemaStatsDivinerSchema }).fields({ count }).build()),\n )\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,gCAA+B;AAC/B,2CAAmC;AACnC,wCAOO;AACP,6BAA+B;AAGxB,IAAMA,4BAAN,MAAMA,kCAAsGC,wDAAAA;EAGjH,MAAgBC,cAAcC,SAAkD;AAjBlF;AAkBI,UAAMC,gBAAYC,wBAAS,MAAM,KAAKC,aAAY,GAAI,6BAAA;AACtD,UAAMC,UAAMF,wBAAS,QAAMD,eAAUG,QAAVH,qCAAmB,kCAAA;AAC9C,UAAMI,WAAWD,IAAIE,OAAOC,wCAAAA,EAAgBD,OAAO,CAACE,OAAOA,GAAGC,UAAUC,SAASV,OAAAA,CAAAA;AAEjF,UAAMW,SAAiCN,SAASO,OAC9C,CAACC,KAAKC,YAAAA;AACJD,UAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAI,IAAI;AACtE,aAAOF;IACT,GACA,CAAC,CAAA;AAEH,WAAOF;EACT;EAEA,MAAgBK,qBAAsD;AAhCxE;AAiCI,UAAMf,gBAAYC,wBAAS,MAAM,KAAKC,aAAY,GAAI,6BAAA;AACtD,UAAMC,UAAMF,wBAAS,QAAMD,eAAUG,QAAVH,qCAAmB,kCAAA;AAE9C,UAAMU,SAAiCP,IAAIQ,OACzC,CAACC,KAAKC,YAAAA;AACJD,UAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAI,IAAI;AACtE,aAAOF;IACT,GACA,CAAC,CAAA;AAEH,WAAOF;EACT;EAEA,MAAyBM,cAAcC,UAA0C;AAC/E,UAAMC,QAAQD,qCAAUE,KAA8BC;AACtD,QAAI,CAACF;AAAO,aAAO,CAAA;AACnB,UAAMV,aAAYU,+BAAOnB,WAAWsB,MAAMC,QAAQJ,+BAAOnB,OAAAA,IAAWmB,MAAMnB,UAAU;MAACmB,MAAMnB;QAAYwB;AACvG,UAAMb,SAASF,YAAY,MAAMgB,QAAQrB,IAAIK,UAAUiB,IAAI,CAAC1B,YAAY,KAAKD,cAAcC,OAAAA,CAAAA,CAAAA,IAAa;MAAC,MAAM,KAAKgB,mBAAkB;;AACtI,WAAO,MAAMS,QAAQrB,IACnBO,OAAOe,IAAI,CAACC,UAAU,IAAIC,sCAAmC;MAAEb,QAAQc;IAAyB,CAAA,EAAGC,OAAO;MAAEH;IAAM,CAAA,EAAGI,MAAK,CAAA,CAAA;EAE9H;AACF;AAzCmHjC;AACjH,cADWD,2BACKmC,iBAAgB;EAACC;;AAD5B,IAAMpC,2BAAN;","names":["MemorySchemaStatsDiviner","SchemaStatsDiviner","divineAddress","address","archivist","assertEx","getArchivist","all","filtered","filter","isBoundWitness","bw","addresses","includes","counts","reduce","acc","payload","schema","divineAllAddresses","divineHandler","payloads","query","find","isSchemaStatsQueryPayload","Array","isArray","undefined","Promise","map","count","PayloadBuilder","SchemaStatsDivinerSchema","fields","build","configSchemas","SchemaStatsDivinerConfigSchema"]}
|
package/dist/node/index.js
CHANGED
|
@@ -1,53 +1,61 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
4
|
+
var __publicField = (obj, key, value) => {
|
|
5
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
6
|
+
return value;
|
|
7
|
+
};
|
|
8
|
+
|
|
1
9
|
// src/MemorySchemaStatsDiviner.ts
|
|
2
10
|
import { assertEx } from "@xylabs/assert";
|
|
3
11
|
import { isBoundWitness } from "@xyo-network/boundwitness-model";
|
|
4
12
|
import { SchemaStatsDiviner } from "@xyo-network/diviner-schema-stats-abstract";
|
|
5
|
-
import {
|
|
6
|
-
isSchemaStatsQueryPayload,
|
|
7
|
-
SchemaStatsDivinerConfigSchema,
|
|
8
|
-
SchemaStatsDivinerSchema
|
|
9
|
-
} from "@xyo-network/diviner-schema-stats-model";
|
|
13
|
+
import { isSchemaStatsQueryPayload, SchemaStatsDivinerConfigSchema, SchemaStatsDivinerSchema } from "@xyo-network/diviner-schema-stats-model";
|
|
10
14
|
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
11
|
-
var
|
|
12
|
-
static configSchemas = [SchemaStatsDivinerConfigSchema];
|
|
15
|
+
var _MemorySchemaStatsDiviner = class _MemorySchemaStatsDiviner extends SchemaStatsDiviner {
|
|
13
16
|
async divineAddress(address) {
|
|
14
17
|
var _a;
|
|
15
18
|
const archivist = assertEx(await this.getArchivist(), "Unable to resolve archivist");
|
|
16
19
|
const all = assertEx(await ((_a = archivist.all) == null ? void 0 : _a.call(archivist)), 'Archivist does not support "all"');
|
|
17
20
|
const filtered = all.filter(isBoundWitness).filter((bw) => bw.addresses.includes(address));
|
|
18
|
-
const counts = filtered.reduce(
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
},
|
|
23
|
-
{}
|
|
24
|
-
);
|
|
21
|
+
const counts = filtered.reduce((acc, payload) => {
|
|
22
|
+
acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1;
|
|
23
|
+
return acc;
|
|
24
|
+
}, {});
|
|
25
25
|
return counts;
|
|
26
26
|
}
|
|
27
27
|
async divineAllAddresses() {
|
|
28
28
|
var _a;
|
|
29
29
|
const archivist = assertEx(await this.getArchivist(), "Unable to resolve archivist");
|
|
30
30
|
const all = assertEx(await ((_a = archivist.all) == null ? void 0 : _a.call(archivist)), 'Archivist does not support "all"');
|
|
31
|
-
const counts = all.reduce(
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
},
|
|
36
|
-
{}
|
|
37
|
-
);
|
|
31
|
+
const counts = all.reduce((acc, payload) => {
|
|
32
|
+
acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1;
|
|
33
|
+
return acc;
|
|
34
|
+
}, {});
|
|
38
35
|
return counts;
|
|
39
36
|
}
|
|
40
37
|
async divineHandler(payloads) {
|
|
41
38
|
const query = payloads == null ? void 0 : payloads.find(isSchemaStatsQueryPayload);
|
|
42
39
|
if (!query)
|
|
43
40
|
return [];
|
|
44
|
-
const addresses = (query == null ? void 0 : query.address) ? Array.isArray(query == null ? void 0 : query.address) ? query.address : [
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
41
|
+
const addresses = (query == null ? void 0 : query.address) ? Array.isArray(query == null ? void 0 : query.address) ? query.address : [
|
|
42
|
+
query.address
|
|
43
|
+
] : void 0;
|
|
44
|
+
const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [
|
|
45
|
+
await this.divineAllAddresses()
|
|
46
|
+
];
|
|
47
|
+
return await Promise.all(counts.map((count) => new PayloadBuilder({
|
|
48
|
+
schema: SchemaStatsDivinerSchema
|
|
49
|
+
}).fields({
|
|
50
|
+
count
|
|
51
|
+
}).build()));
|
|
49
52
|
}
|
|
50
53
|
};
|
|
54
|
+
__name(_MemorySchemaStatsDiviner, "MemorySchemaStatsDiviner");
|
|
55
|
+
__publicField(_MemorySchemaStatsDiviner, "configSchemas", [
|
|
56
|
+
SchemaStatsDivinerConfigSchema
|
|
57
|
+
]);
|
|
58
|
+
var MemorySchemaStatsDiviner = _MemorySchemaStatsDiviner;
|
|
51
59
|
export {
|
|
52
60
|
MemorySchemaStatsDiviner
|
|
53
61
|
};
|
package/dist/node/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/MemorySchemaStatsDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { SchemaStatsDiviner } from '@xyo-network/diviner-schema-stats-abstract'\nimport {\n isSchemaStatsQueryPayload,\n SchemaStatsDivinerConfigSchema,\n SchemaStatsDivinerParams,\n SchemaStatsDivinerSchema,\n SchemaStatsPayload,\n SchemaStatsQueryPayload,\n} from '@xyo-network/diviner-schema-stats-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {\n static override configSchemas = [SchemaStatsDivinerConfigSchema]\n\n protected async divineAddress(address: string): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n const filtered = all.filter(isBoundWitness).filter((bw) => bw.addresses.includes(address))\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = filtered.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected async divineAllAddresses(): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = all.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n const query = payloads?.find<SchemaStatsQueryPayload>(isSchemaStatsQueryPayload)\n if (!query) return []\n const addresses = query?.address ? (Array.isArray(query?.address) ? query.address : [query.address]) : undefined\n const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [await this.divineAllAddresses()]\n return await Promise.all(\n counts.map((count) => new PayloadBuilder<SchemaStatsPayload>({ schema: SchemaStatsDivinerSchema }).fields({ count }).build()),\n )\n }\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/MemorySchemaStatsDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { isBoundWitness } from '@xyo-network/boundwitness-model'\nimport { SchemaStatsDiviner } from '@xyo-network/diviner-schema-stats-abstract'\nimport {\n isSchemaStatsQueryPayload,\n SchemaStatsDivinerConfigSchema,\n SchemaStatsDivinerParams,\n SchemaStatsDivinerSchema,\n SchemaStatsPayload,\n SchemaStatsQueryPayload,\n} from '@xyo-network/diviner-schema-stats-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {\n static override configSchemas = [SchemaStatsDivinerConfigSchema]\n\n protected async divineAddress(address: string): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n const filtered = all.filter(isBoundWitness).filter((bw) => bw.addresses.includes(address))\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = filtered.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected async divineAllAddresses(): Promise<Record<string, number>> {\n const archivist = assertEx(await this.getArchivist(), 'Unable to resolve archivist')\n const all = assertEx(await archivist.all?.(), 'Archivist does not support \"all\"')\n // eslint-disable-next-line unicorn/no-array-reduce\n const counts: Record<string, number> = all.reduce(\n (acc, payload) => {\n acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1\n return acc\n },\n {} as Record<string, number>,\n )\n return counts\n }\n\n protected override async divineHandler(payloads?: Payload[]): Promise<Payload[]> {\n const query = payloads?.find<SchemaStatsQueryPayload>(isSchemaStatsQueryPayload)\n if (!query) return []\n const addresses = query?.address ? (Array.isArray(query?.address) ? query.address : [query.address]) : undefined\n const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [await this.divineAllAddresses()]\n return await Promise.all(\n counts.map((count) => new PayloadBuilder<SchemaStatsPayload>({ schema: SchemaStatsDivinerSchema }).fields({ count }).build()),\n )\n }\n}\n"],"mappings":";;;;;;;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,sBAAsB;AAC/B,SAASC,0BAA0B;AACnC,SACEC,2BACAC,gCAEAC,gCAGK;AACP,SAASC,sBAAsB;AAGxB,IAAMC,4BAAN,MAAMA,kCAAsGC,mBAAAA;EAGjH,MAAgBC,cAAcC,SAAkD;AAjBlF;AAkBI,UAAMC,YAAYC,SAAS,MAAM,KAAKC,aAAY,GAAI,6BAAA;AACtD,UAAMC,MAAMF,SAAS,QAAMD,eAAUG,QAAVH,qCAAmB,kCAAA;AAC9C,UAAMI,WAAWD,IAAIE,OAAOC,cAAAA,EAAgBD,OAAO,CAACE,OAAOA,GAAGC,UAAUC,SAASV,OAAAA,CAAAA;AAEjF,UAAMW,SAAiCN,SAASO,OAC9C,CAACC,KAAKC,YAAAA;AACJD,UAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAI,IAAI;AACtE,aAAOF;IACT,GACA,CAAC,CAAA;AAEH,WAAOF;EACT;EAEA,MAAgBK,qBAAsD;AAhCxE;AAiCI,UAAMf,YAAYC,SAAS,MAAM,KAAKC,aAAY,GAAI,6BAAA;AACtD,UAAMC,MAAMF,SAAS,QAAMD,eAAUG,QAAVH,qCAAmB,kCAAA;AAE9C,UAAMU,SAAiCP,IAAIQ,OACzC,CAACC,KAAKC,YAAAA;AACJD,UAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAIF,IAAIC,QAAQC,MAAM,IAAI,IAAI;AACtE,aAAOF;IACT,GACA,CAAC,CAAA;AAEH,WAAOF;EACT;EAEA,MAAyBM,cAAcC,UAA0C;AAC/E,UAAMC,QAAQD,qCAAUE,KAA8BC;AACtD,QAAI,CAACF;AAAO,aAAO,CAAA;AACnB,UAAMV,aAAYU,+BAAOnB,WAAWsB,MAAMC,QAAQJ,+BAAOnB,OAAAA,IAAWmB,MAAMnB,UAAU;MAACmB,MAAMnB;QAAYwB;AACvG,UAAMb,SAASF,YAAY,MAAMgB,QAAQrB,IAAIK,UAAUiB,IAAI,CAAC1B,YAAY,KAAKD,cAAcC,OAAAA,CAAAA,CAAAA,IAAa;MAAC,MAAM,KAAKgB,mBAAkB;;AACtI,WAAO,MAAMS,QAAQrB,IACnBO,OAAOe,IAAI,CAACC,UAAU,IAAIC,eAAmC;MAAEb,QAAQc;IAAyB,CAAA,EAAGC,OAAO;MAAEH;IAAM,CAAA,EAAGI,MAAK,CAAA,CAAA;EAE9H;AACF;AAzCmHjC;AACjH,cADWD,2BACKmC,iBAAgB;EAACC;;AAD5B,IAAMpC,2BAAN;","names":["assertEx","isBoundWitness","SchemaStatsDiviner","isSchemaStatsQueryPayload","SchemaStatsDivinerConfigSchema","SchemaStatsDivinerSchema","PayloadBuilder","MemorySchemaStatsDiviner","SchemaStatsDiviner","divineAddress","address","archivist","assertEx","getArchivist","all","filtered","filter","isBoundWitness","bw","addresses","includes","counts","reduce","acc","payload","schema","divineAllAddresses","divineHandler","payloads","query","find","isSchemaStatsQueryPayload","Array","isArray","undefined","Promise","map","count","PayloadBuilder","SchemaStatsDivinerSchema","fields","build","configSchemas","SchemaStatsDivinerConfigSchema"]}
|
package/package.json
CHANGED
|
@@ -11,11 +11,11 @@
|
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
13
|
"@xylabs/assert": "^2.13.20",
|
|
14
|
-
"@xyo-network/boundwitness-model": "~2.
|
|
15
|
-
"@xyo-network/diviner-schema-stats-abstract": "~2.
|
|
16
|
-
"@xyo-network/diviner-schema-stats-model": "~2.
|
|
17
|
-
"@xyo-network/payload-builder": "~2.
|
|
18
|
-
"@xyo-network/payload-model": "~2.
|
|
14
|
+
"@xyo-network/boundwitness-model": "~2.85.0",
|
|
15
|
+
"@xyo-network/diviner-schema-stats-abstract": "~2.85.0",
|
|
16
|
+
"@xyo-network/diviner-schema-stats-model": "~2.85.0",
|
|
17
|
+
"@xyo-network/payload-builder": "~2.85.0",
|
|
18
|
+
"@xyo-network/payload-model": "~2.85.0"
|
|
19
19
|
},
|
|
20
20
|
"devDependencies": {
|
|
21
21
|
"@xylabs/ts-scripts-yarn3": "^3.2.25",
|
|
@@ -61,6 +61,6 @@
|
|
|
61
61
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
62
62
|
},
|
|
63
63
|
"sideEffects": false,
|
|
64
|
-
"version": "2.
|
|
64
|
+
"version": "2.85.0",
|
|
65
65
|
"type": "module"
|
|
66
66
|
}
|