@xyo-network/diviner-schema-stats-memory 2.99.1 → 2.99.3
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/neutral/MemorySchemaStatsDiviner.d.cts +12 -0
- package/dist/neutral/MemorySchemaStatsDiviner.d.cts.map +1 -0
- package/dist/neutral/MemorySchemaStatsDiviner.d.mts +12 -0
- package/dist/neutral/MemorySchemaStatsDiviner.d.mts.map +1 -0
- package/dist/neutral/MemorySchemaStatsDiviner.d.ts +12 -0
- package/dist/neutral/MemorySchemaStatsDiviner.d.ts.map +1 -0
- package/dist/neutral/index.cjs +79 -0
- package/dist/neutral/index.cjs.map +1 -0
- package/dist/neutral/index.d.cts +2 -0
- package/dist/neutral/index.d.cts.map +1 -0
- package/dist/neutral/index.d.mts +2 -0
- package/dist/neutral/index.d.mts.map +1 -0
- package/dist/neutral/index.d.ts +2 -0
- package/dist/neutral/index.d.ts.map +1 -0
- package/dist/neutral/index.js +58 -0
- package/dist/neutral/index.js.map +1 -0
- package/package.json +10 -10
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Address } from '@xylabs/hex';
|
|
2
|
+
import { SchemaStatsDiviner } from '@xyo-network/diviner-schema-stats-abstract';
|
|
3
|
+
import { SchemaStatsDivinerParams } from '@xyo-network/diviner-schema-stats-model';
|
|
4
|
+
import { Payload, Schema } from '@xyo-network/payload-model';
|
|
5
|
+
export declare class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {
|
|
6
|
+
static readonly configSchemas: Schema[];
|
|
7
|
+
static readonly defaultConfigSchema: Schema;
|
|
8
|
+
protected divineAddress(address: Address): Promise<Record<string, number>>;
|
|
9
|
+
protected divineAllAddresses(): Promise<Record<string, number>>;
|
|
10
|
+
protected divineHandler(payloads?: Payload[]): Promise<Payload[]>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=MemorySchemaStatsDiviner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MemorySchemaStatsDiviner.d.ts","sourceRoot":"","sources":["../../src/MemorySchemaStatsDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC,OAAO,EAAE,kBAAkB,EAAE,MAAM,4CAA4C,CAAA;AAC/E,OAAO,EAGL,wBAAwB,EAIzB,MAAM,yCAAyC,CAAA;AAEhD,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAE5D,qBAAa,wBAAwB,CAAC,OAAO,SAAS,wBAAwB,GAAG,wBAAwB,CAAE,SAAQ,kBAAkB,CAAC,OAAO,CAAC;IAC5I,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA2D;IAC3G,gBAAyB,mBAAmB,EAAE,MAAM,CAAiC;cAErE,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;cAkBhE,kBAAkB,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;cAc5C,aAAa,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CAcjF"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Address } from '@xylabs/hex';
|
|
2
|
+
import { SchemaStatsDiviner } from '@xyo-network/diviner-schema-stats-abstract';
|
|
3
|
+
import { SchemaStatsDivinerParams } from '@xyo-network/diviner-schema-stats-model';
|
|
4
|
+
import { Payload, Schema } from '@xyo-network/payload-model';
|
|
5
|
+
export declare class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {
|
|
6
|
+
static readonly configSchemas: Schema[];
|
|
7
|
+
static readonly defaultConfigSchema: Schema;
|
|
8
|
+
protected divineAddress(address: Address): Promise<Record<string, number>>;
|
|
9
|
+
protected divineAllAddresses(): Promise<Record<string, number>>;
|
|
10
|
+
protected divineHandler(payloads?: Payload[]): Promise<Payload[]>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=MemorySchemaStatsDiviner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MemorySchemaStatsDiviner.d.ts","sourceRoot":"","sources":["../../src/MemorySchemaStatsDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC,OAAO,EAAE,kBAAkB,EAAE,MAAM,4CAA4C,CAAA;AAC/E,OAAO,EAGL,wBAAwB,EAIzB,MAAM,yCAAyC,CAAA;AAEhD,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAE5D,qBAAa,wBAAwB,CAAC,OAAO,SAAS,wBAAwB,GAAG,wBAAwB,CAAE,SAAQ,kBAAkB,CAAC,OAAO,CAAC;IAC5I,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA2D;IAC3G,gBAAyB,mBAAmB,EAAE,MAAM,CAAiC;cAErE,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;cAkBhE,kBAAkB,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;cAc5C,aAAa,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CAcjF"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Address } from '@xylabs/hex';
|
|
2
|
+
import { SchemaStatsDiviner } from '@xyo-network/diviner-schema-stats-abstract';
|
|
3
|
+
import { SchemaStatsDivinerParams } from '@xyo-network/diviner-schema-stats-model';
|
|
4
|
+
import { Payload, Schema } from '@xyo-network/payload-model';
|
|
5
|
+
export declare class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {
|
|
6
|
+
static readonly configSchemas: Schema[];
|
|
7
|
+
static readonly defaultConfigSchema: Schema;
|
|
8
|
+
protected divineAddress(address: Address): Promise<Record<string, number>>;
|
|
9
|
+
protected divineAllAddresses(): Promise<Record<string, number>>;
|
|
10
|
+
protected divineHandler(payloads?: Payload[]): Promise<Payload[]>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=MemorySchemaStatsDiviner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MemorySchemaStatsDiviner.d.ts","sourceRoot":"","sources":["../../src/MemorySchemaStatsDiviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC,OAAO,EAAE,kBAAkB,EAAE,MAAM,4CAA4C,CAAA;AAC/E,OAAO,EAGL,wBAAwB,EAIzB,MAAM,yCAAyC,CAAA;AAEhD,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAE5D,qBAAa,wBAAwB,CAAC,OAAO,SAAS,wBAAwB,GAAG,wBAAwB,CAAE,SAAQ,kBAAkB,CAAC,OAAO,CAAC;IAC5I,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA2D;IAC3G,gBAAyB,mBAAmB,EAAE,MAAM,CAAiC;cAErE,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;cAkBhE,kBAAkB,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;cAc5C,aAAa,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CAcjF"}
|
|
@@ -0,0 +1,79 @@
|
|
|
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
|
+
MemorySchemaStatsDiviner: () => MemorySchemaStatsDiviner
|
|
25
|
+
});
|
|
26
|
+
module.exports = __toCommonJS(src_exports);
|
|
27
|
+
|
|
28
|
+
// src/MemorySchemaStatsDiviner.ts
|
|
29
|
+
var import_assert = require("@xylabs/assert");
|
|
30
|
+
var import_boundwitness_model = require("@xyo-network/boundwitness-model");
|
|
31
|
+
var import_diviner_schema_stats_abstract = require("@xyo-network/diviner-schema-stats-abstract");
|
|
32
|
+
var import_diviner_schema_stats_model = require("@xyo-network/diviner-schema-stats-model");
|
|
33
|
+
var import_payload_builder = require("@xyo-network/payload-builder");
|
|
34
|
+
var MemorySchemaStatsDiviner = class extends import_diviner_schema_stats_abstract.SchemaStatsDiviner {
|
|
35
|
+
static {
|
|
36
|
+
__name(this, "MemorySchemaStatsDiviner");
|
|
37
|
+
}
|
|
38
|
+
static configSchemas = [
|
|
39
|
+
...super.configSchemas,
|
|
40
|
+
import_diviner_schema_stats_model.SchemaStatsDivinerConfigSchema
|
|
41
|
+
];
|
|
42
|
+
static defaultConfigSchema = import_diviner_schema_stats_model.SchemaStatsDivinerConfigSchema;
|
|
43
|
+
async divineAddress(address) {
|
|
44
|
+
const archivist = (0, import_assert.assertEx)(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
45
|
+
const all = await (0, import_assert.assertEx)(archivist.all, () => 'Archivist does not support "all"')();
|
|
46
|
+
const filtered = all.filter(import_boundwitness_model.isBoundWitness).filter(import_boundwitness_model.isBoundWitnessWithMeta).filter((bw) => bw.addresses.includes(address));
|
|
47
|
+
const counts = filtered.reduce((acc, payload) => {
|
|
48
|
+
acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1;
|
|
49
|
+
return acc;
|
|
50
|
+
}, {});
|
|
51
|
+
return counts;
|
|
52
|
+
}
|
|
53
|
+
async divineAllAddresses() {
|
|
54
|
+
const archivist = (0, import_assert.assertEx)(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
55
|
+
const all = await (0, import_assert.assertEx)(archivist.all, () => 'Archivist does not support "all"')();
|
|
56
|
+
const counts = all.reduce((acc, payload) => {
|
|
57
|
+
acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1;
|
|
58
|
+
return acc;
|
|
59
|
+
}, {});
|
|
60
|
+
return counts;
|
|
61
|
+
}
|
|
62
|
+
async divineHandler(payloads) {
|
|
63
|
+
const query = payloads?.find(import_diviner_schema_stats_model.isSchemaStatsQueryPayload);
|
|
64
|
+
if (!query)
|
|
65
|
+
return [];
|
|
66
|
+
const addresses = query?.address ? Array.isArray(query?.address) ? query.address : [
|
|
67
|
+
query.address
|
|
68
|
+
] : void 0;
|
|
69
|
+
const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [
|
|
70
|
+
await this.divineAllAddresses()
|
|
71
|
+
];
|
|
72
|
+
return await Promise.all(counts.map((count) => new import_payload_builder.PayloadBuilder({
|
|
73
|
+
schema: import_diviner_schema_stats_model.SchemaStatsDivinerSchema
|
|
74
|
+
}).fields({
|
|
75
|
+
count
|
|
76
|
+
}).build()));
|
|
77
|
+
}
|
|
78
|
+
};
|
|
79
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/MemorySchemaStatsDiviner.ts"],"sourcesContent":["export * from './MemorySchemaStatsDiviner'\n","import { assertEx } from '@xylabs/assert'\nimport { Address } from '@xylabs/hex'\nimport { isBoundWitness, isBoundWitnessWithMeta } 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, Schema } from '@xyo-network/payload-model'\n\nexport class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, SchemaStatsDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = SchemaStatsDivinerConfigSchema\n\n protected async divineAddress(address: Address): Promise<Record<string, number>> {\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const all = await assertEx(archivist.all, () => 'Archivist does not support \"all\"')()\n const filtered = all\n .filter(isBoundWitness)\n .filter(isBoundWitnessWithMeta)\n .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.archivistInstance(), () => 'Unable to resolve archivist')\n const all = await assertEx(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 =\n query?.address ?\n Array.isArray(query?.address) ?\n query.address\n : [query.address]\n : 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;AAEzB,gCAAuD;AACvD,2CAAmC;AACnC,wCAOO;AACP,6BAA+B;AAGxB,IAAMA,2BAAN,cAA4GC,wDAAAA;EAfnH,OAemHA;;;EACjH,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAgBE,cAAcC,SAAmD;AAC/E,UAAMC,gBAAYC,wBAAS,MAAM,KAAKC,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAMC,MAAM,UAAMF,wBAASD,UAAUG,KAAK,MAAM,kCAAA,EAAA;AAChD,UAAMC,WAAWD,IACdE,OAAOC,wCAAAA,EACPD,OAAOE,gDAAAA,EACPF,OAAO,CAACG,OAAOA,GAAGC,UAAUC,SAASX,OAAAA,CAAAA;AAExC,UAAMY,SAAiCP,SAASQ,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,UAAMhB,gBAAYC,wBAAS,MAAM,KAAKC,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAMC,MAAM,UAAMF,wBAASD,UAAUG,KAAK,MAAM,kCAAA,EAAA;AAEhD,UAAMQ,SAAiCR,IAAIS,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,YACJU,OAAOpB,UACLuB,MAAMC,QAAQJ,OAAOpB,OAAAA,IACnBoB,MAAMpB,UACN;MAACoB,MAAMpB;QACTyB;AACJ,UAAMb,SAASF,YAAY,MAAMgB,QAAQtB,IAAIM,UAAUiB,IAAI,CAAC3B,YAAY,KAAKD,cAAcC,OAAAA,CAAAA,CAAAA,IAAa;MAAC,MAAM,KAAKiB,mBAAkB;;AACtI,WAAO,MAAMS,QAAQtB,IACnBQ,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","defaultConfigSchema","divineAddress","address","archivist","assertEx","archivistInstance","all","filtered","filter","isBoundWitness","isBoundWitnessWithMeta","bw","addresses","includes","counts","reduce","acc","payload","schema","divineAllAddresses","divineHandler","payloads","query","find","isSchemaStatsQueryPayload","Array","isArray","undefined","Promise","map","count","PayloadBuilder","SchemaStatsDivinerSchema","fields","build"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAA"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
+
|
|
4
|
+
// src/MemorySchemaStatsDiviner.ts
|
|
5
|
+
import { assertEx } from "@xylabs/assert";
|
|
6
|
+
import { isBoundWitness, isBoundWitnessWithMeta } from "@xyo-network/boundwitness-model";
|
|
7
|
+
import { SchemaStatsDiviner } from "@xyo-network/diviner-schema-stats-abstract";
|
|
8
|
+
import { isSchemaStatsQueryPayload, SchemaStatsDivinerConfigSchema, SchemaStatsDivinerSchema } from "@xyo-network/diviner-schema-stats-model";
|
|
9
|
+
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
10
|
+
var MemorySchemaStatsDiviner = class extends SchemaStatsDiviner {
|
|
11
|
+
static {
|
|
12
|
+
__name(this, "MemorySchemaStatsDiviner");
|
|
13
|
+
}
|
|
14
|
+
static configSchemas = [
|
|
15
|
+
...super.configSchemas,
|
|
16
|
+
SchemaStatsDivinerConfigSchema
|
|
17
|
+
];
|
|
18
|
+
static defaultConfigSchema = SchemaStatsDivinerConfigSchema;
|
|
19
|
+
async divineAddress(address) {
|
|
20
|
+
const archivist = assertEx(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
21
|
+
const all = await assertEx(archivist.all, () => 'Archivist does not support "all"')();
|
|
22
|
+
const filtered = all.filter(isBoundWitness).filter(isBoundWitnessWithMeta).filter((bw) => bw.addresses.includes(address));
|
|
23
|
+
const counts = filtered.reduce((acc, payload) => {
|
|
24
|
+
acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1;
|
|
25
|
+
return acc;
|
|
26
|
+
}, {});
|
|
27
|
+
return counts;
|
|
28
|
+
}
|
|
29
|
+
async divineAllAddresses() {
|
|
30
|
+
const archivist = assertEx(await this.archivistInstance(), () => "Unable to resolve archivist");
|
|
31
|
+
const all = await assertEx(archivist.all, () => 'Archivist does not support "all"')();
|
|
32
|
+
const counts = all.reduce((acc, payload) => {
|
|
33
|
+
acc[payload.schema] = acc[payload.schema] ? acc[payload.schema] + 1 : 1;
|
|
34
|
+
return acc;
|
|
35
|
+
}, {});
|
|
36
|
+
return counts;
|
|
37
|
+
}
|
|
38
|
+
async divineHandler(payloads) {
|
|
39
|
+
const query = payloads?.find(isSchemaStatsQueryPayload);
|
|
40
|
+
if (!query)
|
|
41
|
+
return [];
|
|
42
|
+
const addresses = query?.address ? Array.isArray(query?.address) ? query.address : [
|
|
43
|
+
query.address
|
|
44
|
+
] : void 0;
|
|
45
|
+
const counts = addresses ? await Promise.all(addresses.map((address) => this.divineAddress(address))) : [
|
|
46
|
+
await this.divineAllAddresses()
|
|
47
|
+
];
|
|
48
|
+
return await Promise.all(counts.map((count) => new PayloadBuilder({
|
|
49
|
+
schema: SchemaStatsDivinerSchema
|
|
50
|
+
}).fields({
|
|
51
|
+
count
|
|
52
|
+
}).build()));
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
export {
|
|
56
|
+
MemorySchemaStatsDiviner
|
|
57
|
+
};
|
|
58
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/MemorySchemaStatsDiviner.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Address } from '@xylabs/hex'\nimport { isBoundWitness, isBoundWitnessWithMeta } 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, Schema } from '@xyo-network/payload-model'\n\nexport class MemorySchemaStatsDiviner<TParams extends SchemaStatsDivinerParams = SchemaStatsDivinerParams> extends SchemaStatsDiviner<TParams> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, SchemaStatsDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = SchemaStatsDivinerConfigSchema\n\n protected async divineAddress(address: Address): Promise<Record<string, number>> {\n const archivist = assertEx(await this.archivistInstance(), () => 'Unable to resolve archivist')\n const all = await assertEx(archivist.all, () => 'Archivist does not support \"all\"')()\n const filtered = all\n .filter(isBoundWitness)\n .filter(isBoundWitnessWithMeta)\n .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.archivistInstance(), () => 'Unable to resolve archivist')\n const all = await assertEx(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 =\n query?.address ?\n Array.isArray(query?.address) ?\n query.address\n : [query.address]\n : 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;AAEzB,SAASC,gBAAgBC,8BAA8B;AACvD,SAASC,0BAA0B;AACnC,SACEC,2BACAC,gCAEAC,gCAGK;AACP,SAASC,sBAAsB;AAGxB,IAAMC,2BAAN,cAA4GC,mBAAAA;EAfnH,OAemHA;;;EACjH,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EAEvD,MAAgBE,cAAcC,SAAmD;AAC/E,UAAMC,YAAYC,SAAS,MAAM,KAAKC,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAMC,MAAM,MAAMF,SAASD,UAAUG,KAAK,MAAM,kCAAA,EAAA;AAChD,UAAMC,WAAWD,IACdE,OAAOC,cAAAA,EACPD,OAAOE,sBAAAA,EACPF,OAAO,CAACG,OAAOA,GAAGC,UAAUC,SAASX,OAAAA,CAAAA;AAExC,UAAMY,SAAiCP,SAASQ,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,UAAMhB,YAAYC,SAAS,MAAM,KAAKC,kBAAiB,GAAI,MAAM,6BAAA;AACjE,UAAMC,MAAM,MAAMF,SAASD,UAAUG,KAAK,MAAM,kCAAA,EAAA;AAEhD,UAAMQ,SAAiCR,IAAIS,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,YACJU,OAAOpB,UACLuB,MAAMC,QAAQJ,OAAOpB,OAAAA,IACnBoB,MAAMpB,UACN;MAACoB,MAAMpB;QACTyB;AACJ,UAAMb,SAASF,YAAY,MAAMgB,QAAQtB,IAAIM,UAAUiB,IAAI,CAAC3B,YAAY,KAAKD,cAAcC,OAAAA,CAAAA,CAAAA,IAAa;MAAC,MAAM,KAAKiB,mBAAkB;;AACtI,WAAO,MAAMS,QAAQtB,IACnBQ,OAAOe,IAAI,CAACC,UAAU,IAAIC,eAAmC;MAAEb,QAAQc;IAAyB,CAAA,EAAGC,OAAO;MAAEH;IAAM,CAAA,EAAGI,MAAK,CAAA,CAAA;EAE9H;AACF;","names":["assertEx","isBoundWitness","isBoundWitnessWithMeta","SchemaStatsDiviner","isSchemaStatsQueryPayload","SchemaStatsDivinerConfigSchema","SchemaStatsDivinerSchema","PayloadBuilder","MemorySchemaStatsDiviner","SchemaStatsDiviner","configSchemas","SchemaStatsDivinerConfigSchema","defaultConfigSchema","divineAddress","address","archivist","assertEx","archivistInstance","all","filtered","filter","isBoundWitness","isBoundWitnessWithMeta","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/package.json
CHANGED
|
@@ -10,17 +10,17 @@
|
|
|
10
10
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"@xylabs/assert": "^3.
|
|
14
|
-
"@xylabs/hex": "^3.
|
|
15
|
-
"@xyo-network/boundwitness-model": "~2.99.
|
|
16
|
-
"@xyo-network/diviner-schema-stats-abstract": "~2.99.
|
|
17
|
-
"@xyo-network/diviner-schema-stats-model": "~2.99.
|
|
18
|
-
"@xyo-network/payload-builder": "~2.99.
|
|
19
|
-
"@xyo-network/payload-model": "~2.99.
|
|
13
|
+
"@xylabs/assert": "^3.3.2",
|
|
14
|
+
"@xylabs/hex": "^3.3.2",
|
|
15
|
+
"@xyo-network/boundwitness-model": "~2.99.3",
|
|
16
|
+
"@xyo-network/diviner-schema-stats-abstract": "~2.99.3",
|
|
17
|
+
"@xyo-network/diviner-schema-stats-model": "~2.99.3",
|
|
18
|
+
"@xyo-network/payload-builder": "~2.99.3",
|
|
19
|
+
"@xyo-network/payload-model": "~2.99.3"
|
|
20
20
|
},
|
|
21
21
|
"devDependencies": {
|
|
22
|
-
"@xylabs/ts-scripts-yarn3": "^3.
|
|
23
|
-
"@xylabs/tsconfig": "^3.
|
|
22
|
+
"@xylabs/ts-scripts-yarn3": "^3.10.0",
|
|
23
|
+
"@xylabs/tsconfig": "^3.10.0",
|
|
24
24
|
"typescript": "^5.4.5"
|
|
25
25
|
},
|
|
26
26
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
@@ -62,6 +62,6 @@
|
|
|
62
62
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
63
63
|
},
|
|
64
64
|
"sideEffects": false,
|
|
65
|
-
"version": "2.99.
|
|
65
|
+
"version": "2.99.3",
|
|
66
66
|
"type": "module"
|
|
67
67
|
}
|