@xyo-network/abstract-witness 2.94.1 → 2.94.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/browser/AbstractWitness.d.cts +2 -1
- package/dist/browser/AbstractWitness.d.cts.map +1 -1
- package/dist/browser/AbstractWitness.d.mts +2 -1
- package/dist/browser/AbstractWitness.d.mts.map +1 -1
- package/dist/browser/AbstractWitness.d.ts +2 -1
- package/dist/browser/AbstractWitness.d.ts.map +1 -1
- package/dist/browser/index.cjs +3 -1
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +3 -1
- package/dist/browser/index.js.map +1 -1
- package/dist/node/AbstractWitness.d.cts +2 -1
- package/dist/node/AbstractWitness.d.cts.map +1 -1
- package/dist/node/AbstractWitness.d.mts +2 -1
- package/dist/node/AbstractWitness.d.mts.map +1 -1
- package/dist/node/AbstractWitness.d.ts +2 -1
- package/dist/node/AbstractWitness.d.ts.map +1 -1
- package/dist/node/index.cjs +2 -0
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +2 -0
- package/dist/node/index.js.map +1 -1
- package/package.json +10 -9
- package/src/AbstractWitness.ts +2 -0
|
@@ -7,12 +7,13 @@ import { Payload } from '@xyo-network/payload-model';
|
|
|
7
7
|
import { CustomWitnessInstance, WitnessInstance, WitnessModuleEventData, WitnessParams, WitnessQueries } from '@xyo-network/witness-model';
|
|
8
8
|
export declare abstract class AbstractWitness<TParams extends WitnessParams = WitnessParams, TIn extends Payload = Payload, TOut extends Payload = Payload, TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut>> extends AbstractModuleInstance<TParams, TEventData> implements CustomWitnessInstance<TParams, TIn, TOut, TEventData> {
|
|
9
9
|
static readonly configSchemas: string[];
|
|
10
|
+
static readonly uniqueName: string;
|
|
10
11
|
private _archivistInstance;
|
|
11
12
|
get archivist(): string | undefined;
|
|
12
13
|
get queries(): string[];
|
|
13
14
|
protected get _queryAccountPaths(): Record<WitnessQueries['schema'], string>;
|
|
14
15
|
getArchivistInstance(): Promise<ArchivistInstance<import("@xylabs/object").BaseParamsFields & {
|
|
15
|
-
account?: import("@xyo-network/account
|
|
16
|
+
account?: import("@xyo-network/account").AccountInstance | "random" | undefined;
|
|
16
17
|
addToResolvers?: boolean | undefined;
|
|
17
18
|
config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
18
19
|
parents?: import("@xyo-network/archivist-model").ArchivistParents | undefined;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;
|
|
1
|
+
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,EAAmB,YAAY,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAA;AAEnG,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EACL,qBAAqB,EAErB,eAAe,EACf,sBAAsB,EAEtB,aAAa,EACb,cAAc,EACf,MAAM,4BAA4B,CAAA;AAGnC,8BAAsB,eAAe,CACjC,OAAO,SAAS,aAAa,GAAG,aAAa,EAC7C,GAAG,SAAS,OAAO,GAAG,OAAO,EAC7B,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CAEH,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,qBAAqB,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IAEhE,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAwB;IACxE,gBAAyB,UAAU,SAA4D;IAE/F,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,IAAI,SAAS,uBAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,cAAuB,kBAAkB,IAAI,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAIpF;IAEK,oBAAoB;;;;;;;;;;;;;;;;;;IAM1B,wJAAwJ;IAClJ,OAAO,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;IAkBlD,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,GAAG,EAAE,GAAG,UAAU,CAAC,IAAI,EAAE,CAAC;CACxE"}
|
|
@@ -7,12 +7,13 @@ import { Payload } from '@xyo-network/payload-model';
|
|
|
7
7
|
import { CustomWitnessInstance, WitnessInstance, WitnessModuleEventData, WitnessParams, WitnessQueries } from '@xyo-network/witness-model';
|
|
8
8
|
export declare abstract class AbstractWitness<TParams extends WitnessParams = WitnessParams, TIn extends Payload = Payload, TOut extends Payload = Payload, TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut>> extends AbstractModuleInstance<TParams, TEventData> implements CustomWitnessInstance<TParams, TIn, TOut, TEventData> {
|
|
9
9
|
static readonly configSchemas: string[];
|
|
10
|
+
static readonly uniqueName: string;
|
|
10
11
|
private _archivistInstance;
|
|
11
12
|
get archivist(): string | undefined;
|
|
12
13
|
get queries(): string[];
|
|
13
14
|
protected get _queryAccountPaths(): Record<WitnessQueries['schema'], string>;
|
|
14
15
|
getArchivistInstance(): Promise<ArchivistInstance<import("@xylabs/object").BaseParamsFields & {
|
|
15
|
-
account?: import("@xyo-network/account
|
|
16
|
+
account?: import("@xyo-network/account").AccountInstance | "random" | undefined;
|
|
16
17
|
addToResolvers?: boolean | undefined;
|
|
17
18
|
config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
18
19
|
parents?: import("@xyo-network/archivist-model").ArchivistParents | undefined;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;
|
|
1
|
+
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,EAAmB,YAAY,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAA;AAEnG,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EACL,qBAAqB,EAErB,eAAe,EACf,sBAAsB,EAEtB,aAAa,EACb,cAAc,EACf,MAAM,4BAA4B,CAAA;AAGnC,8BAAsB,eAAe,CACjC,OAAO,SAAS,aAAa,GAAG,aAAa,EAC7C,GAAG,SAAS,OAAO,GAAG,OAAO,EAC7B,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CAEH,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,qBAAqB,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IAEhE,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAwB;IACxE,gBAAyB,UAAU,SAA4D;IAE/F,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,IAAI,SAAS,uBAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,cAAuB,kBAAkB,IAAI,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAIpF;IAEK,oBAAoB;;;;;;;;;;;;;;;;;;IAM1B,wJAAwJ;IAClJ,OAAO,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;IAkBlD,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,GAAG,EAAE,GAAG,UAAU,CAAC,IAAI,EAAE,CAAC;CACxE"}
|
|
@@ -7,12 +7,13 @@ import { Payload } from '@xyo-network/payload-model';
|
|
|
7
7
|
import { CustomWitnessInstance, WitnessInstance, WitnessModuleEventData, WitnessParams, WitnessQueries } from '@xyo-network/witness-model';
|
|
8
8
|
export declare abstract class AbstractWitness<TParams extends WitnessParams = WitnessParams, TIn extends Payload = Payload, TOut extends Payload = Payload, TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut>> extends AbstractModuleInstance<TParams, TEventData> implements CustomWitnessInstance<TParams, TIn, TOut, TEventData> {
|
|
9
9
|
static readonly configSchemas: string[];
|
|
10
|
+
static readonly uniqueName: string;
|
|
10
11
|
private _archivistInstance;
|
|
11
12
|
get archivist(): string | undefined;
|
|
12
13
|
get queries(): string[];
|
|
13
14
|
protected get _queryAccountPaths(): Record<WitnessQueries['schema'], string>;
|
|
14
15
|
getArchivistInstance(): Promise<ArchivistInstance<import("@xylabs/object").BaseParamsFields & {
|
|
15
|
-
account?: import("@xyo-network/account
|
|
16
|
+
account?: import("@xyo-network/account").AccountInstance | "random" | undefined;
|
|
16
17
|
addToResolvers?: boolean | undefined;
|
|
17
18
|
config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
18
19
|
parents?: import("@xyo-network/archivist-model").ArchivistParents | undefined;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;
|
|
1
|
+
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,EAAmB,YAAY,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAA;AAEnG,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EACL,qBAAqB,EAErB,eAAe,EACf,sBAAsB,EAEtB,aAAa,EACb,cAAc,EACf,MAAM,4BAA4B,CAAA;AAGnC,8BAAsB,eAAe,CACjC,OAAO,SAAS,aAAa,GAAG,aAAa,EAC7C,GAAG,SAAS,OAAO,GAAG,OAAO,EAC7B,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CAEH,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,qBAAqB,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IAEhE,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAwB;IACxE,gBAAyB,UAAU,SAA4D;IAE/F,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,IAAI,SAAS,uBAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,cAAuB,kBAAkB,IAAI,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAIpF;IAEK,oBAAoB;;;;;;;;;;;;;;;;;;IAM1B,wJAAwJ;IAClJ,OAAO,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;IAkBlD,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,GAAG,EAAE,GAAG,UAAU,CAAC,IAAI,EAAE,CAAC;CACxE"}
|
package/dist/browser/index.cjs
CHANGED
|
@@ -27,19 +27,21 @@ module.exports = __toCommonJS(src_exports);
|
|
|
27
27
|
|
|
28
28
|
// src/AbstractWitness.ts
|
|
29
29
|
var import_assert = require("@xylabs/assert");
|
|
30
|
+
var import_account = require("@xyo-network/account");
|
|
30
31
|
var import_boundwitness_wrapper = require("@xyo-network/boundwitness-wrapper");
|
|
31
32
|
var import_module_abstract = require("@xyo-network/module-abstract");
|
|
32
33
|
var import_module_model = require("@xyo-network/module-model");
|
|
33
34
|
var import_payload_builder = require("@xyo-network/payload-builder");
|
|
34
35
|
var import_witness_model = require("@xyo-network/witness-model");
|
|
35
36
|
(0, import_module_model.creatableModule)();
|
|
36
|
-
var AbstractWitness = class extends import_module_abstract.AbstractModuleInstance {
|
|
37
|
+
var AbstractWitness = class _AbstractWitness extends import_module_abstract.AbstractModuleInstance {
|
|
37
38
|
static {
|
|
38
39
|
__name(this, "AbstractWitness");
|
|
39
40
|
}
|
|
40
41
|
static configSchemas = [
|
|
41
42
|
import_witness_model.WitnessConfigSchema
|
|
42
43
|
];
|
|
44
|
+
static uniqueName = (0, import_account.globallyUnique)("AbstractWitness", _AbstractWitness, "xyo");
|
|
43
45
|
_archivistInstance;
|
|
44
46
|
get archivist() {
|
|
45
47
|
return this.config.archivist;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/AbstractWitness.ts"],"sourcesContent":["export * from './AbstractWitness'\n","import { assertEx } from '@xylabs/assert'\nimport { Promisable } from '@xylabs/promise'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomWitnessInstance,\n WitnessConfigSchema,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuerySchema,\n WitnessParams,\n WitnessQueries,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TIn, TOut, 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 protected override get _queryAccountPaths(): Record<WitnessQueries['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?: TIn[]): Promise<TOut[]> {\n this._noOverride('observe')\n await this.started('throw')\n await this.emit('observeStart', { inPayloads, module: this } as TEventData['observeStart'])\n const outPayloads = assertEx(await this.observeHandler(inPayloads), () => 'Trying to witness nothing')\n //assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n for (const payload of outPayloads ?? []) 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 } as TEventData['observeEnd'])\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 = await QueryBoundWitnessWrapper.parseQuery<WitnessQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await 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 PayloadBuilder.filterExclude(payloads, query.query)) as TIn[]\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?: TIn[]): Promisable<TOut[]>\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/AbstractWitness.ts"],"sourcesContent":["export * from './AbstractWitness'\n","import { assertEx } from '@xylabs/assert'\nimport { Promisable } from '@xylabs/promise'\nimport { globallyUnique } from '@xyo-network/account'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomWitnessInstance,\n WitnessConfigSchema,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuerySchema,\n WitnessParams,\n WitnessQueries,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TIn, TOut, TEventData>\n{\n static override readonly configSchemas: string[] = [WitnessConfigSchema]\n static override readonly uniqueName = globallyUnique('AbstractWitness', AbstractWitness, 'xyo')\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 protected override get _queryAccountPaths(): Record<WitnessQueries['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?: TIn[]): Promise<TOut[]> {\n this._noOverride('observe')\n await this.started('throw')\n await this.emit('observeStart', { inPayloads, module: this } as TEventData['observeStart'])\n const outPayloads = assertEx(await this.observeHandler(inPayloads), () => 'Trying to witness nothing')\n //assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n for (const payload of outPayloads ?? []) 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 } as TEventData['observeEnd'])\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 = await QueryBoundWitnessWrapper.parseQuery<WitnessQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await 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 PayloadBuilder.filterExclude(payloads, query.query)) as TIn[]\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?: TIn[]): Promisable<TOut[]>\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AAEzB,qBAA+B;AAG/B,kCAAyC;AACzC,6BAAuC;AACvC,0BAAwE;AACxE,6BAA+B;AAE/B,2BAQO;IAEPA,qCAAAA;AACO,IAAeC,kBAAf,MAAeA,yBAUZC,8CAAAA;EA/BV,OA+BUA;;;EAGR,OAAyBC,gBAA0B;IAACC;;EACpD,OAAyBC,iBAAaC,+BAAe,mBAAmBL,kBAAiB,KAAA;EAEjFM;EAER,IAAIC,YAAY;AACd,WAAO,KAAKC,OAAOD;EACrB;EAEA,IAAaE,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAuBE,qBAA+D;AACpF,WAAO;MACL,qCAAqC;IACvC;EACF;EAEA,MAAMC,uBAAuB;AAC3B,UAAMC,mBAAmB,KAAKN;AAC9B,SAAKD,qBAAqB,KAAKA,uBAAuBO,mBAAmB,MAAM,KAAKC,QAAQD,gBAAAA,IAAoBE;AAChH,WAAO,KAAKT;EACd;;EAGA,MAAMU,QAAQC,YAAqC;AACjD,SAAKC,YAAY,SAAA;AACjB,UAAM,KAAKC,QAAQ,OAAA;AACnB,UAAM,KAAKC,KAAK,gBAAgB;MAAEH;MAAYI,QAAQ;IAAK,CAAA;AAC3D,UAAMC,kBAAcC,wBAAS,MAAM,KAAKC,eAAeP,UAAAA,GAAa,MAAM,2BAAA;AAE1E,eAAWQ,WAAWH,eAAe,CAAA;AAAIC,kCAASE,QAAQC,QAAQ,MAAM,yBAAA;AAExE,UAAMnB,YAAY,MAAM,KAAKK,qBAAoB;AACjD,QAAIL,WAAW;AACb,YAAMA,UAAUoB,OAAOL,WAAAA;IACzB;AAEA,UAAM,KAAKF,KAAK,cAAc;MAAEH;MAAYI,QAAQ;MAAMC;IAAY,CAAA;AAEtE,WAAOA;EACT;;EAGA,MAAyBM,aACvBC,OACAC,UACAC,aACmC;AACnC,UAAMC,UAAU,MAAMC,qDAAyBC,WAA2BL,OAAOC,QAAAA;AACjF,UAAMK,eAAe,MAAMH,QAAQI,SAAQ;AAC3Cb,gCAAS,MAAM,KAAKc,UAAUR,OAAOC,UAAUC,WAAAA,CAAAA;AAC/C,UAAMO,iBAA4B,CAAA;AAElC,UAAMC,sBAAuB,MAAMC,sCAAeC,cAAcX,UAAUD,MAAMA,KAAK;AACrF,YAAQM,aAAaT,QAAM;MACzB,KAAKhB,gDAA2B;AAC9B,cAAMgC,kBAAkB,MAAM,KAAK1B,QAAQuB,mBAAAA;AAC3CD,uBAAeK,KAAI,GAAID,eAAAA;AACvB;MACF;MACA,SAAS;AACP,eAAO,MAAMd,aAAaC,OAAOC,QAAAA;MACnC;IACF;AACA,WAAOQ;EACT;AAIF;","names":["creatableModule","AbstractWitness","AbstractModuleInstance","configSchemas","WitnessConfigSchema","uniqueName","globallyUnique","_archivistInstance","archivist","config","queries","WitnessObserveQuerySchema","_queryAccountPaths","getArchivistInstance","archivistAddress","resolve","undefined","observe","inPayloads","_noOverride","started","emit","module","outPayloads","assertEx","observeHandler","payload","schema","insert","queryHandler","query","payloads","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","queryPayload","getQuery","queryable","resultPayloads","filteredObservation","PayloadBuilder","filterExclude","observePayloads","push"]}
|
package/dist/browser/index.js
CHANGED
|
@@ -3,19 +3,21 @@ var __name = (target, value) => __defProp(target, "name", { value, configurable:
|
|
|
3
3
|
|
|
4
4
|
// src/AbstractWitness.ts
|
|
5
5
|
import { assertEx } from "@xylabs/assert";
|
|
6
|
+
import { globallyUnique } from "@xyo-network/account";
|
|
6
7
|
import { QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
|
|
7
8
|
import { AbstractModuleInstance } from "@xyo-network/module-abstract";
|
|
8
9
|
import { creatableModule } from "@xyo-network/module-model";
|
|
9
10
|
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
10
11
|
import { WitnessConfigSchema, WitnessObserveQuerySchema } from "@xyo-network/witness-model";
|
|
11
12
|
creatableModule();
|
|
12
|
-
var AbstractWitness = class extends AbstractModuleInstance {
|
|
13
|
+
var AbstractWitness = class _AbstractWitness extends AbstractModuleInstance {
|
|
13
14
|
static {
|
|
14
15
|
__name(this, "AbstractWitness");
|
|
15
16
|
}
|
|
16
17
|
static configSchemas = [
|
|
17
18
|
WitnessConfigSchema
|
|
18
19
|
];
|
|
20
|
+
static uniqueName = globallyUnique("AbstractWitness", _AbstractWitness, "xyo");
|
|
19
21
|
_archivistInstance;
|
|
20
22
|
get archivist() {
|
|
21
23
|
return this.config.archivist;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/AbstractWitness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Promisable } from '@xylabs/promise'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomWitnessInstance,\n WitnessConfigSchema,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuerySchema,\n WitnessParams,\n WitnessQueries,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TIn, TOut, 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 protected override get _queryAccountPaths(): Record<WitnessQueries['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?: TIn[]): Promise<TOut[]> {\n this._noOverride('observe')\n await this.started('throw')\n await this.emit('observeStart', { inPayloads, module: this } as TEventData['observeStart'])\n const outPayloads = assertEx(await this.observeHandler(inPayloads), () => 'Trying to witness nothing')\n //assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n for (const payload of outPayloads ?? []) 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 } as TEventData['observeEnd'])\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 = await QueryBoundWitnessWrapper.parseQuery<WitnessQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await 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 PayloadBuilder.filterExclude(payloads, query.query)) as TIn[]\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?: TIn[]): Promisable<TOut[]>\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;
|
|
1
|
+
{"version":3,"sources":["../../src/AbstractWitness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Promisable } from '@xylabs/promise'\nimport { globallyUnique } from '@xyo-network/account'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomWitnessInstance,\n WitnessConfigSchema,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuerySchema,\n WitnessParams,\n WitnessQueries,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TIn, TOut, TEventData>\n{\n static override readonly configSchemas: string[] = [WitnessConfigSchema]\n static override readonly uniqueName = globallyUnique('AbstractWitness', AbstractWitness, 'xyo')\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 protected override get _queryAccountPaths(): Record<WitnessQueries['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?: TIn[]): Promise<TOut[]> {\n this._noOverride('observe')\n await this.started('throw')\n await this.emit('observeStart', { inPayloads, module: this } as TEventData['observeStart'])\n const outPayloads = assertEx(await this.observeHandler(inPayloads), () => 'Trying to witness nothing')\n //assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n for (const payload of outPayloads ?? []) 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 } as TEventData['observeEnd'])\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 = await QueryBoundWitnessWrapper.parseQuery<WitnessQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await 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 PayloadBuilder.filterExclude(payloads, query.query)) as TIn[]\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?: TIn[]): Promisable<TOut[]>\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AAEzB,SAASC,sBAAsB;AAG/B,SAASC,gCAAgC;AACzC,SAASC,8BAA8B;AACvC,SAASC,uBAA+D;AACxE,SAASC,sBAAsB;AAE/B,SAEEC,qBAGAC,iCAGK;AAEPC,gBAAAA;AACO,IAAeC,kBAAf,MAAeA,yBAUZC,uBAAAA;EA/BV,OA+BUA;;;EAGR,OAAyBC,gBAA0B;IAACC;;EACpD,OAAyBC,aAAaC,eAAe,mBAAmBL,kBAAiB,KAAA;EAEjFM;EAER,IAAIC,YAAY;AACd,WAAO,KAAKC,OAAOD;EACrB;EAEA,IAAaE,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAuBE,qBAA+D;AACpF,WAAO;MACL,qCAAqC;IACvC;EACF;EAEA,MAAMC,uBAAuB;AAC3B,UAAMC,mBAAmB,KAAKN;AAC9B,SAAKD,qBAAqB,KAAKA,uBAAuBO,mBAAmB,MAAM,KAAKC,QAAQD,gBAAAA,IAAoBE;AAChH,WAAO,KAAKT;EACd;;EAGA,MAAMU,QAAQC,YAAqC;AACjD,SAAKC,YAAY,SAAA;AACjB,UAAM,KAAKC,QAAQ,OAAA;AACnB,UAAM,KAAKC,KAAK,gBAAgB;MAAEH;MAAYI,QAAQ;IAAK,CAAA;AAC3D,UAAMC,cAAcC,SAAS,MAAM,KAAKC,eAAeP,UAAAA,GAAa,MAAM,2BAAA;AAE1E,eAAWQ,WAAWH,eAAe,CAAA;AAAIC,eAASE,QAAQC,QAAQ,MAAM,yBAAA;AAExE,UAAMnB,YAAY,MAAM,KAAKK,qBAAoB;AACjD,QAAIL,WAAW;AACb,YAAMA,UAAUoB,OAAOL,WAAAA;IACzB;AAEA,UAAM,KAAKF,KAAK,cAAc;MAAEH;MAAYI,QAAQ;MAAMC;IAAY,CAAA;AAEtE,WAAOA;EACT;;EAGA,MAAyBM,aACvBC,OACAC,UACAC,aACmC;AACnC,UAAMC,UAAU,MAAMC,yBAAyBC,WAA2BL,OAAOC,QAAAA;AACjF,UAAMK,eAAe,MAAMH,QAAQI,SAAQ;AAC3Cb,aAAS,MAAM,KAAKc,UAAUR,OAAOC,UAAUC,WAAAA,CAAAA;AAC/C,UAAMO,iBAA4B,CAAA;AAElC,UAAMC,sBAAuB,MAAMC,eAAeC,cAAcX,UAAUD,MAAMA,KAAK;AACrF,YAAQM,aAAaT,QAAM;MACzB,KAAKhB,2BAA2B;AAC9B,cAAMgC,kBAAkB,MAAM,KAAK1B,QAAQuB,mBAAAA;AAC3CD,uBAAeK,KAAI,GAAID,eAAAA;AACvB;MACF;MACA,SAAS;AACP,eAAO,MAAMd,aAAaC,OAAOC,QAAAA;MACnC;IACF;AACA,WAAOQ;EACT;AAIF;","names":["assertEx","globallyUnique","QueryBoundWitnessWrapper","AbstractModuleInstance","creatableModule","PayloadBuilder","WitnessConfigSchema","WitnessObserveQuerySchema","creatableModule","AbstractWitness","AbstractModuleInstance","configSchemas","WitnessConfigSchema","uniqueName","globallyUnique","_archivistInstance","archivist","config","queries","WitnessObserveQuerySchema","_queryAccountPaths","getArchivistInstance","archivistAddress","resolve","undefined","observe","inPayloads","_noOverride","started","emit","module","outPayloads","assertEx","observeHandler","payload","schema","insert","queryHandler","query","payloads","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","queryPayload","getQuery","queryable","resultPayloads","filteredObservation","PayloadBuilder","filterExclude","observePayloads","push"]}
|
|
@@ -7,12 +7,13 @@ import { Payload } from '@xyo-network/payload-model';
|
|
|
7
7
|
import { CustomWitnessInstance, WitnessInstance, WitnessModuleEventData, WitnessParams, WitnessQueries } from '@xyo-network/witness-model';
|
|
8
8
|
export declare abstract class AbstractWitness<TParams extends WitnessParams = WitnessParams, TIn extends Payload = Payload, TOut extends Payload = Payload, TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut>> extends AbstractModuleInstance<TParams, TEventData> implements CustomWitnessInstance<TParams, TIn, TOut, TEventData> {
|
|
9
9
|
static readonly configSchemas: string[];
|
|
10
|
+
static readonly uniqueName: string;
|
|
10
11
|
private _archivistInstance;
|
|
11
12
|
get archivist(): string | undefined;
|
|
12
13
|
get queries(): string[];
|
|
13
14
|
protected get _queryAccountPaths(): Record<WitnessQueries['schema'], string>;
|
|
14
15
|
getArchivistInstance(): Promise<ArchivistInstance<import("@xylabs/object").BaseParamsFields & {
|
|
15
|
-
account?: import("@xyo-network/account
|
|
16
|
+
account?: import("@xyo-network/account").AccountInstance | "random" | undefined;
|
|
16
17
|
addToResolvers?: boolean | undefined;
|
|
17
18
|
config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
18
19
|
parents?: import("@xyo-network/archivist-model").ArchivistParents | undefined;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;
|
|
1
|
+
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,EAAmB,YAAY,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAA;AAEnG,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EACL,qBAAqB,EAErB,eAAe,EACf,sBAAsB,EAEtB,aAAa,EACb,cAAc,EACf,MAAM,4BAA4B,CAAA;AAGnC,8BAAsB,eAAe,CACjC,OAAO,SAAS,aAAa,GAAG,aAAa,EAC7C,GAAG,SAAS,OAAO,GAAG,OAAO,EAC7B,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CAEH,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,qBAAqB,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IAEhE,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAwB;IACxE,gBAAyB,UAAU,SAA4D;IAE/F,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,IAAI,SAAS,uBAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,cAAuB,kBAAkB,IAAI,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAIpF;IAEK,oBAAoB;;;;;;;;;;;;;;;;;;IAM1B,wJAAwJ;IAClJ,OAAO,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;IAkBlD,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,GAAG,EAAE,GAAG,UAAU,CAAC,IAAI,EAAE,CAAC;CACxE"}
|
|
@@ -7,12 +7,13 @@ import { Payload } from '@xyo-network/payload-model';
|
|
|
7
7
|
import { CustomWitnessInstance, WitnessInstance, WitnessModuleEventData, WitnessParams, WitnessQueries } from '@xyo-network/witness-model';
|
|
8
8
|
export declare abstract class AbstractWitness<TParams extends WitnessParams = WitnessParams, TIn extends Payload = Payload, TOut extends Payload = Payload, TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut>> extends AbstractModuleInstance<TParams, TEventData> implements CustomWitnessInstance<TParams, TIn, TOut, TEventData> {
|
|
9
9
|
static readonly configSchemas: string[];
|
|
10
|
+
static readonly uniqueName: string;
|
|
10
11
|
private _archivistInstance;
|
|
11
12
|
get archivist(): string | undefined;
|
|
12
13
|
get queries(): string[];
|
|
13
14
|
protected get _queryAccountPaths(): Record<WitnessQueries['schema'], string>;
|
|
14
15
|
getArchivistInstance(): Promise<ArchivistInstance<import("@xylabs/object").BaseParamsFields & {
|
|
15
|
-
account?: import("@xyo-network/account
|
|
16
|
+
account?: import("@xyo-network/account").AccountInstance | "random" | undefined;
|
|
16
17
|
addToResolvers?: boolean | undefined;
|
|
17
18
|
config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
18
19
|
parents?: import("@xyo-network/archivist-model").ArchivistParents | undefined;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;
|
|
1
|
+
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,EAAmB,YAAY,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAA;AAEnG,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EACL,qBAAqB,EAErB,eAAe,EACf,sBAAsB,EAEtB,aAAa,EACb,cAAc,EACf,MAAM,4BAA4B,CAAA;AAGnC,8BAAsB,eAAe,CACjC,OAAO,SAAS,aAAa,GAAG,aAAa,EAC7C,GAAG,SAAS,OAAO,GAAG,OAAO,EAC7B,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CAEH,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,qBAAqB,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IAEhE,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAwB;IACxE,gBAAyB,UAAU,SAA4D;IAE/F,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,IAAI,SAAS,uBAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,cAAuB,kBAAkB,IAAI,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAIpF;IAEK,oBAAoB;;;;;;;;;;;;;;;;;;IAM1B,wJAAwJ;IAClJ,OAAO,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;IAkBlD,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,GAAG,EAAE,GAAG,UAAU,CAAC,IAAI,EAAE,CAAC;CACxE"}
|
|
@@ -7,12 +7,13 @@ import { Payload } from '@xyo-network/payload-model';
|
|
|
7
7
|
import { CustomWitnessInstance, WitnessInstance, WitnessModuleEventData, WitnessParams, WitnessQueries } from '@xyo-network/witness-model';
|
|
8
8
|
export declare abstract class AbstractWitness<TParams extends WitnessParams = WitnessParams, TIn extends Payload = Payload, TOut extends Payload = Payload, TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut>> extends AbstractModuleInstance<TParams, TEventData> implements CustomWitnessInstance<TParams, TIn, TOut, TEventData> {
|
|
9
9
|
static readonly configSchemas: string[];
|
|
10
|
+
static readonly uniqueName: string;
|
|
10
11
|
private _archivistInstance;
|
|
11
12
|
get archivist(): string | undefined;
|
|
12
13
|
get queries(): string[];
|
|
13
14
|
protected get _queryAccountPaths(): Record<WitnessQueries['schema'], string>;
|
|
14
15
|
getArchivistInstance(): Promise<ArchivistInstance<import("@xylabs/object").BaseParamsFields & {
|
|
15
|
-
account?: import("@xyo-network/account
|
|
16
|
+
account?: import("@xyo-network/account").AccountInstance | "random" | undefined;
|
|
16
17
|
addToResolvers?: boolean | undefined;
|
|
17
18
|
config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
18
19
|
parents?: import("@xyo-network/archivist-model").ArchivistParents | undefined;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;
|
|
1
|
+
{"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAEnE,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,EAAmB,YAAY,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAA;AAEnG,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EACL,qBAAqB,EAErB,eAAe,EACf,sBAAsB,EAEtB,aAAa,EACb,cAAc,EACf,MAAM,4BAA4B,CAAA;AAGnC,8BAAsB,eAAe,CACjC,OAAO,SAAS,aAAa,GAAG,aAAa,EAC7C,GAAG,SAAS,OAAO,GAAG,OAAO,EAC7B,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CAEH,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,qBAAqB,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IAEhE,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAwB;IACxE,gBAAyB,UAAU,SAA4D;IAE/F,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,IAAI,SAAS,uBAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,cAAuB,kBAAkB,IAAI,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAIpF;IAEK,oBAAoB;;;;;;;;;;;;;;;;;;IAM1B,wJAAwJ;IAClJ,OAAO,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;IAkBlD,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,GAAG,EAAE,GAAG,UAAU,CAAC,IAAI,EAAE,CAAC;CACxE"}
|
package/dist/node/index.cjs
CHANGED
|
@@ -32,6 +32,7 @@ module.exports = __toCommonJS(src_exports);
|
|
|
32
32
|
|
|
33
33
|
// src/AbstractWitness.ts
|
|
34
34
|
var import_assert = require("@xylabs/assert");
|
|
35
|
+
var import_account = require("@xyo-network/account");
|
|
35
36
|
var import_boundwitness_wrapper = require("@xyo-network/boundwitness-wrapper");
|
|
36
37
|
var import_module_abstract = require("@xyo-network/module-abstract");
|
|
37
38
|
var import_module_model = require("@xyo-network/module-model");
|
|
@@ -105,6 +106,7 @@ __name(_AbstractWitness, "AbstractWitness");
|
|
|
105
106
|
__publicField(_AbstractWitness, "configSchemas", [
|
|
106
107
|
import_witness_model.WitnessConfigSchema
|
|
107
108
|
]);
|
|
109
|
+
__publicField(_AbstractWitness, "uniqueName", (0, import_account.globallyUnique)("AbstractWitness", _AbstractWitness, "xyo"));
|
|
108
110
|
var AbstractWitness = _AbstractWitness;
|
|
109
111
|
// Annotate the CommonJS export names for ESM import in node:
|
|
110
112
|
0 && (module.exports = {
|
package/dist/node/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/AbstractWitness.ts"],"sourcesContent":["export * from './AbstractWitness'\n","import { assertEx } from '@xylabs/assert'\nimport { Promisable } from '@xylabs/promise'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomWitnessInstance,\n WitnessConfigSchema,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuerySchema,\n WitnessParams,\n WitnessQueries,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TIn, TOut, 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 protected override get _queryAccountPaths(): Record<WitnessQueries['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?: TIn[]): Promise<TOut[]> {\n this._noOverride('observe')\n await this.started('throw')\n await this.emit('observeStart', { inPayloads, module: this } as TEventData['observeStart'])\n const outPayloads = assertEx(await this.observeHandler(inPayloads), () => 'Trying to witness nothing')\n //assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n for (const payload of outPayloads ?? []) 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 } as TEventData['observeEnd'])\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 = await QueryBoundWitnessWrapper.parseQuery<WitnessQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await 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 PayloadBuilder.filterExclude(payloads, query.query)) as TIn[]\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?: TIn[]): Promisable<TOut[]>\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/AbstractWitness.ts"],"sourcesContent":["export * from './AbstractWitness'\n","import { assertEx } from '@xylabs/assert'\nimport { Promisable } from '@xylabs/promise'\nimport { globallyUnique } from '@xyo-network/account'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomWitnessInstance,\n WitnessConfigSchema,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuerySchema,\n WitnessParams,\n WitnessQueries,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TIn, TOut, TEventData>\n{\n static override readonly configSchemas: string[] = [WitnessConfigSchema]\n static override readonly uniqueName = globallyUnique('AbstractWitness', AbstractWitness, 'xyo')\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 protected override get _queryAccountPaths(): Record<WitnessQueries['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?: TIn[]): Promise<TOut[]> {\n this._noOverride('observe')\n await this.started('throw')\n await this.emit('observeStart', { inPayloads, module: this } as TEventData['observeStart'])\n const outPayloads = assertEx(await this.observeHandler(inPayloads), () => 'Trying to witness nothing')\n //assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n for (const payload of outPayloads ?? []) 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 } as TEventData['observeEnd'])\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 = await QueryBoundWitnessWrapper.parseQuery<WitnessQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await 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 PayloadBuilder.filterExclude(payloads, query.query)) as TIn[]\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?: TIn[]): Promisable<TOut[]>\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AAEzB,qBAA+B;AAG/B,kCAAyC;AACzC,6BAAuC;AACvC,0BAAwE;AACxE,6BAA+B;AAE/B,2BAQO;IAEPA,qCAAAA;AACO,IAAeC,mBAAf,MAAeA,yBAUZC,8CAAAA;EAMAC;EAER,IAAIC,YAAY;AACd,WAAO,KAAKC,OAAOD;EACrB;EAEA,IAAaE,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAuBE,qBAA+D;AACpF,WAAO;MACL,qCAAqC;IACvC;EACF;EAEA,MAAMC,uBAAuB;AAC3B,UAAMC,mBAAmB,KAAKN;AAC9B,SAAKD,qBAAqB,KAAKA,uBAAuBO,mBAAmB,MAAM,KAAKC,QAAQD,gBAAAA,IAAoBE;AAChH,WAAO,KAAKT;EACd;;EAGA,MAAMU,QAAQC,YAAqC;AACjD,SAAKC,YAAY,SAAA;AACjB,UAAM,KAAKC,QAAQ,OAAA;AACnB,UAAM,KAAKC,KAAK,gBAAgB;MAAEH;MAAYI,QAAQ;IAAK,CAAA;AAC3D,UAAMC,kBAAcC,wBAAS,MAAM,KAAKC,eAAeP,UAAAA,GAAa,MAAM,2BAAA;AAE1E,eAAWQ,WAAWH,eAAe,CAAA;AAAIC,kCAASE,QAAQC,QAAQ,MAAM,yBAAA;AAExE,UAAMnB,YAAY,MAAM,KAAKK,qBAAoB;AACjD,QAAIL,WAAW;AACb,YAAMA,UAAUoB,OAAOL,WAAAA;IACzB;AAEA,UAAM,KAAKF,KAAK,cAAc;MAAEH;MAAYI,QAAQ;MAAMC;IAAY,CAAA;AAEtE,WAAOA;EACT;;EAGA,MAAyBM,aACvBC,OACAC,UACAC,aACmC;AACnC,UAAMC,UAAU,MAAMC,qDAAyBC,WAA2BL,OAAOC,QAAAA;AACjF,UAAMK,eAAe,MAAMH,QAAQI,SAAQ;AAC3Cb,gCAAS,MAAM,KAAKc,UAAUR,OAAOC,UAAUC,WAAAA,CAAAA;AAC/C,UAAMO,iBAA4B,CAAA;AAElC,UAAMC,sBAAuB,MAAMC,sCAAeC,cAAcX,UAAUD,MAAMA,KAAK;AACrF,YAAQM,aAAaT,QAAM;MACzB,KAAKhB,gDAA2B;AAC9B,cAAMgC,kBAAkB,MAAM,KAAK1B,QAAQuB,mBAAAA;AAC3CD,uBAAeK,KAAI,GAAID,eAAAA;AACvB;MACF;MACA,SAAS;AACP,eAAO,MAAMd,aAAaC,OAAOC,QAAAA;MACnC;IACF;AACA,WAAOQ;EACT;AAIF;AA1EUjC;AAGR,cAboBD,kBAaKwC,iBAA0B;EAACC;;AACpD,cAdoBzC,kBAcK0C,kBAAaC,+BAAe,mBAAmB3C,kBAAiB,KAAA;AAdpF,IAAeA,kBAAf;","names":["creatableModule","AbstractWitness","AbstractModuleInstance","_archivistInstance","archivist","config","queries","WitnessObserveQuerySchema","_queryAccountPaths","getArchivistInstance","archivistAddress","resolve","undefined","observe","inPayloads","_noOverride","started","emit","module","outPayloads","assertEx","observeHandler","payload","schema","insert","queryHandler","query","payloads","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","queryPayload","getQuery","queryable","resultPayloads","filteredObservation","PayloadBuilder","filterExclude","observePayloads","push","configSchemas","WitnessConfigSchema","uniqueName","globallyUnique"]}
|
package/dist/node/index.js
CHANGED
|
@@ -8,6 +8,7 @@ var __publicField = (obj, key, value) => {
|
|
|
8
8
|
|
|
9
9
|
// src/AbstractWitness.ts
|
|
10
10
|
import { assertEx } from "@xylabs/assert";
|
|
11
|
+
import { globallyUnique } from "@xyo-network/account";
|
|
11
12
|
import { QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
|
|
12
13
|
import { AbstractModuleInstance } from "@xyo-network/module-abstract";
|
|
13
14
|
import { creatableModule } from "@xyo-network/module-model";
|
|
@@ -81,6 +82,7 @@ __name(_AbstractWitness, "AbstractWitness");
|
|
|
81
82
|
__publicField(_AbstractWitness, "configSchemas", [
|
|
82
83
|
WitnessConfigSchema
|
|
83
84
|
]);
|
|
85
|
+
__publicField(_AbstractWitness, "uniqueName", globallyUnique("AbstractWitness", _AbstractWitness, "xyo"));
|
|
84
86
|
var AbstractWitness = _AbstractWitness;
|
|
85
87
|
export {
|
|
86
88
|
AbstractWitness
|
package/dist/node/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/AbstractWitness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Promisable } from '@xylabs/promise'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomWitnessInstance,\n WitnessConfigSchema,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuerySchema,\n WitnessParams,\n WitnessQueries,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TIn, TOut, 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 protected override get _queryAccountPaths(): Record<WitnessQueries['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?: TIn[]): Promise<TOut[]> {\n this._noOverride('observe')\n await this.started('throw')\n await this.emit('observeStart', { inPayloads, module: this } as TEventData['observeStart'])\n const outPayloads = assertEx(await this.observeHandler(inPayloads), () => 'Trying to witness nothing')\n //assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n for (const payload of outPayloads ?? []) 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 } as TEventData['observeEnd'])\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 = await QueryBoundWitnessWrapper.parseQuery<WitnessQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await 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 PayloadBuilder.filterExclude(payloads, query.query)) as TIn[]\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?: TIn[]): Promisable<TOut[]>\n}\n"],"mappings":";;;;;;;;;AAAA,SAASA,gBAAgB;
|
|
1
|
+
{"version":3,"sources":["../../src/AbstractWitness.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Promisable } from '@xylabs/promise'\nimport { globallyUnique } from '@xyo-network/account'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomWitnessInstance,\n WitnessConfigSchema,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuerySchema,\n WitnessParams,\n WitnessQueries,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n >\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TIn, TOut, TEventData>\n{\n static override readonly configSchemas: string[] = [WitnessConfigSchema]\n static override readonly uniqueName = globallyUnique('AbstractWitness', AbstractWitness, 'xyo')\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 protected override get _queryAccountPaths(): Record<WitnessQueries['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?: TIn[]): Promise<TOut[]> {\n this._noOverride('observe')\n await this.started('throw')\n await this.emit('observeStart', { inPayloads, module: this } as TEventData['observeStart'])\n const outPayloads = assertEx(await this.observeHandler(inPayloads), () => 'Trying to witness nothing')\n //assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n for (const payload of outPayloads ?? []) 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 } as TEventData['observeEnd'])\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 = await QueryBoundWitnessWrapper.parseQuery<WitnessQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await 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 PayloadBuilder.filterExclude(payloads, query.query)) as TIn[]\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?: TIn[]): Promisable<TOut[]>\n}\n"],"mappings":";;;;;;;;;AAAA,SAASA,gBAAgB;AAEzB,SAASC,sBAAsB;AAG/B,SAASC,gCAAgC;AACzC,SAASC,8BAA8B;AACvC,SAASC,uBAA+D;AACxE,SAASC,sBAAsB;AAE/B,SAEEC,qBAGAC,iCAGK;AAEPC,gBAAAA;AACO,IAAeC,mBAAf,MAAeA,yBAUZC,uBAAAA;EAMAC;EAER,IAAIC,YAAY;AACd,WAAO,KAAKC,OAAOD;EACrB;EAEA,IAAaE,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAuBE,qBAA+D;AACpF,WAAO;MACL,qCAAqC;IACvC;EACF;EAEA,MAAMC,uBAAuB;AAC3B,UAAMC,mBAAmB,KAAKN;AAC9B,SAAKD,qBAAqB,KAAKA,uBAAuBO,mBAAmB,MAAM,KAAKC,QAAQD,gBAAAA,IAAoBE;AAChH,WAAO,KAAKT;EACd;;EAGA,MAAMU,QAAQC,YAAqC;AACjD,SAAKC,YAAY,SAAA;AACjB,UAAM,KAAKC,QAAQ,OAAA;AACnB,UAAM,KAAKC,KAAK,gBAAgB;MAAEH;MAAYI,QAAQ;IAAK,CAAA;AAC3D,UAAMC,cAAcC,SAAS,MAAM,KAAKC,eAAeP,UAAAA,GAAa,MAAM,2BAAA;AAE1E,eAAWQ,WAAWH,eAAe,CAAA;AAAIC,eAASE,QAAQC,QAAQ,MAAM,yBAAA;AAExE,UAAMnB,YAAY,MAAM,KAAKK,qBAAoB;AACjD,QAAIL,WAAW;AACb,YAAMA,UAAUoB,OAAOL,WAAAA;IACzB;AAEA,UAAM,KAAKF,KAAK,cAAc;MAAEH;MAAYI,QAAQ;MAAMC;IAAY,CAAA;AAEtE,WAAOA;EACT;;EAGA,MAAyBM,aACvBC,OACAC,UACAC,aACmC;AACnC,UAAMC,UAAU,MAAMC,yBAAyBC,WAA2BL,OAAOC,QAAAA;AACjF,UAAMK,eAAe,MAAMH,QAAQI,SAAQ;AAC3Cb,aAAS,MAAM,KAAKc,UAAUR,OAAOC,UAAUC,WAAAA,CAAAA;AAC/C,UAAMO,iBAA4B,CAAA;AAElC,UAAMC,sBAAuB,MAAMC,eAAeC,cAAcX,UAAUD,MAAMA,KAAK;AACrF,YAAQM,aAAaT,QAAM;MACzB,KAAKhB,2BAA2B;AAC9B,cAAMgC,kBAAkB,MAAM,KAAK1B,QAAQuB,mBAAAA;AAC3CD,uBAAeK,KAAI,GAAID,eAAAA;AACvB;MACF;MACA,SAAS;AACP,eAAO,MAAMd,aAAaC,OAAOC,QAAAA;MACnC;IACF;AACA,WAAOQ;EACT;AAIF;AA1EUjC;AAGR,cAboBD,kBAaKwC,iBAA0B;EAACC;;AACpD,cAdoBzC,kBAcK0C,cAAaC,eAAe,mBAAmB3C,kBAAiB,KAAA;AAdpF,IAAeA,kBAAf;","names":["assertEx","globallyUnique","QueryBoundWitnessWrapper","AbstractModuleInstance","creatableModule","PayloadBuilder","WitnessConfigSchema","WitnessObserveQuerySchema","creatableModule","AbstractWitness","AbstractModuleInstance","_archivistInstance","archivist","config","queries","WitnessObserveQuerySchema","_queryAccountPaths","getArchivistInstance","archivistAddress","resolve","undefined","observe","inPayloads","_noOverride","started","emit","module","outPayloads","assertEx","observeHandler","payload","schema","insert","queryHandler","query","payloads","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","queryPayload","getQuery","queryable","resultPayloads","filteredObservation","PayloadBuilder","filterExclude","observePayloads","push","configSchemas","WitnessConfigSchema","uniqueName","globallyUnique"]}
|
package/package.json
CHANGED
|
@@ -12,14 +12,15 @@
|
|
|
12
12
|
"dependencies": {
|
|
13
13
|
"@xylabs/assert": "^3.0.24",
|
|
14
14
|
"@xylabs/promise": "^3.0.24",
|
|
15
|
-
"@xyo-network/
|
|
16
|
-
"@xyo-network/
|
|
17
|
-
"@xyo-network/boundwitness-
|
|
18
|
-
"@xyo-network/
|
|
19
|
-
"@xyo-network/module-
|
|
20
|
-
"@xyo-network/
|
|
21
|
-
"@xyo-network/payload-
|
|
22
|
-
"@xyo-network/
|
|
15
|
+
"@xyo-network/account": "~2.94.3",
|
|
16
|
+
"@xyo-network/archivist-model": "~2.94.3",
|
|
17
|
+
"@xyo-network/boundwitness-model": "~2.94.3",
|
|
18
|
+
"@xyo-network/boundwitness-wrapper": "~2.94.3",
|
|
19
|
+
"@xyo-network/module-abstract": "~2.94.3",
|
|
20
|
+
"@xyo-network/module-model": "~2.94.3",
|
|
21
|
+
"@xyo-network/payload-builder": "~2.94.3",
|
|
22
|
+
"@xyo-network/payload-model": "~2.94.3",
|
|
23
|
+
"@xyo-network/witness-model": "~2.94.3"
|
|
23
24
|
},
|
|
24
25
|
"devDependencies": {
|
|
25
26
|
"@xylabs/ts-scripts-yarn3": "^3.5.2",
|
|
@@ -65,6 +66,6 @@
|
|
|
65
66
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
66
67
|
},
|
|
67
68
|
"sideEffects": false,
|
|
68
|
-
"version": "2.94.
|
|
69
|
+
"version": "2.94.3",
|
|
69
70
|
"type": "module"
|
|
70
71
|
}
|
package/src/AbstractWitness.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { assertEx } from '@xylabs/assert'
|
|
2
2
|
import { Promisable } from '@xylabs/promise'
|
|
3
|
+
import { globallyUnique } from '@xyo-network/account'
|
|
3
4
|
import { ArchivistInstance } from '@xyo-network/archivist-model'
|
|
4
5
|
import { QueryBoundWitness } from '@xyo-network/boundwitness-model'
|
|
5
6
|
import { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'
|
|
@@ -32,6 +33,7 @@ export abstract class AbstractWitness<
|
|
|
32
33
|
implements CustomWitnessInstance<TParams, TIn, TOut, TEventData>
|
|
33
34
|
{
|
|
34
35
|
static override readonly configSchemas: string[] = [WitnessConfigSchema]
|
|
36
|
+
static override readonly uniqueName = globallyUnique('AbstractWitness', AbstractWitness, 'xyo')
|
|
35
37
|
|
|
36
38
|
private _archivistInstance: ArchivistInstance | undefined
|
|
37
39
|
|