@xyo-network/sentinel 2.74.5 → 2.75.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/AbstractSentinel.cjs +113 -0
- package/dist/browser/AbstractSentinel.cjs.map +1 -0
- package/dist/browser/AbstractSentinel.d.cts.map +1 -0
- package/dist/browser/AbstractSentinel.d.mts.map +1 -0
- package/dist/browser/AbstractSentinel.d.ts +22 -0
- package/dist/browser/AbstractSentinel.d.ts.map +1 -0
- package/dist/browser/AbstractSentinel.js +93 -0
- package/dist/browser/AbstractSentinel.js.map +1 -0
- package/dist/browser/Automation.cjs +27 -0
- package/dist/browser/Automation.cjs.map +1 -0
- package/dist/browser/Automation.d.cts.map +1 -0
- package/dist/browser/Automation.d.mts.map +1 -0
- package/dist/browser/Automation.d.ts +28 -0
- package/dist/browser/Automation.d.ts.map +1 -0
- package/dist/browser/Automation.js +5 -0
- package/dist/browser/Automation.js.map +1 -0
- package/dist/browser/MemorySentinel.cjs +149 -0
- package/dist/browser/MemorySentinel.cjs.map +1 -0
- package/dist/browser/MemorySentinel.d.cts.map +1 -0
- package/dist/browser/MemorySentinel.d.mts.map +1 -0
- package/dist/browser/MemorySentinel.d.ts +10 -0
- package/dist/browser/MemorySentinel.d.ts.map +1 -0
- package/dist/browser/MemorySentinel.js +40 -0
- package/dist/browser/MemorySentinel.js.map +1 -0
- package/dist/browser/SentinelIntervalAutomationWrapper.cjs +68 -0
- package/dist/browser/SentinelIntervalAutomationWrapper.cjs.map +1 -0
- package/dist/browser/SentinelIntervalAutomationWrapper.d.cts.map +1 -0
- package/dist/browser/SentinelIntervalAutomationWrapper.d.mts.map +1 -0
- package/dist/browser/SentinelIntervalAutomationWrapper.d.ts +11 -0
- package/dist/browser/SentinelIntervalAutomationWrapper.d.ts.map +1 -0
- package/dist/browser/SentinelIntervalAutomationWrapper.js +46 -0
- package/dist/browser/SentinelIntervalAutomationWrapper.js.map +1 -0
- package/dist/browser/SentinelRunner.cjs +157 -0
- package/dist/browser/SentinelRunner.cjs.map +1 -0
- package/dist/browser/SentinelRunner.d.cts.map +1 -0
- package/dist/browser/SentinelRunner.d.mts.map +1 -0
- package/dist/browser/SentinelRunner.d.ts +24 -0
- package/dist/browser/SentinelRunner.d.ts.map +1 -0
- package/dist/browser/SentinelRunner.js +90 -0
- package/dist/browser/SentinelRunner.js.map +1 -0
- package/dist/browser/Wrapper.cjs +45 -0
- package/dist/browser/Wrapper.cjs.map +1 -0
- package/dist/browser/Wrapper.d.cts.map +1 -0
- package/dist/browser/Wrapper.d.mts.map +1 -0
- package/dist/browser/Wrapper.d.ts +14 -0
- package/dist/browser/Wrapper.d.ts.map +1 -0
- package/dist/browser/Wrapper.js +27 -0
- package/dist/browser/Wrapper.js.map +1 -0
- package/dist/{index.js → browser/index.cjs} +1 -11
- package/dist/browser/index.cjs.map +1 -0
- package/dist/browser/index.d.cts.map +1 -0
- package/dist/browser/index.d.mts.map +1 -0
- package/dist/browser/index.d.ts +8 -0
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/browser/index.js +8 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/docs.json +1558 -1558
- package/dist/node/AbstractSentinel.d.cts +22 -0
- package/dist/node/AbstractSentinel.d.cts.map +1 -0
- package/dist/node/AbstractSentinel.d.mts +22 -0
- package/dist/node/AbstractSentinel.d.mts.map +1 -0
- package/dist/node/AbstractSentinel.d.ts +22 -0
- package/dist/node/AbstractSentinel.d.ts.map +1 -0
- package/dist/node/AbstractSentinel.js +121 -0
- package/dist/node/AbstractSentinel.js.map +1 -0
- package/dist/node/AbstractSentinel.mjs +98 -0
- package/dist/node/AbstractSentinel.mjs.map +1 -0
- package/dist/node/Automation.d.cts +28 -0
- package/dist/node/Automation.d.cts.map +1 -0
- package/dist/node/Automation.d.mts +28 -0
- package/dist/node/Automation.d.mts.map +1 -0
- package/dist/node/Automation.d.ts +28 -0
- package/dist/node/Automation.d.ts.map +1 -0
- package/dist/node/Automation.js +31 -0
- package/dist/node/Automation.js.map +1 -0
- package/dist/node/Automation.mjs +6 -0
- package/dist/node/Automation.mjs.map +1 -0
- package/dist/node/MemorySentinel.d.cts +10 -0
- package/dist/node/MemorySentinel.d.cts.map +1 -0
- package/dist/node/MemorySentinel.d.mts +10 -0
- package/dist/node/MemorySentinel.d.mts.map +1 -0
- package/dist/node/MemorySentinel.d.ts +10 -0
- package/dist/node/MemorySentinel.d.ts.map +1 -0
- package/dist/node/MemorySentinel.js +157 -0
- package/dist/node/MemorySentinel.js.map +1 -0
- package/dist/node/MemorySentinel.mjs +137 -0
- package/dist/node/MemorySentinel.mjs.map +1 -0
- package/dist/node/SentinelIntervalAutomationWrapper.d.cts +11 -0
- package/dist/node/SentinelIntervalAutomationWrapper.d.cts.map +1 -0
- package/dist/node/SentinelIntervalAutomationWrapper.d.mts +11 -0
- package/dist/node/SentinelIntervalAutomationWrapper.d.mts.map +1 -0
- package/dist/node/SentinelIntervalAutomationWrapper.d.ts +11 -0
- package/dist/node/SentinelIntervalAutomationWrapper.d.ts.map +1 -0
- package/dist/node/SentinelIntervalAutomationWrapper.js +72 -0
- package/dist/node/SentinelIntervalAutomationWrapper.js.map +1 -0
- package/dist/node/SentinelIntervalAutomationWrapper.mjs +47 -0
- package/dist/node/SentinelIntervalAutomationWrapper.mjs.map +1 -0
- package/dist/node/SentinelRunner.d.cts +24 -0
- package/dist/node/SentinelRunner.d.cts.map +1 -0
- package/dist/node/SentinelRunner.d.mts +24 -0
- package/dist/node/SentinelRunner.d.mts.map +1 -0
- package/dist/node/SentinelRunner.d.ts +24 -0
- package/dist/node/SentinelRunner.d.ts.map +1 -0
- package/dist/node/SentinelRunner.js +162 -0
- package/dist/node/SentinelRunner.js.map +1 -0
- package/dist/node/SentinelRunner.mjs +137 -0
- package/dist/node/SentinelRunner.mjs.map +1 -0
- package/dist/node/Wrapper.d.cts +14 -0
- package/dist/node/Wrapper.d.cts.map +1 -0
- package/dist/node/Wrapper.d.mts +14 -0
- package/dist/node/Wrapper.d.mts.map +1 -0
- package/dist/node/Wrapper.d.ts +14 -0
- package/dist/node/Wrapper.d.ts.map +1 -0
- package/dist/node/Wrapper.js +49 -0
- package/dist/node/Wrapper.js.map +1 -0
- package/dist/node/Wrapper.mjs +28 -0
- package/dist/node/Wrapper.mjs.map +1 -0
- package/dist/node/index.d.cts +8 -0
- package/dist/node/index.d.cts.map +1 -0
- package/dist/node/index.d.mts +8 -0
- package/dist/node/index.d.mts.map +1 -0
- package/dist/node/index.d.ts +8 -0
- package/dist/node/index.d.ts.map +1 -0
- package/dist/node/index.js +328 -0
- package/dist/node/index.js.map +1 -0
- package/dist/{index.mjs → node/index.mjs} +20 -15
- package/dist/node/index.mjs.map +1 -0
- package/package.json +37 -34
- package/dist/AbstractSentinel.d.mts.map +0 -1
- package/dist/AbstractSentinel.d.ts.map +0 -1
- package/dist/Automation.d.mts.map +0 -1
- package/dist/Automation.d.ts.map +0 -1
- package/dist/MemorySentinel.d.mts.map +0 -1
- package/dist/MemorySentinel.d.ts.map +0 -1
- package/dist/SentinelIntervalAutomationWrapper.d.mts.map +0 -1
- package/dist/SentinelIntervalAutomationWrapper.d.ts.map +0 -1
- package/dist/SentinelRunner.d.mts.map +0 -1
- package/dist/SentinelRunner.d.ts.map +0 -1
- package/dist/Wrapper.d.mts.map +0 -1
- package/dist/Wrapper.d.ts.map +0 -1
- package/dist/index.d.mts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/index.mjs.map +0 -1
- /package/dist/{AbstractSentinel.d.mts → browser/AbstractSentinel.d.cts} +0 -0
- /package/dist/{AbstractSentinel.d.ts → browser/AbstractSentinel.d.mts} +0 -0
- /package/dist/{Automation.d.mts → browser/Automation.d.cts} +0 -0
- /package/dist/{Automation.d.ts → browser/Automation.d.mts} +0 -0
- /package/dist/{MemorySentinel.d.mts → browser/MemorySentinel.d.cts} +0 -0
- /package/dist/{MemorySentinel.d.ts → browser/MemorySentinel.d.mts} +0 -0
- /package/dist/{SentinelIntervalAutomationWrapper.d.mts → browser/SentinelIntervalAutomationWrapper.d.cts} +0 -0
- /package/dist/{SentinelIntervalAutomationWrapper.d.ts → browser/SentinelIntervalAutomationWrapper.d.mts} +0 -0
- /package/dist/{SentinelRunner.d.mts → browser/SentinelRunner.d.cts} +0 -0
- /package/dist/{SentinelRunner.d.ts → browser/SentinelRunner.d.mts} +0 -0
- /package/dist/{Wrapper.d.mts → browser/Wrapper.d.cts} +0 -0
- /package/dist/{Wrapper.d.ts → browser/Wrapper.d.mts} +0 -0
- /package/dist/{index.d.mts → browser/index.d.cts} +0 -0
- /package/dist/{index.d.ts → browser/index.d.mts} +0 -0
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/SentinelRunner.ts
|
|
21
|
+
var SentinelRunner_exports = {};
|
|
22
|
+
__export(SentinelRunner_exports, {
|
|
23
|
+
SentinelRunner: () => SentinelRunner
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(SentinelRunner_exports);
|
|
26
|
+
var import_assert = require("@xylabs/assert");
|
|
27
|
+
var import_payload_wrapper2 = require("@xyo-network/payload-wrapper");
|
|
28
|
+
|
|
29
|
+
// src/SentinelIntervalAutomationWrapper.ts
|
|
30
|
+
var import_payload_wrapper = require("@xyo-network/payload-wrapper");
|
|
31
|
+
var SentinelIntervalAutomationWrapper = class extends import_payload_wrapper.PayloadWrapper {
|
|
32
|
+
constructor(payload) {
|
|
33
|
+
super(payload);
|
|
34
|
+
}
|
|
35
|
+
get frequencyMillis() {
|
|
36
|
+
const frequency = this.payload().frequency;
|
|
37
|
+
if (frequency === void 0)
|
|
38
|
+
return Infinity;
|
|
39
|
+
switch (this.payload().frequencyUnits ?? "hour") {
|
|
40
|
+
case "second":
|
|
41
|
+
return frequency * 1e3;
|
|
42
|
+
case "minute":
|
|
43
|
+
return frequency * 60 * 1e3;
|
|
44
|
+
case "hour":
|
|
45
|
+
return frequency * 60 * 60 * 1e3;
|
|
46
|
+
case "day":
|
|
47
|
+
return frequency * 24 * 60 * 60 * 1e3;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
get remaining() {
|
|
51
|
+
return this.payload().remaining ?? Infinity;
|
|
52
|
+
}
|
|
53
|
+
next() {
|
|
54
|
+
this.payload().start = this.payload().start + this.frequencyMillis;
|
|
55
|
+
this.consumeRemaining();
|
|
56
|
+
this.checkEnd();
|
|
57
|
+
return this;
|
|
58
|
+
}
|
|
59
|
+
checkEnd() {
|
|
60
|
+
if (this.payload().start > (this.payload().end ?? Infinity)) {
|
|
61
|
+
this.payload().start = Infinity;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
consumeRemaining(count = 1) {
|
|
65
|
+
const remaining = this.remaining - count;
|
|
66
|
+
this.payload().remaining = remaining;
|
|
67
|
+
if (remaining <= 0) {
|
|
68
|
+
this.payload().start = Infinity;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
// src/SentinelRunner.ts
|
|
74
|
+
var SentinelRunner = class {
|
|
75
|
+
_automations = {};
|
|
76
|
+
onTriggerResult;
|
|
77
|
+
sentinel;
|
|
78
|
+
timeoutId;
|
|
79
|
+
constructor(sentinel, automations, onTriggerResult) {
|
|
80
|
+
this.sentinel = sentinel;
|
|
81
|
+
this.onTriggerResult = onTriggerResult;
|
|
82
|
+
automations == null ? void 0 : automations.forEach((automation) => this.add(automation));
|
|
83
|
+
}
|
|
84
|
+
get automations() {
|
|
85
|
+
return this._automations;
|
|
86
|
+
}
|
|
87
|
+
get next() {
|
|
88
|
+
return Object.values(this._automations).reduce((previous, current) => {
|
|
89
|
+
if (current.type === "interval") {
|
|
90
|
+
return current.start < ((previous == null ? void 0 : previous.start) ?? Infinity) ? current : previous;
|
|
91
|
+
}
|
|
92
|
+
}, void 0);
|
|
93
|
+
}
|
|
94
|
+
async add(automation, restart = true) {
|
|
95
|
+
const hash = await import_payload_wrapper2.PayloadWrapper.hashAsync(automation);
|
|
96
|
+
this._automations[hash] = automation;
|
|
97
|
+
if (restart)
|
|
98
|
+
await this.restart();
|
|
99
|
+
return hash;
|
|
100
|
+
}
|
|
101
|
+
find(hash) {
|
|
102
|
+
Object.entries(this._automations).find(([key]) => key === hash);
|
|
103
|
+
}
|
|
104
|
+
async remove(hash, restart = true) {
|
|
105
|
+
delete this._automations[hash];
|
|
106
|
+
if (restart)
|
|
107
|
+
await this.restart();
|
|
108
|
+
}
|
|
109
|
+
removeAll() {
|
|
110
|
+
this.stop();
|
|
111
|
+
this._automations = {};
|
|
112
|
+
}
|
|
113
|
+
async restart() {
|
|
114
|
+
this.stop();
|
|
115
|
+
await this.start();
|
|
116
|
+
}
|
|
117
|
+
async start() {
|
|
118
|
+
(0, import_assert.assertEx)(this.timeoutId === void 0, "Already started");
|
|
119
|
+
const automation = this.next;
|
|
120
|
+
if (automation) {
|
|
121
|
+
const delay = automation.start - Date.now();
|
|
122
|
+
if (delay < 0) {
|
|
123
|
+
await this.trigger(automation);
|
|
124
|
+
} else {
|
|
125
|
+
this.timeoutId = setTimeout(
|
|
126
|
+
async () => {
|
|
127
|
+
this.timeoutId = void 0;
|
|
128
|
+
await this.start();
|
|
129
|
+
},
|
|
130
|
+
delay > 0 ? delay : 0
|
|
131
|
+
);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
stop() {
|
|
136
|
+
if (this.timeoutId) {
|
|
137
|
+
clearTimeout(this.timeoutId);
|
|
138
|
+
this.timeoutId = void 0;
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
async update(hash, automation, restart = true) {
|
|
142
|
+
await this.remove(hash, false);
|
|
143
|
+
await this.add(automation, false);
|
|
144
|
+
if (restart)
|
|
145
|
+
await this.restart();
|
|
146
|
+
}
|
|
147
|
+
async trigger(automation) {
|
|
148
|
+
var _a;
|
|
149
|
+
const wrapper = new SentinelIntervalAutomationWrapper(automation);
|
|
150
|
+
await this.remove(await wrapper.hashAsync(), false);
|
|
151
|
+
wrapper.next();
|
|
152
|
+
await this.add(wrapper.payload(), false);
|
|
153
|
+
const triggerResult = await this.sentinel.report();
|
|
154
|
+
(_a = this.onTriggerResult) == null ? void 0 : _a.call(this, triggerResult);
|
|
155
|
+
await this.start();
|
|
156
|
+
}
|
|
157
|
+
};
|
|
158
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
159
|
+
0 && (module.exports = {
|
|
160
|
+
SentinelRunner
|
|
161
|
+
});
|
|
162
|
+
//# sourceMappingURL=SentinelRunner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/SentinelRunner.ts","../../src/SentinelIntervalAutomationWrapper.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\nimport { SentinelInstance } from '@xyo-network/sentinel-model'\n\nimport { SentinelAutomationPayload, SentinelIntervalAutomationPayload } from './Automation'\nimport { SentinelIntervalAutomationWrapper } from './SentinelIntervalAutomationWrapper'\n\nexport type OnSentinelRunnerTriggerResult = (result: Payload[]) => void\n\nexport class SentinelRunner {\n protected _automations: Record<string, SentinelAutomationPayload> = {}\n protected onTriggerResult: OnSentinelRunnerTriggerResult | undefined\n protected sentinel: SentinelInstance\n protected timeoutId?: NodeJS.Timeout | string | number\n\n constructor(sentinel: SentinelInstance, automations?: SentinelAutomationPayload[], onTriggerResult?: OnSentinelRunnerTriggerResult) {\n this.sentinel = sentinel\n this.onTriggerResult = onTriggerResult\n automations?.forEach((automation) => this.add(automation))\n }\n\n get automations() {\n return this._automations\n }\n\n private get next() {\n return Object.values(this._automations).reduce<SentinelIntervalAutomationPayload | undefined>((previous, current) => {\n if (current.type === 'interval') {\n return current.start < (previous?.start ?? Infinity) ? current : previous\n }\n }, undefined)\n }\n\n async add(automation: SentinelAutomationPayload, restart = true) {\n const hash = await PayloadWrapper.hashAsync(automation)\n this._automations[hash] = automation\n if (restart) await this.restart()\n return hash\n }\n\n find(hash: string) {\n Object.entries(this._automations).find(([key]) => key === hash)\n }\n\n async remove(hash: string, restart = true) {\n delete this._automations[hash]\n if (restart) await this.restart()\n }\n\n removeAll() {\n this.stop()\n this._automations = {}\n }\n\n async restart() {\n this.stop()\n await this.start()\n }\n\n async start() {\n assertEx(this.timeoutId === undefined, 'Already started')\n const automation = this.next\n if (automation) {\n const delay = automation.start - Date.now()\n if (delay < 0) {\n //automation is due, just do it\n await this.trigger(automation)\n } else {\n this.timeoutId = setTimeout(\n async () => {\n this.timeoutId = undefined\n await this.start()\n },\n delay > 0 ? delay : 0,\n )\n }\n }\n }\n\n stop() {\n if (this.timeoutId) {\n clearTimeout(this.timeoutId)\n this.timeoutId = undefined\n }\n }\n\n async update(hash: string, automation: SentinelAutomationPayload, restart = true) {\n await this.remove(hash, false)\n await this.add(automation, false)\n if (restart) await this.restart()\n }\n\n private async trigger(automation: SentinelIntervalAutomationPayload) {\n const wrapper = new SentinelIntervalAutomationWrapper(automation)\n await this.remove(await wrapper.hashAsync(), false)\n wrapper.next()\n await this.add(wrapper.payload(), false)\n const triggerResult = await this.sentinel.report()\n this.onTriggerResult?.(triggerResult)\n await this.start()\n }\n}\n","import { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { SentinelIntervalAutomationPayload } from './Automation'\n\nexport class SentinelIntervalAutomationWrapper<\n T extends SentinelIntervalAutomationPayload = SentinelIntervalAutomationPayload,\n> extends PayloadWrapper<T> {\n constructor(payload: T) {\n super(payload)\n }\n\n protected get frequencyMillis() {\n const frequency = this.payload().frequency\n if (frequency === undefined) return Infinity\n switch (this.payload().frequencyUnits ?? 'hour') {\n case 'second':\n return frequency * 1000\n case 'minute':\n return frequency * 60 * 1000\n case 'hour':\n return frequency * 60 * 60 * 1000\n case 'day':\n return frequency * 24 * 60 * 60 * 1000\n }\n }\n\n protected get remaining() {\n //if remaining is not defined, we assume Infinity\n return this.payload().remaining ?? Infinity\n }\n\n next() {\n this.payload().start = this.payload().start + this.frequencyMillis\n this.consumeRemaining()\n this.checkEnd()\n return this\n }\n\n protected checkEnd() {\n if (this.payload().start > (this.payload().end ?? Infinity)) {\n this.payload().start = Infinity\n }\n }\n\n protected consumeRemaining(count = 1) {\n const remaining = this.remaining - count\n this.payload().remaining = remaining\n\n if (remaining <= 0) {\n this.payload().start = Infinity\n }\n }\n}\n"],"mappings":"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","names":["import_payload_wrapper"]}
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
// src/SentinelRunner.ts
|
|
2
|
+
import { assertEx } from "@xylabs/assert";
|
|
3
|
+
import { PayloadWrapper as PayloadWrapper2 } from "@xyo-network/payload-wrapper";
|
|
4
|
+
|
|
5
|
+
// src/SentinelIntervalAutomationWrapper.ts
|
|
6
|
+
import { PayloadWrapper } from "@xyo-network/payload-wrapper";
|
|
7
|
+
var SentinelIntervalAutomationWrapper = class extends PayloadWrapper {
|
|
8
|
+
constructor(payload) {
|
|
9
|
+
super(payload);
|
|
10
|
+
}
|
|
11
|
+
get frequencyMillis() {
|
|
12
|
+
const frequency = this.payload().frequency;
|
|
13
|
+
if (frequency === void 0)
|
|
14
|
+
return Infinity;
|
|
15
|
+
switch (this.payload().frequencyUnits ?? "hour") {
|
|
16
|
+
case "second":
|
|
17
|
+
return frequency * 1e3;
|
|
18
|
+
case "minute":
|
|
19
|
+
return frequency * 60 * 1e3;
|
|
20
|
+
case "hour":
|
|
21
|
+
return frequency * 60 * 60 * 1e3;
|
|
22
|
+
case "day":
|
|
23
|
+
return frequency * 24 * 60 * 60 * 1e3;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
get remaining() {
|
|
27
|
+
return this.payload().remaining ?? Infinity;
|
|
28
|
+
}
|
|
29
|
+
next() {
|
|
30
|
+
this.payload().start = this.payload().start + this.frequencyMillis;
|
|
31
|
+
this.consumeRemaining();
|
|
32
|
+
this.checkEnd();
|
|
33
|
+
return this;
|
|
34
|
+
}
|
|
35
|
+
checkEnd() {
|
|
36
|
+
if (this.payload().start > (this.payload().end ?? Infinity)) {
|
|
37
|
+
this.payload().start = Infinity;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
consumeRemaining(count = 1) {
|
|
41
|
+
const remaining = this.remaining - count;
|
|
42
|
+
this.payload().remaining = remaining;
|
|
43
|
+
if (remaining <= 0) {
|
|
44
|
+
this.payload().start = Infinity;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
// src/SentinelRunner.ts
|
|
50
|
+
var SentinelRunner = class {
|
|
51
|
+
_automations = {};
|
|
52
|
+
onTriggerResult;
|
|
53
|
+
sentinel;
|
|
54
|
+
timeoutId;
|
|
55
|
+
constructor(sentinel, automations, onTriggerResult) {
|
|
56
|
+
this.sentinel = sentinel;
|
|
57
|
+
this.onTriggerResult = onTriggerResult;
|
|
58
|
+
automations == null ? void 0 : automations.forEach((automation) => this.add(automation));
|
|
59
|
+
}
|
|
60
|
+
get automations() {
|
|
61
|
+
return this._automations;
|
|
62
|
+
}
|
|
63
|
+
get next() {
|
|
64
|
+
return Object.values(this._automations).reduce((previous, current) => {
|
|
65
|
+
if (current.type === "interval") {
|
|
66
|
+
return current.start < ((previous == null ? void 0 : previous.start) ?? Infinity) ? current : previous;
|
|
67
|
+
}
|
|
68
|
+
}, void 0);
|
|
69
|
+
}
|
|
70
|
+
async add(automation, restart = true) {
|
|
71
|
+
const hash = await PayloadWrapper2.hashAsync(automation);
|
|
72
|
+
this._automations[hash] = automation;
|
|
73
|
+
if (restart)
|
|
74
|
+
await this.restart();
|
|
75
|
+
return hash;
|
|
76
|
+
}
|
|
77
|
+
find(hash) {
|
|
78
|
+
Object.entries(this._automations).find(([key]) => key === hash);
|
|
79
|
+
}
|
|
80
|
+
async remove(hash, restart = true) {
|
|
81
|
+
delete this._automations[hash];
|
|
82
|
+
if (restart)
|
|
83
|
+
await this.restart();
|
|
84
|
+
}
|
|
85
|
+
removeAll() {
|
|
86
|
+
this.stop();
|
|
87
|
+
this._automations = {};
|
|
88
|
+
}
|
|
89
|
+
async restart() {
|
|
90
|
+
this.stop();
|
|
91
|
+
await this.start();
|
|
92
|
+
}
|
|
93
|
+
async start() {
|
|
94
|
+
assertEx(this.timeoutId === void 0, "Already started");
|
|
95
|
+
const automation = this.next;
|
|
96
|
+
if (automation) {
|
|
97
|
+
const delay = automation.start - Date.now();
|
|
98
|
+
if (delay < 0) {
|
|
99
|
+
await this.trigger(automation);
|
|
100
|
+
} else {
|
|
101
|
+
this.timeoutId = setTimeout(
|
|
102
|
+
async () => {
|
|
103
|
+
this.timeoutId = void 0;
|
|
104
|
+
await this.start();
|
|
105
|
+
},
|
|
106
|
+
delay > 0 ? delay : 0
|
|
107
|
+
);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
stop() {
|
|
112
|
+
if (this.timeoutId) {
|
|
113
|
+
clearTimeout(this.timeoutId);
|
|
114
|
+
this.timeoutId = void 0;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
async update(hash, automation, restart = true) {
|
|
118
|
+
await this.remove(hash, false);
|
|
119
|
+
await this.add(automation, false);
|
|
120
|
+
if (restart)
|
|
121
|
+
await this.restart();
|
|
122
|
+
}
|
|
123
|
+
async trigger(automation) {
|
|
124
|
+
var _a;
|
|
125
|
+
const wrapper = new SentinelIntervalAutomationWrapper(automation);
|
|
126
|
+
await this.remove(await wrapper.hashAsync(), false);
|
|
127
|
+
wrapper.next();
|
|
128
|
+
await this.add(wrapper.payload(), false);
|
|
129
|
+
const triggerResult = await this.sentinel.report();
|
|
130
|
+
(_a = this.onTriggerResult) == null ? void 0 : _a.call(this, triggerResult);
|
|
131
|
+
await this.start();
|
|
132
|
+
}
|
|
133
|
+
};
|
|
134
|
+
export {
|
|
135
|
+
SentinelRunner
|
|
136
|
+
};
|
|
137
|
+
//# sourceMappingURL=SentinelRunner.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/SentinelRunner.ts","../../src/SentinelIntervalAutomationWrapper.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Payload } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\nimport { SentinelInstance } from '@xyo-network/sentinel-model'\n\nimport { SentinelAutomationPayload, SentinelIntervalAutomationPayload } from './Automation'\nimport { SentinelIntervalAutomationWrapper } from './SentinelIntervalAutomationWrapper'\n\nexport type OnSentinelRunnerTriggerResult = (result: Payload[]) => void\n\nexport class SentinelRunner {\n protected _automations: Record<string, SentinelAutomationPayload> = {}\n protected onTriggerResult: OnSentinelRunnerTriggerResult | undefined\n protected sentinel: SentinelInstance\n protected timeoutId?: NodeJS.Timeout | string | number\n\n constructor(sentinel: SentinelInstance, automations?: SentinelAutomationPayload[], onTriggerResult?: OnSentinelRunnerTriggerResult) {\n this.sentinel = sentinel\n this.onTriggerResult = onTriggerResult\n automations?.forEach((automation) => this.add(automation))\n }\n\n get automations() {\n return this._automations\n }\n\n private get next() {\n return Object.values(this._automations).reduce<SentinelIntervalAutomationPayload | undefined>((previous, current) => {\n if (current.type === 'interval') {\n return current.start < (previous?.start ?? Infinity) ? current : previous\n }\n }, undefined)\n }\n\n async add(automation: SentinelAutomationPayload, restart = true) {\n const hash = await PayloadWrapper.hashAsync(automation)\n this._automations[hash] = automation\n if (restart) await this.restart()\n return hash\n }\n\n find(hash: string) {\n Object.entries(this._automations).find(([key]) => key === hash)\n }\n\n async remove(hash: string, restart = true) {\n delete this._automations[hash]\n if (restart) await this.restart()\n }\n\n removeAll() {\n this.stop()\n this._automations = {}\n }\n\n async restart() {\n this.stop()\n await this.start()\n }\n\n async start() {\n assertEx(this.timeoutId === undefined, 'Already started')\n const automation = this.next\n if (automation) {\n const delay = automation.start - Date.now()\n if (delay < 0) {\n //automation is due, just do it\n await this.trigger(automation)\n } else {\n this.timeoutId = setTimeout(\n async () => {\n this.timeoutId = undefined\n await this.start()\n },\n delay > 0 ? delay : 0,\n )\n }\n }\n }\n\n stop() {\n if (this.timeoutId) {\n clearTimeout(this.timeoutId)\n this.timeoutId = undefined\n }\n }\n\n async update(hash: string, automation: SentinelAutomationPayload, restart = true) {\n await this.remove(hash, false)\n await this.add(automation, false)\n if (restart) await this.restart()\n }\n\n private async trigger(automation: SentinelIntervalAutomationPayload) {\n const wrapper = new SentinelIntervalAutomationWrapper(automation)\n await this.remove(await wrapper.hashAsync(), false)\n wrapper.next()\n await this.add(wrapper.payload(), false)\n const triggerResult = await this.sentinel.report()\n this.onTriggerResult?.(triggerResult)\n await this.start()\n }\n}\n","import { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nimport { SentinelIntervalAutomationPayload } from './Automation'\n\nexport class SentinelIntervalAutomationWrapper<\n T extends SentinelIntervalAutomationPayload = SentinelIntervalAutomationPayload,\n> extends PayloadWrapper<T> {\n constructor(payload: T) {\n super(payload)\n }\n\n protected get frequencyMillis() {\n const frequency = this.payload().frequency\n if (frequency === undefined) return Infinity\n switch (this.payload().frequencyUnits ?? 'hour') {\n case 'second':\n return frequency * 1000\n case 'minute':\n return frequency * 60 * 1000\n case 'hour':\n return frequency * 60 * 60 * 1000\n case 'day':\n return frequency * 24 * 60 * 60 * 1000\n }\n }\n\n protected get remaining() {\n //if remaining is not defined, we assume Infinity\n return this.payload().remaining ?? Infinity\n }\n\n next() {\n this.payload().start = this.payload().start + this.frequencyMillis\n this.consumeRemaining()\n this.checkEnd()\n return this\n }\n\n protected checkEnd() {\n if (this.payload().start > (this.payload().end ?? Infinity)) {\n this.payload().start = Infinity\n }\n }\n\n protected consumeRemaining(count = 1) {\n const remaining = this.remaining - count\n this.payload().remaining = remaining\n\n if (remaining <= 0) {\n this.payload().start = Infinity\n }\n }\n}\n"],"mappings":";AAAA,SAAS,gBAAgB;AAEzB,SAAS,kBAAAA,uBAAsB;;;ACF/B,SAAS,sBAAsB;AAIxB,IAAM,oCAAN,cAEG,eAAkB;AAAA,EAC1B,YAAY,SAAY;AACtB,UAAM,OAAO;AAAA,EACf;AAAA,EAEA,IAAc,kBAAkB;AAC9B,UAAM,YAAY,KAAK,QAAQ,EAAE;AACjC,QAAI,cAAc;AAAW,aAAO;AACpC,YAAQ,KAAK,QAAQ,EAAE,kBAAkB,QAAQ;AAAA,MAC/C,KAAK;AACH,eAAO,YAAY;AAAA,MACrB,KAAK;AACH,eAAO,YAAY,KAAK;AAAA,MAC1B,KAAK;AACH,eAAO,YAAY,KAAK,KAAK;AAAA,MAC/B,KAAK;AACH,eAAO,YAAY,KAAK,KAAK,KAAK;AAAA,IACtC;AAAA,EACF;AAAA,EAEA,IAAc,YAAY;AAExB,WAAO,KAAK,QAAQ,EAAE,aAAa;AAAA,EACrC;AAAA,EAEA,OAAO;AACL,SAAK,QAAQ,EAAE,QAAQ,KAAK,QAAQ,EAAE,QAAQ,KAAK;AACnD,SAAK,iBAAiB;AACtB,SAAK,SAAS;AACd,WAAO;AAAA,EACT;AAAA,EAEU,WAAW;AACnB,QAAI,KAAK,QAAQ,EAAE,SAAS,KAAK,QAAQ,EAAE,OAAO,WAAW;AAC3D,WAAK,QAAQ,EAAE,QAAQ;AAAA,IACzB;AAAA,EACF;AAAA,EAEU,iBAAiB,QAAQ,GAAG;AACpC,UAAM,YAAY,KAAK,YAAY;AACnC,SAAK,QAAQ,EAAE,YAAY;AAE3B,QAAI,aAAa,GAAG;AAClB,WAAK,QAAQ,EAAE,QAAQ;AAAA,IACzB;AAAA,EACF;AACF;;;AD1CO,IAAM,iBAAN,MAAqB;AAAA,EAChB,eAA0D,CAAC;AAAA,EAC3D;AAAA,EACA;AAAA,EACA;AAAA,EAEV,YAAY,UAA4B,aAA2C,iBAAiD;AAClI,SAAK,WAAW;AAChB,SAAK,kBAAkB;AACvB,+CAAa,QAAQ,CAAC,eAAe,KAAK,IAAI,UAAU;AAAA,EAC1D;AAAA,EAEA,IAAI,cAAc;AAChB,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAY,OAAO;AACjB,WAAO,OAAO,OAAO,KAAK,YAAY,EAAE,OAAsD,CAAC,UAAU,YAAY;AACnH,UAAI,QAAQ,SAAS,YAAY;AAC/B,eAAO,QAAQ,UAAS,qCAAU,UAAS,YAAY,UAAU;AAAA,MACnE;AAAA,IACF,GAAG,MAAS;AAAA,EACd;AAAA,EAEA,MAAM,IAAI,YAAuC,UAAU,MAAM;AAC/D,UAAM,OAAO,MAAMC,gBAAe,UAAU,UAAU;AACtD,SAAK,aAAa,IAAI,IAAI;AAC1B,QAAI;AAAS,YAAM,KAAK,QAAQ;AAChC,WAAO;AAAA,EACT;AAAA,EAEA,KAAK,MAAc;AACjB,WAAO,QAAQ,KAAK,YAAY,EAAE,KAAK,CAAC,CAAC,GAAG,MAAM,QAAQ,IAAI;AAAA,EAChE;AAAA,EAEA,MAAM,OAAO,MAAc,UAAU,MAAM;AACzC,WAAO,KAAK,aAAa,IAAI;AAC7B,QAAI;AAAS,YAAM,KAAK,QAAQ;AAAA,EAClC;AAAA,EAEA,YAAY;AACV,SAAK,KAAK;AACV,SAAK,eAAe,CAAC;AAAA,EACvB;AAAA,EAEA,MAAM,UAAU;AACd,SAAK,KAAK;AACV,UAAM,KAAK,MAAM;AAAA,EACnB;AAAA,EAEA,MAAM,QAAQ;AACZ,aAAS,KAAK,cAAc,QAAW,iBAAiB;AACxD,UAAM,aAAa,KAAK;AACxB,QAAI,YAAY;AACd,YAAM,QAAQ,WAAW,QAAQ,KAAK,IAAI;AAC1C,UAAI,QAAQ,GAAG;AAEb,cAAM,KAAK,QAAQ,UAAU;AAAA,MAC/B,OAAO;AACL,aAAK,YAAY;AAAA,UACf,YAAY;AACV,iBAAK,YAAY;AACjB,kBAAM,KAAK,MAAM;AAAA,UACnB;AAAA,UACA,QAAQ,IAAI,QAAQ;AAAA,QACtB;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA,EAEA,OAAO;AACL,QAAI,KAAK,WAAW;AAClB,mBAAa,KAAK,SAAS;AAC3B,WAAK,YAAY;AAAA,IACnB;AAAA,EACF;AAAA,EAEA,MAAM,OAAO,MAAc,YAAuC,UAAU,MAAM;AAChF,UAAM,KAAK,OAAO,MAAM,KAAK;AAC7B,UAAM,KAAK,IAAI,YAAY,KAAK;AAChC,QAAI;AAAS,YAAM,KAAK,QAAQ;AAAA,EAClC;AAAA,EAEA,MAAc,QAAQ,YAA+C;AA7FvE;AA8FI,UAAM,UAAU,IAAI,kCAAkC,UAAU;AAChE,UAAM,KAAK,OAAO,MAAM,QAAQ,UAAU,GAAG,KAAK;AAClD,YAAQ,KAAK;AACb,UAAM,KAAK,IAAI,QAAQ,QAAQ,GAAG,KAAK;AACvC,UAAM,gBAAgB,MAAM,KAAK,SAAS,OAAO;AACjD,eAAK,oBAAL,8BAAuB;AACvB,UAAM,KAAK,MAAM;AAAA,EACnB;AACF;","names":["PayloadWrapper","PayloadWrapper"]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { ArchivistInstance } from '@xyo-network/archivist';
|
|
2
|
+
import { ModuleWrapper } from '@xyo-network/module';
|
|
3
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
4
|
+
import { SentinelInstance, SentinelModule } from '@xyo-network/sentinel-model';
|
|
5
|
+
import { WitnessInstance } from '@xyo-network/witness';
|
|
6
|
+
export declare class SentinelWrapper<TModule extends SentinelModule = SentinelModule> extends ModuleWrapper<TModule> implements SentinelInstance<TModule['params']> {
|
|
7
|
+
static instanceIdentityCheck: import("@xyo-network/object").ObjectTypeCheck<SentinelInstance>;
|
|
8
|
+
static moduleIdentityCheck: import("@xyo-network/module").ModuleTypeCheck<SentinelModule>;
|
|
9
|
+
static requiredQueries: string[];
|
|
10
|
+
archivists(): Promise<ArchivistInstance[]>;
|
|
11
|
+
report(payloads?: Payload[]): Promise<Payload[]>;
|
|
12
|
+
witnesses(): Promise<WitnessInstance[]>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=Wrapper.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Wrapper.d.ts","sourceRoot":"","sources":["../../src/Wrapper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAC1D,OAAO,EAA8B,aAAa,EAAE,MAAM,qBAAqB,CAAA;AAC/E,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAGL,gBAAgB,EAChB,cAAc,EAGf,MAAM,6BAA6B,CAAA;AACpC,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAGtD,qBAAa,eAAe,CAAC,OAAO,SAAS,cAAc,GAAG,cAAc,CAC1E,SAAQ,aAAa,CAAC,OAAO,CAC7B,YAAW,gBAAgB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAE9C,OAAgB,qBAAqB,kEAAqB;IAC1D,OAAgB,mBAAmB,gEAAmB;IACtD,OAAgB,eAAe,WAAwD;IAEvF,UAAU,IAAI,OAAO,CAAC,iBAAiB,EAAE,CAAC;IAIpC,MAAM,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAMtD,SAAS,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;CAGxC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { ArchivistInstance } from '@xyo-network/archivist';
|
|
2
|
+
import { ModuleWrapper } from '@xyo-network/module';
|
|
3
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
4
|
+
import { SentinelInstance, SentinelModule } from '@xyo-network/sentinel-model';
|
|
5
|
+
import { WitnessInstance } from '@xyo-network/witness';
|
|
6
|
+
export declare class SentinelWrapper<TModule extends SentinelModule = SentinelModule> extends ModuleWrapper<TModule> implements SentinelInstance<TModule['params']> {
|
|
7
|
+
static instanceIdentityCheck: import("@xyo-network/object").ObjectTypeCheck<SentinelInstance>;
|
|
8
|
+
static moduleIdentityCheck: import("@xyo-network/module").ModuleTypeCheck<SentinelModule>;
|
|
9
|
+
static requiredQueries: string[];
|
|
10
|
+
archivists(): Promise<ArchivistInstance[]>;
|
|
11
|
+
report(payloads?: Payload[]): Promise<Payload[]>;
|
|
12
|
+
witnesses(): Promise<WitnessInstance[]>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=Wrapper.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Wrapper.d.ts","sourceRoot":"","sources":["../../src/Wrapper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAC1D,OAAO,EAA8B,aAAa,EAAE,MAAM,qBAAqB,CAAA;AAC/E,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAGL,gBAAgB,EAChB,cAAc,EAGf,MAAM,6BAA6B,CAAA;AACpC,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAGtD,qBAAa,eAAe,CAAC,OAAO,SAAS,cAAc,GAAG,cAAc,CAC1E,SAAQ,aAAa,CAAC,OAAO,CAC7B,YAAW,gBAAgB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAE9C,OAAgB,qBAAqB,kEAAqB;IAC1D,OAAgB,mBAAmB,gEAAmB;IACtD,OAAgB,eAAe,WAAwD;IAEvF,UAAU,IAAI,OAAO,CAAC,iBAAiB,EAAE,CAAC;IAIpC,MAAM,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAMtD,SAAS,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;CAGxC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { ArchivistInstance } from '@xyo-network/archivist';
|
|
2
|
+
import { ModuleWrapper } from '@xyo-network/module';
|
|
3
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
4
|
+
import { SentinelInstance, SentinelModule } from '@xyo-network/sentinel-model';
|
|
5
|
+
import { WitnessInstance } from '@xyo-network/witness';
|
|
6
|
+
export declare class SentinelWrapper<TModule extends SentinelModule = SentinelModule> extends ModuleWrapper<TModule> implements SentinelInstance<TModule['params']> {
|
|
7
|
+
static instanceIdentityCheck: import("@xyo-network/object").ObjectTypeCheck<SentinelInstance>;
|
|
8
|
+
static moduleIdentityCheck: import("@xyo-network/module").ModuleTypeCheck<SentinelModule>;
|
|
9
|
+
static requiredQueries: string[];
|
|
10
|
+
archivists(): Promise<ArchivistInstance[]>;
|
|
11
|
+
report(payloads?: Payload[]): Promise<Payload[]>;
|
|
12
|
+
witnesses(): Promise<WitnessInstance[]>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=Wrapper.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Wrapper.d.ts","sourceRoot":"","sources":["../../src/Wrapper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAC1D,OAAO,EAA8B,aAAa,EAAE,MAAM,qBAAqB,CAAA;AAC/E,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAGL,gBAAgB,EAChB,cAAc,EAGf,MAAM,6BAA6B,CAAA;AACpC,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAGtD,qBAAa,eAAe,CAAC,OAAO,SAAS,cAAc,GAAG,cAAc,CAC1E,SAAQ,aAAa,CAAC,OAAO,CAC7B,YAAW,gBAAgB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAE9C,OAAgB,qBAAqB,kEAAqB;IAC1D,OAAgB,mBAAmB,gEAAmB;IACtD,OAAgB,eAAe,WAAwD;IAEvF,UAAU,IAAI,OAAO,CAAC,iBAAiB,EAAE,CAAC;IAIpC,MAAM,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAMtD,SAAS,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;CAGxC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/Wrapper.ts
|
|
21
|
+
var Wrapper_exports = {};
|
|
22
|
+
__export(Wrapper_exports, {
|
|
23
|
+
SentinelWrapper: () => SentinelWrapper
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(Wrapper_exports);
|
|
26
|
+
var import_module = require("@xyo-network/module");
|
|
27
|
+
var import_sentinel_model = require("@xyo-network/sentinel-model");
|
|
28
|
+
(0, import_module.constructableModuleWrapper)();
|
|
29
|
+
var SentinelWrapper = class extends import_module.ModuleWrapper {
|
|
30
|
+
static instanceIdentityCheck = import_sentinel_model.isSentinelInstance;
|
|
31
|
+
static moduleIdentityCheck = import_sentinel_model.isSentinelModule;
|
|
32
|
+
static requiredQueries = [import_sentinel_model.SentinelReportQuerySchema, ...super.requiredQueries];
|
|
33
|
+
archivists() {
|
|
34
|
+
throw Error("Not supported");
|
|
35
|
+
}
|
|
36
|
+
async report(payloads) {
|
|
37
|
+
const queryPayload = { schema: import_sentinel_model.SentinelReportQuerySchema };
|
|
38
|
+
const result = await this.sendQuery(queryPayload, payloads);
|
|
39
|
+
return result;
|
|
40
|
+
}
|
|
41
|
+
witnesses() {
|
|
42
|
+
throw Error("Not supported");
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
46
|
+
0 && (module.exports = {
|
|
47
|
+
SentinelWrapper
|
|
48
|
+
});
|
|
49
|
+
//# sourceMappingURL=Wrapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/Wrapper.ts"],"sourcesContent":["import { ArchivistInstance } from '@xyo-network/archivist'\nimport { constructableModuleWrapper, ModuleWrapper } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n isSentinelInstance,\n isSentinelModule,\n SentinelInstance,\n SentinelModule,\n SentinelReportQuery,\n SentinelReportQuerySchema,\n} from '@xyo-network/sentinel-model'\nimport { WitnessInstance } from '@xyo-network/witness'\n\nconstructableModuleWrapper()\nexport class SentinelWrapper<TModule extends SentinelModule = SentinelModule>\n extends ModuleWrapper<TModule>\n implements SentinelInstance<TModule['params']>\n{\n static override instanceIdentityCheck = isSentinelInstance\n static override moduleIdentityCheck = isSentinelModule\n static override requiredQueries = [SentinelReportQuerySchema, ...super.requiredQueries]\n\n archivists(): Promise<ArchivistInstance[]> {\n throw Error('Not supported')\n }\n\n async report(payloads?: Payload[]): Promise<Payload[]> {\n const queryPayload: SentinelReportQuery = { schema: SentinelReportQuerySchema }\n const result = await this.sendQuery(queryPayload, payloads)\n return result\n }\n\n witnesses(): Promise<WitnessInstance[]> {\n throw Error('Not supported')\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA0D;AAE1D,4BAOO;AAAA,IAGP,0CAA2B;AACpB,IAAM,kBAAN,cACG,4BAEV;AAAA,EACE,OAAgB,wBAAwB;AAAA,EACxC,OAAgB,sBAAsB;AAAA,EACtC,OAAgB,kBAAkB,CAAC,iDAA2B,GAAG,MAAM,eAAe;AAAA,EAEtF,aAA2C;AACzC,UAAM,MAAM,eAAe;AAAA,EAC7B;AAAA,EAEA,MAAM,OAAO,UAA0C;AACrD,UAAM,eAAoC,EAAE,QAAQ,gDAA0B;AAC9E,UAAM,SAAS,MAAM,KAAK,UAAU,cAAc,QAAQ;AAC1D,WAAO;AAAA,EACT;AAAA,EAEA,YAAwC;AACtC,UAAM,MAAM,eAAe;AAAA,EAC7B;AACF;","names":[]}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
// src/Wrapper.ts
|
|
2
|
+
import { constructableModuleWrapper, ModuleWrapper } from "@xyo-network/module";
|
|
3
|
+
import {
|
|
4
|
+
isSentinelInstance,
|
|
5
|
+
isSentinelModule,
|
|
6
|
+
SentinelReportQuerySchema
|
|
7
|
+
} from "@xyo-network/sentinel-model";
|
|
8
|
+
constructableModuleWrapper();
|
|
9
|
+
var SentinelWrapper = class extends ModuleWrapper {
|
|
10
|
+
static instanceIdentityCheck = isSentinelInstance;
|
|
11
|
+
static moduleIdentityCheck = isSentinelModule;
|
|
12
|
+
static requiredQueries = [SentinelReportQuerySchema, ...super.requiredQueries];
|
|
13
|
+
archivists() {
|
|
14
|
+
throw Error("Not supported");
|
|
15
|
+
}
|
|
16
|
+
async report(payloads) {
|
|
17
|
+
const queryPayload = { schema: SentinelReportQuerySchema };
|
|
18
|
+
const result = await this.sendQuery(queryPayload, payloads);
|
|
19
|
+
return result;
|
|
20
|
+
}
|
|
21
|
+
witnesses() {
|
|
22
|
+
throw Error("Not supported");
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
export {
|
|
26
|
+
SentinelWrapper
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=Wrapper.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/Wrapper.ts"],"sourcesContent":["import { ArchivistInstance } from '@xyo-network/archivist'\nimport { constructableModuleWrapper, ModuleWrapper } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport {\n isSentinelInstance,\n isSentinelModule,\n SentinelInstance,\n SentinelModule,\n SentinelReportQuery,\n SentinelReportQuerySchema,\n} from '@xyo-network/sentinel-model'\nimport { WitnessInstance } from '@xyo-network/witness'\n\nconstructableModuleWrapper()\nexport class SentinelWrapper<TModule extends SentinelModule = SentinelModule>\n extends ModuleWrapper<TModule>\n implements SentinelInstance<TModule['params']>\n{\n static override instanceIdentityCheck = isSentinelInstance\n static override moduleIdentityCheck = isSentinelModule\n static override requiredQueries = [SentinelReportQuerySchema, ...super.requiredQueries]\n\n archivists(): Promise<ArchivistInstance[]> {\n throw Error('Not supported')\n }\n\n async report(payloads?: Payload[]): Promise<Payload[]> {\n const queryPayload: SentinelReportQuery = { schema: SentinelReportQuerySchema }\n const result = await this.sendQuery(queryPayload, payloads)\n return result\n }\n\n witnesses(): Promise<WitnessInstance[]> {\n throw Error('Not supported')\n }\n}\n"],"mappings":";AACA,SAAS,4BAA4B,qBAAqB;AAE1D;AAAA,EACE;AAAA,EACA;AAAA,EAIA;AAAA,OACK;AAGP,2BAA2B;AACpB,IAAM,kBAAN,cACG,cAEV;AAAA,EACE,OAAgB,wBAAwB;AAAA,EACxC,OAAgB,sBAAsB;AAAA,EACtC,OAAgB,kBAAkB,CAAC,2BAA2B,GAAG,MAAM,eAAe;AAAA,EAEtF,aAA2C;AACzC,UAAM,MAAM,eAAe;AAAA,EAC7B;AAAA,EAEA,MAAM,OAAO,UAA0C;AACrD,UAAM,eAAoC,EAAE,QAAQ,0BAA0B;AAC9E,UAAM,SAAS,MAAM,KAAK,UAAU,cAAc,QAAQ;AAC1D,WAAO;AAAA,EACT;AAAA,EAEA,YAAwC;AACtC,UAAM,MAAM,eAAe;AAAA,EAC7B;AACF;","names":[]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export * from './AbstractSentinel';
|
|
2
|
+
export * from './Automation';
|
|
3
|
+
export * from './MemorySentinel';
|
|
4
|
+
export * from './SentinelIntervalAutomationWrapper';
|
|
5
|
+
export * from './SentinelRunner';
|
|
6
|
+
export * from './Wrapper';
|
|
7
|
+
export * from '@xyo-network/sentinel-model';
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAA;AAClC,cAAc,cAAc,CAAA;AAC5B,cAAc,kBAAkB,CAAA;AAChC,cAAc,qCAAqC,CAAA;AACnD,cAAc,kBAAkB,CAAA;AAChC,cAAc,WAAW,CAAA;AACzB,cAAc,6BAA6B,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export * from './AbstractSentinel';
|
|
2
|
+
export * from './Automation';
|
|
3
|
+
export * from './MemorySentinel';
|
|
4
|
+
export * from './SentinelIntervalAutomationWrapper';
|
|
5
|
+
export * from './SentinelRunner';
|
|
6
|
+
export * from './Wrapper';
|
|
7
|
+
export * from '@xyo-network/sentinel-model';
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAA;AAClC,cAAc,cAAc,CAAA;AAC5B,cAAc,kBAAkB,CAAA;AAChC,cAAc,qCAAqC,CAAA;AACnD,cAAc,kBAAkB,CAAA;AAChC,cAAc,WAAW,CAAA;AACzB,cAAc,6BAA6B,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export * from './AbstractSentinel';
|
|
2
|
+
export * from './Automation';
|
|
3
|
+
export * from './MemorySentinel';
|
|
4
|
+
export * from './SentinelIntervalAutomationWrapper';
|
|
5
|
+
export * from './SentinelRunner';
|
|
6
|
+
export * from './Wrapper';
|
|
7
|
+
export * from '@xyo-network/sentinel-model';
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAA;AAClC,cAAc,cAAc,CAAA;AAC5B,cAAc,kBAAkB,CAAA;AAChC,cAAc,qCAAqC,CAAA;AACnD,cAAc,kBAAkB,CAAA;AAChC,cAAc,WAAW,CAAA;AACzB,cAAc,6BAA6B,CAAA"}
|