@xyo-network/abstract-witness 2.84.2 → 2.84.4
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/node/{index.mjs → index.cjs} +44 -19
- package/dist/node/index.cjs.map +1 -0
- package/dist/node/index.js +18 -43
- package/dist/node/index.js.map +1 -1
- package/package.json +17 -17
- package/dist/node/index.mjs.map +0 -1
|
@@ -1,27 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
1
2
|
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
2
6
|
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
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);
|
|
4
21
|
var __publicField = (obj, key, value) => {
|
|
5
22
|
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
6
23
|
return value;
|
|
7
24
|
};
|
|
8
25
|
|
|
26
|
+
// src/index.ts
|
|
27
|
+
var src_exports = {};
|
|
28
|
+
__export(src_exports, {
|
|
29
|
+
AbstractWitness: () => AbstractWitness
|
|
30
|
+
});
|
|
31
|
+
module.exports = __toCommonJS(src_exports);
|
|
32
|
+
|
|
9
33
|
// src/AbstractWitness.ts
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
creatableModule();
|
|
17
|
-
var _AbstractWitness = class _AbstractWitness extends AbstractModuleInstance {
|
|
34
|
+
var import_assert = require("@xylabs/assert");
|
|
35
|
+
var import_boundwitness_builder = require("@xyo-network/boundwitness-builder");
|
|
36
|
+
var import_hash = require("@xyo-network/hash");
|
|
37
|
+
var import_module_abstract = require("@xyo-network/module-abstract");
|
|
38
|
+
var import_module_model = require("@xyo-network/module-model");
|
|
39
|
+
var import_witness_model = require("@xyo-network/witness-model");
|
|
40
|
+
(0, import_module_model.creatableModule)();
|
|
41
|
+
var _AbstractWitness = class _AbstractWitness extends import_module_abstract.AbstractModuleInstance {
|
|
18
42
|
_archivistInstance;
|
|
19
43
|
get archivist() {
|
|
20
44
|
return this.config.archivist;
|
|
21
45
|
}
|
|
22
46
|
get queries() {
|
|
23
47
|
return [
|
|
24
|
-
WitnessObserveQuerySchema,
|
|
48
|
+
import_witness_model.WitnessObserveQuerySchema,
|
|
25
49
|
...super.queries
|
|
26
50
|
];
|
|
27
51
|
}
|
|
@@ -47,8 +71,8 @@ var _AbstractWitness = class _AbstractWitness extends AbstractModuleInstance {
|
|
|
47
71
|
inPayloads,
|
|
48
72
|
module: this
|
|
49
73
|
});
|
|
50
|
-
const outPayloads = assertEx(await this.observeHandler(inPayloads), "Trying to witness nothing");
|
|
51
|
-
outPayloads == null ? void 0 : outPayloads.forEach((payload) => assertEx(payload.schema, "observe: Missing Schema"));
|
|
74
|
+
const outPayloads = (0, import_assert.assertEx)(await this.observeHandler(inPayloads), "Trying to witness nothing");
|
|
75
|
+
outPayloads == null ? void 0 : outPayloads.forEach((payload) => (0, import_assert.assertEx)(payload.schema, "observe: Missing Schema"));
|
|
52
76
|
const archivist = await this.getArchivistInstance();
|
|
53
77
|
if (archivist) {
|
|
54
78
|
await archivist.insert(outPayloads);
|
|
@@ -62,13 +86,13 @@ var _AbstractWitness = class _AbstractWitness extends AbstractModuleInstance {
|
|
|
62
86
|
}
|
|
63
87
|
/** @function queryHandler Calls observe for an observe query. Override to support additional queries. */
|
|
64
88
|
async queryHandler(query, payloads, queryConfig) {
|
|
65
|
-
const wrapper = QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
89
|
+
const wrapper = import_boundwitness_builder.QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
66
90
|
const queryPayload = await wrapper.getQuery();
|
|
67
|
-
assertEx(this.queryable(query, payloads, queryConfig));
|
|
91
|
+
(0, import_assert.assertEx)(this.queryable(query, payloads, queryConfig));
|
|
68
92
|
const resultPayloads = [];
|
|
69
|
-
const filteredObservation = await PayloadHasher.filterExclude(payloads, query.query);
|
|
93
|
+
const filteredObservation = await import_hash.PayloadHasher.filterExclude(payloads, query.query);
|
|
70
94
|
switch (queryPayload.schema) {
|
|
71
|
-
case WitnessObserveQuerySchema: {
|
|
95
|
+
case import_witness_model.WitnessObserveQuerySchema: {
|
|
72
96
|
const observePayloads = await this.observe(filteredObservation);
|
|
73
97
|
resultPayloads.push(...observePayloads);
|
|
74
98
|
break;
|
|
@@ -82,10 +106,11 @@ var _AbstractWitness = class _AbstractWitness extends AbstractModuleInstance {
|
|
|
82
106
|
};
|
|
83
107
|
__name(_AbstractWitness, "AbstractWitness");
|
|
84
108
|
__publicField(_AbstractWitness, "configSchemas", [
|
|
85
|
-
WitnessConfigSchema
|
|
109
|
+
import_witness_model.WitnessConfigSchema
|
|
86
110
|
]);
|
|
87
111
|
var AbstractWitness = _AbstractWitness;
|
|
88
|
-
export
|
|
112
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
113
|
+
0 && (module.exports = {
|
|
89
114
|
AbstractWitness
|
|
90
|
-
};
|
|
91
|
-
//# sourceMappingURL=index.
|
|
115
|
+
});
|
|
116
|
+
//# sourceMappingURL=index.cjs.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 { Promisable } from '@xylabs/promise'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\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 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 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?: TIn[]): Promise<TOut[]> {\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)) 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;AAGzB,kCAAyC;AAEzC,kBAA8B;AAC9B,6BAAuC;AACvC,0BAAwE;AAExE,2BASO;IAEPA,qCAAAA;AACO,IAAeC,mBAAf,MAAeA,yBAUZC,8CAAAA;EAKAC;EAER,IAAIC,YAAY;AACd,WAAO,KAAKC,OAAOD;EACrB;EAEA,IAAaE,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAIE,YAAY;AA9ClB;AA+CI,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,YAAqC;AACjD,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;AAEpEK,+CAAaG,QAAQ,CAACC,gBAAYH,wBAASG,QAAQC,QAAQ,yBAAA;AAE3D,UAAMrB,YAAY,MAAM,KAAKM,qBAAoB;AACjD,QAAIN,WAAW;AACb,YAAMA,UAAUsB,OAAON,WAAAA;IACzB;AAEA,UAAM,KAAKF,KAAK,cAAc;MAAEH;MAAYI,QAAQ;MAAMC;IAAY,CAAA;AAEtE,WAAOA;EACT;;EAGA,MAAyBO,aACvBC,OACAC,UACAC,aACmC;AACnC,UAAMC,UAAUC,qDAAyBC,WAAyBL,OAAOC,QAAAA;AACzE,UAAMK,eAAe,MAAMH,QAAQI,SAAQ;AAC3Cd,gCAAS,KAAKe,UAAUR,OAAOC,UAAUC,WAAAA,CAAAA;AACzC,UAAMO,iBAA4B,CAAA;AAElC,UAAMC,sBAAuB,MAAMC,0BAAcC,cAAcX,UAAUD,MAAMA,KAAK;AACpF,YAAQM,aAAaT,QAAM;MACzB,KAAKlB,gDAA2B;AAC9B,cAAMkC,kBAAkB,MAAM,KAAK3B,QAAQwB,mBAAAA;AAC3CD,uBAAeK,KAAI,GAAID,eAAAA;AACvB;MACF;MACA,SAAS;AACP,eAAO,MAAMd,aAAaC,OAAOC,QAAAA;MACnC;IACF;AACA,WAAOQ;EACT;AAIF;AA7EUnC;AAGR,cAboBD,kBAaK0C,iBAA0B;EAACC;;AAb/C,IAAe3C,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","forEach","payload","schema","insert","queryHandler","query","payloads","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","queryPayload","getQuery","queryable","resultPayloads","filteredObservation","PayloadHasher","filterExclude","observePayloads","push","configSchemas","WitnessConfigSchema"]}
|
package/dist/node/index.js
CHANGED
|
@@ -1,51 +1,27 @@
|
|
|
1
|
-
"use strict";
|
|
2
1
|
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
2
|
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
7
3
|
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
4
|
var __publicField = (obj, key, value) => {
|
|
22
5
|
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
23
6
|
return value;
|
|
24
7
|
};
|
|
25
8
|
|
|
26
|
-
// src/index.ts
|
|
27
|
-
var src_exports = {};
|
|
28
|
-
__export(src_exports, {
|
|
29
|
-
AbstractWitness: () => AbstractWitness
|
|
30
|
-
});
|
|
31
|
-
module.exports = __toCommonJS(src_exports);
|
|
32
|
-
|
|
33
9
|
// src/AbstractWitness.ts
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
var _AbstractWitness = class _AbstractWitness extends
|
|
10
|
+
import { assertEx } from "@xylabs/assert";
|
|
11
|
+
import { QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-builder";
|
|
12
|
+
import { PayloadHasher } from "@xyo-network/hash";
|
|
13
|
+
import { AbstractModuleInstance } from "@xyo-network/module-abstract";
|
|
14
|
+
import { creatableModule } from "@xyo-network/module-model";
|
|
15
|
+
import { WitnessConfigSchema, WitnessObserveQuerySchema } from "@xyo-network/witness-model";
|
|
16
|
+
creatableModule();
|
|
17
|
+
var _AbstractWitness = class _AbstractWitness extends AbstractModuleInstance {
|
|
42
18
|
_archivistInstance;
|
|
43
19
|
get archivist() {
|
|
44
20
|
return this.config.archivist;
|
|
45
21
|
}
|
|
46
22
|
get queries() {
|
|
47
23
|
return [
|
|
48
|
-
|
|
24
|
+
WitnessObserveQuerySchema,
|
|
49
25
|
...super.queries
|
|
50
26
|
];
|
|
51
27
|
}
|
|
@@ -71,8 +47,8 @@ var _AbstractWitness = class _AbstractWitness extends import_module_abstract.Abs
|
|
|
71
47
|
inPayloads,
|
|
72
48
|
module: this
|
|
73
49
|
});
|
|
74
|
-
const outPayloads =
|
|
75
|
-
outPayloads == null ? void 0 : outPayloads.forEach((payload) =>
|
|
50
|
+
const outPayloads = assertEx(await this.observeHandler(inPayloads), "Trying to witness nothing");
|
|
51
|
+
outPayloads == null ? void 0 : outPayloads.forEach((payload) => assertEx(payload.schema, "observe: Missing Schema"));
|
|
76
52
|
const archivist = await this.getArchivistInstance();
|
|
77
53
|
if (archivist) {
|
|
78
54
|
await archivist.insert(outPayloads);
|
|
@@ -86,13 +62,13 @@ var _AbstractWitness = class _AbstractWitness extends import_module_abstract.Abs
|
|
|
86
62
|
}
|
|
87
63
|
/** @function queryHandler Calls observe for an observe query. Override to support additional queries. */
|
|
88
64
|
async queryHandler(query, payloads, queryConfig) {
|
|
89
|
-
const wrapper =
|
|
65
|
+
const wrapper = QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
90
66
|
const queryPayload = await wrapper.getQuery();
|
|
91
|
-
|
|
67
|
+
assertEx(this.queryable(query, payloads, queryConfig));
|
|
92
68
|
const resultPayloads = [];
|
|
93
|
-
const filteredObservation = await
|
|
69
|
+
const filteredObservation = await PayloadHasher.filterExclude(payloads, query.query);
|
|
94
70
|
switch (queryPayload.schema) {
|
|
95
|
-
case
|
|
71
|
+
case WitnessObserveQuerySchema: {
|
|
96
72
|
const observePayloads = await this.observe(filteredObservation);
|
|
97
73
|
resultPayloads.push(...observePayloads);
|
|
98
74
|
break;
|
|
@@ -106,11 +82,10 @@ var _AbstractWitness = class _AbstractWitness extends import_module_abstract.Abs
|
|
|
106
82
|
};
|
|
107
83
|
__name(_AbstractWitness, "AbstractWitness");
|
|
108
84
|
__publicField(_AbstractWitness, "configSchemas", [
|
|
109
|
-
|
|
85
|
+
WitnessConfigSchema
|
|
110
86
|
]);
|
|
111
87
|
var AbstractWitness = _AbstractWitness;
|
|
112
|
-
|
|
113
|
-
0 && (module.exports = {
|
|
88
|
+
export {
|
|
114
89
|
AbstractWitness
|
|
115
|
-
}
|
|
90
|
+
};
|
|
116
91
|
//# sourceMappingURL=index.js.map
|
package/dist/node/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/
|
|
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 { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\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 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 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?: TIn[]): Promise<TOut[]> {\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)) 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;AAGzB,SAASC,gCAAgC;AAEzC,SAASC,qBAAqB;AAC9B,SAASC,8BAA8B;AACvC,SAASC,uBAA+D;AAExE,SAEEC,qBAGAC,iCAIK;AAEPC,gBAAAA;AACO,IAAeC,mBAAf,MAAeA,yBAUZC,uBAAAA;EAKAC;EAER,IAAIC,YAAY;AACd,WAAO,KAAKC,OAAOD;EACrB;EAEA,IAAaE,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAIE,YAAY;AA9ClB;AA+CI,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,YAAqC;AACjD,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;AAEpEK,+CAAaG,QAAQ,CAACC,YAAYH,SAASG,QAAQC,QAAQ,yBAAA;AAE3D,UAAMrB,YAAY,MAAM,KAAKM,qBAAoB;AACjD,QAAIN,WAAW;AACb,YAAMA,UAAUsB,OAAON,WAAAA;IACzB;AAEA,UAAM,KAAKF,KAAK,cAAc;MAAEH;MAAYI,QAAQ;MAAMC;IAAY,CAAA;AAEtE,WAAOA;EACT;;EAGA,MAAyBO,aACvBC,OACAC,UACAC,aACmC;AACnC,UAAMC,UAAUC,yBAAyBC,WAAyBL,OAAOC,QAAAA;AACzE,UAAMK,eAAe,MAAMH,QAAQI,SAAQ;AAC3Cd,aAAS,KAAKe,UAAUR,OAAOC,UAAUC,WAAAA,CAAAA;AACzC,UAAMO,iBAA4B,CAAA;AAElC,UAAMC,sBAAuB,MAAMC,cAAcC,cAAcX,UAAUD,MAAMA,KAAK;AACpF,YAAQM,aAAaT,QAAM;MACzB,KAAKlB,2BAA2B;AAC9B,cAAMkC,kBAAkB,MAAM,KAAK3B,QAAQwB,mBAAAA;AAC3CD,uBAAeK,KAAI,GAAID,eAAAA;AACvB;MACF;MACA,SAAS;AACP,eAAO,MAAMd,aAAaC,OAAOC,QAAAA;MACnC;IACF;AACA,WAAOQ;EACT;AAIF;AA7EUnC;AAGR,cAboBD,kBAaK0C,iBAA0B;EAACC;;AAb/C,IAAe3C,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","forEach","payload","schema","insert","queryHandler","query","payloads","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","queryPayload","getQuery","queryable","resultPayloads","filteredObservation","PayloadHasher","filterExclude","observePayloads","push","configSchemas","WitnessConfigSchema"]}
|
package/package.json
CHANGED
|
@@ -12,22 +12,21 @@
|
|
|
12
12
|
"dependencies": {
|
|
13
13
|
"@xylabs/assert": "^2.13.20",
|
|
14
14
|
"@xylabs/promise": "^2.13.20",
|
|
15
|
-
"@xyo-network/archivist-model": "~2.84.
|
|
16
|
-
"@xyo-network/boundwitness-builder": "~2.84.
|
|
17
|
-
"@xyo-network/boundwitness-model": "~2.84.
|
|
18
|
-
"@xyo-network/hash": "~2.84.
|
|
19
|
-
"@xyo-network/module-abstract": "~2.84.
|
|
20
|
-
"@xyo-network/module-model": "~2.84.
|
|
21
|
-
"@xyo-network/payload-model": "~2.84.
|
|
22
|
-
"@xyo-network/witness-model": "~2.84.
|
|
15
|
+
"@xyo-network/archivist-model": "~2.84.4",
|
|
16
|
+
"@xyo-network/boundwitness-builder": "~2.84.4",
|
|
17
|
+
"@xyo-network/boundwitness-model": "~2.84.4",
|
|
18
|
+
"@xyo-network/hash": "~2.84.4",
|
|
19
|
+
"@xyo-network/module-abstract": "~2.84.4",
|
|
20
|
+
"@xyo-network/module-model": "~2.84.4",
|
|
21
|
+
"@xyo-network/payload-model": "~2.84.4",
|
|
22
|
+
"@xyo-network/witness-model": "~2.84.4"
|
|
23
23
|
},
|
|
24
24
|
"devDependencies": {
|
|
25
|
-
"@xylabs/ts-scripts-yarn3": "^3.2.
|
|
26
|
-
"@xylabs/tsconfig": "^3.2.
|
|
25
|
+
"@xylabs/ts-scripts-yarn3": "^3.2.19",
|
|
26
|
+
"@xylabs/tsconfig": "^3.2.19",
|
|
27
27
|
"typescript": "^5.3.3"
|
|
28
28
|
},
|
|
29
29
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
30
|
-
"docs": "dist/docs.json",
|
|
31
30
|
"types": "dist/node/index.d.ts",
|
|
32
31
|
"exports": {
|
|
33
32
|
".": {
|
|
@@ -43,19 +42,19 @@
|
|
|
43
42
|
},
|
|
44
43
|
"node": {
|
|
45
44
|
"require": {
|
|
46
|
-
"types": "./dist/node/index.d.
|
|
47
|
-
"default": "./dist/node/index.
|
|
45
|
+
"types": "./dist/node/index.d.cts",
|
|
46
|
+
"default": "./dist/node/index.cjs"
|
|
48
47
|
},
|
|
49
48
|
"import": {
|
|
50
49
|
"types": "./dist/node/index.d.mts",
|
|
51
|
-
"default": "./dist/node/index.
|
|
50
|
+
"default": "./dist/node/index.js"
|
|
52
51
|
}
|
|
53
52
|
}
|
|
54
53
|
},
|
|
55
54
|
"./package.json": "./package.json"
|
|
56
55
|
},
|
|
57
|
-
"main": "dist/node/index.
|
|
58
|
-
"module": "dist/node/index.
|
|
56
|
+
"main": "dist/node/index.cjs",
|
|
57
|
+
"module": "dist/node/index.js",
|
|
59
58
|
"homepage": "https://xyo.network",
|
|
60
59
|
"license": "LGPL-3.0-only",
|
|
61
60
|
"publishConfig": {
|
|
@@ -66,5 +65,6 @@
|
|
|
66
65
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
67
66
|
},
|
|
68
67
|
"sideEffects": false,
|
|
69
|
-
"version": "2.84.
|
|
68
|
+
"version": "2.84.4",
|
|
69
|
+
"type": "module"
|
|
70
70
|
}
|
package/dist/node/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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 { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { creatableModule, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\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 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 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?: TIn[]): Promise<TOut[]> {\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)) 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;AAGzB,SAASC,gCAAgC;AAEzC,SAASC,qBAAqB;AAC9B,SAASC,8BAA8B;AACvC,SAASC,uBAA+D;AAExE,SAEEC,qBAGAC,iCAIK;AAEPC,gBAAAA;AACO,IAAeC,mBAAf,MAAeA,yBAUZC,uBAAAA;EAKAC;EAER,IAAIC,YAAY;AACd,WAAO,KAAKC,OAAOD;EACrB;EAEA,IAAaE,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAIE,YAAY;AA9ClB;AA+CI,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,YAAqC;AACjD,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;AAEpEK,+CAAaG,QAAQ,CAACC,YAAYH,SAASG,QAAQC,QAAQ,yBAAA;AAE3D,UAAMrB,YAAY,MAAM,KAAKM,qBAAoB;AACjD,QAAIN,WAAW;AACb,YAAMA,UAAUsB,OAAON,WAAAA;IACzB;AAEA,UAAM,KAAKF,KAAK,cAAc;MAAEH;MAAYI,QAAQ;MAAMC;IAAY,CAAA;AAEtE,WAAOA;EACT;;EAGA,MAAyBO,aACvBC,OACAC,UACAC,aACmC;AACnC,UAAMC,UAAUC,yBAAyBC,WAAyBL,OAAOC,QAAAA;AACzE,UAAMK,eAAe,MAAMH,QAAQI,SAAQ;AAC3Cd,aAAS,KAAKe,UAAUR,OAAOC,UAAUC,WAAAA,CAAAA;AACzC,UAAMO,iBAA4B,CAAA;AAElC,UAAMC,sBAAuB,MAAMC,cAAcC,cAAcX,UAAUD,MAAMA,KAAK;AACpF,YAAQM,aAAaT,QAAM;MACzB,KAAKlB,2BAA2B;AAC9B,cAAMkC,kBAAkB,MAAM,KAAK3B,QAAQwB,mBAAAA;AAC3CD,uBAAeK,KAAI,GAAID,eAAAA;AACvB;MACF;MACA,SAAS;AACP,eAAO,MAAMd,aAAaC,OAAOC,QAAAA;MACnC;IACF;AACA,WAAOQ;EACT;AAIF;AA7EUnC;AAGR,cAboBD,kBAaK0C,iBAA0B;EAACC;;AAb/C,IAAe3C,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","forEach","payload","schema","insert","queryHandler","query","payloads","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","queryPayload","getQuery","queryable","resultPayloads","filteredObservation","PayloadHasher","filterExclude","observePayloads","push","configSchemas","WitnessConfigSchema"]}
|