homebridge-easy-mqtt 1.2.0-beta.0 → 1.2.0-beta.1
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 +6 -1
- package/config.schema.json +2 -3
- package/dist/accessory/abstract/base.d.ts +17 -10
- package/dist/accessory/abstract/base.js +74 -4
- package/dist/accessory/abstract/base.js.map +1 -1
- package/dist/accessory/abstract/statusActive.d.ts +4 -7
- package/dist/accessory/abstract/statusActive.js +11 -20
- package/dist/accessory/abstract/statusActive.js.map +1 -1
- package/dist/accessory/lock.d.ts +3 -6
- package/dist/accessory/lock.js +38 -62
- package/dist/accessory/lock.js.map +1 -1
- package/dist/accessory/onoff/lightbulb.d.ts +9 -17
- package/dist/accessory/onoff/lightbulb.js +53 -70
- package/dist/accessory/onoff/lightbulb.js.map +1 -1
- package/dist/accessory/onoff/onoff.d.ts +5 -6
- package/dist/accessory/onoff/onoff.js +28 -29
- package/dist/accessory/onoff/onoff.js.map +1 -1
- package/dist/accessory/onoff/outlet.d.ts +2 -4
- package/dist/accessory/onoff/outlet.js +14 -27
- package/dist/accessory/onoff/outlet.js.map +1 -1
- package/dist/accessory/onoff/switch.js.map +1 -1
- package/dist/accessory/security.d.ts +2 -7
- package/dist/accessory/security.js +42 -77
- package/dist/accessory/security.js.map +1 -1
- package/dist/accessory/temperatureSensor.d.ts +1 -2
- package/dist/accessory/temperatureSensor.js +6 -8
- package/dist/accessory/temperatureSensor.js.map +1 -1
- package/dist/homebridge/platform.js +7 -6
- package/dist/homebridge/platform.js.map +1 -1
- package/dist/homebridge-ui/public/index.html +2 -2
- package/dist/i18n/en.d.ts +8 -2
- package/dist/i18n/en.js +54 -48
- package/dist/i18n/en.js.map +1 -1
- package/dist/i18n/i18n.d.ts +8 -2
- package/dist/i18n/template.d.ts +8 -2
- package/dist/model/enums.d.ts +23 -0
- package/dist/model/enums.js +25 -0
- package/dist/model/enums.js.map +1 -1
- package/dist/model/mqtt.d.ts +3 -3
- package/dist/model/mqtt.js.map +1 -1
- package/dist/model/types.d.ts +2 -2
- package/dist/tools/primitive.d.ts +3 -3
- package/dist/tools/primitive.js.map +1 -1
- package/package.json +1 -1
|
@@ -1,104 +1,87 @@
|
|
|
1
|
-
import { makeHandler } from '../abstract/base.js';
|
|
2
1
|
import { OnOffAccessory } from './onoff.js';
|
|
3
2
|
import { strings } from '../../i18n/i18n.js';
|
|
4
|
-
import {
|
|
3
|
+
import { CharacteristicKey } from '../../model/enums.js';
|
|
5
4
|
export class LightbulbAccessory extends OnOffAccessory {
|
|
6
|
-
brightness = 100;
|
|
7
|
-
hue = 0;
|
|
8
|
-
colorTemperature = 500;
|
|
9
|
-
saturation = 100;
|
|
10
5
|
constructor(Service, Characteristic, accessory, config, log) {
|
|
11
6
|
super(Service, Characteristic, accessory, config, log, LightbulbAccessory.name);
|
|
7
|
+
this.set(CharacteristicKey.Brightness, 100);
|
|
8
|
+
this.set(CharacteristicKey.ColorTemperature, 500);
|
|
9
|
+
this.set(CharacteristicKey.Hue, 0);
|
|
10
|
+
this.set(CharacteristicKey.Saturation, 100);
|
|
12
11
|
this.accessoryService.getCharacteristic(this.Characteristic.Brightness)
|
|
13
12
|
.onGet(this.getBrightness.bind(this))
|
|
14
|
-
.onSet(this.
|
|
15
|
-
this.accessoryService.getCharacteristic(this.Characteristic.Hue)
|
|
16
|
-
.onGet(this.getHue.bind(this))
|
|
17
|
-
.onSet(this.setHue.bind(this));
|
|
13
|
+
.onSet(this.onSetBrightness.bind(this));
|
|
18
14
|
this.accessoryService.getCharacteristic(this.Characteristic.ColorTemperature)
|
|
19
15
|
.onGet(this.getColorTemperature.bind(this))
|
|
20
|
-
.onSet(this.
|
|
16
|
+
.onSet(this.onSetColorTemperature.bind(this));
|
|
17
|
+
this.accessoryService.getCharacteristic(this.Characteristic.Hue)
|
|
18
|
+
.onGet(this.getHue.bind(this))
|
|
19
|
+
.onSet(this.onSetHue.bind(this));
|
|
21
20
|
this.accessoryService.getCharacteristic(this.Characteristic.Saturation)
|
|
22
21
|
.onGet(this.getSaturation.bind(this))
|
|
23
|
-
.onSet(this.
|
|
22
|
+
.onSet(this.onSetSaturation.bind(this));
|
|
24
23
|
}
|
|
25
24
|
getAccessoryService() {
|
|
26
25
|
return this.accessory.getService(this.Service.Lightbulb) || this.accessory.addService(this.Service.Lightbulb);
|
|
27
26
|
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
topicHandlers.push(makeHandler(this.config.topicGetHue, this.onHueUpdate.bind(this)));
|
|
35
|
-
}
|
|
36
|
-
if (this.config.topicGetColorTemperature) {
|
|
37
|
-
topicHandlers.push(makeHandler(this.config.topicGetColorTemperature, this.onColorTemperatureUpdate.bind(this)));
|
|
38
|
-
}
|
|
39
|
-
if (this.config.topicGetSaturation) {
|
|
40
|
-
topicHandlers.push(makeHandler(this.config.topicGetSaturation, this.onSaturationUpdate.bind(this)));
|
|
41
|
-
}
|
|
42
|
-
return topicHandlers;
|
|
27
|
+
addTopicHandlers() {
|
|
28
|
+
super.addTopicHandlers();
|
|
29
|
+
this.addTopicHandler('topicGetBrightness', this.onBrightnessUpdate.bind(this), false);
|
|
30
|
+
this.addTopicHandler('topicGetColorTemperature', this.onColorTemperatureUpdate.bind(this), false);
|
|
31
|
+
this.addTopicHandler('topicGetHue', this.onHueUpdate.bind(this), false);
|
|
32
|
+
this.addTopicHandler('topicGetSaturation', this.onSaturationUpdate.bind(this), false);
|
|
43
33
|
}
|
|
44
34
|
async getBrightness() {
|
|
45
|
-
return this.
|
|
35
|
+
return this.get(CharacteristicKey.Brightness);
|
|
46
36
|
}
|
|
47
|
-
async
|
|
48
|
-
|
|
37
|
+
async onBrightnessUpdate(topic, value) {
|
|
38
|
+
if (this.assertNumber(value, strings.lightbulb.badBrightness)) {
|
|
39
|
+
const logString = strings.lightbulb.brightness.replace('%d', `${value.toString()}%`);
|
|
40
|
+
this.onUpdate(CharacteristicKey.Brightness, value, logString);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
async onSetBrightness(value) {
|
|
44
|
+
const logString = strings.lightbulb.futureBrightness.replace('%d', `${value.toString()}%`);
|
|
45
|
+
this.onSet(CharacteristicKey.Brightness, value, value, 'topicSetBrightness', logString);
|
|
49
46
|
}
|
|
50
47
|
async getColorTemperature() {
|
|
51
|
-
return this.
|
|
48
|
+
return this.get(CharacteristicKey.ColorTemperature);
|
|
52
49
|
}
|
|
53
|
-
async
|
|
54
|
-
|
|
50
|
+
async onColorTemperatureUpdate(topic, value) {
|
|
51
|
+
if (this.assertNumber(value, strings.lightbulb.badColorTemperature)) {
|
|
52
|
+
const logString = strings.lightbulb.colorTemperature.replace('%d', `${value.toString()}M`);
|
|
53
|
+
this.onUpdate(CharacteristicKey.ColorTemperature, value, logString);
|
|
54
|
+
}
|
|
55
55
|
}
|
|
56
|
-
async
|
|
57
|
-
|
|
56
|
+
async onSetColorTemperature(value) {
|
|
57
|
+
const logString = strings.lightbulb.futureColorTemperature.replace('%d', `${value.toString()}M`);
|
|
58
|
+
this.onSet(CharacteristicKey.ColorTemperature, value, value, 'topicSetColorTemperature', logString);
|
|
58
59
|
}
|
|
59
|
-
async
|
|
60
|
-
this.
|
|
60
|
+
async getHue() {
|
|
61
|
+
return this.get(CharacteristicKey.Hue);
|
|
61
62
|
}
|
|
62
63
|
async onHueUpdate(topic, value) {
|
|
63
|
-
this.
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
64
|
+
if (this.assertNumber(value, strings.lightbulb.badHue)) {
|
|
65
|
+
const logString = strings.lightbulb.hue.replace('%d', `${value.toString()}°`);
|
|
66
|
+
this.onUpdate(CharacteristicKey.Hue, value, logString);
|
|
67
|
+
}
|
|
67
68
|
}
|
|
68
|
-
async
|
|
69
|
-
|
|
69
|
+
async onSetHue(value) {
|
|
70
|
+
const logString = strings.lightbulb.futureHue.replace('%d', `${value.toString()}°`);
|
|
71
|
+
this.onSet(CharacteristicKey.Hue, value, value, 'topicSetHue', logString);
|
|
70
72
|
}
|
|
71
|
-
async
|
|
72
|
-
this.
|
|
73
|
+
async getSaturation() {
|
|
74
|
+
return this.get(CharacteristicKey.Saturation);
|
|
73
75
|
}
|
|
74
76
|
async onSaturationUpdate(topic, value) {
|
|
75
|
-
this.
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
this._set('topicSetSaturation', 'saturation', value, strings.lightbulb.futureSaturation);
|
|
79
|
-
}
|
|
80
|
-
async _onUpdate(propertyKey, value, logString) {
|
|
81
|
-
if (value === this[propertyKey]) {
|
|
82
|
-
return;
|
|
83
|
-
}
|
|
84
|
-
this[propertyKey] = value;
|
|
85
|
-
const characteristicKey = this.toCharacteristicKey(propertyKey);
|
|
86
|
-
this.accessoryService.updateCharacteristic(this.Characteristic[characteristicKey], value);
|
|
87
|
-
this.logIfDesired(logString, value.toString());
|
|
88
|
-
}
|
|
89
|
-
_set(topic, propertyKey, value, logString) {
|
|
90
|
-
if (!this.assert(topic)) {
|
|
91
|
-
return;
|
|
77
|
+
if (this.assertNumber(value, strings.lightbulb.badSaturation)) {
|
|
78
|
+
const logString = strings.lightbulb.saturation.replace('%d', `${value.toString()}%`);
|
|
79
|
+
this.onUpdate(CharacteristicKey.Saturation, value, logString);
|
|
92
80
|
}
|
|
93
|
-
this[propertyKey] = value;
|
|
94
|
-
this.logIfDesired(logString, value.toString());
|
|
95
|
-
const characteristicKey = this.toCharacteristicKey(propertyKey);
|
|
96
|
-
this.accessoryService.updateCharacteristic(this.Characteristic[characteristicKey], value);
|
|
97
|
-
this.publish(this.config[topic], toPrimitive(value));
|
|
98
81
|
}
|
|
99
|
-
|
|
100
|
-
const
|
|
101
|
-
|
|
82
|
+
async onSetSaturation(value) {
|
|
83
|
+
const logString = strings.lightbulb.futureSaturation.replace('%d', `${value.toString()}%`);
|
|
84
|
+
this.onSet(CharacteristicKey.Saturation, value, value, 'topicSetSaturation', logString);
|
|
102
85
|
}
|
|
103
86
|
}
|
|
104
87
|
//# sourceMappingURL=lightbulb.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lightbulb.js","sourceRoot":"","sources":["../../../src/accessory/onoff/lightbulb.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"lightbulb.js","sourceRoot":"","sources":["../../../src/accessory/onoff/lightbulb.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,14 +1,13 @@
|
|
|
1
|
-
import { PlatformAccessory } from 'homebridge';
|
|
2
|
-
import { TopicHandler } from '../abstract/base.js';
|
|
1
|
+
import { PlatformAccessory, PrimitiveTypes } from 'homebridge';
|
|
3
2
|
import { StatusActiveAccessory } from '../abstract/statusActive.js';
|
|
4
3
|
import { CharacteristicType, OnOffConfig, ServiceType } from '../../model/types.js';
|
|
5
4
|
import { Log } from '../../tools/log.js';
|
|
6
5
|
export declare abstract class OnOffAccessory<C extends OnOffConfig = OnOffConfig> extends StatusActiveAccessory<C> {
|
|
7
|
-
private on;
|
|
8
6
|
constructor(Service: ServiceType, Characteristic: CharacteristicType, accessory: PlatformAccessory, config: C, log: Log, className: string);
|
|
9
|
-
|
|
10
|
-
private onOnUpdate;
|
|
7
|
+
addTopicHandlers(): void;
|
|
11
8
|
private getOn;
|
|
12
|
-
private
|
|
9
|
+
private onOnUpdate;
|
|
10
|
+
private onSetOn;
|
|
11
|
+
protected booleanForValue(value: PrimitiveTypes, positive: keyof C, negative: keyof C, errorString: string): boolean | undefined;
|
|
13
12
|
private stringForState;
|
|
14
13
|
}
|
|
@@ -1,47 +1,46 @@
|
|
|
1
|
-
import { makeHandler } from '../abstract/base.js';
|
|
2
1
|
import { StatusActiveAccessory } from '../abstract/statusActive.js';
|
|
3
2
|
import { strings } from '../../i18n/i18n.js';
|
|
4
|
-
import {
|
|
3
|
+
import { CharacteristicKey } from '../../model/enums.js';
|
|
5
4
|
export class OnOffAccessory extends StatusActiveAccessory {
|
|
6
|
-
on = false;
|
|
7
5
|
constructor(Service, Characteristic, accessory, config, log, className) {
|
|
8
6
|
super(Service, Characteristic, accessory, config, log, className);
|
|
7
|
+
this.set(CharacteristicKey.On, false);
|
|
9
8
|
this.accessoryService.getCharacteristic(Characteristic.On)
|
|
10
9
|
.onGet(this.getOn.bind(this))
|
|
11
|
-
.onSet(this.
|
|
10
|
+
.onSet(this.onSetOn.bind(this));
|
|
12
11
|
}
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
return topicHandlers;
|
|
12
|
+
addTopicHandlers() {
|
|
13
|
+
super.addTopicHandlers();
|
|
14
|
+
this.addTopicHandler('topicGetOn', this.onOnUpdate.bind(this));
|
|
15
|
+
}
|
|
16
|
+
async getOn() {
|
|
17
|
+
return this.get(CharacteristicKey.On);
|
|
20
18
|
}
|
|
21
19
|
async onOnUpdate(topic, value) {
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
const on = value === toPrimitive(this.config.valueOn);
|
|
26
|
-
if (on === this.on) {
|
|
27
|
-
return;
|
|
20
|
+
const on = this.booleanForValue(value, 'valueOn', 'valueOff', strings.onOff.badValue);
|
|
21
|
+
if (on !== undefined) {
|
|
22
|
+
this.onUpdate(CharacteristicKey.On, on, this.stringForState(on));
|
|
28
23
|
}
|
|
29
|
-
this.on = on;
|
|
30
|
-
this.accessoryService.updateCharacteristic(this.Characteristic.On, this.on);
|
|
31
|
-
this.logIfDesired(this.stringForState(this.on));
|
|
32
24
|
}
|
|
33
|
-
async
|
|
34
|
-
|
|
25
|
+
async onSetOn(value) {
|
|
26
|
+
const on = value ? this.getPrimitiveValue('valueOn') : this.getPrimitiveValue('valueOff');
|
|
27
|
+
if (on !== undefined) {
|
|
28
|
+
this.onSet(CharacteristicKey.On, value, on, 'topicSetOn', this.stringForState(value, true));
|
|
29
|
+
}
|
|
35
30
|
}
|
|
36
|
-
|
|
37
|
-
|
|
31
|
+
booleanForValue(value, positive, negative, errorString) {
|
|
32
|
+
let bool = undefined;
|
|
33
|
+
if (value === this.getPrimitiveValue(positive)) {
|
|
34
|
+
bool = true;
|
|
35
|
+
}
|
|
36
|
+
else if (value === this.getPrimitiveValue(negative)) {
|
|
37
|
+
bool = false;
|
|
38
|
+
}
|
|
39
|
+
if (bool === undefined) {
|
|
40
|
+
this.log.error(errorString, this.name, `'${value}'`);
|
|
38
41
|
return;
|
|
39
42
|
}
|
|
40
|
-
|
|
41
|
-
this.on = value;
|
|
42
|
-
this.logIfDesired(this.stringForState(this.on, true));
|
|
43
|
-
this.accessoryService.updateCharacteristic(this.Characteristic.On, this.on);
|
|
44
|
-
this.publish(this.config.topicSetOn, on);
|
|
43
|
+
return bool;
|
|
45
44
|
}
|
|
46
45
|
stringForState(on, future = false) {
|
|
47
46
|
if (on) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"onoff.js","sourceRoot":"","sources":["../../../src/accessory/onoff/onoff.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"onoff.js","sourceRoot":"","sources":["../../../src/accessory/onoff/onoff.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,15 +1,13 @@
|
|
|
1
1
|
import { PlatformAccessory, Service } from 'homebridge';
|
|
2
2
|
import { OnOffAccessory } from './onoff.js';
|
|
3
|
-
import { TopicHandler } from '../abstract/base.js';
|
|
4
3
|
import { CharacteristicType, OutletConfig, ServiceType } from '../../model/types.js';
|
|
5
4
|
import { Log } from '../../tools/log.js';
|
|
6
5
|
export declare class OutletAccessory extends OnOffAccessory<OutletConfig> {
|
|
7
|
-
private inUse;
|
|
8
6
|
constructor(Service: ServiceType, Characteristic: CharacteristicType, accessory: PlatformAccessory, config: OutletConfig, log: Log);
|
|
9
7
|
protected getAccessoryService(): Service;
|
|
10
|
-
|
|
8
|
+
addTopicHandlers(): void;
|
|
11
9
|
private getInUse;
|
|
12
10
|
private onInUseUpdate;
|
|
13
|
-
private
|
|
11
|
+
private onSetInUse;
|
|
14
12
|
private stringForInUse;
|
|
15
13
|
}
|
|
@@ -1,49 +1,36 @@
|
|
|
1
1
|
import { OnOffAccessory } from './onoff.js';
|
|
2
|
-
import { makeHandler } from '../abstract/base.js';
|
|
3
2
|
import { strings } from '../../i18n/i18n.js';
|
|
4
|
-
import {
|
|
3
|
+
import { CharacteristicKey } from '../../model/enums.js';
|
|
5
4
|
export class OutletAccessory extends OnOffAccessory {
|
|
6
|
-
inUse = false;
|
|
7
5
|
constructor(Service, Characteristic, accessory, config, log) {
|
|
8
6
|
super(Service, Characteristic, accessory, config, log, OutletAccessory.name);
|
|
7
|
+
this.set(CharacteristicKey.OutletInUse, false);
|
|
9
8
|
this.accessoryService.getCharacteristic(this.Characteristic.OutletInUse)
|
|
10
9
|
.onGet(this.getInUse.bind(this))
|
|
11
|
-
.onSet(this.
|
|
10
|
+
.onSet(this.onSetInUse.bind(this));
|
|
12
11
|
}
|
|
13
12
|
getAccessoryService() {
|
|
14
13
|
return this.accessory.getService(this.Service.Outlet) || this.accessory.addService(this.Service.Outlet);
|
|
15
14
|
}
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
topicHandlers.push(makeHandler(this.config.topicGetOutletInUse, this.onInUseUpdate.bind(this)));
|
|
20
|
-
}
|
|
21
|
-
return topicHandlers;
|
|
15
|
+
addTopicHandlers() {
|
|
16
|
+
super.addTopicHandlers();
|
|
17
|
+
this.addTopicHandler('topicGetOutletInUse', this.onInUseUpdate.bind(this), false);
|
|
22
18
|
}
|
|
23
19
|
async getInUse() {
|
|
24
|
-
return this.
|
|
20
|
+
return this.get(CharacteristicKey.OutletInUse);
|
|
25
21
|
}
|
|
26
22
|
async onInUseUpdate(topic, value) {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
const inUse = value === toPrimitive(this.config.valueOutletInUse);
|
|
31
|
-
if (inUse === this.inUse) {
|
|
32
|
-
return;
|
|
23
|
+
const inUse = this.booleanForValue(value, 'valueOutletInUse', 'valueOutletNotInUse', strings.outlet.badValue);
|
|
24
|
+
if (inUse !== undefined) {
|
|
25
|
+
this.onUpdate(CharacteristicKey.OutletInUse, inUse, this.stringForInUse(inUse));
|
|
33
26
|
}
|
|
34
|
-
this.inUse = inUse;
|
|
35
|
-
this.accessoryService.updateCharacteristic(this.Characteristic.OutletInUse, this.inUse);
|
|
36
|
-
this.logIfDesired(this.stringForInUse(this.inUse));
|
|
37
27
|
}
|
|
38
|
-
async
|
|
39
|
-
|
|
28
|
+
async onSetInUse(value) {
|
|
29
|
+
const inUse = value ? this.getPrimitiveValue('valueOutletInUse') : this.getPrimitiveValue('valueOutletNotInUse');
|
|
30
|
+
if (!inUse) {
|
|
40
31
|
return;
|
|
41
32
|
}
|
|
42
|
-
|
|
43
|
-
this.inUse = value;
|
|
44
|
-
this.logIfDesired(this.stringForInUse(this.inUse, true));
|
|
45
|
-
this.accessoryService.updateCharacteristic(this.Characteristic.OutletInUse, this.inUse);
|
|
46
|
-
this.publish(this.config.topicSetOutletInUse, inUse);
|
|
33
|
+
this.onSet(CharacteristicKey.OutletInUse, value, inUse, 'topicSetOutletInUse', this.stringForInUse(inUse, true));
|
|
47
34
|
}
|
|
48
35
|
stringForInUse(inUse, future = false) {
|
|
49
36
|
if (inUse) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outlet.js","sourceRoot":"","sources":["../../../src/accessory/onoff/outlet.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"outlet.js","sourceRoot":"","sources":["../../../src/accessory/onoff/outlet.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAE5C,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAE7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAKzD,MAAM,OAAO,eAAgB,SAAQ,cAA4B;IAE/D,YAAY,OAAoB,EAAE,cAAkC,EAAE,SAA4B,EAAE,MAAoB,EAAE,GAAQ;QAChI,KAAK,CAAC,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,eAAe,CAAC,IAAI,CAAC,CAAC;QAE7E,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;QAE/C,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC;aACrE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAC/B,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACvC,CAAC;IAES,mBAAmB;QAC3B,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC1G,CAAC;IAEQ,gBAAgB;QACvB,KAAK,CAAC,gBAAgB,EAAE,CAAC;QACzB,IAAI,CAAC,eAAe,CAAC,qBAAqB,EAAE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC;IACpF,CAAC;IAEO,KAAK,CAAC,QAAQ;QACpB,OAAO,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;IACjD,CAAC;IAEO,KAAK,CAAC,aAAa,CAAC,KAAa,EAAE,KAAqB;QAC9D,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC9G,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACxB,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,WAAW,EAAE,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;QAClF,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,UAAU,CAAC,KAA0B;QAEjD,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,qBAAqB,CAAC,CAAC;QACjH,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,OAAO;QACT,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,WAAW,EAAE,KAAK,EAAE,KAAK,EAAC,qBAAqB,EAAE,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC;IAClH,CAAC;IAEO,cAAc,CAAC,KAA0B,EAAE,SAAkB,KAAK;QACxE,IAAI,KAAK,EAAE,CAAC;YACV,OAAO,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;QACpE,CAAC;aAAM,CAAC;YACN,OAAO,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC;QAC1E,CAAC;IACH,CAAC;CACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"switch.js","sourceRoot":"","sources":["../../../src/accessory/onoff/switch.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAM5C,MAAM,OAAO,eAAgB,SAAQ,cAA4B;IAE/D,
|
|
1
|
+
{"version":3,"file":"switch.js","sourceRoot":"","sources":["../../../src/accessory/onoff/switch.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAM5C,MAAM,OAAO,eAAgB,SAAQ,cAA4B;IAE/D,YAAY,OAAoB,EAAE,cAAkC,EAAE,SAA4B,EAAE,MAAoB,EAAE,GAAQ;QAChI,KAAK,CAAC,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,eAAe,CAAC,IAAI,CAAC,CAAC;IAC/E,CAAC;IAES,mBAAmB;QAC3B,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC1G,CAAC;CACF"}
|
|
@@ -2,16 +2,11 @@ import { PlatformAccessory, Service } from 'homebridge';
|
|
|
2
2
|
import { StatusActiveAccessory } from './abstract/statusActive.js';
|
|
3
3
|
import { CharacteristicType, SecuritySystemConfig, ServiceType } from '../model/types.js';
|
|
4
4
|
import { Log } from '../tools/log.js';
|
|
5
|
-
import { TopicHandler } from './abstract/base.js';
|
|
6
5
|
export declare class SecuritySystemAccessory extends StatusActiveAccessory<SecuritySystemConfig> {
|
|
7
|
-
private currentState;
|
|
8
|
-
private targetState;
|
|
9
|
-
private isTampered;
|
|
10
|
-
private hasStatusFault;
|
|
11
6
|
private readonly STATE_MAP;
|
|
12
7
|
constructor(Service: ServiceType, Characteristic: CharacteristicType, accessory: PlatformAccessory, config: SecuritySystemConfig, log: Log);
|
|
13
8
|
protected getAccessoryService(): Service;
|
|
14
|
-
|
|
9
|
+
addTopicHandlers(): void;
|
|
15
10
|
private getCurrentState;
|
|
16
11
|
private getTargetState;
|
|
17
12
|
private getIsTampered;
|
|
@@ -20,7 +15,7 @@ export declare class SecuritySystemAccessory extends StatusActiveAccessory<Secur
|
|
|
20
15
|
private onTargetStateUpdate;
|
|
21
16
|
private onTamperedUpdate;
|
|
22
17
|
private onStatusFaultUpdate;
|
|
23
|
-
private
|
|
18
|
+
private onSetTargetState;
|
|
24
19
|
private fromCVState;
|
|
25
20
|
private toCVState;
|
|
26
21
|
private stateStringForCV;
|