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.
Files changed (56) hide show
  1. package/CHANGELOG.md +9 -9
  2. package/README.md +15 -11
  3. package/config.schema.json +13 -13
  4. package/dist/accessory/base.d.ts +2 -2
  5. package/dist/accessory/base.js +9 -9
  6. package/dist/accessory/base.js.map +1 -1
  7. package/dist/accessory/lock.d.ts +1 -1
  8. package/dist/accessory/lock.js +4 -4
  9. package/dist/accessory/lock.js.map +1 -1
  10. package/dist/accessory/onoff/lightbulb.js +1 -1
  11. package/dist/accessory/onoff/lightbulb.js.map +1 -1
  12. package/dist/accessory/onoff/onoff.d.ts +1 -1
  13. package/dist/accessory/onoff/onoff.js +3 -3
  14. package/dist/accessory/onoff/onoff.js.map +1 -1
  15. package/dist/accessory/position/position.d.ts +1 -1
  16. package/dist/accessory/position/position.js +4 -4
  17. package/dist/accessory/position/position.js.map +1 -1
  18. package/dist/accessory/sensor.d.ts +9 -10
  19. package/dist/accessory/sensor.js +27 -21
  20. package/dist/accessory/sensor.js.map +1 -1
  21. package/dist/accessory/thermostat.d.ts +1 -1
  22. package/dist/accessory/thermostat.js +2 -2
  23. package/dist/accessory/thermostat.js.map +1 -1
  24. package/dist/homebridge-ui/public/index.html +1 -1
  25. package/dist/i18n/en.d.ts +3 -3
  26. package/dist/i18n/en.js +13 -13
  27. package/dist/i18n/en.js.map +1 -1
  28. package/dist/i18n/i18n.d.ts +3 -3
  29. package/dist/i18n/template.d.ts +3 -3
  30. package/dist/i18n/zz.d.ts +3 -3
  31. package/dist/model/types.d.ts +9 -9
  32. package/dist/model/types.js +5 -5
  33. package/dist/model/types.js.map +1 -1
  34. package/dist/{model → timeout}/fader.d.ts +4 -8
  35. package/dist/{model → timeout}/fader.js +8 -24
  36. package/dist/timeout/fader.js.map +1 -0
  37. package/dist/timeout/schedule.d.ts +14 -0
  38. package/dist/timeout/schedule.js +68 -0
  39. package/dist/timeout/schedule.js.map +1 -0
  40. package/dist/timeout/timeout.d.ts +23 -0
  41. package/dist/timeout/timeout.js +91 -0
  42. package/dist/timeout/timeout.js.map +1 -0
  43. package/dist/timeout/timer.d.ts +10 -0
  44. package/dist/timeout/timer.js +29 -0
  45. package/dist/timeout/timer.js.map +1 -0
  46. package/package.json +19 -3
  47. package/dist/model/fader.js.map +0 -1
  48. package/dist/model/timer.d.ts +0 -16
  49. package/dist/model/timer.js +0 -51
  50. package/dist/model/timer.js.map +0 -1
  51. package/dist/model/trigger.d.ts +0 -18
  52. package/dist/model/trigger.js +0 -81
  53. package/dist/model/trigger.js.map +0 -1
  54. package/dist/tools/time.d.ts +0 -11
  55. package/dist/tools/time.js +0 -59
  56. 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 devices for Homebridge",
5
+ "description": "Dummy accessories for automation with scheduling, delays, sensors, commands, and more",
6
6
  "type": "module",
7
- "version": "1.1.0-beta.7",
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",
@@ -1 +0,0 @@
1
- {"version":3,"file":"fader.js","sourceRoot":"","sources":["../../src/model/fader.ts"],"names":[],"mappings":"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"}
@@ -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
- }
@@ -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
@@ -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"}
@@ -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
- }
@@ -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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"}
@@ -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 {};
@@ -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
@@ -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"}