homebridge-dummy 1.1.0-beta.7 → 1.1.0-beta.9
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/CHANGELOG.md +9 -9
- package/README.md +15 -11
- package/config.schema.json +13 -13
- package/dist/accessory/base.d.ts +2 -2
- package/dist/accessory/base.js +9 -9
- package/dist/accessory/base.js.map +1 -1
- package/dist/accessory/lock.d.ts +1 -1
- package/dist/accessory/lock.js +4 -4
- package/dist/accessory/lock.js.map +1 -1
- package/dist/accessory/onoff/lightbulb.js +1 -1
- package/dist/accessory/onoff/lightbulb.js.map +1 -1
- package/dist/accessory/onoff/onoff.d.ts +1 -1
- package/dist/accessory/onoff/onoff.js +3 -3
- package/dist/accessory/onoff/onoff.js.map +1 -1
- package/dist/accessory/position/position.d.ts +1 -1
- package/dist/accessory/position/position.js +4 -4
- package/dist/accessory/position/position.js.map +1 -1
- package/dist/accessory/sensor.d.ts +9 -10
- package/dist/accessory/sensor.js +27 -21
- package/dist/accessory/sensor.js.map +1 -1
- package/dist/accessory/thermostat.d.ts +1 -1
- package/dist/accessory/thermostat.js +2 -2
- package/dist/accessory/thermostat.js.map +1 -1
- package/dist/homebridge-ui/public/index.html +1 -1
- package/dist/i18n/en.d.ts +3 -3
- package/dist/i18n/en.js +13 -13
- package/dist/i18n/en.js.map +1 -1
- package/dist/i18n/i18n.d.ts +3 -3
- package/dist/i18n/template.d.ts +3 -3
- package/dist/i18n/zz.d.ts +3 -3
- package/dist/model/types.d.ts +9 -9
- package/dist/model/types.js +5 -5
- package/dist/model/types.js.map +1 -1
- package/dist/{model → timeout}/fader.d.ts +4 -8
- package/dist/{model → timeout}/fader.js +8 -24
- package/dist/timeout/fader.js.map +1 -0
- package/dist/timeout/schedule.d.ts +14 -0
- package/dist/timeout/schedule.js +68 -0
- package/dist/timeout/schedule.js.map +1 -0
- package/dist/timeout/timeout.d.ts +23 -0
- package/dist/timeout/timeout.js +91 -0
- package/dist/timeout/timeout.js.map +1 -0
- package/dist/timeout/timer.d.ts +10 -0
- package/dist/timeout/timer.js +29 -0
- package/dist/timeout/timer.js.map +1 -0
- package/package.json +19 -3
- package/dist/model/fader.js.map +0 -1
- package/dist/model/timer.d.ts +0 -16
- package/dist/model/timer.js +0 -51
- package/dist/model/timer.js.map +0 -1
- package/dist/model/trigger.d.ts +0 -18
- package/dist/model/trigger.js +0 -81
- package/dist/model/trigger.js.map +0 -1
- package/dist/tools/time.d.ts +0 -11
- package/dist/tools/time.js +0 -59
- package/dist/tools/time.js.map +0 -1
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { TimeUnits } from '../model/types.js';
|
|
2
|
+
const SECOND = 1000;
|
|
3
|
+
const MINUTE = 60 * SECOND;
|
|
4
|
+
const HOUR = 60 * MINUTE;
|
|
5
|
+
export function DelayLogStrings(milliseconds, seconds, minutes, hours) {
|
|
6
|
+
return { milliseconds: milliseconds, seconds: seconds, minutes: minutes, hours: hours };
|
|
7
|
+
}
|
|
8
|
+
export class Timeout {
|
|
9
|
+
caller;
|
|
10
|
+
log;
|
|
11
|
+
disableLogging;
|
|
12
|
+
timeout;
|
|
13
|
+
constructor(caller, log, disableLogging) {
|
|
14
|
+
this.caller = caller;
|
|
15
|
+
this.log = log;
|
|
16
|
+
this.disableLogging = disableLogging;
|
|
17
|
+
}
|
|
18
|
+
cancel() {
|
|
19
|
+
if (this.timeout) {
|
|
20
|
+
this.logIfDesired(this.cancelString);
|
|
21
|
+
}
|
|
22
|
+
this.reset();
|
|
23
|
+
}
|
|
24
|
+
teardown() {
|
|
25
|
+
this.reset();
|
|
26
|
+
}
|
|
27
|
+
reset() {
|
|
28
|
+
clearTimeout(this.timeout);
|
|
29
|
+
this.timeout = undefined;
|
|
30
|
+
}
|
|
31
|
+
getDelay(rawTime, units, random, strings) {
|
|
32
|
+
let time;
|
|
33
|
+
switch (units) {
|
|
34
|
+
case TimeUnits.MILLISECONDS:
|
|
35
|
+
time = rawTime;
|
|
36
|
+
break;
|
|
37
|
+
case TimeUnits.SECONDS:
|
|
38
|
+
time = rawTime * SECOND;
|
|
39
|
+
break;
|
|
40
|
+
case TimeUnits.MINUTES:
|
|
41
|
+
time = rawTime * MINUTE;
|
|
42
|
+
break;
|
|
43
|
+
case TimeUnits.HOURS:
|
|
44
|
+
time = rawTime * HOUR;
|
|
45
|
+
break;
|
|
46
|
+
}
|
|
47
|
+
if (random) {
|
|
48
|
+
time = Math.floor(Math.max(1, Math.random() * time));
|
|
49
|
+
if (time < SECOND) {
|
|
50
|
+
units = TimeUnits.MILLISECONDS;
|
|
51
|
+
}
|
|
52
|
+
else if (time < MINUTE) {
|
|
53
|
+
units = TimeUnits.SECONDS;
|
|
54
|
+
}
|
|
55
|
+
else if (time < HOUR) {
|
|
56
|
+
units = TimeUnits.MINUTES;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
if (!this.disableLogging) {
|
|
60
|
+
let string;
|
|
61
|
+
let divisor;
|
|
62
|
+
switch (units) {
|
|
63
|
+
case TimeUnits.MILLISECONDS:
|
|
64
|
+
string = strings.milliseconds;
|
|
65
|
+
divisor = 1;
|
|
66
|
+
break;
|
|
67
|
+
case TimeUnits.SECONDS:
|
|
68
|
+
string = strings.seconds;
|
|
69
|
+
divisor = SECOND;
|
|
70
|
+
break;
|
|
71
|
+
case TimeUnits.MINUTES:
|
|
72
|
+
string = strings.minutes;
|
|
73
|
+
divisor = MINUTE;
|
|
74
|
+
break;
|
|
75
|
+
case TimeUnits.HOURS:
|
|
76
|
+
string = strings.hours;
|
|
77
|
+
divisor = HOUR;
|
|
78
|
+
break;
|
|
79
|
+
}
|
|
80
|
+
this.log.always(string, this.caller, Math.round(time / divisor));
|
|
81
|
+
}
|
|
82
|
+
return time;
|
|
83
|
+
}
|
|
84
|
+
logIfDesired(message, ...parameters) {
|
|
85
|
+
if (this.disableLogging) {
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
this.log.always(message, this.caller, ...parameters);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
//# sourceMappingURL=timeout.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timeout.js","sourceRoot":"","sources":["../../src/timeout/timeout.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Timeout } from './timeout.js';
|
|
2
|
+
import { TimerConfig } from '../model/types.js';
|
|
3
|
+
import { Log } from '../tools/log.js';
|
|
4
|
+
export declare class Timer extends Timeout {
|
|
5
|
+
private readonly config;
|
|
6
|
+
static new(config: TimerConfig, caller: string, log: Log, disableLogging: boolean): Timer | undefined;
|
|
7
|
+
private constructor();
|
|
8
|
+
protected get cancelString(): string;
|
|
9
|
+
start(callback: () => Promise<void>): void;
|
|
10
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { DelayLogStrings, Timeout } from './timeout.js';
|
|
2
|
+
import { strings } from '../i18n/i18n.js';
|
|
3
|
+
import { assert } from '../tools/validation.js';
|
|
4
|
+
export class Timer extends Timeout {
|
|
5
|
+
config;
|
|
6
|
+
static new(config, caller, log, disableLogging) {
|
|
7
|
+
if (!assert(log, caller, config, 'delay', 'units')) {
|
|
8
|
+
return undefined;
|
|
9
|
+
}
|
|
10
|
+
return new Timer(config, caller, log, disableLogging);
|
|
11
|
+
}
|
|
12
|
+
constructor(config, caller, log, disableLogging) {
|
|
13
|
+
super(caller, log, disableLogging);
|
|
14
|
+
this.config = config;
|
|
15
|
+
}
|
|
16
|
+
get cancelString() {
|
|
17
|
+
return strings.accessory.timer.cancel;
|
|
18
|
+
}
|
|
19
|
+
start(callback) {
|
|
20
|
+
this.cancel();
|
|
21
|
+
const logStrings = DelayLogStrings(strings.accessory.timer.setMilliseconds, strings.accessory.timer.setSeconds, strings.accessory.timer.setMinutes, strings.accessory.timer.setHours);
|
|
22
|
+
const delay = this.getDelay(this.config.delay, this.config.units, this.config.random, logStrings);
|
|
23
|
+
this.timeout = setTimeout(async () => {
|
|
24
|
+
this.reset();
|
|
25
|
+
await callback();
|
|
26
|
+
}, delay);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=timer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timer.js","sourceRoot":"","sources":["../../src/timeout/timer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAIxD,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAG1C,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAEhD,MAAM,OAAO,KAAM,SAAQ,OAAO;IAUb;IARnB,MAAM,CAAC,GAAG,CAAC,MAAmB,EAAE,MAAc,EAAE,GAAQ,EAAE,cAAuB;QAC/E,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC;YACnD,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,OAAO,IAAI,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,cAAc,CAAC,CAAC;IACxD,CAAC;IAED,YACmB,MAAmB,EACpC,MAAc,EACd,GAAQ,EACR,cAAuB;QAEvB,KAAK,CAAC,MAAM,EAAE,GAAG,EAAE,cAAc,CAAC,CAAC;QALlB,WAAM,GAAN,MAAM,CAAa;IAMtC,CAAC;IAED,IAAc,YAAY;QACxB,OAAO,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC;IACxC,CAAC;IAEM,KAAK,CAAC,QAA8B;QAEzC,IAAI,CAAC,MAAM,EAAE,CAAC;QAEd,MAAM,UAAU,GAAG,eAAe,CAChC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,eAAe,EACvC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,EAClC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,EAClC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,CACjC,CAAC;QAEF,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;QAElG,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC,KAAK,IAAI,EAAE;YACnC,IAAI,CAAC,KAAK,EAAE,CAAC;YACb,MAAM,QAAQ,EAAE,CAAC;QACnB,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;CACF"}
|
package/package.json
CHANGED
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
"name": "homebridge-dummy",
|
|
3
3
|
"platform": "HomebridgeDummy",
|
|
4
4
|
"displayName": "Homebridge Dummy",
|
|
5
|
-
"description": "Dummy
|
|
5
|
+
"description": "Dummy accessories for automation with scheduling, delays, sensors, commands, and more",
|
|
6
6
|
"type": "module",
|
|
7
|
-
"version": "1.1.0-beta.
|
|
7
|
+
"version": "1.1.0-beta.9",
|
|
8
8
|
"homepage": "https://github.com/mpatfield/homebridge-dummy#readme",
|
|
9
9
|
"repository": {
|
|
10
10
|
"type": "git",
|
|
@@ -31,7 +31,23 @@
|
|
|
31
31
|
"homebridge-dummy",
|
|
32
32
|
"hoobs",
|
|
33
33
|
"hoobs-plugin",
|
|
34
|
-
"homekit"
|
|
34
|
+
"homekit",
|
|
35
|
+
"dummy",
|
|
36
|
+
"automation",
|
|
37
|
+
"timer",
|
|
38
|
+
"delay",
|
|
39
|
+
"delay-switch",
|
|
40
|
+
"reset",
|
|
41
|
+
"schedule",
|
|
42
|
+
"command",
|
|
43
|
+
"cmd",
|
|
44
|
+
"cmdtrigger",
|
|
45
|
+
"http",
|
|
46
|
+
"sensor",
|
|
47
|
+
"motion",
|
|
48
|
+
"contact",
|
|
49
|
+
"leak",
|
|
50
|
+
"occupancy"
|
|
35
51
|
],
|
|
36
52
|
"engines": {
|
|
37
53
|
"homebridge": "^1.8.0 || ^2.0.0-beta.0",
|
package/dist/model/fader.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"fader.js","sourceRoot":"","sources":["../../src/model/fader.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAG1C,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAEhD,MAAM,OAAO,KAAK;IAeG;IACA;IACA;IACA;IACA;IAjBnB,MAAM,CAAC,GAAG,CAAC,WAAwB,EAAE,MAAe,EAAE,MAAc,EAAE,GAAQ,EAAE,cAAuB;QAErG,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC;YACxD,OAAO;QACT,CAAC;QAED,OAAO,IAAI,KAAK,CAAC,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,cAAc,CAAC,CAAC;IACrE,CAAC;IAEO,OAAO,CAAkB;IACzB,KAAK,CAAU;IAEvB,YACmB,WAAwB,EACxB,MAAe,EACf,MAAc,EACd,GAAQ,EACR,cAAuB;QAJvB,gBAAW,GAAX,WAAW,CAAa;QACxB,WAAM,GAAN,MAAM,CAAS;QACf,WAAM,GAAN,MAAM,CAAQ;QACd,QAAG,GAAH,GAAG,CAAK;QACR,mBAAc,GAAd,cAAc,CAAS;IAE1C,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAEM,KAAK,CAAC,OAAe,EAAE,QAA0C;QAEtE,IAAI,CAAC,MAAM,EAAE,CAAC;QAEd,MAAM,UAAU,GAAG,eAAe,CAChC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,iBAAiB,EACxC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,EACnC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,EACnC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAClC,CAAC;QAEF,MAAM,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;QAExJ,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACpC,MAAM,QAAQ,GAAG,KAAK,GAAG,OAAO,CAAC;QAEjC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QAEvC,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;YAEpC,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;gBAC7B,OAAO;YACT,CAAC;YAED,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;YAEjC,MAAM,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE7B,CAAC,EAAE,QAAQ,CAAC,CAAC;IACf,CAAC;IAEM,MAAM;QAEX,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAChE,CAAC;QAED,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAEM,KAAK;QACV,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;IACzB,CAAC;IAEO,YAAY,CAAC,OAAe,EAAE,GAAG,UAA+B;QAEtE,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,UAAU,CAAC,CAAC;IACvD,CAAC;CACF"}
|
package/dist/model/timer.d.ts
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { TimerConfig } from './types.js';
|
|
2
|
-
import { Log } from '../tools/log.js';
|
|
3
|
-
export declare class Timer {
|
|
4
|
-
private readonly config;
|
|
5
|
-
private readonly caller;
|
|
6
|
-
private readonly log;
|
|
7
|
-
private readonly disableLogging;
|
|
8
|
-
static new(config: TimerConfig, caller: string, log: Log, disableLogging: boolean): Timer | undefined;
|
|
9
|
-
private timeout?;
|
|
10
|
-
private constructor();
|
|
11
|
-
start(callback: () => Promise<void>): void;
|
|
12
|
-
cancel(): void;
|
|
13
|
-
teardown(): void;
|
|
14
|
-
private reset;
|
|
15
|
-
private logIfDesired;
|
|
16
|
-
}
|
package/dist/model/timer.js
DELETED
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import { strings } from '../i18n/i18n.js';
|
|
2
|
-
import { DelayLogStrings, getDelay } from '../tools/time.js';
|
|
3
|
-
import { assert } from '../tools/validation.js';
|
|
4
|
-
export class Timer {
|
|
5
|
-
config;
|
|
6
|
-
caller;
|
|
7
|
-
log;
|
|
8
|
-
disableLogging;
|
|
9
|
-
static new(config, caller, log, disableLogging) {
|
|
10
|
-
if (!assert(log, caller, config, 'delay', 'units')) {
|
|
11
|
-
return undefined;
|
|
12
|
-
}
|
|
13
|
-
return new Timer(config, caller, log, disableLogging);
|
|
14
|
-
}
|
|
15
|
-
timeout;
|
|
16
|
-
constructor(config, caller, log, disableLogging) {
|
|
17
|
-
this.config = config;
|
|
18
|
-
this.caller = caller;
|
|
19
|
-
this.log = log;
|
|
20
|
-
this.disableLogging = disableLogging;
|
|
21
|
-
}
|
|
22
|
-
start(callback) {
|
|
23
|
-
this.cancel();
|
|
24
|
-
const logStrings = DelayLogStrings(strings.accessory.timer.setMilliseconds, strings.accessory.timer.setSeconds, strings.accessory.timer.setMinutes, strings.accessory.timer.setHours);
|
|
25
|
-
const delay = getDelay(this.config.delay, this.config.units, this.config.random, this.log, this.disableLogging, this.caller, logStrings);
|
|
26
|
-
this.timeout = setTimeout(async () => {
|
|
27
|
-
this.reset();
|
|
28
|
-
await callback();
|
|
29
|
-
}, delay);
|
|
30
|
-
}
|
|
31
|
-
cancel() {
|
|
32
|
-
if (this.timeout) {
|
|
33
|
-
this.logIfDesired(strings.accessory.timer.cancel);
|
|
34
|
-
this.reset();
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
teardown() {
|
|
38
|
-
this.reset();
|
|
39
|
-
}
|
|
40
|
-
reset() {
|
|
41
|
-
clearTimeout(this.timeout);
|
|
42
|
-
this.timeout = undefined;
|
|
43
|
-
}
|
|
44
|
-
logIfDesired(message, ...parameters) {
|
|
45
|
-
if (this.disableLogging) {
|
|
46
|
-
return;
|
|
47
|
-
}
|
|
48
|
-
this.log.always(message, this.caller, ...parameters);
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
//# sourceMappingURL=timer.js.map
|
package/dist/model/timer.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"timer.js","sourceRoot":"","sources":["../../src/model/timer.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAG1C,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAEhD,MAAM,OAAO,KAAK;IAYG;IACA;IACA;IACA;IAbnB,MAAM,CAAC,GAAG,CAAC,MAAmB,EAAE,MAAc,EAAE,GAAQ,EAAE,cAAuB;QAC/E,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC;YACnD,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,OAAO,IAAI,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,cAAc,CAAC,CAAC;IACxD,CAAC;IAEO,OAAO,CAAkB;IAEjC,YACmB,MAAmB,EACnB,MAAc,EACd,GAAQ,EACR,cAAuB;QAHvB,WAAM,GAAN,MAAM,CAAa;QACnB,WAAM,GAAN,MAAM,CAAQ;QACd,QAAG,GAAH,GAAG,CAAK;QACR,mBAAc,GAAd,cAAc,CAAS;IACvC,CAAC;IAEG,KAAK,CAAC,QAA8B;QAEzC,IAAI,CAAC,MAAM,EAAE,CAAC;QAEd,MAAM,UAAU,GAAG,eAAe,CAChC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,eAAe,EACvC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,EAClC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,EAClC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,CACjC,CAAC;QAEF,MAAM,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;QAEzI,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC,KAAK,IAAI,EAAE;YACnC,IAAI,CAAC,KAAK,EAAE,CAAC;YACb,MAAM,QAAQ,EAAE,CAAC;QACnB,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;IAEM,MAAM;QACX,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAClD,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC;IACH,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAEO,KAAK;QACX,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;IAC3B,CAAC;IAEO,YAAY,CAAC,OAAe,EAAE,GAAG,UAA+B;QAEtE,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,UAAU,CAAC,CAAC;IACvD,CAAC;CACF"}
|
package/dist/model/trigger.d.ts
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { TriggerConfig } from './types.js';
|
|
2
|
-
import { Log } from '../tools/log.js';
|
|
3
|
-
export declare class Trigger {
|
|
4
|
-
private readonly trigger;
|
|
5
|
-
private readonly caller;
|
|
6
|
-
private readonly log;
|
|
7
|
-
private readonly disableLogging;
|
|
8
|
-
private readonly callback;
|
|
9
|
-
static new(trigger: TriggerConfig, caller: string, log: Log, disableLogging: boolean, callback: () => Promise<void>): Trigger | undefined;
|
|
10
|
-
private timeout?;
|
|
11
|
-
private cronjob?;
|
|
12
|
-
private constructor();
|
|
13
|
-
private startTimeout;
|
|
14
|
-
private startCron;
|
|
15
|
-
teardown(): void;
|
|
16
|
-
private resetTimeout;
|
|
17
|
-
private logIfDesired;
|
|
18
|
-
}
|
package/dist/model/trigger.js
DELETED
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
import { CronJob, validateCronExpression } from 'cron';
|
|
2
|
-
import { TriggerType } from './types.js';
|
|
3
|
-
import { strings } from '../i18n/i18n.js';
|
|
4
|
-
import { DelayLogStrings, getDelay } from '../tools/time.js';
|
|
5
|
-
import { assert } from '../tools/validation.js';
|
|
6
|
-
export class Trigger {
|
|
7
|
-
trigger;
|
|
8
|
-
caller;
|
|
9
|
-
log;
|
|
10
|
-
disableLogging;
|
|
11
|
-
callback;
|
|
12
|
-
static new(trigger, caller, log, disableLogging, callback) {
|
|
13
|
-
if (!assert(log, caller, trigger, 'type')) {
|
|
14
|
-
return;
|
|
15
|
-
}
|
|
16
|
-
switch (trigger.type) {
|
|
17
|
-
case TriggerType.INTERVAL:
|
|
18
|
-
if (!assert(log, caller, trigger, 'interval', 'units')) {
|
|
19
|
-
return;
|
|
20
|
-
}
|
|
21
|
-
break;
|
|
22
|
-
case TriggerType.CRON:
|
|
23
|
-
if (!assert(log, caller, trigger, 'cron')) {
|
|
24
|
-
return;
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
return new Trigger(trigger, caller, log, disableLogging, callback);
|
|
28
|
-
}
|
|
29
|
-
timeout;
|
|
30
|
-
cronjob;
|
|
31
|
-
constructor(trigger, caller, log, disableLogging, callback) {
|
|
32
|
-
this.trigger = trigger;
|
|
33
|
-
this.caller = caller;
|
|
34
|
-
this.log = log;
|
|
35
|
-
this.disableLogging = disableLogging;
|
|
36
|
-
this.callback = callback;
|
|
37
|
-
switch (this.trigger.type) {
|
|
38
|
-
case TriggerType.INTERVAL:
|
|
39
|
-
this.startTimeout();
|
|
40
|
-
break;
|
|
41
|
-
case TriggerType.CRON:
|
|
42
|
-
this.startCron();
|
|
43
|
-
break;
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
startTimeout() {
|
|
47
|
-
this.resetTimeout();
|
|
48
|
-
const logStrings = DelayLogStrings(strings.accessory.trigger.intervalMilliseconds, strings.accessory.trigger.intervalSeconds, strings.accessory.trigger.intervalMinutes, strings.accessory.trigger.intervalHours);
|
|
49
|
-
const delay = getDelay(this.trigger.interval, this.trigger.units, this.trigger.random, this.log, this.disableLogging, this.caller, logStrings);
|
|
50
|
-
this.timeout = setTimeout(async () => {
|
|
51
|
-
this.resetTimeout();
|
|
52
|
-
await this.callback();
|
|
53
|
-
this.startTimeout();
|
|
54
|
-
}, delay);
|
|
55
|
-
}
|
|
56
|
-
startCron() {
|
|
57
|
-
const cron = this.trigger.cron;
|
|
58
|
-
if (!validateCronExpression(cron).valid) {
|
|
59
|
-
this.log.error(strings.accessory.invalidCron, this.caller, `'${this.trigger.cron}'`);
|
|
60
|
-
return;
|
|
61
|
-
}
|
|
62
|
-
this.logIfDesired(strings.accessory.trigger.cron, this.caller);
|
|
63
|
-
this.cronjob = new CronJob(this.trigger.cron, this.callback);
|
|
64
|
-
this.cronjob.start();
|
|
65
|
-
}
|
|
66
|
-
teardown() {
|
|
67
|
-
this.resetTimeout();
|
|
68
|
-
this.cronjob?.stop();
|
|
69
|
-
}
|
|
70
|
-
resetTimeout() {
|
|
71
|
-
clearTimeout(this.timeout);
|
|
72
|
-
this.timeout = undefined;
|
|
73
|
-
}
|
|
74
|
-
logIfDesired(message, ...parameters) {
|
|
75
|
-
if (this.disableLogging) {
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
this.log.always(message, this.caller, ...parameters);
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
//# sourceMappingURL=trigger.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"trigger.js","sourceRoot":"","sources":["../../src/model/trigger.ts"],"names":[],"mappings":"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"}
|
package/dist/tools/time.d.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { TimeUnits } from '../model/types.js';
|
|
2
|
-
import { Log } from '../tools/log.js';
|
|
3
|
-
type DelayLogStrings = {
|
|
4
|
-
milliseconds: string;
|
|
5
|
-
seconds: string;
|
|
6
|
-
minutes: string;
|
|
7
|
-
hours: string;
|
|
8
|
-
};
|
|
9
|
-
export declare function DelayLogStrings(milliseconds: string, seconds: string, minutes: string, hours: string): DelayLogStrings;
|
|
10
|
-
export declare function getDelay(rawTime: number, units: TimeUnits, random: boolean | undefined, log: Log, disableLogging: boolean, caller: string, strings: DelayLogStrings): number;
|
|
11
|
-
export {};
|
package/dist/tools/time.js
DELETED
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import { TimeUnits } from '../model/types.js';
|
|
2
|
-
const SECOND = 1000;
|
|
3
|
-
const MINUTE = 60 * SECOND;
|
|
4
|
-
const HOUR = 60 * MINUTE;
|
|
5
|
-
export function DelayLogStrings(milliseconds, seconds, minutes, hours) {
|
|
6
|
-
return { milliseconds: milliseconds, seconds: seconds, minutes: minutes, hours: hours };
|
|
7
|
-
}
|
|
8
|
-
function toMilliseconds(value, units) {
|
|
9
|
-
switch (units) {
|
|
10
|
-
case TimeUnits.MILLISECONDS:
|
|
11
|
-
return value;
|
|
12
|
-
case TimeUnits.SECONDS:
|
|
13
|
-
return value * SECOND;
|
|
14
|
-
case TimeUnits.MINUTES:
|
|
15
|
-
return value * MINUTE;
|
|
16
|
-
case TimeUnits.HOURS:
|
|
17
|
-
return value * HOUR;
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
export function getDelay(rawTime, units, random, log, disableLogging, caller, strings) {
|
|
21
|
-
let time = toMilliseconds(rawTime, units);
|
|
22
|
-
if (random) {
|
|
23
|
-
time = Math.floor(Math.max(1, Math.random() * time));
|
|
24
|
-
if (time < SECOND) {
|
|
25
|
-
units = TimeUnits.MILLISECONDS;
|
|
26
|
-
}
|
|
27
|
-
else if (time < MINUTE) {
|
|
28
|
-
units = TimeUnits.SECONDS;
|
|
29
|
-
}
|
|
30
|
-
else if (time < HOUR) {
|
|
31
|
-
units = TimeUnits.MINUTES;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
if (!disableLogging) {
|
|
35
|
-
let string;
|
|
36
|
-
let divisor;
|
|
37
|
-
switch (units) {
|
|
38
|
-
case TimeUnits.MILLISECONDS:
|
|
39
|
-
string = strings.milliseconds;
|
|
40
|
-
divisor = 1;
|
|
41
|
-
break;
|
|
42
|
-
case TimeUnits.SECONDS:
|
|
43
|
-
string = strings.seconds;
|
|
44
|
-
divisor = SECOND;
|
|
45
|
-
break;
|
|
46
|
-
case TimeUnits.MINUTES:
|
|
47
|
-
string = strings.minutes;
|
|
48
|
-
divisor = MINUTE;
|
|
49
|
-
break;
|
|
50
|
-
case TimeUnits.HOURS:
|
|
51
|
-
string = strings.hours;
|
|
52
|
-
divisor = HOUR;
|
|
53
|
-
break;
|
|
54
|
-
}
|
|
55
|
-
log.always(string, caller, Math.round(time / divisor));
|
|
56
|
-
}
|
|
57
|
-
return time;
|
|
58
|
-
}
|
|
59
|
-
//# sourceMappingURL=time.js.map
|
package/dist/tools/time.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"time.js","sourceRoot":"","sources":["../../src/tools/time.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAI9C,MAAM,MAAM,GAAG,IAAI,CAAC;AACpB,MAAM,MAAM,GAAG,EAAE,GAAG,MAAM,CAAC;AAC3B,MAAM,IAAI,GAAG,EAAE,GAAG,MAAM,CAAC;AASzB,MAAM,UAAU,eAAe,CAAC,YAAoB,EAAE,OAAe,EAAE,OAAe,EAAE,KAAa;IACnG,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;AAC1F,CAAC;AAED,SAAS,cAAc,CAAC,KAAa,EAAE,KAAgB;IACrD,QAAO,KAAK,EAAE,CAAC;QACf,KAAK,SAAS,CAAC,YAAY;YACzB,OAAO,KAAK,CAAC;QACf,KAAK,SAAS,CAAC,OAAO;YACpB,OAAO,KAAK,GAAG,MAAM,CAAC;QACxB,KAAK,SAAS,CAAC,OAAO;YACpB,OAAO,KAAK,GAAG,MAAM,CAAC;QACxB,KAAK,SAAS,CAAC,KAAK;YAClB,OAAO,KAAK,GAAG,IAAI,CAAC;IACtB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,OAAe,EAAE,KAAgB,EAAE,MAA2B,EACrF,GAAQ,EAAE,cAAuB,EAAE,MAAc,EAAE,OAAwB;IAE3E,IAAI,IAAI,GAAG,cAAc,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;IAE1C,IAAI,MAAM,EAAE,CAAC;QACX,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;QAErD,IAAI,IAAI,GAAG,MAAM,EAAE,CAAC;YAClB,KAAK,GAAG,SAAS,CAAC,YAAY,CAAC;QACjC,CAAC;aAAM,IAAI,IAAI,GAAG,MAAM,EAAE,CAAC;YACzB,KAAK,GAAG,SAAS,CAAC,OAAO,CAAC;QAC5B,CAAC;aAAM,IAAI,IAAI,GAAG,IAAI,EAAE,CAAC;YACvB,KAAK,GAAG,SAAS,CAAC,OAAO,CAAC;QAC5B,CAAC;IACH,CAAC;IAED,IAAI,CAAC,cAAc,EAAE,CAAC;QAEpB,IAAI,MAAc,CAAC;QACnB,IAAI,OAAe,CAAC;QAEpB,QAAO,KAAK,EAAE,CAAC;YACf,KAAK,SAAS,CAAC,YAAY;gBACzB,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;gBAC9B,OAAO,GAAG,CAAC,CAAC;gBACZ,MAAM;YACR,KAAK,SAAS,CAAC,OAAO;gBACpB,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;gBACzB,OAAO,GAAG,MAAM,CAAC;gBACjB,MAAM;YACR,KAAK,SAAS,CAAC,OAAO;gBACpB,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;gBACzB,OAAO,GAAG,MAAM,CAAC;gBACjB,MAAM;YACR,KAAK,SAAS,CAAC,KAAK;gBAClB,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC;gBACvB,OAAO,GAAG,IAAI,CAAC;gBACf,MAAM;QACR,CAAC;QAED,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC;IACzD,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC"}
|