@xyo-network/abstract-witness 2.74.5 → 2.75.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/AbstractWitness.cjs +105 -0
- package/dist/browser/AbstractWitness.cjs.map +1 -0
- package/dist/browser/AbstractWitness.d.cts.map +1 -0
- package/dist/browser/AbstractWitness.d.mts.map +1 -0
- package/dist/browser/AbstractWitness.d.ts +24 -0
- package/dist/browser/AbstractWitness.d.ts.map +1 -0
- package/dist/{index.mjs → browser/AbstractWitness.js} +3 -5
- package/dist/browser/AbstractWitness.js.map +1 -0
- package/dist/{index.js → browser/index.cjs} +1 -5
- package/dist/browser/index.cjs.map +1 -0
- package/dist/browser/index.d.cts.map +1 -0
- package/dist/{index.d.mts.map → browser/index.d.mts.map} +1 -1
- package/dist/browser/index.d.ts +2 -0
- package/dist/{index.d.ts.map → browser/index.d.ts.map} +1 -1
- package/dist/browser/index.js +2 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/docs.json +484 -484
- package/dist/node/AbstractWitness.d.cts +24 -0
- package/dist/node/AbstractWitness.d.cts.map +1 -0
- package/dist/node/AbstractWitness.d.mts +24 -0
- package/dist/node/AbstractWitness.d.mts.map +1 -0
- package/dist/node/AbstractWitness.d.ts +24 -0
- package/dist/node/AbstractWitness.d.ts.map +1 -0
- package/dist/node/AbstractWitness.js +114 -0
- package/dist/node/AbstractWitness.js.map +1 -0
- package/dist/node/AbstractWitness.mjs +91 -0
- package/dist/node/AbstractWitness.mjs.map +1 -0
- package/dist/node/index.d.cts +2 -0
- package/dist/node/index.d.cts.map +1 -0
- package/dist/node/index.d.mts +2 -0
- package/dist/node/index.d.mts.map +1 -0
- package/dist/node/index.d.ts +2 -0
- package/dist/node/index.d.ts.map +1 -0
- package/dist/node/index.js +116 -0
- package/dist/node/index.js.map +1 -0
- package/dist/node/index.mjs +91 -0
- package/dist/node/index.mjs.map +1 -0
- package/package.json +32 -29
- package/dist/AbstractWitness.d.mts.map +0 -1
- package/dist/AbstractWitness.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/index.mjs.map +0 -1
- /package/dist/{AbstractWitness.d.mts → browser/AbstractWitness.d.cts} +0 -0
- /package/dist/{AbstractWitness.d.ts → browser/AbstractWitness.d.mts} +0 -0
- /package/dist/{index.d.mts → browser/index.d.cts} +0 -0
- /package/dist/{index.d.ts → browser/index.d.mts} +0 -0
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { ArchivistInstance } from '@xyo-network/archivist-model';
|
|
2
|
+
import { QueryBoundWitness } from '@xyo-network/boundwitness-builder';
|
|
3
|
+
import { AbstractModuleInstance, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module';
|
|
4
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
5
|
+
import { Promisable } from '@xyo-network/promise';
|
|
6
|
+
import { CustomWitnessInstance, WitnessInstance, WitnessModuleEventData, WitnessParams, WitnessQueryBase } from '@xyo-network/witness-model';
|
|
7
|
+
export declare abstract class AbstractWitness<TParams extends WitnessParams = WitnessParams, TEventData extends WitnessModuleEventData<WitnessInstance<TParams>> = WitnessModuleEventData<WitnessInstance<TParams>>> extends AbstractModuleInstance<TParams, TEventData> implements CustomWitnessInstance<TParams, TEventData> {
|
|
8
|
+
static readonly configSchemas: string[];
|
|
9
|
+
private _archivistInstance;
|
|
10
|
+
get archivist(): (import("@xyo-network/module").ArchivistModuleConfig & (import("@xyo-network/module").ArchivistModuleConfig & string)) | undefined;
|
|
11
|
+
get queries(): string[];
|
|
12
|
+
get targetSet(): (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & import("@xyo-network/payload-model").PayloadSet & {
|
|
13
|
+
schema: "network.xyo.payload.set";
|
|
14
|
+
}) | undefined;
|
|
15
|
+
protected get _queryAccountPaths(): Record<WitnessQueryBase['schema'], string>;
|
|
16
|
+
getArchivistInstance(): Promise<ArchivistInstance | undefined>;
|
|
17
|
+
/** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */
|
|
18
|
+
observe(inPayloads?: Payload[]): Promise<Payload[]>;
|
|
19
|
+
/** @function queryHandler Calls observe for an observe query. Override to support additional queries. */
|
|
20
|
+
protected queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(query: T, payloads?: Payload[], queryConfig?: TConfig): Promise<ModuleQueryHandlerResult>;
|
|
21
|
+
/** @function observeHandler Implement or override to add custom functionality to a witness */
|
|
22
|
+
protected abstract observeHandler(payloads?: Payload[]): Promisable<Payload[]>;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=AbstractWitness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAE,iBAAiB,EAA4B,MAAM,mCAAmC,CAAA;AAE/F,OAAO,EAAE,sBAAsB,EAAmB,YAAY,EAAE,wBAAwB,EAAE,MAAM,qBAAqB,CAAA;AACrH,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EACL,qBAAqB,EAErB,eAAe,EACf,sBAAsB,EAEtB,aAAa,EAEb,gBAAgB,EACjB,MAAM,4BAA4B,CAAA;AAGnC,8BAAsB,eAAe,CACjC,OAAO,SAAS,aAAa,GAAG,aAAa,EAC7C,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,GAAG,sBAAsB,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,CAExH,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,qBAAqB,CAAC,OAAO,EAAE,UAAU,CAAC;IAErD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAwB;IAExE,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,IAAI,SAAS,uIAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,IAAI,SAAS;;mBAEZ;IAED,cAAuB,kBAAkB,IAAI,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAItF;IAEK,oBAAoB;IAM1B,wJAAwJ;IAClJ,OAAO,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAkBzD,0GAA0G;cACjF,YAAY,CAAC,CAAC,SAAS,iBAAiB,GAAG,iBAAiB,EAAE,OAAO,SAAS,YAAY,GAAG,YAAY,EAChI,KAAK,EAAE,CAAC,EACR,QAAQ,CAAC,EAAE,OAAO,EAAE,EACpB,WAAW,CAAC,EAAE,OAAO,GACpB,OAAO,CAAC,wBAAwB,CAAC;IAoBpC,8FAA8F;IAC9F,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;CAC/E"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { ArchivistInstance } from '@xyo-network/archivist-model';
|
|
2
|
+
import { QueryBoundWitness } from '@xyo-network/boundwitness-builder';
|
|
3
|
+
import { AbstractModuleInstance, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module';
|
|
4
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
5
|
+
import { Promisable } from '@xyo-network/promise';
|
|
6
|
+
import { CustomWitnessInstance, WitnessInstance, WitnessModuleEventData, WitnessParams, WitnessQueryBase } from '@xyo-network/witness-model';
|
|
7
|
+
export declare abstract class AbstractWitness<TParams extends WitnessParams = WitnessParams, TEventData extends WitnessModuleEventData<WitnessInstance<TParams>> = WitnessModuleEventData<WitnessInstance<TParams>>> extends AbstractModuleInstance<TParams, TEventData> implements CustomWitnessInstance<TParams, TEventData> {
|
|
8
|
+
static readonly configSchemas: string[];
|
|
9
|
+
private _archivistInstance;
|
|
10
|
+
get archivist(): (import("@xyo-network/module").ArchivistModuleConfig & (import("@xyo-network/module").ArchivistModuleConfig & string)) | undefined;
|
|
11
|
+
get queries(): string[];
|
|
12
|
+
get targetSet(): (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & import("@xyo-network/payload-model").PayloadSet & {
|
|
13
|
+
schema: "network.xyo.payload.set";
|
|
14
|
+
}) | undefined;
|
|
15
|
+
protected get _queryAccountPaths(): Record<WitnessQueryBase['schema'], string>;
|
|
16
|
+
getArchivistInstance(): Promise<ArchivistInstance | undefined>;
|
|
17
|
+
/** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */
|
|
18
|
+
observe(inPayloads?: Payload[]): Promise<Payload[]>;
|
|
19
|
+
/** @function queryHandler Calls observe for an observe query. Override to support additional queries. */
|
|
20
|
+
protected queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(query: T, payloads?: Payload[], queryConfig?: TConfig): Promise<ModuleQueryHandlerResult>;
|
|
21
|
+
/** @function observeHandler Implement or override to add custom functionality to a witness */
|
|
22
|
+
protected abstract observeHandler(payloads?: Payload[]): Promisable<Payload[]>;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=AbstractWitness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAE,iBAAiB,EAA4B,MAAM,mCAAmC,CAAA;AAE/F,OAAO,EAAE,sBAAsB,EAAmB,YAAY,EAAE,wBAAwB,EAAE,MAAM,qBAAqB,CAAA;AACrH,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EACL,qBAAqB,EAErB,eAAe,EACf,sBAAsB,EAEtB,aAAa,EAEb,gBAAgB,EACjB,MAAM,4BAA4B,CAAA;AAGnC,8BAAsB,eAAe,CACjC,OAAO,SAAS,aAAa,GAAG,aAAa,EAC7C,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,GAAG,sBAAsB,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,CAExH,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,qBAAqB,CAAC,OAAO,EAAE,UAAU,CAAC;IAErD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAwB;IAExE,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,IAAI,SAAS,uIAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,IAAI,SAAS;;mBAEZ;IAED,cAAuB,kBAAkB,IAAI,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAItF;IAEK,oBAAoB;IAM1B,wJAAwJ;IAClJ,OAAO,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAkBzD,0GAA0G;cACjF,YAAY,CAAC,CAAC,SAAS,iBAAiB,GAAG,iBAAiB,EAAE,OAAO,SAAS,YAAY,GAAG,YAAY,EAChI,KAAK,EAAE,CAAC,EACR,QAAQ,CAAC,EAAE,OAAO,EAAE,EACpB,WAAW,CAAC,EAAE,OAAO,GACpB,OAAO,CAAC,wBAAwB,CAAC;IAoBpC,8FAA8F;IAC9F,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;CAC/E"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { ArchivistInstance } from '@xyo-network/archivist-model';
|
|
2
|
+
import { QueryBoundWitness } from '@xyo-network/boundwitness-builder';
|
|
3
|
+
import { AbstractModuleInstance, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module';
|
|
4
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
5
|
+
import { Promisable } from '@xyo-network/promise';
|
|
6
|
+
import { CustomWitnessInstance, WitnessInstance, WitnessModuleEventData, WitnessParams, WitnessQueryBase } from '@xyo-network/witness-model';
|
|
7
|
+
export declare abstract class AbstractWitness<TParams extends WitnessParams = WitnessParams, TEventData extends WitnessModuleEventData<WitnessInstance<TParams>> = WitnessModuleEventData<WitnessInstance<TParams>>> extends AbstractModuleInstance<TParams, TEventData> implements CustomWitnessInstance<TParams, TEventData> {
|
|
8
|
+
static readonly configSchemas: string[];
|
|
9
|
+
private _archivistInstance;
|
|
10
|
+
get archivist(): (import("@xyo-network/module").ArchivistModuleConfig & (import("@xyo-network/module").ArchivistModuleConfig & string)) | undefined;
|
|
11
|
+
get queries(): string[];
|
|
12
|
+
get targetSet(): (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & import("@xyo-network/payload-model").PayloadSet & {
|
|
13
|
+
schema: "network.xyo.payload.set";
|
|
14
|
+
}) | undefined;
|
|
15
|
+
protected get _queryAccountPaths(): Record<WitnessQueryBase['schema'], string>;
|
|
16
|
+
getArchivistInstance(): Promise<ArchivistInstance | undefined>;
|
|
17
|
+
/** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */
|
|
18
|
+
observe(inPayloads?: Payload[]): Promise<Payload[]>;
|
|
19
|
+
/** @function queryHandler Calls observe for an observe query. Override to support additional queries. */
|
|
20
|
+
protected queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(query: T, payloads?: Payload[], queryConfig?: TConfig): Promise<ModuleQueryHandlerResult>;
|
|
21
|
+
/** @function observeHandler Implement or override to add custom functionality to a witness */
|
|
22
|
+
protected abstract observeHandler(payloads?: Payload[]): Promisable<Payload[]>;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=AbstractWitness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAE,iBAAiB,EAA4B,MAAM,mCAAmC,CAAA;AAE/F,OAAO,EAAE,sBAAsB,EAAmB,YAAY,EAAE,wBAAwB,EAAE,MAAM,qBAAqB,CAAA;AACrH,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EACL,qBAAqB,EAErB,eAAe,EACf,sBAAsB,EAEtB,aAAa,EAEb,gBAAgB,EACjB,MAAM,4BAA4B,CAAA;AAGnC,8BAAsB,eAAe,CACjC,OAAO,SAAS,aAAa,GAAG,aAAa,EAC7C,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,GAAG,sBAAsB,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,CAExH,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,qBAAqB,CAAC,OAAO,EAAE,UAAU,CAAC;IAErD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAwB;IAExE,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,IAAI,SAAS,uIAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,IAAI,SAAS;;mBAEZ;IAED,cAAuB,kBAAkB,IAAI,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAItF;IAEK,oBAAoB;IAM1B,wJAAwJ;IAClJ,OAAO,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAkBzD,0GAA0G;cACjF,YAAY,CAAC,CAAC,SAAS,iBAAiB,GAAG,iBAAiB,EAAE,OAAO,SAAS,YAAY,GAAG,YAAY,EAChI,KAAK,EAAE,CAAC,EACR,QAAQ,CAAC,EAAE,OAAO,EAAE,EACpB,WAAW,CAAC,EAAE,OAAO,GACpB,OAAO,CAAC,wBAAwB,CAAC;IAoBpC,8FAA8F;IAC9F,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;CAC/E"}
|
|
@@ -0,0 +1,114 @@
|
|
|
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 __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 });
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
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
|
+
};
|
|
25
|
+
|
|
26
|
+
// src/AbstractWitness.ts
|
|
27
|
+
var AbstractWitness_exports = {};
|
|
28
|
+
__export(AbstractWitness_exports, {
|
|
29
|
+
AbstractWitness: () => AbstractWitness
|
|
30
|
+
});
|
|
31
|
+
module.exports = __toCommonJS(AbstractWitness_exports);
|
|
32
|
+
var import_assert = require("@xylabs/assert");
|
|
33
|
+
var import_boundwitness_builder = require("@xyo-network/boundwitness-builder");
|
|
34
|
+
var import_core = require("@xyo-network/core");
|
|
35
|
+
var import_module = require("@xyo-network/module");
|
|
36
|
+
var import_witness_model = require("@xyo-network/witness-model");
|
|
37
|
+
(0, import_module.creatableModule)();
|
|
38
|
+
var _AbstractWitness = class _AbstractWitness extends import_module.AbstractModuleInstance {
|
|
39
|
+
_archivistInstance;
|
|
40
|
+
get archivist() {
|
|
41
|
+
return this.config.archivist;
|
|
42
|
+
}
|
|
43
|
+
get queries() {
|
|
44
|
+
return [
|
|
45
|
+
import_witness_model.WitnessObserveQuerySchema,
|
|
46
|
+
...super.queries
|
|
47
|
+
];
|
|
48
|
+
}
|
|
49
|
+
get targetSet() {
|
|
50
|
+
var _a;
|
|
51
|
+
return (_a = this.config) == null ? void 0 : _a.targetSet;
|
|
52
|
+
}
|
|
53
|
+
get _queryAccountPaths() {
|
|
54
|
+
return {
|
|
55
|
+
"network.xyo.query.witness.observe": "1/1"
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
async getArchivistInstance() {
|
|
59
|
+
const archivistAddress = this.archivist;
|
|
60
|
+
this._archivistInstance = this._archivistInstance ?? (archivistAddress ? await this.resolve(archivistAddress) : void 0);
|
|
61
|
+
return this._archivistInstance;
|
|
62
|
+
}
|
|
63
|
+
/** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */
|
|
64
|
+
async observe(inPayloads) {
|
|
65
|
+
this._noOverride("observe");
|
|
66
|
+
await this.started("throw");
|
|
67
|
+
await this.emit("observeStart", {
|
|
68
|
+
inPayloads,
|
|
69
|
+
module: this
|
|
70
|
+
});
|
|
71
|
+
const outPayloads = (0, import_assert.assertEx)(await this.observeHandler(inPayloads), "Trying to witness nothing");
|
|
72
|
+
(0, import_assert.assertEx)(outPayloads.length > 0, "Trying to witness empty list");
|
|
73
|
+
outPayloads == null ? void 0 : outPayloads.forEach((payload) => (0, import_assert.assertEx)(payload.schema, "observe: Missing Schema"));
|
|
74
|
+
const archivist = await this.getArchivistInstance();
|
|
75
|
+
if (archivist) {
|
|
76
|
+
await archivist.insert(outPayloads);
|
|
77
|
+
}
|
|
78
|
+
await this.emit("observeEnd", {
|
|
79
|
+
inPayloads,
|
|
80
|
+
module: this,
|
|
81
|
+
outPayloads
|
|
82
|
+
});
|
|
83
|
+
return outPayloads;
|
|
84
|
+
}
|
|
85
|
+
/** @function queryHandler Calls observe for an observe query. Override to support additional queries. */
|
|
86
|
+
async queryHandler(query, payloads, queryConfig) {
|
|
87
|
+
const wrapper = import_boundwitness_builder.QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
88
|
+
const queryPayload = await wrapper.getQuery();
|
|
89
|
+
(0, import_assert.assertEx)(this.queryable(query, payloads, queryConfig));
|
|
90
|
+
const resultPayloads = [];
|
|
91
|
+
const filteredObservation = await import_core.PayloadHasher.filterExclude(payloads, query.query);
|
|
92
|
+
switch (queryPayload.schema) {
|
|
93
|
+
case import_witness_model.WitnessObserveQuerySchema: {
|
|
94
|
+
const observePayloads = await this.observe(filteredObservation);
|
|
95
|
+
resultPayloads.push(...observePayloads);
|
|
96
|
+
break;
|
|
97
|
+
}
|
|
98
|
+
default: {
|
|
99
|
+
return super.queryHandler(query, payloads);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
return resultPayloads;
|
|
103
|
+
}
|
|
104
|
+
};
|
|
105
|
+
__name(_AbstractWitness, "AbstractWitness");
|
|
106
|
+
__publicField(_AbstractWitness, "configSchemas", [
|
|
107
|
+
import_witness_model.WitnessConfigSchema
|
|
108
|
+
]);
|
|
109
|
+
var AbstractWitness = _AbstractWitness;
|
|
110
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
111
|
+
0 && (module.exports = {
|
|
112
|
+
AbstractWitness
|
|
113
|
+
});
|
|
114
|
+
//# sourceMappingURL=AbstractWitness.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/AbstractWitness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { AbstractModuleInstance, creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { Promisable } from '@xyo-network/promise'\nimport {\n CustomWitnessInstance,\n WitnessConfigSchema,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuerySchema,\n WitnessParams,\n WitnessQuery,\n WitnessQueryBase,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams>> = WitnessModuleEventData<WitnessInstance<TParams>>,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TEventData>\n{\n static override readonly configSchemas: string[] = [WitnessConfigSchema]\n\n private _archivistInstance: ArchivistInstance | undefined\n\n get archivist() {\n return this.config.archivist\n }\n\n override get queries(): string[] {\n return [WitnessObserveQuerySchema, ...super.queries]\n }\n\n get targetSet() {\n return this.config?.targetSet\n }\n\n protected override get _queryAccountPaths(): Record<WitnessQueryBase['schema'], string> {\n return {\n 'network.xyo.query.witness.observe': '1/1',\n }\n }\n\n async getArchivistInstance() {\n const archivistAddress = this.archivist\n this._archivistInstance = this._archivistInstance ?? (archivistAddress ? await this.resolve(archivistAddress) : undefined)\n return this._archivistInstance\n }\n\n /** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */\n async observe(inPayloads?: Payload[]): Promise<Payload[]> {\n this._noOverride('observe')\n await this.started('throw')\n await this.emit('observeStart', { inPayloads: inPayloads, module: this })\n const outPayloads = assertEx(await this.observeHandler(inPayloads), 'Trying to witness nothing')\n assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n outPayloads?.forEach((payload) => assertEx(payload.schema, 'observe: Missing Schema'))\n\n const archivist = await this.getArchivistInstance()\n if (archivist) {\n await archivist.insert(outPayloads)\n }\n\n await this.emit('observeEnd', { inPayloads, module: this, outPayloads })\n\n return outPayloads\n }\n\n /** @function queryHandler Calls observe for an observe query. Override to support additional queries. */\n protected override async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n const wrapper = QueryBoundWitnessWrapper.parseQuery<WitnessQuery>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n // Remove the query payload from the arguments passed to us so we don't observe it\n const filteredObservation = await PayloadHasher.filterExclude(payloads, query.query)\n switch (queryPayload.schema) {\n case WitnessObserveQuerySchema: {\n const observePayloads = await this.observe(filteredObservation)\n resultPayloads.push(...observePayloads)\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return resultPayloads\n }\n\n /** @function observeHandler Implement or override to add custom functionality to a witness */\n protected abstract observeHandler(payloads?: Payload[]): Promisable<Payload[]>\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;oBAAyB;AAEzB,kCAA4D;AAC5D,kBAA8B;AAC9B,oBAAgG;AAGhG,2BASO;IAEPA,+BAAAA;AACO,IAAeC,mBAAf,MAAeA,yBAIZC,qCAAAA;EAKAC;EAER,IAAIC,YAAY;AACd,WAAO,KAAKC,OAAOD;EACrB;EAEA,IAAaE,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAIE,YAAY;AAtClB;AAuCI,YAAO,UAAKH,WAAL,mBAAaG;EACtB;EAEA,IAAuBC,qBAAiE;AACtF,WAAO;MACL,qCAAqC;IACvC;EACF;EAEA,MAAMC,uBAAuB;AAC3B,UAAMC,mBAAmB,KAAKP;AAC9B,SAAKD,qBAAqB,KAAKA,uBAAuBQ,mBAAmB,MAAM,KAAKC,QAAQD,gBAAAA,IAAoBE;AAChH,WAAO,KAAKV;EACd;;EAGA,MAAMW,QAAQC,YAA4C;AACxD,SAAKC,YAAY,SAAA;AACjB,UAAM,KAAKC,QAAQ,OAAA;AACnB,UAAM,KAAKC,KAAK,gBAAgB;MAAEH;MAAwBI,QAAQ;IAAK,CAAA;AACvE,UAAMC,kBAAcC,wBAAS,MAAM,KAAKC,eAAeP,UAAAA,GAAa,2BAAA;AACpEM,gCAASD,YAAYG,SAAS,GAAG,8BAAA;AACjCH,+CAAaI,QAAQ,CAACC,gBAAYJ,wBAASI,QAAQC,QAAQ,yBAAA;AAE3D,UAAMtB,YAAY,MAAM,KAAKM,qBAAoB;AACjD,QAAIN,WAAW;AACb,YAAMA,UAAUuB,OAAOP,WAAAA;IACzB;AAEA,UAAM,KAAKF,KAAK,cAAc;MAAEH;MAAYI,QAAQ;MAAMC;IAAY,CAAA;AAEtE,WAAOA;EACT;;EAGA,MAAyBQ,aACvBC,OACAC,UACAC,aACmC;AACnC,UAAMC,UAAUC,qDAAyBC,WAAyBL,OAAOC,QAAAA;AACzE,UAAMK,eAAe,MAAMH,QAAQI,SAAQ;AAC3Cf,gCAAS,KAAKgB,UAAUR,OAAOC,UAAUC,WAAAA,CAAAA;AACzC,UAAMO,iBAA4B,CAAA;AAElC,UAAMC,sBAAsB,MAAMC,0BAAcC,cAAcX,UAAUD,MAAMA,KAAK;AACnF,YAAQM,aAAaT,QAAM;MACzB,KAAKnB,gDAA2B;AAC9B,cAAMmC,kBAAkB,MAAM,KAAK5B,QAAQyB,mBAAAA;AAC3CD,uBAAeK,KAAI,GAAID,eAAAA;AACvB;MACF;MACA,SAAS;AACP,eAAO,MAAMd,aAAaC,OAAOC,QAAAA;MACnC;IACF;AACA,WAAOQ;EACT;AAIF;AA7EUpC;AAGR,cAPoBD,kBAOK2C,iBAA0B;EAACC;;AAP/C,IAAe5C,kBAAf;","names":["creatableModule","AbstractWitness","AbstractModuleInstance","_archivistInstance","archivist","config","queries","WitnessObserveQuerySchema","targetSet","_queryAccountPaths","getArchivistInstance","archivistAddress","resolve","undefined","observe","inPayloads","_noOverride","started","emit","module","outPayloads","assertEx","observeHandler","length","forEach","payload","schema","insert","queryHandler","query","payloads","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","queryPayload","getQuery","queryable","resultPayloads","filteredObservation","PayloadHasher","filterExclude","observePayloads","push","configSchemas","WitnessConfigSchema"]}
|
|
@@ -0,0 +1,91 @@
|
|
|
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
|
+
|
|
9
|
+
// src/AbstractWitness.ts
|
|
10
|
+
import { assertEx } from "@xylabs/assert";
|
|
11
|
+
import { QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-builder";
|
|
12
|
+
import { PayloadHasher } from "@xyo-network/core";
|
|
13
|
+
import { AbstractModuleInstance, creatableModule } from "@xyo-network/module";
|
|
14
|
+
import { WitnessConfigSchema, WitnessObserveQuerySchema } from "@xyo-network/witness-model";
|
|
15
|
+
creatableModule();
|
|
16
|
+
var _AbstractWitness = class _AbstractWitness extends AbstractModuleInstance {
|
|
17
|
+
_archivistInstance;
|
|
18
|
+
get archivist() {
|
|
19
|
+
return this.config.archivist;
|
|
20
|
+
}
|
|
21
|
+
get queries() {
|
|
22
|
+
return [
|
|
23
|
+
WitnessObserveQuerySchema,
|
|
24
|
+
...super.queries
|
|
25
|
+
];
|
|
26
|
+
}
|
|
27
|
+
get targetSet() {
|
|
28
|
+
var _a;
|
|
29
|
+
return (_a = this.config) == null ? void 0 : _a.targetSet;
|
|
30
|
+
}
|
|
31
|
+
get _queryAccountPaths() {
|
|
32
|
+
return {
|
|
33
|
+
"network.xyo.query.witness.observe": "1/1"
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
async getArchivistInstance() {
|
|
37
|
+
const archivistAddress = this.archivist;
|
|
38
|
+
this._archivistInstance = this._archivistInstance ?? (archivistAddress ? await this.resolve(archivistAddress) : void 0);
|
|
39
|
+
return this._archivistInstance;
|
|
40
|
+
}
|
|
41
|
+
/** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */
|
|
42
|
+
async observe(inPayloads) {
|
|
43
|
+
this._noOverride("observe");
|
|
44
|
+
await this.started("throw");
|
|
45
|
+
await this.emit("observeStart", {
|
|
46
|
+
inPayloads,
|
|
47
|
+
module: this
|
|
48
|
+
});
|
|
49
|
+
const outPayloads = assertEx(await this.observeHandler(inPayloads), "Trying to witness nothing");
|
|
50
|
+
assertEx(outPayloads.length > 0, "Trying to witness empty list");
|
|
51
|
+
outPayloads == null ? void 0 : outPayloads.forEach((payload) => assertEx(payload.schema, "observe: Missing Schema"));
|
|
52
|
+
const archivist = await this.getArchivistInstance();
|
|
53
|
+
if (archivist) {
|
|
54
|
+
await archivist.insert(outPayloads);
|
|
55
|
+
}
|
|
56
|
+
await this.emit("observeEnd", {
|
|
57
|
+
inPayloads,
|
|
58
|
+
module: this,
|
|
59
|
+
outPayloads
|
|
60
|
+
});
|
|
61
|
+
return outPayloads;
|
|
62
|
+
}
|
|
63
|
+
/** @function queryHandler Calls observe for an observe query. Override to support additional queries. */
|
|
64
|
+
async queryHandler(query, payloads, queryConfig) {
|
|
65
|
+
const wrapper = QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
66
|
+
const queryPayload = await wrapper.getQuery();
|
|
67
|
+
assertEx(this.queryable(query, payloads, queryConfig));
|
|
68
|
+
const resultPayloads = [];
|
|
69
|
+
const filteredObservation = await PayloadHasher.filterExclude(payloads, query.query);
|
|
70
|
+
switch (queryPayload.schema) {
|
|
71
|
+
case WitnessObserveQuerySchema: {
|
|
72
|
+
const observePayloads = await this.observe(filteredObservation);
|
|
73
|
+
resultPayloads.push(...observePayloads);
|
|
74
|
+
break;
|
|
75
|
+
}
|
|
76
|
+
default: {
|
|
77
|
+
return super.queryHandler(query, payloads);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
return resultPayloads;
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
__name(_AbstractWitness, "AbstractWitness");
|
|
84
|
+
__publicField(_AbstractWitness, "configSchemas", [
|
|
85
|
+
WitnessConfigSchema
|
|
86
|
+
]);
|
|
87
|
+
var AbstractWitness = _AbstractWitness;
|
|
88
|
+
export {
|
|
89
|
+
AbstractWitness
|
|
90
|
+
};
|
|
91
|
+
//# sourceMappingURL=AbstractWitness.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/AbstractWitness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { AbstractModuleInstance, creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { Promisable } from '@xyo-network/promise'\nimport {\n CustomWitnessInstance,\n WitnessConfigSchema,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuerySchema,\n WitnessParams,\n WitnessQuery,\n WitnessQueryBase,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams>> = WitnessModuleEventData<WitnessInstance<TParams>>,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TEventData>\n{\n static override readonly configSchemas: string[] = [WitnessConfigSchema]\n\n private _archivistInstance: ArchivistInstance | undefined\n\n get archivist() {\n return this.config.archivist\n }\n\n override get queries(): string[] {\n return [WitnessObserveQuerySchema, ...super.queries]\n }\n\n get targetSet() {\n return this.config?.targetSet\n }\n\n protected override get _queryAccountPaths(): Record<WitnessQueryBase['schema'], string> {\n return {\n 'network.xyo.query.witness.observe': '1/1',\n }\n }\n\n async getArchivistInstance() {\n const archivistAddress = this.archivist\n this._archivistInstance = this._archivistInstance ?? (archivistAddress ? await this.resolve(archivistAddress) : undefined)\n return this._archivistInstance\n }\n\n /** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */\n async observe(inPayloads?: Payload[]): Promise<Payload[]> {\n this._noOverride('observe')\n await this.started('throw')\n await this.emit('observeStart', { inPayloads: inPayloads, module: this })\n const outPayloads = assertEx(await this.observeHandler(inPayloads), 'Trying to witness nothing')\n assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n outPayloads?.forEach((payload) => assertEx(payload.schema, 'observe: Missing Schema'))\n\n const archivist = await this.getArchivistInstance()\n if (archivist) {\n await archivist.insert(outPayloads)\n }\n\n await this.emit('observeEnd', { inPayloads, module: this, outPayloads })\n\n return outPayloads\n }\n\n /** @function queryHandler Calls observe for an observe query. Override to support additional queries. */\n protected override async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n const wrapper = QueryBoundWitnessWrapper.parseQuery<WitnessQuery>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n // Remove the query payload from the arguments passed to us so we don't observe it\n const filteredObservation = await PayloadHasher.filterExclude(payloads, query.query)\n switch (queryPayload.schema) {\n case WitnessObserveQuerySchema: {\n const observePayloads = await this.observe(filteredObservation)\n resultPayloads.push(...observePayloads)\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return resultPayloads\n }\n\n /** @function observeHandler Implement or override to add custom functionality to a witness */\n protected abstract observeHandler(payloads?: Payload[]): Promisable<Payload[]>\n}\n"],"mappings":";;;;;;;;;AAAA,SAASA,gBAAgB;AAEzB,SAA4BC,gCAAgC;AAC5D,SAASC,qBAAqB;AAC9B,SAASC,wBAAwBC,uBAA+D;AAGhG,SAEEC,qBAGAC,iCAIK;AAEPC,gBAAAA;AACO,IAAeC,mBAAf,MAAeA,yBAIZC,uBAAAA;EAKAC;EAER,IAAIC,YAAY;AACd,WAAO,KAAKC,OAAOD;EACrB;EAEA,IAAaE,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAIE,YAAY;AAtClB;AAuCI,YAAO,UAAKH,WAAL,mBAAaG;EACtB;EAEA,IAAuBC,qBAAiE;AACtF,WAAO;MACL,qCAAqC;IACvC;EACF;EAEA,MAAMC,uBAAuB;AAC3B,UAAMC,mBAAmB,KAAKP;AAC9B,SAAKD,qBAAqB,KAAKA,uBAAuBQ,mBAAmB,MAAM,KAAKC,QAAQD,gBAAAA,IAAoBE;AAChH,WAAO,KAAKV;EACd;;EAGA,MAAMW,QAAQC,YAA4C;AACxD,SAAKC,YAAY,SAAA;AACjB,UAAM,KAAKC,QAAQ,OAAA;AACnB,UAAM,KAAKC,KAAK,gBAAgB;MAAEH;MAAwBI,QAAQ;IAAK,CAAA;AACvE,UAAMC,cAAcC,SAAS,MAAM,KAAKC,eAAeP,UAAAA,GAAa,2BAAA;AACpEM,aAASD,YAAYG,SAAS,GAAG,8BAAA;AACjCH,+CAAaI,QAAQ,CAACC,YAAYJ,SAASI,QAAQC,QAAQ,yBAAA;AAE3D,UAAMtB,YAAY,MAAM,KAAKM,qBAAoB;AACjD,QAAIN,WAAW;AACb,YAAMA,UAAUuB,OAAOP,WAAAA;IACzB;AAEA,UAAM,KAAKF,KAAK,cAAc;MAAEH;MAAYI,QAAQ;MAAMC;IAAY,CAAA;AAEtE,WAAOA;EACT;;EAGA,MAAyBQ,aACvBC,OACAC,UACAC,aACmC;AACnC,UAAMC,UAAUC,yBAAyBC,WAAyBL,OAAOC,QAAAA;AACzE,UAAMK,eAAe,MAAMH,QAAQI,SAAQ;AAC3Cf,aAAS,KAAKgB,UAAUR,OAAOC,UAAUC,WAAAA,CAAAA;AACzC,UAAMO,iBAA4B,CAAA;AAElC,UAAMC,sBAAsB,MAAMC,cAAcC,cAAcX,UAAUD,MAAMA,KAAK;AACnF,YAAQM,aAAaT,QAAM;MACzB,KAAKnB,2BAA2B;AAC9B,cAAMmC,kBAAkB,MAAM,KAAK5B,QAAQyB,mBAAAA;AAC3CD,uBAAeK,KAAI,GAAID,eAAAA;AACvB;MACF;MACA,SAAS;AACP,eAAO,MAAMd,aAAaC,OAAOC,QAAAA;MACnC;IACF;AACA,WAAOQ;EACT;AAIF;AA7EUpC;AAGR,cAPoBD,kBAOK2C,iBAA0B;EAACC;;AAP/C,IAAe5C,kBAAf;","names":["assertEx","QueryBoundWitnessWrapper","PayloadHasher","AbstractModuleInstance","creatableModule","WitnessConfigSchema","WitnessObserveQuerySchema","creatableModule","AbstractWitness","AbstractModuleInstance","_archivistInstance","archivist","config","queries","WitnessObserveQuerySchema","targetSet","_queryAccountPaths","getArchivistInstance","archivistAddress","resolve","undefined","observe","inPayloads","_noOverride","started","emit","module","outPayloads","assertEx","observeHandler","length","forEach","payload","schema","insert","queryHandler","query","payloads","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","queryPayload","getQuery","queryable","resultPayloads","filteredObservation","PayloadHasher","filterExclude","observePayloads","push","configSchemas","WitnessConfigSchema"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAA"}
|
|
@@ -0,0 +1,116 @@
|
|
|
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 __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 });
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
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
|
+
};
|
|
25
|
+
|
|
26
|
+
// src/index.ts
|
|
27
|
+
var src_exports = {};
|
|
28
|
+
__export(src_exports, {
|
|
29
|
+
AbstractWitness: () => AbstractWitness
|
|
30
|
+
});
|
|
31
|
+
module.exports = __toCommonJS(src_exports);
|
|
32
|
+
|
|
33
|
+
// src/AbstractWitness.ts
|
|
34
|
+
var import_assert = require("@xylabs/assert");
|
|
35
|
+
var import_boundwitness_builder = require("@xyo-network/boundwitness-builder");
|
|
36
|
+
var import_core = require("@xyo-network/core");
|
|
37
|
+
var import_module = require("@xyo-network/module");
|
|
38
|
+
var import_witness_model = require("@xyo-network/witness-model");
|
|
39
|
+
(0, import_module.creatableModule)();
|
|
40
|
+
var _AbstractWitness = class _AbstractWitness extends import_module.AbstractModuleInstance {
|
|
41
|
+
_archivistInstance;
|
|
42
|
+
get archivist() {
|
|
43
|
+
return this.config.archivist;
|
|
44
|
+
}
|
|
45
|
+
get queries() {
|
|
46
|
+
return [
|
|
47
|
+
import_witness_model.WitnessObserveQuerySchema,
|
|
48
|
+
...super.queries
|
|
49
|
+
];
|
|
50
|
+
}
|
|
51
|
+
get targetSet() {
|
|
52
|
+
var _a;
|
|
53
|
+
return (_a = this.config) == null ? void 0 : _a.targetSet;
|
|
54
|
+
}
|
|
55
|
+
get _queryAccountPaths() {
|
|
56
|
+
return {
|
|
57
|
+
"network.xyo.query.witness.observe": "1/1"
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
async getArchivistInstance() {
|
|
61
|
+
const archivistAddress = this.archivist;
|
|
62
|
+
this._archivistInstance = this._archivistInstance ?? (archivistAddress ? await this.resolve(archivistAddress) : void 0);
|
|
63
|
+
return this._archivistInstance;
|
|
64
|
+
}
|
|
65
|
+
/** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */
|
|
66
|
+
async observe(inPayloads) {
|
|
67
|
+
this._noOverride("observe");
|
|
68
|
+
await this.started("throw");
|
|
69
|
+
await this.emit("observeStart", {
|
|
70
|
+
inPayloads,
|
|
71
|
+
module: this
|
|
72
|
+
});
|
|
73
|
+
const outPayloads = (0, import_assert.assertEx)(await this.observeHandler(inPayloads), "Trying to witness nothing");
|
|
74
|
+
(0, import_assert.assertEx)(outPayloads.length > 0, "Trying to witness empty list");
|
|
75
|
+
outPayloads == null ? void 0 : outPayloads.forEach((payload) => (0, import_assert.assertEx)(payload.schema, "observe: Missing Schema"));
|
|
76
|
+
const archivist = await this.getArchivistInstance();
|
|
77
|
+
if (archivist) {
|
|
78
|
+
await archivist.insert(outPayloads);
|
|
79
|
+
}
|
|
80
|
+
await this.emit("observeEnd", {
|
|
81
|
+
inPayloads,
|
|
82
|
+
module: this,
|
|
83
|
+
outPayloads
|
|
84
|
+
});
|
|
85
|
+
return outPayloads;
|
|
86
|
+
}
|
|
87
|
+
/** @function queryHandler Calls observe for an observe query. Override to support additional queries. */
|
|
88
|
+
async queryHandler(query, payloads, queryConfig) {
|
|
89
|
+
const wrapper = import_boundwitness_builder.QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
90
|
+
const queryPayload = await wrapper.getQuery();
|
|
91
|
+
(0, import_assert.assertEx)(this.queryable(query, payloads, queryConfig));
|
|
92
|
+
const resultPayloads = [];
|
|
93
|
+
const filteredObservation = await import_core.PayloadHasher.filterExclude(payloads, query.query);
|
|
94
|
+
switch (queryPayload.schema) {
|
|
95
|
+
case import_witness_model.WitnessObserveQuerySchema: {
|
|
96
|
+
const observePayloads = await this.observe(filteredObservation);
|
|
97
|
+
resultPayloads.push(...observePayloads);
|
|
98
|
+
break;
|
|
99
|
+
}
|
|
100
|
+
default: {
|
|
101
|
+
return super.queryHandler(query, payloads);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return resultPayloads;
|
|
105
|
+
}
|
|
106
|
+
};
|
|
107
|
+
__name(_AbstractWitness, "AbstractWitness");
|
|
108
|
+
__publicField(_AbstractWitness, "configSchemas", [
|
|
109
|
+
import_witness_model.WitnessConfigSchema
|
|
110
|
+
]);
|
|
111
|
+
var AbstractWitness = _AbstractWitness;
|
|
112
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
113
|
+
0 && (module.exports = {
|
|
114
|
+
AbstractWitness
|
|
115
|
+
});
|
|
116
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/AbstractWitness.ts"],"sourcesContent":["export * from './AbstractWitness'\n","import { assertEx } from '@xylabs/assert'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { AbstractModuleInstance, creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { Promisable } from '@xyo-network/promise'\nimport {\n CustomWitnessInstance,\n WitnessConfigSchema,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuerySchema,\n WitnessParams,\n WitnessQuery,\n WitnessQueryBase,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams>> = WitnessModuleEventData<WitnessInstance<TParams>>,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TEventData>\n{\n static override readonly configSchemas: string[] = [WitnessConfigSchema]\n\n private _archivistInstance: ArchivistInstance | undefined\n\n get archivist() {\n return this.config.archivist\n }\n\n override get queries(): string[] {\n return [WitnessObserveQuerySchema, ...super.queries]\n }\n\n get targetSet() {\n return this.config?.targetSet\n }\n\n protected override get _queryAccountPaths(): Record<WitnessQueryBase['schema'], string> {\n return {\n 'network.xyo.query.witness.observe': '1/1',\n }\n }\n\n async getArchivistInstance() {\n const archivistAddress = this.archivist\n this._archivistInstance = this._archivistInstance ?? (archivistAddress ? await this.resolve(archivistAddress) : undefined)\n return this._archivistInstance\n }\n\n /** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */\n async observe(inPayloads?: Payload[]): Promise<Payload[]> {\n this._noOverride('observe')\n await this.started('throw')\n await this.emit('observeStart', { inPayloads: inPayloads, module: this })\n const outPayloads = assertEx(await this.observeHandler(inPayloads), 'Trying to witness nothing')\n assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n outPayloads?.forEach((payload) => assertEx(payload.schema, 'observe: Missing Schema'))\n\n const archivist = await this.getArchivistInstance()\n if (archivist) {\n await archivist.insert(outPayloads)\n }\n\n await this.emit('observeEnd', { inPayloads, module: this, outPayloads })\n\n return outPayloads\n }\n\n /** @function queryHandler Calls observe for an observe query. Override to support additional queries. */\n protected override async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n const wrapper = QueryBoundWitnessWrapper.parseQuery<WitnessQuery>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n // Remove the query payload from the arguments passed to us so we don't observe it\n const filteredObservation = await PayloadHasher.filterExclude(payloads, query.query)\n switch (queryPayload.schema) {\n case WitnessObserveQuerySchema: {\n const observePayloads = await this.observe(filteredObservation)\n resultPayloads.push(...observePayloads)\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return resultPayloads\n }\n\n /** @function observeHandler Implement or override to add custom functionality to a witness */\n protected abstract observeHandler(payloads?: Payload[]): Promisable<Payload[]>\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AAEzB,kCAA4D;AAC5D,kBAA8B;AAC9B,oBAAgG;AAGhG,2BASO;IAEPA,+BAAAA;AACO,IAAeC,mBAAf,MAAeA,yBAIZC,qCAAAA;EAKAC;EAER,IAAIC,YAAY;AACd,WAAO,KAAKC,OAAOD;EACrB;EAEA,IAAaE,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAIE,YAAY;AAtClB;AAuCI,YAAO,UAAKH,WAAL,mBAAaG;EACtB;EAEA,IAAuBC,qBAAiE;AACtF,WAAO;MACL,qCAAqC;IACvC;EACF;EAEA,MAAMC,uBAAuB;AAC3B,UAAMC,mBAAmB,KAAKP;AAC9B,SAAKD,qBAAqB,KAAKA,uBAAuBQ,mBAAmB,MAAM,KAAKC,QAAQD,gBAAAA,IAAoBE;AAChH,WAAO,KAAKV;EACd;;EAGA,MAAMW,QAAQC,YAA4C;AACxD,SAAKC,YAAY,SAAA;AACjB,UAAM,KAAKC,QAAQ,OAAA;AACnB,UAAM,KAAKC,KAAK,gBAAgB;MAAEH;MAAwBI,QAAQ;IAAK,CAAA;AACvE,UAAMC,kBAAcC,wBAAS,MAAM,KAAKC,eAAeP,UAAAA,GAAa,2BAAA;AACpEM,gCAASD,YAAYG,SAAS,GAAG,8BAAA;AACjCH,+CAAaI,QAAQ,CAACC,gBAAYJ,wBAASI,QAAQC,QAAQ,yBAAA;AAE3D,UAAMtB,YAAY,MAAM,KAAKM,qBAAoB;AACjD,QAAIN,WAAW;AACb,YAAMA,UAAUuB,OAAOP,WAAAA;IACzB;AAEA,UAAM,KAAKF,KAAK,cAAc;MAAEH;MAAYI,QAAQ;MAAMC;IAAY,CAAA;AAEtE,WAAOA;EACT;;EAGA,MAAyBQ,aACvBC,OACAC,UACAC,aACmC;AACnC,UAAMC,UAAUC,qDAAyBC,WAAyBL,OAAOC,QAAAA;AACzE,UAAMK,eAAe,MAAMH,QAAQI,SAAQ;AAC3Cf,gCAAS,KAAKgB,UAAUR,OAAOC,UAAUC,WAAAA,CAAAA;AACzC,UAAMO,iBAA4B,CAAA;AAElC,UAAMC,sBAAsB,MAAMC,0BAAcC,cAAcX,UAAUD,MAAMA,KAAK;AACnF,YAAQM,aAAaT,QAAM;MACzB,KAAKnB,gDAA2B;AAC9B,cAAMmC,kBAAkB,MAAM,KAAK5B,QAAQyB,mBAAAA;AAC3CD,uBAAeK,KAAI,GAAID,eAAAA;AACvB;MACF;MACA,SAAS;AACP,eAAO,MAAMd,aAAaC,OAAOC,QAAAA;MACnC;IACF;AACA,WAAOQ;EACT;AAIF;AA7EUpC;AAGR,cAPoBD,kBAOK2C,iBAA0B;EAACC;;AAP/C,IAAe5C,kBAAf;","names":["creatableModule","AbstractWitness","AbstractModuleInstance","_archivistInstance","archivist","config","queries","WitnessObserveQuerySchema","targetSet","_queryAccountPaths","getArchivistInstance","archivistAddress","resolve","undefined","observe","inPayloads","_noOverride","started","emit","module","outPayloads","assertEx","observeHandler","length","forEach","payload","schema","insert","queryHandler","query","payloads","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","queryPayload","getQuery","queryable","resultPayloads","filteredObservation","PayloadHasher","filterExclude","observePayloads","push","configSchemas","WitnessConfigSchema"]}
|
|
@@ -0,0 +1,91 @@
|
|
|
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
|
+
|
|
9
|
+
// src/AbstractWitness.ts
|
|
10
|
+
import { assertEx } from "@xylabs/assert";
|
|
11
|
+
import { QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-builder";
|
|
12
|
+
import { PayloadHasher } from "@xyo-network/core";
|
|
13
|
+
import { AbstractModuleInstance, creatableModule } from "@xyo-network/module";
|
|
14
|
+
import { WitnessConfigSchema, WitnessObserveQuerySchema } from "@xyo-network/witness-model";
|
|
15
|
+
creatableModule();
|
|
16
|
+
var _AbstractWitness = class _AbstractWitness extends AbstractModuleInstance {
|
|
17
|
+
_archivistInstance;
|
|
18
|
+
get archivist() {
|
|
19
|
+
return this.config.archivist;
|
|
20
|
+
}
|
|
21
|
+
get queries() {
|
|
22
|
+
return [
|
|
23
|
+
WitnessObserveQuerySchema,
|
|
24
|
+
...super.queries
|
|
25
|
+
];
|
|
26
|
+
}
|
|
27
|
+
get targetSet() {
|
|
28
|
+
var _a;
|
|
29
|
+
return (_a = this.config) == null ? void 0 : _a.targetSet;
|
|
30
|
+
}
|
|
31
|
+
get _queryAccountPaths() {
|
|
32
|
+
return {
|
|
33
|
+
"network.xyo.query.witness.observe": "1/1"
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
async getArchivistInstance() {
|
|
37
|
+
const archivistAddress = this.archivist;
|
|
38
|
+
this._archivistInstance = this._archivistInstance ?? (archivistAddress ? await this.resolve(archivistAddress) : void 0);
|
|
39
|
+
return this._archivistInstance;
|
|
40
|
+
}
|
|
41
|
+
/** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */
|
|
42
|
+
async observe(inPayloads) {
|
|
43
|
+
this._noOverride("observe");
|
|
44
|
+
await this.started("throw");
|
|
45
|
+
await this.emit("observeStart", {
|
|
46
|
+
inPayloads,
|
|
47
|
+
module: this
|
|
48
|
+
});
|
|
49
|
+
const outPayloads = assertEx(await this.observeHandler(inPayloads), "Trying to witness nothing");
|
|
50
|
+
assertEx(outPayloads.length > 0, "Trying to witness empty list");
|
|
51
|
+
outPayloads == null ? void 0 : outPayloads.forEach((payload) => assertEx(payload.schema, "observe: Missing Schema"));
|
|
52
|
+
const archivist = await this.getArchivistInstance();
|
|
53
|
+
if (archivist) {
|
|
54
|
+
await archivist.insert(outPayloads);
|
|
55
|
+
}
|
|
56
|
+
await this.emit("observeEnd", {
|
|
57
|
+
inPayloads,
|
|
58
|
+
module: this,
|
|
59
|
+
outPayloads
|
|
60
|
+
});
|
|
61
|
+
return outPayloads;
|
|
62
|
+
}
|
|
63
|
+
/** @function queryHandler Calls observe for an observe query. Override to support additional queries. */
|
|
64
|
+
async queryHandler(query, payloads, queryConfig) {
|
|
65
|
+
const wrapper = QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
66
|
+
const queryPayload = await wrapper.getQuery();
|
|
67
|
+
assertEx(this.queryable(query, payloads, queryConfig));
|
|
68
|
+
const resultPayloads = [];
|
|
69
|
+
const filteredObservation = await PayloadHasher.filterExclude(payloads, query.query);
|
|
70
|
+
switch (queryPayload.schema) {
|
|
71
|
+
case WitnessObserveQuerySchema: {
|
|
72
|
+
const observePayloads = await this.observe(filteredObservation);
|
|
73
|
+
resultPayloads.push(...observePayloads);
|
|
74
|
+
break;
|
|
75
|
+
}
|
|
76
|
+
default: {
|
|
77
|
+
return super.queryHandler(query, payloads);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
return resultPayloads;
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
__name(_AbstractWitness, "AbstractWitness");
|
|
84
|
+
__publicField(_AbstractWitness, "configSchemas", [
|
|
85
|
+
WitnessConfigSchema
|
|
86
|
+
]);
|
|
87
|
+
var AbstractWitness = _AbstractWitness;
|
|
88
|
+
export {
|
|
89
|
+
AbstractWitness
|
|
90
|
+
};
|
|
91
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/AbstractWitness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { AbstractModuleInstance, creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { Promisable } from '@xyo-network/promise'\nimport {\n CustomWitnessInstance,\n WitnessConfigSchema,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuerySchema,\n WitnessParams,\n WitnessQuery,\n WitnessQueryBase,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams>> = WitnessModuleEventData<WitnessInstance<TParams>>,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TEventData>\n{\n static override readonly configSchemas: string[] = [WitnessConfigSchema]\n\n private _archivistInstance: ArchivistInstance | undefined\n\n get archivist() {\n return this.config.archivist\n }\n\n override get queries(): string[] {\n return [WitnessObserveQuerySchema, ...super.queries]\n }\n\n get targetSet() {\n return this.config?.targetSet\n }\n\n protected override get _queryAccountPaths(): Record<WitnessQueryBase['schema'], string> {\n return {\n 'network.xyo.query.witness.observe': '1/1',\n }\n }\n\n async getArchivistInstance() {\n const archivistAddress = this.archivist\n this._archivistInstance = this._archivistInstance ?? (archivistAddress ? await this.resolve(archivistAddress) : undefined)\n return this._archivistInstance\n }\n\n /** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */\n async observe(inPayloads?: Payload[]): Promise<Payload[]> {\n this._noOverride('observe')\n await this.started('throw')\n await this.emit('observeStart', { inPayloads: inPayloads, module: this })\n const outPayloads = assertEx(await this.observeHandler(inPayloads), 'Trying to witness nothing')\n assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n outPayloads?.forEach((payload) => assertEx(payload.schema, 'observe: Missing Schema'))\n\n const archivist = await this.getArchivistInstance()\n if (archivist) {\n await archivist.insert(outPayloads)\n }\n\n await this.emit('observeEnd', { inPayloads, module: this, outPayloads })\n\n return outPayloads\n }\n\n /** @function queryHandler Calls observe for an observe query. Override to support additional queries. */\n protected override async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n const wrapper = QueryBoundWitnessWrapper.parseQuery<WitnessQuery>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n // Remove the query payload from the arguments passed to us so we don't observe it\n const filteredObservation = await PayloadHasher.filterExclude(payloads, query.query)\n switch (queryPayload.schema) {\n case WitnessObserveQuerySchema: {\n const observePayloads = await this.observe(filteredObservation)\n resultPayloads.push(...observePayloads)\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return resultPayloads\n }\n\n /** @function observeHandler Implement or override to add custom functionality to a witness */\n protected abstract observeHandler(payloads?: Payload[]): Promisable<Payload[]>\n}\n"],"mappings":";;;;;;;;;AAAA,SAASA,gBAAgB;AAEzB,SAA4BC,gCAAgC;AAC5D,SAASC,qBAAqB;AAC9B,SAASC,wBAAwBC,uBAA+D;AAGhG,SAEEC,qBAGAC,iCAIK;AAEPC,gBAAAA;AACO,IAAeC,mBAAf,MAAeA,yBAIZC,uBAAAA;EAKAC;EAER,IAAIC,YAAY;AACd,WAAO,KAAKC,OAAOD;EACrB;EAEA,IAAaE,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAIE,YAAY;AAtClB;AAuCI,YAAO,UAAKH,WAAL,mBAAaG;EACtB;EAEA,IAAuBC,qBAAiE;AACtF,WAAO;MACL,qCAAqC;IACvC;EACF;EAEA,MAAMC,uBAAuB;AAC3B,UAAMC,mBAAmB,KAAKP;AAC9B,SAAKD,qBAAqB,KAAKA,uBAAuBQ,mBAAmB,MAAM,KAAKC,QAAQD,gBAAAA,IAAoBE;AAChH,WAAO,KAAKV;EACd;;EAGA,MAAMW,QAAQC,YAA4C;AACxD,SAAKC,YAAY,SAAA;AACjB,UAAM,KAAKC,QAAQ,OAAA;AACnB,UAAM,KAAKC,KAAK,gBAAgB;MAAEH;MAAwBI,QAAQ;IAAK,CAAA;AACvE,UAAMC,cAAcC,SAAS,MAAM,KAAKC,eAAeP,UAAAA,GAAa,2BAAA;AACpEM,aAASD,YAAYG,SAAS,GAAG,8BAAA;AACjCH,+CAAaI,QAAQ,CAACC,YAAYJ,SAASI,QAAQC,QAAQ,yBAAA;AAE3D,UAAMtB,YAAY,MAAM,KAAKM,qBAAoB;AACjD,QAAIN,WAAW;AACb,YAAMA,UAAUuB,OAAOP,WAAAA;IACzB;AAEA,UAAM,KAAKF,KAAK,cAAc;MAAEH;MAAYI,QAAQ;MAAMC;IAAY,CAAA;AAEtE,WAAOA;EACT;;EAGA,MAAyBQ,aACvBC,OACAC,UACAC,aACmC;AACnC,UAAMC,UAAUC,yBAAyBC,WAAyBL,OAAOC,QAAAA;AACzE,UAAMK,eAAe,MAAMH,QAAQI,SAAQ;AAC3Cf,aAAS,KAAKgB,UAAUR,OAAOC,UAAUC,WAAAA,CAAAA;AACzC,UAAMO,iBAA4B,CAAA;AAElC,UAAMC,sBAAsB,MAAMC,cAAcC,cAAcX,UAAUD,MAAMA,KAAK;AACnF,YAAQM,aAAaT,QAAM;MACzB,KAAKnB,2BAA2B;AAC9B,cAAMmC,kBAAkB,MAAM,KAAK5B,QAAQyB,mBAAAA;AAC3CD,uBAAeK,KAAI,GAAID,eAAAA;AACvB;MACF;MACA,SAAS;AACP,eAAO,MAAMd,aAAaC,OAAOC,QAAAA;MACnC;IACF;AACA,WAAOQ;EACT;AAIF;AA7EUpC;AAGR,cAPoBD,kBAOK2C,iBAA0B;EAACC;;AAP/C,IAAe5C,kBAAf;","names":["assertEx","QueryBoundWitnessWrapper","PayloadHasher","AbstractModuleInstance","creatableModule","WitnessConfigSchema","WitnessObserveQuerySchema","creatableModule","AbstractWitness","AbstractModuleInstance","_archivistInstance","archivist","config","queries","WitnessObserveQuerySchema","targetSet","_queryAccountPaths","getArchivistInstance","archivistAddress","resolve","undefined","observe","inPayloads","_noOverride","started","emit","module","outPayloads","assertEx","observeHandler","length","forEach","payload","schema","insert","queryHandler","query","payloads","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","queryPayload","getQuery","queryable","resultPayloads","filteredObservation","PayloadHasher","filterExclude","observePayloads","push","configSchemas","WitnessConfigSchema"]}
|