@xyo-network/sentinel 2.75.0 → 2.75.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.
Files changed (72) hide show
  1. package/dist/browser/AbstractSentinel.d.cts +22 -0
  2. package/dist/browser/AbstractSentinel.d.cts.map +1 -0
  3. package/dist/browser/AbstractSentinel.js +2 -3
  4. package/dist/browser/AbstractSentinel.js.map +1 -1
  5. package/dist/browser/Automation.d.cts +28 -0
  6. package/dist/browser/Automation.d.cts.map +1 -0
  7. package/dist/browser/Automation.js +1 -2
  8. package/dist/browser/Automation.js.map +1 -1
  9. package/dist/browser/MemorySentinel.d.cts +10 -0
  10. package/dist/browser/MemorySentinel.d.cts.map +1 -0
  11. package/dist/browser/MemorySentinel.js +6 -99
  12. package/dist/browser/MemorySentinel.js.map +1 -1
  13. package/dist/browser/SentinelIntervalAutomationWrapper.d.cts +11 -0
  14. package/dist/browser/SentinelIntervalAutomationWrapper.d.cts.map +1 -0
  15. package/dist/browser/SentinelIntervalAutomationWrapper.js +2 -3
  16. package/dist/browser/SentinelIntervalAutomationWrapper.js.map +1 -1
  17. package/dist/browser/SentinelRunner.d.cts +24 -0
  18. package/dist/browser/SentinelRunner.d.cts.map +1 -0
  19. package/dist/browser/SentinelRunner.js +4 -50
  20. package/dist/browser/SentinelRunner.js.map +1 -1
  21. package/dist/browser/Wrapper.d.cts +14 -0
  22. package/dist/browser/Wrapper.d.cts.map +1 -0
  23. package/dist/browser/Wrapper.js +2 -3
  24. package/dist/browser/Wrapper.js.map +1 -1
  25. package/dist/browser/index.d.cts +8 -0
  26. package/dist/browser/index.d.cts.map +1 -0
  27. package/dist/browser/index.js +6 -296
  28. package/dist/browser/index.js.map +1 -1
  29. package/dist/docs.json +63876 -0
  30. package/dist/node/AbstractSentinel.d.cts +22 -0
  31. package/dist/node/AbstractSentinel.d.cts.map +1 -0
  32. package/dist/node/AbstractSentinel.js +19 -13
  33. package/dist/node/AbstractSentinel.js.map +1 -1
  34. package/dist/node/AbstractSentinel.mjs +18 -13
  35. package/dist/node/AbstractSentinel.mjs.map +1 -1
  36. package/dist/node/Automation.d.cts +28 -0
  37. package/dist/node/Automation.d.cts.map +1 -0
  38. package/dist/node/Automation.js +3 -1
  39. package/dist/node/Automation.js.map +1 -1
  40. package/dist/node/Automation.mjs +2 -1
  41. package/dist/node/Automation.mjs.map +1 -1
  42. package/dist/node/MemorySentinel.d.cts +10 -0
  43. package/dist/node/MemorySentinel.d.cts.map +1 -0
  44. package/dist/node/MemorySentinel.js +104 -8
  45. package/dist/node/MemorySentinel.js.map +1 -1
  46. package/dist/node/MemorySentinel.mjs +104 -7
  47. package/dist/node/MemorySentinel.mjs.map +1 -1
  48. package/dist/node/SentinelIntervalAutomationWrapper.d.cts +11 -0
  49. package/dist/node/SentinelIntervalAutomationWrapper.d.cts.map +1 -0
  50. package/dist/node/SentinelIntervalAutomationWrapper.js +4 -2
  51. package/dist/node/SentinelIntervalAutomationWrapper.js.map +1 -1
  52. package/dist/node/SentinelIntervalAutomationWrapper.mjs +3 -2
  53. package/dist/node/SentinelIntervalAutomationWrapper.mjs.map +1 -1
  54. package/dist/node/SentinelRunner.d.cts +24 -0
  55. package/dist/node/SentinelRunner.d.cts.map +1 -0
  56. package/dist/node/SentinelRunner.js +56 -8
  57. package/dist/node/SentinelRunner.js.map +1 -1
  58. package/dist/node/SentinelRunner.mjs +54 -7
  59. package/dist/node/SentinelRunner.mjs.map +1 -1
  60. package/dist/node/Wrapper.d.cts +14 -0
  61. package/dist/node/Wrapper.d.cts.map +1 -0
  62. package/dist/node/Wrapper.js +4 -2
  63. package/dist/node/Wrapper.js.map +1 -1
  64. package/dist/node/Wrapper.mjs +3 -2
  65. package/dist/node/Wrapper.mjs.map +1 -1
  66. package/dist/node/index.d.cts +8 -0
  67. package/dist/node/index.d.cts.map +1 -0
  68. package/dist/node/index.js +305 -12
  69. package/dist/node/index.js.map +1 -1
  70. package/dist/node/index.mjs +301 -6
  71. package/dist/node/index.mjs.map +1 -1
  72. package/package.json +17 -17
@@ -0,0 +1,22 @@
1
+ import { AbstractArchivingModule } from '@xyo-network/archivist';
2
+ import { QueryBoundWitness } from '@xyo-network/boundwitness-builder';
3
+ import { BoundWitness } from '@xyo-network/boundwitness-model';
4
+ import { ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module';
5
+ import { Payload } from '@xyo-network/payload-model';
6
+ import { CustomSentinelInstance, SentinelInstance, SentinelModuleEventData, SentinelParams, SentinelQueryBase } from '@xyo-network/sentinel-model';
7
+ import { WitnessInstance } from '@xyo-network/witness';
8
+ export declare abstract class AbstractSentinel<TParams extends SentinelParams = SentinelParams, TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>> extends AbstractArchivingModule<TParams, TEventData> implements CustomSentinelInstance<TParams, TEventData> {
9
+ history: BoundWitness[];
10
+ get queries(): string[];
11
+ protected get _queryAccountPaths(): Record<SentinelQueryBase['schema'], string>;
12
+ addArchivist(address: string[]): void;
13
+ addWitness(address: string[]): void;
14
+ archivists(): Promise<import("@xyo-network/archivist").ArchivistInstance[]>;
15
+ removeArchivist(address: string[]): void;
16
+ removeWitness(address: string[]): void;
17
+ report(inPayloads?: Payload[]): Promise<Payload[]>;
18
+ witnesses(): Promise<WitnessInstance[]>;
19
+ protected queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(query: T, payloads?: Payload[], queryConfig?: TConfig): Promise<ModuleQueryHandlerResult>;
20
+ abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>;
21
+ }
22
+ //# sourceMappingURL=AbstractSentinel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AbstractSentinel.d.ts","sourceRoot":"","sources":["../../src/AbstractSentinel.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,uBAAuB,EAAuB,MAAM,wBAAwB,CAAA;AACrF,OAAO,EAAE,iBAAiB,EAA4B,MAAM,mCAAmC,CAAA;AAC/F,OAAO,EAAE,YAAY,EAAmC,MAAM,iCAAiC,CAAA;AAC/F,OAAO,EAAE,YAAY,EAAE,wBAAwB,EAAE,MAAM,qBAAqB,CAAA;AAC5E,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EACL,sBAAsB,EACtB,gBAAgB,EAChB,uBAAuB,EACvB,cAAc,EACd,iBAAiB,EAElB,MAAM,6BAA6B,CAAA;AACpC,OAAO,EAAqB,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAEzE,8BAAsB,gBAAgB,CAClC,OAAO,SAAS,cAAc,GAAG,cAAc,EAC/C,UAAU,SAAS,uBAAuB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,GAAG,uBAAuB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAE5H,SAAQ,uBAAuB,CAAC,OAAO,EAAE,UAAU,CACnD,YAAW,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAAC;IAEtD,OAAO,EAAE,YAAY,EAAE,CAAK;IAE5B,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,cAAuB,kBAAkB,IAAI,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAIvF;IAED,YAAY,CAAC,OAAO,EAAE,MAAM,EAAE;IAI9B,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE;IAItB,UAAU;IAsBhB,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE;IAIjC,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE;IAIzB,MAAM,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAYlD,SAAS;cAyBU,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;IAiBpC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CACjE"}
@@ -16,6 +16,8 @@ var __copyProps = (to, from, except, desc) => {
16
16
  return to;
17
17
  };
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/AbstractSentinel.ts
19
21
  var AbstractSentinel_exports = {};
20
22
  __export(AbstractSentinel_exports, {
21
23
  AbstractSentinel: () => AbstractSentinel
@@ -28,7 +30,7 @@ var import_boundwitness_builder = require("@xyo-network/boundwitness-builder");
28
30
  var import_boundwitness_model = require("@xyo-network/boundwitness-model");
29
31
  var import_sentinel_model = require("@xyo-network/sentinel-model");
30
32
  var import_witness = require("@xyo-network/witness");
31
- class AbstractSentinel extends import_archivist.AbstractArchivingModule {
33
+ var AbstractSentinel = class extends import_archivist.AbstractArchivingModule {
32
34
  history = [];
33
35
  get queries() {
34
36
  return [import_sentinel_model.SentinelReportQuerySchema, ...super.queries];
@@ -45,17 +47,18 @@ class AbstractSentinel extends import_archivist.AbstractArchivingModule {
45
47
  this.config.witnesses = (0, import_lodash.uniq)([...address, ...this.config.witnesses ?? []]);
46
48
  }
47
49
  async archivists() {
48
- this.logger?.debug(`archivists:config:archivist: ${this.config?.archivists?.length}`);
49
- const namesOrAddresses = this.config?.archivists ? Array.isArray(this.config.archivists) ? this.config?.archivists : [this.config.archivists] : void 0;
50
- this.logger?.debug(`archivist:namesOrAddresses: ${namesOrAddresses?.length}`);
50
+ var _a, _b, _c, _d, _e, _f, _g, _h;
51
+ (_c = this.logger) == null ? void 0 : _c.debug(`archivists:config:archivist: ${(_b = (_a = this.config) == null ? void 0 : _a.archivists) == null ? void 0 : _b.length}`);
52
+ const namesOrAddresses = ((_d = this.config) == null ? void 0 : _d.archivists) ? Array.isArray(this.config.archivists) ? (_e = this.config) == null ? void 0 : _e.archivists : [this.config.archivists] : void 0;
53
+ (_f = this.logger) == null ? void 0 : _f.debug(`archivist:namesOrAddresses: ${namesOrAddresses == null ? void 0 : namesOrAddresses.length}`);
51
54
  const result = [
52
55
  ...await this.resolve(namesOrAddresses ? { address: namesOrAddresses } : void 0),
53
56
  ...await this.resolve(namesOrAddresses ? { name: namesOrAddresses } : void 0)
54
57
  ].map((module2) => (0, import_assert.assertEx)((0, import_archivist.asArchivistInstance)(module2), "Tried to resolve a non-archivist as an archivist"));
55
58
  if (namesOrAddresses && namesOrAddresses.length !== result.length) {
56
- this.logger?.warn(`Not all archivists found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`);
59
+ (_g = this.logger) == null ? void 0 : _g.warn(`Not all archivists found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`);
57
60
  }
58
- this.logger?.debug(`archivists:result: ${result?.length}`);
61
+ (_h = this.logger) == null ? void 0 : _h.debug(`archivists:result: ${result == null ? void 0 : result.length}`);
59
62
  return result;
60
63
  }
61
64
  removeArchivist(address) {
@@ -65,10 +68,11 @@ class AbstractSentinel extends import_archivist.AbstractArchivingModule {
65
68
  this.config.witnesses = (this.config.witnesses ?? []).filter((witness) => !address.includes(witness));
66
69
  }
67
70
  async report(inPayloads) {
71
+ var _a;
68
72
  this._noOverride("report");
69
73
  await this.emit("reportStart", { inPayloads, module: this });
70
74
  const payloads = await this.reportHandler(inPayloads);
71
- this.logger?.debug(`report:payloads: ${JSON.stringify(payloads, null, 2)}`);
75
+ (_a = this.logger) == null ? void 0 : _a.debug(`report:payloads: ${JSON.stringify(payloads, null, 2)}`);
72
76
  const outPayloads = payloads.filter(import_boundwitness_model.notBoundWitness);
73
77
  const boundwitnesses = payloads.filter(import_boundwitness_model.isBoundWitness);
74
78
  const boundwitness = boundwitnesses.find((bw) => bw.addresses.includes(this.address));
@@ -76,18 +80,20 @@ class AbstractSentinel extends import_archivist.AbstractArchivingModule {
76
80
  return payloads;
77
81
  }
78
82
  async witnesses() {
79
- this.logger?.debug(`witnesses:config:witnesses: ${this.config?.witnesses?.length}`);
80
- const namesOrAddresses = this.config?.witnesses ? Array.isArray(this.config.witnesses) ? this.config?.witnesses : [this.config.witnesses] : void 0;
81
- this.logger?.debug(`witnesses:namesOrAddresses: ${namesOrAddresses?.length}`);
83
+ var _a, _b, _c, _d, _e, _f, _g;
84
+ (_c = this.logger) == null ? void 0 : _c.debug(`witnesses:config:witnesses: ${(_b = (_a = this.config) == null ? void 0 : _a.witnesses) == null ? void 0 : _b.length}`);
85
+ const namesOrAddresses = ((_d = this.config) == null ? void 0 : _d.witnesses) ? Array.isArray(this.config.witnesses) ? (_e = this.config) == null ? void 0 : _e.witnesses : [this.config.witnesses] : void 0;
86
+ (_f = this.logger) == null ? void 0 : _f.debug(`witnesses:namesOrAddresses: ${namesOrAddresses == null ? void 0 : namesOrAddresses.length}`);
82
87
  const result = namesOrAddresses ? [
83
88
  ...await this.resolve({ address: namesOrAddresses }, { identity: import_witness.isWitnessInstance }),
84
89
  ...await this.resolve({ name: namesOrAddresses }, { identity: import_witness.isWitnessInstance })
85
90
  ] : await this.resolve(void 0, { identity: import_witness.isWitnessInstance });
86
91
  if (namesOrAddresses && namesOrAddresses.length !== result.length) {
87
- this.logger?.warn(`Not all witnesses found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`);
92
+ (_g = this.logger) == null ? void 0 : _g.warn(`Not all witnesses found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`);
88
93
  }
89
94
  result.map((item) => {
90
- this.logger?.debug(`witnesses:result: ${item.config.schema}`);
95
+ var _a2;
96
+ (_a2 = this.logger) == null ? void 0 : _a2.debug(`witnesses:result: ${item.config.schema}`);
91
97
  });
92
98
  return result;
93
99
  }
@@ -107,7 +113,7 @@ class AbstractSentinel extends import_archivist.AbstractArchivingModule {
107
113
  }
108
114
  return resultPayloads;
109
115
  }
110
- }
116
+ };
111
117
  // Annotate the CommonJS export names for ESM import in node:
112
118
  0 && (module.exports = {
113
119
  AbstractSentinel
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/AbstractSentinel.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { uniq } from '@xylabs/lodash'\nimport { AbstractArchivingModule, asArchivistInstance } from '@xyo-network/archivist'\nimport { QueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitness, notBoundWitness } from '@xyo-network/boundwitness-model'\nimport { ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomSentinelInstance,\n SentinelInstance,\n SentinelModuleEventData,\n SentinelParams,\n SentinelQueryBase,\n SentinelReportQuerySchema,\n} from '@xyo-network/sentinel-model'\nimport { isWitnessInstance, WitnessInstance } from '@xyo-network/witness'\n\nexport abstract class AbstractSentinel<\n TParams extends SentinelParams = SentinelParams,\n TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>,\n >\n extends AbstractArchivingModule<TParams, TEventData>\n implements CustomSentinelInstance<TParams, TEventData>\n{\n history: BoundWitness[] = []\n\n override get queries(): string[] {\n return [SentinelReportQuerySchema, ...super.queries]\n }\n\n protected override get _queryAccountPaths(): Record<SentinelQueryBase['schema'], string> {\n return {\n 'network.xyo.query.sentinel.report': '1/1',\n }\n }\n\n addArchivist(address: string[]) {\n this.config.archivists = uniq([...address, ...(this.config.archivists ?? [])])\n }\n\n addWitness(address: string[]) {\n this.config.witnesses = uniq([...address, ...(this.config.witnesses ?? [])])\n }\n\n async archivists() {\n this.logger?.debug(`archivists:config:archivist: ${this.config?.archivists?.length}`)\n const namesOrAddresses = this.config?.archivists\n ? Array.isArray(this.config.archivists)\n ? this.config?.archivists\n : [this.config.archivists]\n : undefined\n this.logger?.debug(`archivist:namesOrAddresses: ${namesOrAddresses?.length}`)\n const result = [\n ...(await this.resolve(namesOrAddresses ? { address: namesOrAddresses } : undefined)),\n ...(await this.resolve(namesOrAddresses ? { name: namesOrAddresses } : undefined)),\n ].map((module) => assertEx(asArchivistInstance(module), 'Tried to resolve a non-archivist as an archivist'))\n\n if (namesOrAddresses && namesOrAddresses.length !== result.length) {\n this.logger?.warn(`Not all archivists found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`)\n }\n\n this.logger?.debug(`archivists:result: ${result?.length}`)\n\n return result\n }\n\n removeArchivist(address: string[]) {\n this.config.archivists = (this.config.archivists ?? []).filter((archivist) => !address.includes(archivist))\n }\n\n removeWitness(address: string[]) {\n this.config.witnesses = (this.config.witnesses ?? []).filter((witness) => !address.includes(witness))\n }\n\n async report(inPayloads?: Payload[]): Promise<Payload[]> {\n this._noOverride('report')\n await this.emit('reportStart', { inPayloads, module: this })\n const payloads = await this.reportHandler(inPayloads)\n this.logger?.debug(`report:payloads: ${JSON.stringify(payloads, null, 2)}`)\n const outPayloads = payloads.filter(notBoundWitness)\n const boundwitnesses = payloads.filter(isBoundWitness)\n const boundwitness = boundwitnesses.find((bw) => bw.addresses.includes(this.address))\n await this.emit('reportEnd', { boundwitness, inPayloads, module: this, outPayloads })\n return payloads\n }\n\n async witnesses() {\n this.logger?.debug(`witnesses:config:witnesses: ${this.config?.witnesses?.length}`)\n const namesOrAddresses = this.config?.witnesses\n ? Array.isArray(this.config.witnesses)\n ? this.config?.witnesses\n : [this.config.witnesses]\n : undefined\n this.logger?.debug(`witnesses:namesOrAddresses: ${namesOrAddresses?.length}`)\n const result = namesOrAddresses\n ? [\n ...(await this.resolve<WitnessInstance>({ address: namesOrAddresses }, { identity: isWitnessInstance })),\n ...(await this.resolve<WitnessInstance>({ name: namesOrAddresses }, { identity: isWitnessInstance })),\n ]\n : await this.resolve<WitnessInstance>(undefined, { identity: isWitnessInstance })\n\n if (namesOrAddresses && namesOrAddresses.length !== result.length) {\n this.logger?.warn(`Not all witnesses found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`)\n }\n result.map((item) => {\n this.logger?.debug(`witnesses:result: ${item.config.schema}`)\n })\n\n return result\n }\n\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<SentinelQueryBase>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case SentinelReportQuerySchema: {\n resultPayloads.push(...(await this.report(payloads)))\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return resultPayloads\n }\n\n abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>\n}\n"],"mappings":"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","names":["module"]}
1
+ {"version":3,"sources":["../../src/AbstractSentinel.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { uniq } from '@xylabs/lodash'\nimport { AbstractArchivingModule, asArchivistInstance } from '@xyo-network/archivist'\nimport { QueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitness, notBoundWitness } from '@xyo-network/boundwitness-model'\nimport { ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomSentinelInstance,\n SentinelInstance,\n SentinelModuleEventData,\n SentinelParams,\n SentinelQueryBase,\n SentinelReportQuerySchema,\n} from '@xyo-network/sentinel-model'\nimport { isWitnessInstance, WitnessInstance } from '@xyo-network/witness'\n\nexport abstract class AbstractSentinel<\n TParams extends SentinelParams = SentinelParams,\n TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>,\n >\n extends AbstractArchivingModule<TParams, TEventData>\n implements CustomSentinelInstance<TParams, TEventData>\n{\n history: BoundWitness[] = []\n\n override get queries(): string[] {\n return [SentinelReportQuerySchema, ...super.queries]\n }\n\n protected override get _queryAccountPaths(): Record<SentinelQueryBase['schema'], string> {\n return {\n 'network.xyo.query.sentinel.report': '1/1',\n }\n }\n\n addArchivist(address: string[]) {\n this.config.archivists = uniq([...address, ...(this.config.archivists ?? [])])\n }\n\n addWitness(address: string[]) {\n this.config.witnesses = uniq([...address, ...(this.config.witnesses ?? [])])\n }\n\n async archivists() {\n this.logger?.debug(`archivists:config:archivist: ${this.config?.archivists?.length}`)\n const namesOrAddresses = this.config?.archivists\n ? Array.isArray(this.config.archivists)\n ? this.config?.archivists\n : [this.config.archivists]\n : undefined\n this.logger?.debug(`archivist:namesOrAddresses: ${namesOrAddresses?.length}`)\n const result = [\n ...(await this.resolve(namesOrAddresses ? { address: namesOrAddresses } : undefined)),\n ...(await this.resolve(namesOrAddresses ? { name: namesOrAddresses } : undefined)),\n ].map((module) => assertEx(asArchivistInstance(module), 'Tried to resolve a non-archivist as an archivist'))\n\n if (namesOrAddresses && namesOrAddresses.length !== result.length) {\n this.logger?.warn(`Not all archivists found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`)\n }\n\n this.logger?.debug(`archivists:result: ${result?.length}`)\n\n return result\n }\n\n removeArchivist(address: string[]) {\n this.config.archivists = (this.config.archivists ?? []).filter((archivist) => !address.includes(archivist))\n }\n\n removeWitness(address: string[]) {\n this.config.witnesses = (this.config.witnesses ?? []).filter((witness) => !address.includes(witness))\n }\n\n async report(inPayloads?: Payload[]): Promise<Payload[]> {\n this._noOverride('report')\n await this.emit('reportStart', { inPayloads, module: this })\n const payloads = await this.reportHandler(inPayloads)\n this.logger?.debug(`report:payloads: ${JSON.stringify(payloads, null, 2)}`)\n const outPayloads = payloads.filter(notBoundWitness)\n const boundwitnesses = payloads.filter(isBoundWitness)\n const boundwitness = boundwitnesses.find((bw) => bw.addresses.includes(this.address))\n await this.emit('reportEnd', { boundwitness, inPayloads, module: this, outPayloads })\n return payloads\n }\n\n async witnesses() {\n this.logger?.debug(`witnesses:config:witnesses: ${this.config?.witnesses?.length}`)\n const namesOrAddresses = this.config?.witnesses\n ? Array.isArray(this.config.witnesses)\n ? this.config?.witnesses\n : [this.config.witnesses]\n : undefined\n this.logger?.debug(`witnesses:namesOrAddresses: ${namesOrAddresses?.length}`)\n const result = namesOrAddresses\n ? [\n ...(await this.resolve<WitnessInstance>({ address: namesOrAddresses }, { identity: isWitnessInstance })),\n ...(await this.resolve<WitnessInstance>({ name: namesOrAddresses }, { identity: isWitnessInstance })),\n ]\n : await this.resolve<WitnessInstance>(undefined, { identity: isWitnessInstance })\n\n if (namesOrAddresses && namesOrAddresses.length !== result.length) {\n this.logger?.warn(`Not all witnesses found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`)\n }\n result.map((item) => {\n this.logger?.debug(`witnesses:result: ${item.config.schema}`)\n })\n\n return result\n }\n\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<SentinelQueryBase>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case SentinelReportQuerySchema: {\n resultPayloads.push(...(await this.report(payloads)))\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return resultPayloads\n }\n\n abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>\n}\n"],"mappings":"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","names":["module","_a"]}
@@ -1,3 +1,4 @@
1
+ // src/AbstractSentinel.ts
1
2
  import { assertEx } from "@xylabs/assert";
2
3
  import { uniq } from "@xylabs/lodash";
3
4
  import { AbstractArchivingModule, asArchivistInstance } from "@xyo-network/archivist";
@@ -7,7 +8,7 @@ import {
7
8
  SentinelReportQuerySchema
8
9
  } from "@xyo-network/sentinel-model";
9
10
  import { isWitnessInstance } from "@xyo-network/witness";
10
- class AbstractSentinel extends AbstractArchivingModule {
11
+ var AbstractSentinel = class extends AbstractArchivingModule {
11
12
  history = [];
12
13
  get queries() {
13
14
  return [SentinelReportQuerySchema, ...super.queries];
@@ -24,17 +25,18 @@ class AbstractSentinel extends AbstractArchivingModule {
24
25
  this.config.witnesses = uniq([...address, ...this.config.witnesses ?? []]);
25
26
  }
26
27
  async archivists() {
27
- this.logger?.debug(`archivists:config:archivist: ${this.config?.archivists?.length}`);
28
- const namesOrAddresses = this.config?.archivists ? Array.isArray(this.config.archivists) ? this.config?.archivists : [this.config.archivists] : void 0;
29
- this.logger?.debug(`archivist:namesOrAddresses: ${namesOrAddresses?.length}`);
28
+ var _a, _b, _c, _d, _e, _f, _g, _h;
29
+ (_c = this.logger) == null ? void 0 : _c.debug(`archivists:config:archivist: ${(_b = (_a = this.config) == null ? void 0 : _a.archivists) == null ? void 0 : _b.length}`);
30
+ const namesOrAddresses = ((_d = this.config) == null ? void 0 : _d.archivists) ? Array.isArray(this.config.archivists) ? (_e = this.config) == null ? void 0 : _e.archivists : [this.config.archivists] : void 0;
31
+ (_f = this.logger) == null ? void 0 : _f.debug(`archivist:namesOrAddresses: ${namesOrAddresses == null ? void 0 : namesOrAddresses.length}`);
30
32
  const result = [
31
33
  ...await this.resolve(namesOrAddresses ? { address: namesOrAddresses } : void 0),
32
34
  ...await this.resolve(namesOrAddresses ? { name: namesOrAddresses } : void 0)
33
35
  ].map((module) => assertEx(asArchivistInstance(module), "Tried to resolve a non-archivist as an archivist"));
34
36
  if (namesOrAddresses && namesOrAddresses.length !== result.length) {
35
- this.logger?.warn(`Not all archivists found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`);
37
+ (_g = this.logger) == null ? void 0 : _g.warn(`Not all archivists found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`);
36
38
  }
37
- this.logger?.debug(`archivists:result: ${result?.length}`);
39
+ (_h = this.logger) == null ? void 0 : _h.debug(`archivists:result: ${result == null ? void 0 : result.length}`);
38
40
  return result;
39
41
  }
40
42
  removeArchivist(address) {
@@ -44,10 +46,11 @@ class AbstractSentinel extends AbstractArchivingModule {
44
46
  this.config.witnesses = (this.config.witnesses ?? []).filter((witness) => !address.includes(witness));
45
47
  }
46
48
  async report(inPayloads) {
49
+ var _a;
47
50
  this._noOverride("report");
48
51
  await this.emit("reportStart", { inPayloads, module: this });
49
52
  const payloads = await this.reportHandler(inPayloads);
50
- this.logger?.debug(`report:payloads: ${JSON.stringify(payloads, null, 2)}`);
53
+ (_a = this.logger) == null ? void 0 : _a.debug(`report:payloads: ${JSON.stringify(payloads, null, 2)}`);
51
54
  const outPayloads = payloads.filter(notBoundWitness);
52
55
  const boundwitnesses = payloads.filter(isBoundWitness);
53
56
  const boundwitness = boundwitnesses.find((bw) => bw.addresses.includes(this.address));
@@ -55,18 +58,20 @@ class AbstractSentinel extends AbstractArchivingModule {
55
58
  return payloads;
56
59
  }
57
60
  async witnesses() {
58
- this.logger?.debug(`witnesses:config:witnesses: ${this.config?.witnesses?.length}`);
59
- const namesOrAddresses = this.config?.witnesses ? Array.isArray(this.config.witnesses) ? this.config?.witnesses : [this.config.witnesses] : void 0;
60
- this.logger?.debug(`witnesses:namesOrAddresses: ${namesOrAddresses?.length}`);
61
+ var _a, _b, _c, _d, _e, _f, _g;
62
+ (_c = this.logger) == null ? void 0 : _c.debug(`witnesses:config:witnesses: ${(_b = (_a = this.config) == null ? void 0 : _a.witnesses) == null ? void 0 : _b.length}`);
63
+ const namesOrAddresses = ((_d = this.config) == null ? void 0 : _d.witnesses) ? Array.isArray(this.config.witnesses) ? (_e = this.config) == null ? void 0 : _e.witnesses : [this.config.witnesses] : void 0;
64
+ (_f = this.logger) == null ? void 0 : _f.debug(`witnesses:namesOrAddresses: ${namesOrAddresses == null ? void 0 : namesOrAddresses.length}`);
61
65
  const result = namesOrAddresses ? [
62
66
  ...await this.resolve({ address: namesOrAddresses }, { identity: isWitnessInstance }),
63
67
  ...await this.resolve({ name: namesOrAddresses }, { identity: isWitnessInstance })
64
68
  ] : await this.resolve(void 0, { identity: isWitnessInstance });
65
69
  if (namesOrAddresses && namesOrAddresses.length !== result.length) {
66
- this.logger?.warn(`Not all witnesses found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`);
70
+ (_g = this.logger) == null ? void 0 : _g.warn(`Not all witnesses found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`);
67
71
  }
68
72
  result.map((item) => {
69
- this.logger?.debug(`witnesses:result: ${item.config.schema}`);
73
+ var _a2;
74
+ (_a2 = this.logger) == null ? void 0 : _a2.debug(`witnesses:result: ${item.config.schema}`);
70
75
  });
71
76
  return result;
72
77
  }
@@ -86,7 +91,7 @@ class AbstractSentinel extends AbstractArchivingModule {
86
91
  }
87
92
  return resultPayloads;
88
93
  }
89
- }
94
+ };
90
95
  export {
91
96
  AbstractSentinel
92
97
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/AbstractSentinel.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { uniq } from '@xylabs/lodash'\nimport { AbstractArchivingModule, asArchivistInstance } from '@xyo-network/archivist'\nimport { QueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitness, notBoundWitness } from '@xyo-network/boundwitness-model'\nimport { ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomSentinelInstance,\n SentinelInstance,\n SentinelModuleEventData,\n SentinelParams,\n SentinelQueryBase,\n SentinelReportQuerySchema,\n} from '@xyo-network/sentinel-model'\nimport { isWitnessInstance, WitnessInstance } from '@xyo-network/witness'\n\nexport abstract class AbstractSentinel<\n TParams extends SentinelParams = SentinelParams,\n TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>,\n >\n extends AbstractArchivingModule<TParams, TEventData>\n implements CustomSentinelInstance<TParams, TEventData>\n{\n history: BoundWitness[] = []\n\n override get queries(): string[] {\n return [SentinelReportQuerySchema, ...super.queries]\n }\n\n protected override get _queryAccountPaths(): Record<SentinelQueryBase['schema'], string> {\n return {\n 'network.xyo.query.sentinel.report': '1/1',\n }\n }\n\n addArchivist(address: string[]) {\n this.config.archivists = uniq([...address, ...(this.config.archivists ?? [])])\n }\n\n addWitness(address: string[]) {\n this.config.witnesses = uniq([...address, ...(this.config.witnesses ?? [])])\n }\n\n async archivists() {\n this.logger?.debug(`archivists:config:archivist: ${this.config?.archivists?.length}`)\n const namesOrAddresses = this.config?.archivists\n ? Array.isArray(this.config.archivists)\n ? this.config?.archivists\n : [this.config.archivists]\n : undefined\n this.logger?.debug(`archivist:namesOrAddresses: ${namesOrAddresses?.length}`)\n const result = [\n ...(await this.resolve(namesOrAddresses ? { address: namesOrAddresses } : undefined)),\n ...(await this.resolve(namesOrAddresses ? { name: namesOrAddresses } : undefined)),\n ].map((module) => assertEx(asArchivistInstance(module), 'Tried to resolve a non-archivist as an archivist'))\n\n if (namesOrAddresses && namesOrAddresses.length !== result.length) {\n this.logger?.warn(`Not all archivists found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`)\n }\n\n this.logger?.debug(`archivists:result: ${result?.length}`)\n\n return result\n }\n\n removeArchivist(address: string[]) {\n this.config.archivists = (this.config.archivists ?? []).filter((archivist) => !address.includes(archivist))\n }\n\n removeWitness(address: string[]) {\n this.config.witnesses = (this.config.witnesses ?? []).filter((witness) => !address.includes(witness))\n }\n\n async report(inPayloads?: Payload[]): Promise<Payload[]> {\n this._noOverride('report')\n await this.emit('reportStart', { inPayloads, module: this })\n const payloads = await this.reportHandler(inPayloads)\n this.logger?.debug(`report:payloads: ${JSON.stringify(payloads, null, 2)}`)\n const outPayloads = payloads.filter(notBoundWitness)\n const boundwitnesses = payloads.filter(isBoundWitness)\n const boundwitness = boundwitnesses.find((bw) => bw.addresses.includes(this.address))\n await this.emit('reportEnd', { boundwitness, inPayloads, module: this, outPayloads })\n return payloads\n }\n\n async witnesses() {\n this.logger?.debug(`witnesses:config:witnesses: ${this.config?.witnesses?.length}`)\n const namesOrAddresses = this.config?.witnesses\n ? Array.isArray(this.config.witnesses)\n ? this.config?.witnesses\n : [this.config.witnesses]\n : undefined\n this.logger?.debug(`witnesses:namesOrAddresses: ${namesOrAddresses?.length}`)\n const result = namesOrAddresses\n ? [\n ...(await this.resolve<WitnessInstance>({ address: namesOrAddresses }, { identity: isWitnessInstance })),\n ...(await this.resolve<WitnessInstance>({ name: namesOrAddresses }, { identity: isWitnessInstance })),\n ]\n : await this.resolve<WitnessInstance>(undefined, { identity: isWitnessInstance })\n\n if (namesOrAddresses && namesOrAddresses.length !== result.length) {\n this.logger?.warn(`Not all witnesses found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`)\n }\n result.map((item) => {\n this.logger?.debug(`witnesses:result: ${item.config.schema}`)\n })\n\n return result\n }\n\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<SentinelQueryBase>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case SentinelReportQuerySchema: {\n resultPayloads.push(...(await this.report(payloads)))\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return resultPayloads\n }\n\n abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../../src/AbstractSentinel.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { uniq } from '@xylabs/lodash'\nimport { AbstractArchivingModule, asArchivistInstance } from '@xyo-network/archivist'\nimport { QueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitness, notBoundWitness } from '@xyo-network/boundwitness-model'\nimport { ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomSentinelInstance,\n SentinelInstance,\n SentinelModuleEventData,\n SentinelParams,\n SentinelQueryBase,\n SentinelReportQuerySchema,\n} from '@xyo-network/sentinel-model'\nimport { isWitnessInstance, WitnessInstance } from '@xyo-network/witness'\n\nexport abstract class AbstractSentinel<\n TParams extends SentinelParams = SentinelParams,\n TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>,\n >\n extends AbstractArchivingModule<TParams, TEventData>\n implements CustomSentinelInstance<TParams, TEventData>\n{\n history: BoundWitness[] = []\n\n override get queries(): string[] {\n return [SentinelReportQuerySchema, ...super.queries]\n }\n\n protected override get _queryAccountPaths(): Record<SentinelQueryBase['schema'], string> {\n return {\n 'network.xyo.query.sentinel.report': '1/1',\n }\n }\n\n addArchivist(address: string[]) {\n this.config.archivists = uniq([...address, ...(this.config.archivists ?? [])])\n }\n\n addWitness(address: string[]) {\n this.config.witnesses = uniq([...address, ...(this.config.witnesses ?? [])])\n }\n\n async archivists() {\n this.logger?.debug(`archivists:config:archivist: ${this.config?.archivists?.length}`)\n const namesOrAddresses = this.config?.archivists\n ? Array.isArray(this.config.archivists)\n ? this.config?.archivists\n : [this.config.archivists]\n : undefined\n this.logger?.debug(`archivist:namesOrAddresses: ${namesOrAddresses?.length}`)\n const result = [\n ...(await this.resolve(namesOrAddresses ? { address: namesOrAddresses } : undefined)),\n ...(await this.resolve(namesOrAddresses ? { name: namesOrAddresses } : undefined)),\n ].map((module) => assertEx(asArchivistInstance(module), 'Tried to resolve a non-archivist as an archivist'))\n\n if (namesOrAddresses && namesOrAddresses.length !== result.length) {\n this.logger?.warn(`Not all archivists found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`)\n }\n\n this.logger?.debug(`archivists:result: ${result?.length}`)\n\n return result\n }\n\n removeArchivist(address: string[]) {\n this.config.archivists = (this.config.archivists ?? []).filter((archivist) => !address.includes(archivist))\n }\n\n removeWitness(address: string[]) {\n this.config.witnesses = (this.config.witnesses ?? []).filter((witness) => !address.includes(witness))\n }\n\n async report(inPayloads?: Payload[]): Promise<Payload[]> {\n this._noOverride('report')\n await this.emit('reportStart', { inPayloads, module: this })\n const payloads = await this.reportHandler(inPayloads)\n this.logger?.debug(`report:payloads: ${JSON.stringify(payloads, null, 2)}`)\n const outPayloads = payloads.filter(notBoundWitness)\n const boundwitnesses = payloads.filter(isBoundWitness)\n const boundwitness = boundwitnesses.find((bw) => bw.addresses.includes(this.address))\n await this.emit('reportEnd', { boundwitness, inPayloads, module: this, outPayloads })\n return payloads\n }\n\n async witnesses() {\n this.logger?.debug(`witnesses:config:witnesses: ${this.config?.witnesses?.length}`)\n const namesOrAddresses = this.config?.witnesses\n ? Array.isArray(this.config.witnesses)\n ? this.config?.witnesses\n : [this.config.witnesses]\n : undefined\n this.logger?.debug(`witnesses:namesOrAddresses: ${namesOrAddresses?.length}`)\n const result = namesOrAddresses\n ? [\n ...(await this.resolve<WitnessInstance>({ address: namesOrAddresses }, { identity: isWitnessInstance })),\n ...(await this.resolve<WitnessInstance>({ name: namesOrAddresses }, { identity: isWitnessInstance })),\n ]\n : await this.resolve<WitnessInstance>(undefined, { identity: isWitnessInstance })\n\n if (namesOrAddresses && namesOrAddresses.length !== result.length) {\n this.logger?.warn(`Not all witnesses found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`)\n }\n result.map((item) => {\n this.logger?.debug(`witnesses:result: ${item.config.schema}`)\n })\n\n return result\n }\n\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<SentinelQueryBase>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case SentinelReportQuerySchema: {\n resultPayloads.push(...(await this.report(payloads)))\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return resultPayloads\n }\n\n abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>\n}\n"],"mappings":"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","names":["_a"]}
@@ -0,0 +1,28 @@
1
+ import { AnyObject } from '@xyo-network/core';
2
+ import { Payload } from '@xyo-network/payload-model';
3
+ export type SentinelAutomationSchema = 'network.xyo.automation';
4
+ export declare const SentinelAutomationSchema: SentinelAutomationSchema;
5
+ export type SentinelBaseAutomationPayload<T extends AnyObject = AnyObject> = Payload<T & {
6
+ schema: SentinelAutomationSchema;
7
+ type?: 'interval' | 'change';
8
+ /** @field The list of witnesses to invoke [all if undefined] */
9
+ witnesses?: string[];
10
+ }>;
11
+ export type SentinelIntervalAutomationPayload = SentinelBaseAutomationPayload<{
12
+ /** @field epoch after which any reoccurrence stops */
13
+ end?: number;
14
+ /** @field time between triggers [non-repeating if undefined] */
15
+ frequency?: number;
16
+ /** @field units for frequency field [hour if undefined] */
17
+ frequencyUnits?: 'second' | 'minute' | 'hour' | 'day';
18
+ /** @field remaining triggers [infinite if undefined] */
19
+ remaining?: number;
20
+ /** @field epoch of the next trigger */
21
+ start: number;
22
+ type: 'interval';
23
+ }>;
24
+ export type SentinelChangeAutomationPayload = SentinelBaseAutomationPayload<{
25
+ type: 'change';
26
+ }>;
27
+ export type SentinelAutomationPayload = SentinelIntervalAutomationPayload | SentinelChangeAutomationPayload;
28
+ //# sourceMappingURL=Automation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Automation.d.ts","sourceRoot":"","sources":["../../src/Automation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAA;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAEpD,MAAM,MAAM,wBAAwB,GAAG,wBAAwB,CAAA;AAC/D,eAAO,MAAM,wBAAwB,EAAE,wBAAmD,CAAA;AAE1F,MAAM,MAAM,6BAA6B,CAAC,CAAC,SAAS,SAAS,GAAG,SAAS,IAAI,OAAO,CAClF,CAAC,GAAG;IACF,MAAM,EAAE,wBAAwB,CAAA;IAChC,IAAI,CAAC,EAAE,UAAU,GAAG,QAAQ,CAAA;IAC5B,gEAAgE;IAChE,SAAS,CAAC,EAAE,MAAM,EAAE,CAAA;CACrB,CACF,CAAA;AAED,MAAM,MAAM,iCAAiC,GAAG,6BAA6B,CAAC;IAC5E,sDAAsD;IACtD,GAAG,CAAC,EAAE,MAAM,CAAA;IAEZ,gEAAgE;IAChE,SAAS,CAAC,EAAE,MAAM,CAAA;IAElB,2DAA2D;IAC3D,cAAc,CAAC,EAAE,QAAQ,GAAG,QAAQ,GAAG,MAAM,GAAG,KAAK,CAAA;IAErD,wDAAwD;IACxD,SAAS,CAAC,EAAE,MAAM,CAAA;IAElB,uCAAuC;IACvC,KAAK,EAAE,MAAM,CAAA;IAEb,IAAI,EAAE,UAAU,CAAA;CACjB,CAAC,CAAA;AAEF,MAAM,MAAM,+BAA+B,GAAG,6BAA6B,CAAC;IAC1E,IAAI,EAAE,QAAQ,CAAA;CACf,CAAC,CAAA;AAEF,MAAM,MAAM,yBAAyB,GAAG,iCAAiC,GAAG,+BAA+B,CAAA"}
@@ -16,12 +16,14 @@ var __copyProps = (to, from, except, desc) => {
16
16
  return to;
17
17
  };
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/Automation.ts
19
21
  var Automation_exports = {};
20
22
  __export(Automation_exports, {
21
23
  SentinelAutomationSchema: () => SentinelAutomationSchema
22
24
  });
23
25
  module.exports = __toCommonJS(Automation_exports);
24
- const SentinelAutomationSchema = "network.xyo.automation";
26
+ var SentinelAutomationSchema = "network.xyo.automation";
25
27
  // Annotate the CommonJS export names for ESM import in node:
26
28
  0 && (module.exports = {
27
29
  SentinelAutomationSchema
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Automation.ts"],"sourcesContent":["import { AnyObject } from '@xyo-network/core'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport type SentinelAutomationSchema = 'network.xyo.automation'\nexport const SentinelAutomationSchema: SentinelAutomationSchema = 'network.xyo.automation'\n\nexport type SentinelBaseAutomationPayload<T extends AnyObject = AnyObject> = Payload<\n T & {\n schema: SentinelAutomationSchema\n type?: 'interval' | 'change'\n /** @field The list of witnesses to invoke [all if undefined] */\n witnesses?: string[]\n }\n>\n\nexport type SentinelIntervalAutomationPayload = SentinelBaseAutomationPayload<{\n /** @field epoch after which any reoccurrence stops */\n end?: number\n\n /** @field time between triggers [non-repeating if undefined] */\n frequency?: number\n\n /** @field units for frequency field [hour if undefined] */\n frequencyUnits?: 'second' | 'minute' | 'hour' | 'day'\n\n /** @field remaining triggers [infinite if undefined] */\n remaining?: number\n\n /** @field epoch of the next trigger */\n start: number\n\n type: 'interval'\n}>\n\nexport type SentinelChangeAutomationPayload = SentinelBaseAutomationPayload<{\n type: 'change'\n}>\n\nexport type SentinelAutomationPayload = SentinelIntervalAutomationPayload | SentinelChangeAutomationPayload\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAIO,MAAM,2BAAqD;","names":[]}
1
+ {"version":3,"sources":["../../src/Automation.ts"],"sourcesContent":["import { AnyObject } from '@xyo-network/core'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport type SentinelAutomationSchema = 'network.xyo.automation'\nexport const SentinelAutomationSchema: SentinelAutomationSchema = 'network.xyo.automation'\n\nexport type SentinelBaseAutomationPayload<T extends AnyObject = AnyObject> = Payload<\n T & {\n schema: SentinelAutomationSchema\n type?: 'interval' | 'change'\n /** @field The list of witnesses to invoke [all if undefined] */\n witnesses?: string[]\n }\n>\n\nexport type SentinelIntervalAutomationPayload = SentinelBaseAutomationPayload<{\n /** @field epoch after which any reoccurrence stops */\n end?: number\n\n /** @field time between triggers [non-repeating if undefined] */\n frequency?: number\n\n /** @field units for frequency field [hour if undefined] */\n frequencyUnits?: 'second' | 'minute' | 'hour' | 'day'\n\n /** @field remaining triggers [infinite if undefined] */\n remaining?: number\n\n /** @field epoch of the next trigger */\n start: number\n\n type: 'interval'\n}>\n\nexport type SentinelChangeAutomationPayload = SentinelBaseAutomationPayload<{\n type: 'change'\n}>\n\nexport type SentinelAutomationPayload = SentinelIntervalAutomationPayload | SentinelChangeAutomationPayload\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAIO,IAAM,2BAAqD;","names":[]}
@@ -1,4 +1,5 @@
1
- const SentinelAutomationSchema = "network.xyo.automation";
1
+ // src/Automation.ts
2
+ var SentinelAutomationSchema = "network.xyo.automation";
2
3
  export {
3
4
  SentinelAutomationSchema
4
5
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Automation.ts"],"sourcesContent":["import { AnyObject } from '@xyo-network/core'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport type SentinelAutomationSchema = 'network.xyo.automation'\nexport const SentinelAutomationSchema: SentinelAutomationSchema = 'network.xyo.automation'\n\nexport type SentinelBaseAutomationPayload<T extends AnyObject = AnyObject> = Payload<\n T & {\n schema: SentinelAutomationSchema\n type?: 'interval' | 'change'\n /** @field The list of witnesses to invoke [all if undefined] */\n witnesses?: string[]\n }\n>\n\nexport type SentinelIntervalAutomationPayload = SentinelBaseAutomationPayload<{\n /** @field epoch after which any reoccurrence stops */\n end?: number\n\n /** @field time between triggers [non-repeating if undefined] */\n frequency?: number\n\n /** @field units for frequency field [hour if undefined] */\n frequencyUnits?: 'second' | 'minute' | 'hour' | 'day'\n\n /** @field remaining triggers [infinite if undefined] */\n remaining?: number\n\n /** @field epoch of the next trigger */\n start: number\n\n type: 'interval'\n}>\n\nexport type SentinelChangeAutomationPayload = SentinelBaseAutomationPayload<{\n type: 'change'\n}>\n\nexport type SentinelAutomationPayload = SentinelIntervalAutomationPayload | SentinelChangeAutomationPayload\n"],"mappings":"AAIO,MAAM,2BAAqD;","names":[]}
1
+ {"version":3,"sources":["../../src/Automation.ts"],"sourcesContent":["import { AnyObject } from '@xyo-network/core'\nimport { Payload } from '@xyo-network/payload-model'\n\nexport type SentinelAutomationSchema = 'network.xyo.automation'\nexport const SentinelAutomationSchema: SentinelAutomationSchema = 'network.xyo.automation'\n\nexport type SentinelBaseAutomationPayload<T extends AnyObject = AnyObject> = Payload<\n T & {\n schema: SentinelAutomationSchema\n type?: 'interval' | 'change'\n /** @field The list of witnesses to invoke [all if undefined] */\n witnesses?: string[]\n }\n>\n\nexport type SentinelIntervalAutomationPayload = SentinelBaseAutomationPayload<{\n /** @field epoch after which any reoccurrence stops */\n end?: number\n\n /** @field time between triggers [non-repeating if undefined] */\n frequency?: number\n\n /** @field units for frequency field [hour if undefined] */\n frequencyUnits?: 'second' | 'minute' | 'hour' | 'day'\n\n /** @field remaining triggers [infinite if undefined] */\n remaining?: number\n\n /** @field epoch of the next trigger */\n start: number\n\n type: 'interval'\n}>\n\nexport type SentinelChangeAutomationPayload = SentinelBaseAutomationPayload<{\n type: 'change'\n}>\n\nexport type SentinelAutomationPayload = SentinelIntervalAutomationPayload | SentinelChangeAutomationPayload\n"],"mappings":";AAIO,IAAM,2BAAqD;","names":[]}
@@ -0,0 +1,10 @@
1
+ import { Payload } from '@xyo-network/payload-model';
2
+ import { SentinelConfig, SentinelInstance, SentinelModuleEventData, SentinelParams } from '@xyo-network/sentinel-model';
3
+ import { AbstractSentinel } from './AbstractSentinel';
4
+ export type MemorySentinelParams<TConfig extends SentinelConfig = SentinelConfig> = SentinelParams<TConfig>;
5
+ export declare class MemorySentinel<TParams extends MemorySentinelParams = MemorySentinelParams, TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>> extends AbstractSentinel<TParams, TEventData> {
6
+ static configSchemas: "network.xyo.sentinel.config"[];
7
+ reportHandler(payloads?: Payload[]): Promise<Payload[]>;
8
+ private generateResults;
9
+ }
10
+ //# sourceMappingURL=MemorySentinel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MemorySentinel.d.ts","sourceRoot":"","sources":["../../src/MemorySentinel.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EACL,cAAc,EAEd,gBAAgB,EAChB,uBAAuB,EACvB,cAAc,EAEf,MAAM,6BAA6B,CAAA;AAGpC,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AAErD,MAAM,MAAM,oBAAoB,CAAC,OAAO,SAAS,cAAc,GAAG,cAAc,IAAI,cAAc,CAAC,OAAO,CAAC,CAAA;AAE3G,qBAAa,cAAc,CACzB,OAAO,SAAS,oBAAoB,GAAG,oBAAoB,EAC3D,UAAU,SAAS,uBAAuB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,GAAG,uBAAuB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAC1H,SAAQ,gBAAgB,CAAC,OAAO,EAAE,UAAU,CAAC;IAC7C,OAAgB,aAAa,kCAAyB;IAEhD,aAAa,CAAC,QAAQ,GAAE,OAAO,EAAO,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;YAsBnD,eAAe;CAY9B"}
@@ -16,18 +16,114 @@ var __copyProps = (to, from, except, desc) => {
16
16
  return to;
17
17
  };
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/MemorySentinel.ts
19
21
  var MemorySentinel_exports = {};
20
22
  __export(MemorySentinel_exports, {
21
23
  MemorySentinel: () => MemorySentinel
22
24
  });
23
25
  module.exports = __toCommonJS(MemorySentinel_exports);
24
- var import_assert = require("@xylabs/assert");
26
+ var import_assert2 = require("@xylabs/assert");
25
27
  var import_promise = require("@xylabs/promise");
26
28
  var import_error = require("@xyo-network/error");
29
+ var import_sentinel_model2 = require("@xyo-network/sentinel-model");
30
+
31
+ // src/AbstractSentinel.ts
32
+ var import_assert = require("@xylabs/assert");
33
+ var import_lodash = require("@xylabs/lodash");
34
+ var import_archivist = require("@xyo-network/archivist");
35
+ var import_boundwitness_builder = require("@xyo-network/boundwitness-builder");
36
+ var import_boundwitness_model = require("@xyo-network/boundwitness-model");
27
37
  var import_sentinel_model = require("@xyo-network/sentinel-model");
28
- var import_AbstractSentinel = require("./AbstractSentinel");
29
- class MemorySentinel extends import_AbstractSentinel.AbstractSentinel {
30
- static configSchemas = [import_sentinel_model.SentinelConfigSchema];
38
+ var import_witness = require("@xyo-network/witness");
39
+ var AbstractSentinel = class extends import_archivist.AbstractArchivingModule {
40
+ history = [];
41
+ get queries() {
42
+ return [import_sentinel_model.SentinelReportQuerySchema, ...super.queries];
43
+ }
44
+ get _queryAccountPaths() {
45
+ return {
46
+ "network.xyo.query.sentinel.report": "1/1"
47
+ };
48
+ }
49
+ addArchivist(address) {
50
+ this.config.archivists = (0, import_lodash.uniq)([...address, ...this.config.archivists ?? []]);
51
+ }
52
+ addWitness(address) {
53
+ this.config.witnesses = (0, import_lodash.uniq)([...address, ...this.config.witnesses ?? []]);
54
+ }
55
+ async archivists() {
56
+ var _a, _b, _c, _d, _e, _f, _g, _h;
57
+ (_c = this.logger) == null ? void 0 : _c.debug(`archivists:config:archivist: ${(_b = (_a = this.config) == null ? void 0 : _a.archivists) == null ? void 0 : _b.length}`);
58
+ const namesOrAddresses = ((_d = this.config) == null ? void 0 : _d.archivists) ? Array.isArray(this.config.archivists) ? (_e = this.config) == null ? void 0 : _e.archivists : [this.config.archivists] : void 0;
59
+ (_f = this.logger) == null ? void 0 : _f.debug(`archivist:namesOrAddresses: ${namesOrAddresses == null ? void 0 : namesOrAddresses.length}`);
60
+ const result = [
61
+ ...await this.resolve(namesOrAddresses ? { address: namesOrAddresses } : void 0),
62
+ ...await this.resolve(namesOrAddresses ? { name: namesOrAddresses } : void 0)
63
+ ].map((module2) => (0, import_assert.assertEx)((0, import_archivist.asArchivistInstance)(module2), "Tried to resolve a non-archivist as an archivist"));
64
+ if (namesOrAddresses && namesOrAddresses.length !== result.length) {
65
+ (_g = this.logger) == null ? void 0 : _g.warn(`Not all archivists found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`);
66
+ }
67
+ (_h = this.logger) == null ? void 0 : _h.debug(`archivists:result: ${result == null ? void 0 : result.length}`);
68
+ return result;
69
+ }
70
+ removeArchivist(address) {
71
+ this.config.archivists = (this.config.archivists ?? []).filter((archivist) => !address.includes(archivist));
72
+ }
73
+ removeWitness(address) {
74
+ this.config.witnesses = (this.config.witnesses ?? []).filter((witness) => !address.includes(witness));
75
+ }
76
+ async report(inPayloads) {
77
+ var _a;
78
+ this._noOverride("report");
79
+ await this.emit("reportStart", { inPayloads, module: this });
80
+ const payloads = await this.reportHandler(inPayloads);
81
+ (_a = this.logger) == null ? void 0 : _a.debug(`report:payloads: ${JSON.stringify(payloads, null, 2)}`);
82
+ const outPayloads = payloads.filter(import_boundwitness_model.notBoundWitness);
83
+ const boundwitnesses = payloads.filter(import_boundwitness_model.isBoundWitness);
84
+ const boundwitness = boundwitnesses.find((bw) => bw.addresses.includes(this.address));
85
+ await this.emit("reportEnd", { boundwitness, inPayloads, module: this, outPayloads });
86
+ return payloads;
87
+ }
88
+ async witnesses() {
89
+ var _a, _b, _c, _d, _e, _f, _g;
90
+ (_c = this.logger) == null ? void 0 : _c.debug(`witnesses:config:witnesses: ${(_b = (_a = this.config) == null ? void 0 : _a.witnesses) == null ? void 0 : _b.length}`);
91
+ const namesOrAddresses = ((_d = this.config) == null ? void 0 : _d.witnesses) ? Array.isArray(this.config.witnesses) ? (_e = this.config) == null ? void 0 : _e.witnesses : [this.config.witnesses] : void 0;
92
+ (_f = this.logger) == null ? void 0 : _f.debug(`witnesses:namesOrAddresses: ${namesOrAddresses == null ? void 0 : namesOrAddresses.length}`);
93
+ const result = namesOrAddresses ? [
94
+ ...await this.resolve({ address: namesOrAddresses }, { identity: import_witness.isWitnessInstance }),
95
+ ...await this.resolve({ name: namesOrAddresses }, { identity: import_witness.isWitnessInstance })
96
+ ] : await this.resolve(void 0, { identity: import_witness.isWitnessInstance });
97
+ if (namesOrAddresses && namesOrAddresses.length !== result.length) {
98
+ (_g = this.logger) == null ? void 0 : _g.warn(`Not all witnesses found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`);
99
+ }
100
+ result.map((item) => {
101
+ var _a2;
102
+ (_a2 = this.logger) == null ? void 0 : _a2.debug(`witnesses:result: ${item.config.schema}`);
103
+ });
104
+ return result;
105
+ }
106
+ async queryHandler(query, payloads, queryConfig) {
107
+ const wrapper = import_boundwitness_builder.QueryBoundWitnessWrapper.parseQuery(query, payloads);
108
+ const queryPayload = await wrapper.getQuery();
109
+ (0, import_assert.assertEx)(this.queryable(query, payloads, queryConfig));
110
+ const resultPayloads = [];
111
+ switch (queryPayload.schema) {
112
+ case import_sentinel_model.SentinelReportQuerySchema: {
113
+ resultPayloads.push(...await this.report(payloads));
114
+ break;
115
+ }
116
+ default: {
117
+ return super.queryHandler(query, payloads);
118
+ }
119
+ }
120
+ return resultPayloads;
121
+ }
122
+ };
123
+
124
+ // src/MemorySentinel.ts
125
+ var MemorySentinel = class extends AbstractSentinel {
126
+ static configSchemas = [import_sentinel_model2.SentinelConfigSchema];
31
127
  async reportHandler(payloads = []) {
32
128
  await this.started("throw");
33
129
  const errors = [];
@@ -43,17 +139,17 @@ class MemorySentinel extends import_AbstractSentinel.AbstractSentinel {
43
139
  errors.push(error);
44
140
  });
45
141
  }
46
- const [boundWitness] = await this.bindQueryResult({ schema: import_sentinel_model.SentinelReportQuerySchema }, resultPayloads);
47
- this.history.push((0, import_assert.assertEx)(boundWitness));
142
+ const [boundWitness] = await this.bindQueryResult({ schema: import_sentinel_model2.SentinelReportQuerySchema }, resultPayloads);
143
+ this.history.push((0, import_assert2.assertEx)(boundWitness));
48
144
  return [boundWitness, ...resultPayloads];
49
145
  }
50
146
  async generateResults(witnesses) {
51
- const results = await Promise.allSettled(witnesses?.map((witness) => witness.observe()));
147
+ const results = await Promise.allSettled(witnesses == null ? void 0 : witnesses.map((witness) => witness.observe()));
52
148
  const payloads = results.filter(import_promise.fulfilled).map((result) => result.value).flat();
53
149
  const errors = results.filter(import_promise.rejected).map((result) => result.reason).flat();
54
150
  return [payloads, errors];
55
151
  }
56
- }
152
+ };
57
153
  // Annotate the CommonJS export names for ESM import in node:
58
154
  0 && (module.exports = {
59
155
  MemorySentinel
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/MemorySentinel.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { fulfilled, rejected } from '@xylabs/promise'\nimport { handleError } from '@xyo-network/error'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n SentinelConfig,\n SentinelConfigSchema,\n SentinelInstance,\n SentinelModuleEventData,\n SentinelParams,\n SentinelReportQuerySchema,\n} from '@xyo-network/sentinel-model'\nimport { WitnessInstance } from '@xyo-network/witness'\n\nimport { AbstractSentinel } from './AbstractSentinel'\n\nexport type MemorySentinelParams<TConfig extends SentinelConfig = SentinelConfig> = SentinelParams<TConfig>\n\nexport class MemorySentinel<\n TParams extends MemorySentinelParams = MemorySentinelParams,\n TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>,\n> extends AbstractSentinel<TParams, TEventData> {\n static override configSchemas = [SentinelConfigSchema]\n\n async reportHandler(payloads: Payload[] = []): Promise<Payload[]> {\n await this.started('throw')\n const errors: Error[] = []\n const allWitnesses = [...(await this.witnesses())]\n const resultPayloads: Payload[] = []\n\n try {\n const [generatedPayloads, generatedErrors] = await this.generateResults(allWitnesses)\n const combinedPayloads = [...generatedPayloads, ...payloads]\n resultPayloads.push(...combinedPayloads)\n errors.push(...generatedErrors)\n } catch (ex) {\n handleError(ex, (error) => {\n errors.push(error)\n })\n }\n\n const [boundWitness] = await this.bindQueryResult({ schema: SentinelReportQuerySchema }, resultPayloads)\n this.history.push(assertEx(boundWitness))\n return [boundWitness, ...resultPayloads]\n }\n\n private async generateResults(witnesses: WitnessInstance[]): Promise<[Payload[], Error[]]> {\n const results = await Promise.allSettled(witnesses?.map((witness) => witness.observe()))\n const payloads = results\n .filter(fulfilled)\n .map((result) => result.value)\n .flat()\n const errors = results\n .filter(rejected)\n .map((result) => result.reason)\n .flat()\n return [payloads, errors]\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAyB;AACzB,qBAAoC;AACpC,mBAA4B;AAE5B,4BAOO;AAGP,8BAAiC;AAI1B,MAAM,uBAGH,yCAAsC;AAAA,EAC9C,OAAgB,gBAAgB,CAAC,0CAAoB;AAAA,EAErD,MAAM,cAAc,WAAsB,CAAC,GAAuB;AAChE,UAAM,KAAK,QAAQ,OAAO;AAC1B,UAAM,SAAkB,CAAC;AACzB,UAAM,eAAe,CAAC,GAAI,MAAM,KAAK,UAAU,CAAE;AACjD,UAAM,iBAA4B,CAAC;AAEnC,QAAI;AACF,YAAM,CAAC,mBAAmB,eAAe,IAAI,MAAM,KAAK,gBAAgB,YAAY;AACpF,YAAM,mBAAmB,CAAC,GAAG,mBAAmB,GAAG,QAAQ;AAC3D,qBAAe,KAAK,GAAG,gBAAgB;AACvC,aAAO,KAAK,GAAG,eAAe;AAAA,IAChC,SAAS,IAAI;AACX,oCAAY,IAAI,CAAC,UAAU;AACzB,eAAO,KAAK,KAAK;AAAA,MACnB,CAAC;AAAA,IACH;AAEA,UAAM,CAAC,YAAY,IAAI,MAAM,KAAK,gBAAgB,EAAE,QAAQ,gDAA0B,GAAG,cAAc;AACvG,SAAK,QAAQ,SAAK,wBAAS,YAAY,CAAC;AACxC,WAAO,CAAC,cAAc,GAAG,cAAc;AAAA,EACzC;AAAA,EAEA,MAAc,gBAAgB,WAA6D;AACzF,UAAM,UAAU,MAAM,QAAQ,WAAW,WAAW,IAAI,CAAC,YAAY,QAAQ,QAAQ,CAAC,CAAC;AACvF,UAAM,WAAW,QACd,OAAO,wBAAS,EAChB,IAAI,CAAC,WAAW,OAAO,KAAK,EAC5B,KAAK;AACR,UAAM,SAAS,QACZ,OAAO,uBAAQ,EACf,IAAI,CAAC,WAAW,OAAO,MAAM,EAC7B,KAAK;AACR,WAAO,CAAC,UAAU,MAAM;AAAA,EAC1B;AACF;","names":[]}
1
+ {"version":3,"sources":["../../src/MemorySentinel.ts","../../src/AbstractSentinel.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { fulfilled, rejected } from '@xylabs/promise'\nimport { handleError } from '@xyo-network/error'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n SentinelConfig,\n SentinelConfigSchema,\n SentinelInstance,\n SentinelModuleEventData,\n SentinelParams,\n SentinelReportQuerySchema,\n} from '@xyo-network/sentinel-model'\nimport { WitnessInstance } from '@xyo-network/witness'\n\nimport { AbstractSentinel } from './AbstractSentinel'\n\nexport type MemorySentinelParams<TConfig extends SentinelConfig = SentinelConfig> = SentinelParams<TConfig>\n\nexport class MemorySentinel<\n TParams extends MemorySentinelParams = MemorySentinelParams,\n TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>,\n> extends AbstractSentinel<TParams, TEventData> {\n static override configSchemas = [SentinelConfigSchema]\n\n async reportHandler(payloads: Payload[] = []): Promise<Payload[]> {\n await this.started('throw')\n const errors: Error[] = []\n const allWitnesses = [...(await this.witnesses())]\n const resultPayloads: Payload[] = []\n\n try {\n const [generatedPayloads, generatedErrors] = await this.generateResults(allWitnesses)\n const combinedPayloads = [...generatedPayloads, ...payloads]\n resultPayloads.push(...combinedPayloads)\n errors.push(...generatedErrors)\n } catch (ex) {\n handleError(ex, (error) => {\n errors.push(error)\n })\n }\n\n const [boundWitness] = await this.bindQueryResult({ schema: SentinelReportQuerySchema }, resultPayloads)\n this.history.push(assertEx(boundWitness))\n return [boundWitness, ...resultPayloads]\n }\n\n private async generateResults(witnesses: WitnessInstance[]): Promise<[Payload[], Error[]]> {\n const results = await Promise.allSettled(witnesses?.map((witness) => witness.observe()))\n const payloads = results\n .filter(fulfilled)\n .map((result) => result.value)\n .flat()\n const errors = results\n .filter(rejected)\n .map((result) => result.reason)\n .flat()\n return [payloads, errors]\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { uniq } from '@xylabs/lodash'\nimport { AbstractArchivingModule, asArchivistInstance } from '@xyo-network/archivist'\nimport { QueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitness, notBoundWitness } from '@xyo-network/boundwitness-model'\nimport { ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n CustomSentinelInstance,\n SentinelInstance,\n SentinelModuleEventData,\n SentinelParams,\n SentinelQueryBase,\n SentinelReportQuerySchema,\n} from '@xyo-network/sentinel-model'\nimport { isWitnessInstance, WitnessInstance } from '@xyo-network/witness'\n\nexport abstract class AbstractSentinel<\n TParams extends SentinelParams = SentinelParams,\n TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>,\n >\n extends AbstractArchivingModule<TParams, TEventData>\n implements CustomSentinelInstance<TParams, TEventData>\n{\n history: BoundWitness[] = []\n\n override get queries(): string[] {\n return [SentinelReportQuerySchema, ...super.queries]\n }\n\n protected override get _queryAccountPaths(): Record<SentinelQueryBase['schema'], string> {\n return {\n 'network.xyo.query.sentinel.report': '1/1',\n }\n }\n\n addArchivist(address: string[]) {\n this.config.archivists = uniq([...address, ...(this.config.archivists ?? [])])\n }\n\n addWitness(address: string[]) {\n this.config.witnesses = uniq([...address, ...(this.config.witnesses ?? [])])\n }\n\n async archivists() {\n this.logger?.debug(`archivists:config:archivist: ${this.config?.archivists?.length}`)\n const namesOrAddresses = this.config?.archivists\n ? Array.isArray(this.config.archivists)\n ? this.config?.archivists\n : [this.config.archivists]\n : undefined\n this.logger?.debug(`archivist:namesOrAddresses: ${namesOrAddresses?.length}`)\n const result = [\n ...(await this.resolve(namesOrAddresses ? { address: namesOrAddresses } : undefined)),\n ...(await this.resolve(namesOrAddresses ? { name: namesOrAddresses } : undefined)),\n ].map((module) => assertEx(asArchivistInstance(module), 'Tried to resolve a non-archivist as an archivist'))\n\n if (namesOrAddresses && namesOrAddresses.length !== result.length) {\n this.logger?.warn(`Not all archivists found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`)\n }\n\n this.logger?.debug(`archivists:result: ${result?.length}`)\n\n return result\n }\n\n removeArchivist(address: string[]) {\n this.config.archivists = (this.config.archivists ?? []).filter((archivist) => !address.includes(archivist))\n }\n\n removeWitness(address: string[]) {\n this.config.witnesses = (this.config.witnesses ?? []).filter((witness) => !address.includes(witness))\n }\n\n async report(inPayloads?: Payload[]): Promise<Payload[]> {\n this._noOverride('report')\n await this.emit('reportStart', { inPayloads, module: this })\n const payloads = await this.reportHandler(inPayloads)\n this.logger?.debug(`report:payloads: ${JSON.stringify(payloads, null, 2)}`)\n const outPayloads = payloads.filter(notBoundWitness)\n const boundwitnesses = payloads.filter(isBoundWitness)\n const boundwitness = boundwitnesses.find((bw) => bw.addresses.includes(this.address))\n await this.emit('reportEnd', { boundwitness, inPayloads, module: this, outPayloads })\n return payloads\n }\n\n async witnesses() {\n this.logger?.debug(`witnesses:config:witnesses: ${this.config?.witnesses?.length}`)\n const namesOrAddresses = this.config?.witnesses\n ? Array.isArray(this.config.witnesses)\n ? this.config?.witnesses\n : [this.config.witnesses]\n : undefined\n this.logger?.debug(`witnesses:namesOrAddresses: ${namesOrAddresses?.length}`)\n const result = namesOrAddresses\n ? [\n ...(await this.resolve<WitnessInstance>({ address: namesOrAddresses }, { identity: isWitnessInstance })),\n ...(await this.resolve<WitnessInstance>({ name: namesOrAddresses }, { identity: isWitnessInstance })),\n ]\n : await this.resolve<WitnessInstance>(undefined, { identity: isWitnessInstance })\n\n if (namesOrAddresses && namesOrAddresses.length !== result.length) {\n this.logger?.warn(`Not all witnesses found [Requested: ${namesOrAddresses.length}, Found: ${result.length}]`)\n }\n result.map((item) => {\n this.logger?.debug(`witnesses:result: ${item.config.schema}`)\n })\n\n return result\n }\n\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<SentinelQueryBase>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case SentinelReportQuerySchema: {\n resultPayloads.push(...(await this.report(payloads)))\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return resultPayloads\n }\n\n abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAAA,iBAAyB;AACzB,qBAAoC;AACpC,mBAA4B;AAE5B,IAAAC,yBAOO;;;ACXP,oBAAyB;AACzB,oBAAqB;AACrB,uBAA6D;AAC7D,kCAA4D;AAC5D,gCAA8D;AAG9D,4BAOO;AACP,qBAAmD;AAE5C,IAAe,mBAAf,cAIG,yCAEV;AAAA,EACE,UAA0B,CAAC;AAAA,EAE3B,IAAa,UAAoB;AAC/B,WAAO,CAAC,iDAA2B,GAAG,MAAM,OAAO;AAAA,EACrD;AAAA,EAEA,IAAuB,qBAAkE;AACvF,WAAO;AAAA,MACL,qCAAqC;AAAA,IACvC;AAAA,EACF;AAAA,EAEA,aAAa,SAAmB;AAC9B,SAAK,OAAO,iBAAa,oBAAK,CAAC,GAAG,SAAS,GAAI,KAAK,OAAO,cAAc,CAAC,CAAE,CAAC;AAAA,EAC/E;AAAA,EAEA,WAAW,SAAmB;AAC5B,SAAK,OAAO,gBAAY,oBAAK,CAAC,GAAG,SAAS,GAAI,KAAK,OAAO,aAAa,CAAC,CAAE,CAAC;AAAA,EAC7E;AAAA,EAEA,MAAM,aAAa;AA5CrB;AA6CI,eAAK,WAAL,mBAAa,MAAM,iCAAgC,gBAAK,WAAL,mBAAa,eAAb,mBAAyB,MAAM;AAClF,UAAM,qBAAmB,UAAK,WAAL,mBAAa,cAClC,MAAM,QAAQ,KAAK,OAAO,UAAU,KAClC,UAAK,WAAL,mBAAa,aACb,CAAC,KAAK,OAAO,UAAU,IACzB;AACJ,eAAK,WAAL,mBAAa,MAAM,+BAA+B,qDAAkB,MAAM;AAC1E,UAAM,SAAS;AAAA,MACb,GAAI,MAAM,KAAK,QAAQ,mBAAmB,EAAE,SAAS,iBAAiB,IAAI,MAAS;AAAA,MACnF,GAAI,MAAM,KAAK,QAAQ,mBAAmB,EAAE,MAAM,iBAAiB,IAAI,MAAS;AAAA,IAClF,EAAE,IAAI,CAACC,gBAAW,4BAAS,sCAAoBA,OAAM,GAAG,kDAAkD,CAAC;AAE3G,QAAI,oBAAoB,iBAAiB,WAAW,OAAO,QAAQ;AACjE,iBAAK,WAAL,mBAAa,KAAK,wCAAwC,iBAAiB,MAAM,YAAY,OAAO,MAAM;AAAA,IAC5G;AAEA,eAAK,WAAL,mBAAa,MAAM,sBAAsB,iCAAQ,MAAM;AAEvD,WAAO;AAAA,EACT;AAAA,EAEA,gBAAgB,SAAmB;AACjC,SAAK,OAAO,cAAc,KAAK,OAAO,cAAc,CAAC,GAAG,OAAO,CAAC,cAAc,CAAC,QAAQ,SAAS,SAAS,CAAC;AAAA,EAC5G;AAAA,EAEA,cAAc,SAAmB;AAC/B,SAAK,OAAO,aAAa,KAAK,OAAO,aAAa,CAAC,GAAG,OAAO,CAAC,YAAY,CAAC,QAAQ,SAAS,OAAO,CAAC;AAAA,EACtG;AAAA,EAEA,MAAM,OAAO,YAA4C;AA1E3D;AA2EI,SAAK,YAAY,QAAQ;AACzB,UAAM,KAAK,KAAK,eAAe,EAAE,YAAY,QAAQ,KAAK,CAAC;AAC3D,UAAM,WAAW,MAAM,KAAK,cAAc,UAAU;AACpD,eAAK,WAAL,mBAAa,MAAM,oBAAoB,KAAK,UAAU,UAAU,MAAM,CAAC,CAAC;AACxE,UAAM,cAAc,SAAS,OAAO,yCAAe;AACnD,UAAM,iBAAiB,SAAS,OAAO,wCAAc;AACrD,UAAM,eAAe,eAAe,KAAK,CAAC,OAAO,GAAG,UAAU,SAAS,KAAK,OAAO,CAAC;AACpF,UAAM,KAAK,KAAK,aAAa,EAAE,cAAc,YAAY,QAAQ,MAAM,YAAY,CAAC;AACpF,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,YAAY;AAtFpB;AAuFI,eAAK,WAAL,mBAAa,MAAM,gCAA+B,gBAAK,WAAL,mBAAa,cAAb,mBAAwB,MAAM;AAChF,UAAM,qBAAmB,UAAK,WAAL,mBAAa,aAClC,MAAM,QAAQ,KAAK,OAAO,SAAS,KACjC,UAAK,WAAL,mBAAa,YACb,CAAC,KAAK,OAAO,SAAS,IACxB;AACJ,eAAK,WAAL,mBAAa,MAAM,+BAA+B,qDAAkB,MAAM;AAC1E,UAAM,SAAS,mBACX;AAAA,MACE,GAAI,MAAM,KAAK,QAAyB,EAAE,SAAS,iBAAiB,GAAG,EAAE,UAAU,iCAAkB,CAAC;AAAA,MACtG,GAAI,MAAM,KAAK,QAAyB,EAAE,MAAM,iBAAiB,GAAG,EAAE,UAAU,iCAAkB,CAAC;AAAA,IACrG,IACA,MAAM,KAAK,QAAyB,QAAW,EAAE,UAAU,iCAAkB,CAAC;AAElF,QAAI,oBAAoB,iBAAiB,WAAW,OAAO,QAAQ;AACjE,iBAAK,WAAL,mBAAa,KAAK,uCAAuC,iBAAiB,MAAM,YAAY,OAAO,MAAM;AAAA,IAC3G;AACA,WAAO,IAAI,CAAC,SAAS;AAxGzB,UAAAC;AAyGM,OAAAA,MAAA,KAAK,WAAL,gBAAAA,IAAa,MAAM,qBAAqB,KAAK,OAAO,MAAM;AAAA,IAC5D,CAAC;AAED,WAAO;AAAA,EACT;AAAA,EAEA,MAAyB,aACvB,OACA,UACA,aACmC;AACnC,UAAM,UAAU,qDAAyB,WAA8B,OAAO,QAAQ;AACtF,UAAM,eAAe,MAAM,QAAQ,SAAS;AAC5C,gCAAS,KAAK,UAAU,OAAO,UAAU,WAAW,CAAC;AACrD,UAAM,iBAA4B,CAAC;AACnC,YAAQ,aAAa,QAAQ;AAAA,MAC3B,KAAK,iDAA2B;AAC9B,uBAAe,KAAK,GAAI,MAAM,KAAK,OAAO,QAAQ,CAAE;AACpD;AAAA,MACF;AAAA,MACA,SAAS;AACP,eAAO,MAAM,aAAa,OAAO,QAAQ;AAAA,MAC3C;AAAA,IACF;AACA,WAAO;AAAA,EACT;AAGF;;;ADnHO,IAAM,iBAAN,cAGG,iBAAsC;AAAA,EAC9C,OAAgB,gBAAgB,CAAC,2CAAoB;AAAA,EAErD,MAAM,cAAc,WAAsB,CAAC,GAAuB;AAChE,UAAM,KAAK,QAAQ,OAAO;AAC1B,UAAM,SAAkB,CAAC;AACzB,UAAM,eAAe,CAAC,GAAI,MAAM,KAAK,UAAU,CAAE;AACjD,UAAM,iBAA4B,CAAC;AAEnC,QAAI;AACF,YAAM,CAAC,mBAAmB,eAAe,IAAI,MAAM,KAAK,gBAAgB,YAAY;AACpF,YAAM,mBAAmB,CAAC,GAAG,mBAAmB,GAAG,QAAQ;AAC3D,qBAAe,KAAK,GAAG,gBAAgB;AACvC,aAAO,KAAK,GAAG,eAAe;AAAA,IAChC,SAAS,IAAI;AACX,oCAAY,IAAI,CAAC,UAAU;AACzB,eAAO,KAAK,KAAK;AAAA,MACnB,CAAC;AAAA,IACH;AAEA,UAAM,CAAC,YAAY,IAAI,MAAM,KAAK,gBAAgB,EAAE,QAAQ,iDAA0B,GAAG,cAAc;AACvG,SAAK,QAAQ,SAAK,yBAAS,YAAY,CAAC;AACxC,WAAO,CAAC,cAAc,GAAG,cAAc;AAAA,EACzC;AAAA,EAEA,MAAc,gBAAgB,WAA6D;AACzF,UAAM,UAAU,MAAM,QAAQ,WAAW,uCAAW,IAAI,CAAC,YAAY,QAAQ,QAAQ,EAAE;AACvF,UAAM,WAAW,QACd,OAAO,wBAAS,EAChB,IAAI,CAAC,WAAW,OAAO,KAAK,EAC5B,KAAK;AACR,UAAM,SAAS,QACZ,OAAO,uBAAQ,EACf,IAAI,CAAC,WAAW,OAAO,MAAM,EAC7B,KAAK;AACR,WAAO,CAAC,UAAU,MAAM;AAAA,EAC1B;AACF;","names":["import_assert","import_sentinel_model","module","_a"]}