homebridge-easy-mqtt 1.4.1-beta.0 → 1.5.0-beta.0
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 -1
- package/README.md +102 -6
- package/config.schema.json +216 -7
- package/dist/accessory/abstract/base.d.ts +4 -6
- package/dist/accessory/abstract/base.js +17 -37
- package/dist/accessory/abstract/base.js.map +1 -1
- package/dist/accessory/abstract/common.d.ts +18 -4
- package/dist/accessory/abstract/common.js +165 -9
- package/dist/accessory/abstract/common.js.map +1 -1
- package/dist/accessory/abstract/group.d.ts +2 -4
- package/dist/accessory/abstract/group.js +11 -11
- package/dist/accessory/abstract/group.js.map +1 -1
- package/dist/accessory/abstract/helper.d.ts +3 -5
- package/dist/accessory/abstract/helper.js +34 -30
- package/dist/accessory/abstract/helper.js.map +1 -1
- package/dist/accessory/abstract/mqtt.d.ts +11 -8
- package/dist/accessory/abstract/mqtt.js +41 -33
- package/dist/accessory/abstract/mqtt.js.map +1 -1
- package/dist/accessory/addons/filter.d.ts +0 -1
- package/dist/accessory/addons/filter.js +6 -18
- package/dist/accessory/addons/filter.js.map +1 -1
- package/dist/accessory/button/button.d.ts +6 -0
- package/dist/accessory/{button.js → button/button.js} +6 -10
- package/dist/accessory/button/button.js.map +1 -0
- package/dist/accessory/button/doorbell.d.ts +7 -0
- package/dist/accessory/button/doorbell.js +25 -0
- package/dist/accessory/button/doorbell.js.map +1 -0
- package/dist/accessory/button/stateless.d.ts +6 -0
- package/dist/accessory/button/stateless.js +8 -0
- package/dist/accessory/button/stateless.js.map +1 -0
- package/dist/accessory/characteristic/characteristic.d.ts +3 -0
- package/dist/accessory/characteristic/characteristic.js +23 -0
- package/dist/accessory/characteristic/characteristic.js.map +1 -0
- package/dist/accessory/{abstract/customCharacteristic.d.ts → characteristic/custom.d.ts} +1 -0
- package/dist/accessory/{abstract/customCharacteristic.js → characteristic/custom.js} +4 -1
- package/dist/accessory/characteristic/custom.js.map +1 -0
- package/dist/accessory/characteristic/eve.d.ts +6 -0
- package/dist/accessory/characteristic/eve.js +24 -0
- package/dist/accessory/characteristic/eve.js.map +1 -0
- package/dist/accessory/climate/active.d.ts +2 -8
- package/dist/accessory/climate/active.js +9 -41
- package/dist/accessory/climate/active.js.map +1 -1
- package/dist/accessory/climate/fan2.d.ts +2 -15
- package/dist/accessory/climate/fan2.js +30 -109
- package/dist/accessory/climate/fan2.js.map +1 -1
- package/dist/accessory/climate/heaterCooler.d.ts +2 -14
- package/dist/accessory/climate/heaterCooler.js +32 -108
- package/dist/accessory/climate/heaterCooler.js.map +1 -1
- package/dist/accessory/climate/purifier.d.ts +2 -14
- package/dist/accessory/climate/purifier.js +27 -97
- package/dist/accessory/climate/purifier.js.map +1 -1
- package/dist/accessory/climate/temperatureControl.d.ts +5 -5
- package/dist/accessory/climate/temperatureControl.js +8 -8
- package/dist/accessory/climate/temperatureControl.js.map +1 -1
- package/dist/accessory/climate/thermostat.d.ts +2 -12
- package/dist/accessory/climate/thermostat.js +31 -84
- package/dist/accessory/climate/thermostat.js.map +1 -1
- package/dist/accessory/garage.d.ts +2 -12
- package/dist/accessory/garage.js +27 -93
- package/dist/accessory/garage.js.map +1 -1
- package/dist/accessory/lock.d.ts +2 -8
- package/dist/accessory/lock.js +28 -62
- package/dist/accessory/lock.js.map +1 -1
- package/dist/accessory/onoff/lightbulb.d.ts +2 -5
- package/dist/accessory/onoff/lightbulb.js +12 -18
- package/dist/accessory/onoff/lightbulb.js.map +1 -1
- package/dist/accessory/onoff/onoff.d.ts +4 -8
- package/dist/accessory/onoff/onoff.js +30 -34
- package/dist/accessory/onoff/onoff.js.map +1 -1
- package/dist/accessory/onoff/outlet.d.ts +2 -4
- package/dist/accessory/onoff/outlet.js +5 -5
- package/dist/accessory/onoff/outlet.js.map +1 -1
- package/dist/accessory/onoff/switch.d.ts +1 -4
- package/dist/accessory/onoff/switch.js +0 -3
- package/dist/accessory/onoff/switch.js.map +1 -1
- package/dist/accessory/position/blind.d.ts +2 -5
- package/dist/accessory/position/blind.js +7 -13
- package/dist/accessory/position/blind.js.map +1 -1
- package/dist/accessory/position/position.d.ts +2 -11
- package/dist/accessory/position/position.js +20 -71
- package/dist/accessory/position/position.js.map +1 -1
- package/dist/accessory/security.d.ts +4 -10
- package/dist/accessory/security.js +49 -81
- package/dist/accessory/security.js.map +1 -1
- package/dist/accessory/sensor/air.d.ts +2 -8
- package/dist/accessory/sensor/air.js +35 -67
- package/dist/accessory/sensor/air.js.map +1 -1
- package/dist/accessory/sensor/carbonDioxide.d.ts +2 -4
- package/dist/accessory/sensor/carbonDioxide.js +7 -7
- package/dist/accessory/sensor/carbonDioxide.js.map +1 -1
- package/dist/accessory/sensor/carbonMonoxide.d.ts +2 -4
- package/dist/accessory/sensor/carbonMonoxide.js +7 -7
- package/dist/accessory/sensor/carbonMonoxide.js.map +1 -1
- package/dist/accessory/sensor/contact.d.ts +2 -4
- package/dist/accessory/sensor/contact.js +20 -7
- package/dist/accessory/sensor/contact.js.map +1 -1
- package/dist/accessory/sensor/humidity.d.ts +2 -4
- package/dist/accessory/sensor/humidity.js +8 -5
- package/dist/accessory/sensor/humidity.js.map +1 -1
- package/dist/accessory/sensor/leak.d.ts +2 -4
- package/dist/accessory/sensor/leak.js +5 -5
- package/dist/accessory/sensor/leak.js.map +1 -1
- package/dist/accessory/sensor/light.d.ts +2 -4
- package/dist/accessory/sensor/light.js +5 -5
- package/dist/accessory/sensor/light.js.map +1 -1
- package/dist/accessory/sensor/motion.d.ts +2 -4
- package/dist/accessory/sensor/motion.js +8 -5
- package/dist/accessory/sensor/motion.js.map +1 -1
- package/dist/accessory/sensor/occupancy.d.ts +2 -4
- package/dist/accessory/sensor/occupancy.js +5 -5
- package/dist/accessory/sensor/occupancy.js.map +1 -1
- package/dist/accessory/sensor/sensor.d.ts +2 -6
- package/dist/accessory/sensor/sensor.js +5 -29
- package/dist/accessory/sensor/sensor.js.map +1 -1
- package/dist/accessory/sensor/smoke.d.ts +2 -4
- package/dist/accessory/sensor/smoke.js +5 -5
- package/dist/accessory/sensor/smoke.js.map +1 -1
- package/dist/accessory/sensor/temperature.d.ts +2 -4
- package/dist/accessory/sensor/temperature.js +8 -5
- package/dist/accessory/sensor/temperature.js.map +1 -1
- package/dist/accessory/valve.d.ts +2 -8
- package/dist/accessory/valve.js +10 -44
- package/dist/accessory/valve.js.map +1 -1
- package/dist/homebridge/platform.js +10 -4
- package/dist/homebridge/platform.js.map +1 -1
- package/dist/homebridge-ui/public/index.html +1 -1
- package/dist/homebridge-ui/public/ui.js +1 -1
- package/dist/i18n/en.d.ts +41 -5
- package/dist/i18n/en.js +43 -7
- package/dist/i18n/en.js.map +1 -1
- package/dist/i18n/fr.d.ts +41 -5
- package/dist/i18n/i18n.d.ts +41 -5
- package/dist/i18n/it.d.ts +41 -5
- package/dist/i18n/ro.d.ts +41 -5
- package/dist/i18n/template.d.ts +41 -5
- package/dist/i18n/vi.d.ts +41 -5
- package/dist/model/enums.d.ts +17 -2
- package/dist/model/enums.js +92 -77
- package/dist/model/enums.js.map +1 -1
- package/dist/model/history.d.ts +32 -0
- package/dist/model/history.js +128 -0
- package/dist/model/history.js.map +1 -0
- package/dist/model/mqtt.d.ts +1 -0
- package/dist/model/mqtt.js +37 -11
- package/dist/model/mqtt.js.map +1 -1
- package/dist/model/types.d.ts +39 -4
- package/dist/tools/log.d.ts +1 -1
- package/dist/tools/log.js.map +1 -1
- package/dist/tools/properties.js +1 -1
- package/dist/tools/properties.js.map +1 -1
- package/package.json +2 -1
- package/dist/accessory/abstract/customCharacteristic.js.map +0 -1
- package/dist/accessory/button.d.ts +0 -10
- package/dist/accessory/button.js.map +0 -1
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { CharacteristicValue
|
|
1
|
+
import { CharacteristicValue } from 'homebridge';
|
|
2
2
|
import { BaseAccessory } from '../abstract/base.js';
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
3
|
+
import { HKCharacteristicKey } from '../../model/enums.js';
|
|
4
|
+
import { MQTTAccessoryDependency, TemperatureControlConfig } from '../../model/types.js';
|
|
5
5
|
import { TemperatureUnits } from '../../tools/temperature.js';
|
|
6
6
|
export declare const DEFAULT_TEMPERATURE = 10;
|
|
7
7
|
export declare abstract class TemperatureControlAccessory<C extends TemperatureControlConfig = TemperatureControlConfig> extends BaseAccessory<C> {
|
|
8
|
-
constructor(
|
|
8
|
+
constructor(dependency: MQTTAccessoryDependency<C>);
|
|
9
9
|
protected setupTemperatureControlCharacteristics(): void;
|
|
10
10
|
protected get temperatureUnits(): TemperatureUnits;
|
|
11
|
-
|
|
11
|
+
protected bindOnSetTemperature(charKey: HKCharacteristicKey, topic: keyof C, logTemplate: string): (value: CharacteristicValue) => Promise<void>;
|
|
12
12
|
protected temperatureFromCV(value: CharacteristicValue): number;
|
|
13
13
|
}
|
|
@@ -1,26 +1,26 @@
|
|
|
1
1
|
import { BaseAccessory } from '../abstract/base.js';
|
|
2
2
|
import { strings } from '../../i18n/i18n.js';
|
|
3
|
-
import {
|
|
3
|
+
import { HKCharacteristicKey } from '../../model/enums.js';
|
|
4
4
|
import { fromCelsius, temperatureUnits, TemperatureUnits } from '../../tools/temperature.js';
|
|
5
5
|
export const DEFAULT_TEMPERATURE = 10;
|
|
6
6
|
const DEFAULT_COOLING_THRESHOLD = 25;
|
|
7
7
|
const DEFAULT_HEATING_THRESHOLD = 20;
|
|
8
8
|
export class TemperatureControlAccessory extends BaseAccessory {
|
|
9
|
-
constructor(
|
|
10
|
-
super(
|
|
9
|
+
constructor(dependency) {
|
|
10
|
+
super(dependency);
|
|
11
11
|
}
|
|
12
12
|
setupTemperatureControlCharacteristics() {
|
|
13
13
|
const temperatureDisplayUnits = this.temperatureUnits === TemperatureUnits.FAHRENHEIT
|
|
14
14
|
? this.Characteristic.TemperatureDisplayUnits.FAHRENHEIT : this.Characteristic.TemperatureDisplayUnits.CELSIUS;
|
|
15
|
-
this.setCharacteristicValue(
|
|
16
|
-
this.setup(
|
|
17
|
-
this.setup(
|
|
18
|
-
this.setup(
|
|
15
|
+
this.setCharacteristicValue(HKCharacteristicKey.TemperatureDisplayUnits, temperatureDisplayUnits);
|
|
16
|
+
this.setup(HKCharacteristicKey.CurrentTemperature, DEFAULT_TEMPERATURE, 'topicGetCurrentTemperature', this.bindOnUpdateTemperature(this.config, HKCharacteristicKey.CurrentTemperature, strings.climate.temperatureUpdate), true);
|
|
17
|
+
this.setup(HKCharacteristicKey.CoolingThresholdTemperature, DEFAULT_COOLING_THRESHOLD, 'topicGetCoolingThresholdTemperature', this.bindOnUpdateTemperature(this.config, HKCharacteristicKey.CoolingThresholdTemperature, strings.climate.coolingThreshold), false, 'topicSetCoolingThresholdTemperature', this.bindOnSetTemperature(HKCharacteristicKey.CoolingThresholdTemperature, 'topicSetCoolingThresholdTemperature', strings.climate.coolingThresholdFuture));
|
|
18
|
+
this.setup(HKCharacteristicKey.HeatingThresholdTemperature, DEFAULT_HEATING_THRESHOLD, 'topicGetHeatingThresholdTemperature', this.bindOnUpdateTemperature(this.config, HKCharacteristicKey.HeatingThresholdTemperature, strings.climate.heatingThreshold), false, 'topicSetHeatingThresholdTemperature', this.bindOnSetTemperature(HKCharacteristicKey.HeatingThresholdTemperature, 'topicSetHeatingThresholdTemperature', strings.climate.heatingThresholdFuture));
|
|
19
19
|
}
|
|
20
20
|
get temperatureUnits() {
|
|
21
21
|
return temperatureUnits(this.config.temperatureUnits);
|
|
22
22
|
}
|
|
23
|
-
|
|
23
|
+
bindOnSetTemperature(charKey, topic, logTemplate) {
|
|
24
24
|
return (async (value) => {
|
|
25
25
|
const temperature = this.temperatureFromCV(value);
|
|
26
26
|
const logString = logTemplate.replace('%d°%s', `${temperature}°${this.temperatureUnits}`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"temperatureControl.js","sourceRoot":"","sources":["../../../src/accessory/climate/temperatureControl.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"temperatureControl.js","sourceRoot":"","sources":["../../../src/accessory/climate/temperatureControl.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,17 +1,7 @@
|
|
|
1
|
-
import { PlatformAccessory } from 'homebridge';
|
|
2
1
|
import { TemperatureControlAccessory } from './temperatureControl.js';
|
|
3
2
|
import { AccessoryType } from '../../model/enums.js';
|
|
4
|
-
import {
|
|
5
|
-
import { Log } from '../../tools/log.js';
|
|
3
|
+
import { MQTTAccessoryDependency, ThermostatConfig } from '../../model/types.js';
|
|
6
4
|
export declare class ThermostatAccessory extends TemperatureControlAccessory<ThermostatConfig> {
|
|
7
|
-
private readonly STATE_MAP;
|
|
8
|
-
constructor(Service: ServiceType, Characteristic: CharacteristicType, accessory: PlatformAccessory, config: ThermostatConfig, log: Log, isGrouped: boolean);
|
|
9
5
|
protected getAccessoryType(): AccessoryType;
|
|
10
|
-
|
|
11
|
-
private onSetTargetState;
|
|
12
|
-
private onSetTemperature;
|
|
13
|
-
private onSetHumidity;
|
|
14
|
-
private fromCVState;
|
|
15
|
-
private toCVState;
|
|
16
|
-
private stateStringForCV;
|
|
6
|
+
constructor(dependency: MQTTAccessoryDependency<ThermostatConfig>);
|
|
17
7
|
}
|
|
@@ -1,97 +1,44 @@
|
|
|
1
1
|
import { TemperatureControlAccessory, DEFAULT_TEMPERATURE } from './temperatureControl.js';
|
|
2
2
|
import { strings } from '../../i18n/i18n.js';
|
|
3
|
-
import { AccessoryType,
|
|
3
|
+
import { AccessoryType, HKCharacteristicKey } from '../../model/enums.js';
|
|
4
|
+
import { HistoryType } from '../../model/history.js';
|
|
4
5
|
export class ThermostatAccessory extends TemperatureControlAccessory {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
6
|
+
getAccessoryType() {
|
|
7
|
+
return AccessoryType.Thermostat;
|
|
8
|
+
}
|
|
9
|
+
constructor(dependency) {
|
|
10
|
+
super(dependency);
|
|
8
11
|
this.setupTemperatureControlCharacteristics();
|
|
9
|
-
|
|
10
|
-
['valueModeOff', Characteristic.TargetHeatingCoolingState.OFF],
|
|
11
|
-
['valueModeHeat', Characteristic.TargetHeatingCoolingState.HEAT],
|
|
12
|
-
['valueModeCool', Characteristic.TargetHeatingCoolingState.COOL],
|
|
13
|
-
['valueModeAuto', Characteristic.TargetHeatingCoolingState.AUTO],
|
|
12
|
+
const stateMap = new Map([
|
|
13
|
+
['valueModeOff', dependency.Characteristic.TargetHeatingCoolingState.OFF],
|
|
14
|
+
['valueModeHeat', dependency.Characteristic.TargetHeatingCoolingState.HEAT],
|
|
15
|
+
['valueModeCool', dependency.Characteristic.TargetHeatingCoolingState.COOL],
|
|
16
|
+
['valueModeAuto', dependency.Characteristic.TargetHeatingCoolingState.AUTO],
|
|
14
17
|
]);
|
|
15
|
-
const validTargetStates = Array.from(
|
|
18
|
+
const validTargetStates = Array.from(stateMap.keys()).filter((key) => this.getRawValue(key, false) !== undefined);
|
|
16
19
|
if (validTargetStates.length === 0 || (validTargetStates.length === 1 && validTargetStates[0] === 'valueModeAuto')) {
|
|
17
20
|
this.log.error(strings.thermostat.noStateValues, this.name);
|
|
18
21
|
return;
|
|
19
22
|
}
|
|
20
|
-
|
|
21
|
-
|
|
23
|
+
const targetStrings = new Map([
|
|
24
|
+
[dependency.Characteristic.TargetHeatingCoolingState.AUTO, strings.thermostat.stateAutoFuture],
|
|
25
|
+
[dependency.Characteristic.TargetHeatingCoolingState.COOL, strings.thermostat.stateCoolFuture],
|
|
26
|
+
[dependency.Characteristic.TargetHeatingCoolingState.HEAT, strings.thermostat.stateHeatFuture],
|
|
27
|
+
[dependency.Characteristic.TargetHeatingCoolingState.OFF, strings.thermostat.stateOffFuture],
|
|
28
|
+
]);
|
|
29
|
+
this.setup(HKCharacteristicKey.TargetHeatingCoolingState, stateMap.get(validTargetStates[0]), 'topicGetTargetHeatingCoolingState', this.bindOnUpdateState(HKCharacteristicKey.TargetHeatingCoolingState, stateMap, targetStrings, strings.thermostat.stateUnknown), true, 'topicSetTargetHeatingCoolingState', this.bindOnSetState(HKCharacteristicKey.TargetHeatingCoolingState, 'topicSetTargetHeatingCoolingState', stateMap, targetStrings, strings.thermostat.badValue))?.setProps({ validValues: validTargetStates.map((key) => stateMap.get(key)) });
|
|
30
|
+
const currentStrings = new Map([
|
|
31
|
+
[dependency.Characteristic.CurrentHeatingCoolingState.COOL, strings.thermostat.stateCool],
|
|
32
|
+
[dependency.Characteristic.CurrentHeatingCoolingState.HEAT, strings.thermostat.stateHeat],
|
|
33
|
+
[dependency.Characteristic.CurrentHeatingCoolingState.OFF, strings.thermostat.stateOff],
|
|
34
|
+
]);
|
|
22
35
|
const validCurrentStates = validTargetStates.filter((key) => key !== 'valueModeAuto');
|
|
23
|
-
this.setup(
|
|
24
|
-
|
|
25
|
-
this.setup(
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
getAccessoryType() {
|
|
30
|
-
return AccessoryType.Thermostat;
|
|
31
|
-
}
|
|
32
|
-
bindOnStateUpdate(charKey, future = false) {
|
|
33
|
-
return (async (_topic, value) => {
|
|
34
|
-
const state = this.toCVState(value);
|
|
35
|
-
if (state === undefined) {
|
|
36
|
-
return;
|
|
37
|
-
}
|
|
38
|
-
this.onUpdate(charKey, state, this.stateStringForCV(state, future));
|
|
39
|
-
}).bind(this);
|
|
40
|
-
}
|
|
41
|
-
async onSetTargetState(value) {
|
|
42
|
-
const target = this.fromCVState(value);
|
|
43
|
-
if (target === undefined) {
|
|
44
|
-
return;
|
|
45
|
-
}
|
|
46
|
-
this.onSet(CharacteristicKey.TargetHeatingCoolingState, value, target, 'topicSetTargetHeatingCoolingState', this.stateStringForCV(value, true));
|
|
47
|
-
}
|
|
48
|
-
async onSetTemperature(value) {
|
|
49
|
-
const temperature = this.temperatureFromCV(value);
|
|
50
|
-
const logString = strings.thermostat.temperatureTargetFuture.replace('%d°%s', `${temperature}°${this.temperatureUnits}`);
|
|
51
|
-
this.onSet(CharacteristicKey.TargetTemperature, value, temperature, 'topicSetTargetTemperature', logString);
|
|
52
|
-
}
|
|
53
|
-
async onSetHumidity(value) {
|
|
54
|
-
const logString = strings.thermostat.humidityFuture.replace('%d', value.toString());
|
|
55
|
-
this.onSet(CharacteristicKey.TargetRelativeHumidity, value, value, 'topicSetTargetRelativeHumidity', logString);
|
|
56
|
-
}
|
|
57
|
-
fromCVState(value) {
|
|
58
|
-
let primative = undefined;
|
|
59
|
-
this.STATE_MAP.forEach((test, key) => {
|
|
60
|
-
if (value === test) {
|
|
61
|
-
primative = this.getPrimitiveValue(key);
|
|
62
|
-
}
|
|
63
|
-
});
|
|
64
|
-
if (primative === undefined) {
|
|
65
|
-
this.log.error(strings.thermostat.badValue, this.name, `'${value}'`);
|
|
66
|
-
}
|
|
67
|
-
return primative;
|
|
68
|
-
}
|
|
69
|
-
toCVState(value) {
|
|
70
|
-
switch (value) {
|
|
71
|
-
case this.getPrimitiveValue('valueModeAuto', false):
|
|
72
|
-
return this.STATE_MAP.get('valueModeAuto');
|
|
73
|
-
case this.getPrimitiveValue('valueModeCool', false):
|
|
74
|
-
return this.STATE_MAP.get('valueModeCool');
|
|
75
|
-
case this.getPrimitiveValue('valueModeHeat', false):
|
|
76
|
-
return this.STATE_MAP.get('valueModeHeat');
|
|
77
|
-
case this.getPrimitiveValue('valueModeOff', false):
|
|
78
|
-
return this.STATE_MAP.get('valueModeOff');
|
|
79
|
-
}
|
|
80
|
-
this.logIfDesired(strings.thermostat.unknownValue, `'${value}'`);
|
|
81
|
-
}
|
|
82
|
-
stateStringForCV(state, future = false) {
|
|
83
|
-
switch (state) {
|
|
84
|
-
case this.Characteristic.TargetHeatingCoolingState.AUTO:
|
|
85
|
-
return strings.thermostat.stateAutoFuture;
|
|
86
|
-
case this.Characteristic.TargetHeatingCoolingState.COOL:
|
|
87
|
-
return future ? strings.thermostat.stateCoolFuture : strings.thermostat.stateCool;
|
|
88
|
-
case this.Characteristic.TargetHeatingCoolingState.HEAT:
|
|
89
|
-
return future ? strings.thermostat.stateHeatFuture : strings.thermostat.stateHeat;
|
|
90
|
-
case this.Characteristic.TargetHeatingCoolingState.OFF:
|
|
91
|
-
return future ? strings.thermostat.stateOffFuture : strings.thermostat.stateOff;
|
|
92
|
-
default:
|
|
93
|
-
return strings.thermostat.stateUnknown;
|
|
94
|
-
}
|
|
36
|
+
this.setup(HKCharacteristicKey.CurrentHeatingCoolingState, stateMap.get(validCurrentStates[0]), 'topicGetCurrentHeatingCoolingState', this.bindOnUpdateState(HKCharacteristicKey.CurrentHeatingCoolingState, stateMap, currentStrings, strings.thermostat.stateUnknown), true)?.setProps({ validValues: validCurrentStates.map((key) => stateMap.get(key)) });
|
|
37
|
+
this.setup(HKCharacteristicKey.TargetTemperature, DEFAULT_TEMPERATURE, 'topicGetTargetTemperature', this.bindOnUpdateTemperature(dependency.config, HKCharacteristicKey.TargetTemperature, strings.thermostat.temperatureTarget), true, 'topicSetTargetTemperature', this.bindOnSetTemperature(HKCharacteristicKey.TargetTemperature, 'topicSetTargetTemperature', strings.thermostat.temperatureTargetFuture));
|
|
38
|
+
this.setup(HKCharacteristicKey.CurrentRelativeHumidity, 0, 'topicGetCurrentRelativeHumidity', this.bindOnUpdateNumeric(HKCharacteristicKey.CurrentRelativeHumidity, strings.climate.humidityUpdate, (value) => {
|
|
39
|
+
this.recordHistory(HistoryType.WEATHER, { humidity: value });
|
|
40
|
+
}), false);
|
|
41
|
+
this.setup(HKCharacteristicKey.TargetRelativeHumidity, 0, 'topicGetTargetRelativeHumidity', this.bindOnUpdateNumeric(HKCharacteristicKey.TargetRelativeHumidity, strings.thermostat.humidityFuture), false, 'topicSetTargetRelativeHumidity', this.bindOnSetNumeric(HKCharacteristicKey.TargetRelativeHumidity, 'topicSetTargetRelativeHumidity', strings.thermostat.humidityFuture));
|
|
95
42
|
}
|
|
96
43
|
}
|
|
97
44
|
//# sourceMappingURL=thermostat.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"thermostat.js","sourceRoot":"","sources":["../../../src/accessory/climate/thermostat.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"thermostat.js","sourceRoot":"","sources":["../../../src/accessory/climate/thermostat.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,17 +1,7 @@
|
|
|
1
|
-
import { PlatformAccessory } from 'homebridge';
|
|
2
1
|
import { LockMechanismAccessory } from './lock.js';
|
|
3
2
|
import { AccessoryType } from '../model/enums.js';
|
|
4
|
-
import {
|
|
5
|
-
import { Log } from '../tools/log.js';
|
|
3
|
+
import { GarageDoorConfig, MQTTAccessoryDependency } from '../model/types.js';
|
|
6
4
|
export declare class GarageDoorAccessory extends LockMechanismAccessory<GarageDoorConfig> {
|
|
7
|
-
private readonly STATE_MAP;
|
|
8
|
-
constructor(Service: ServiceType, Characteristic: CharacteristicType, accessory: PlatformAccessory, config: GarageDoorConfig, log: Log, isGrouped: boolean);
|
|
9
5
|
protected getAccessoryType(): AccessoryType;
|
|
10
|
-
|
|
11
|
-
private onTargetDoorStateUpdate;
|
|
12
|
-
private onSetTargetDoorState;
|
|
13
|
-
private onObstructionUpdate;
|
|
14
|
-
private toCVState;
|
|
15
|
-
private fromCVState;
|
|
16
|
-
private stateStringForCV;
|
|
6
|
+
constructor(dependency: MQTTAccessoryDependency<GarageDoorConfig>);
|
|
17
7
|
}
|
package/dist/accessory/garage.js
CHANGED
|
@@ -1,110 +1,44 @@
|
|
|
1
1
|
import { LockMechanismAccessory } from './lock.js';
|
|
2
2
|
import { strings } from '../i18n/i18n.js';
|
|
3
|
-
import { AccessoryType,
|
|
3
|
+
import { AccessoryType, HKCharacteristicKey } from '../model/enums.js';
|
|
4
4
|
import { LogType } from '../tools/log.js';
|
|
5
5
|
export class GarageDoorAccessory extends LockMechanismAccessory {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
['
|
|
13
|
-
['
|
|
14
|
-
['
|
|
6
|
+
getAccessoryType() {
|
|
7
|
+
return AccessoryType.GarageDoorOpener;
|
|
8
|
+
}
|
|
9
|
+
constructor(dependency) {
|
|
10
|
+
super(dependency, false);
|
|
11
|
+
const stateMap = new Map([
|
|
12
|
+
['valueDoorStateOpen', dependency.Characteristic.CurrentDoorState.OPEN],
|
|
13
|
+
['valueDoorStateClosed', dependency.Characteristic.CurrentDoorState.CLOSED],
|
|
14
|
+
['valueDoorStateOpening', dependency.Characteristic.CurrentDoorState.OPENING],
|
|
15
|
+
['valueDoorStateClosing', dependency.Characteristic.CurrentDoorState.CLOSING],
|
|
16
|
+
['valueDoorStateStopped', dependency.Characteristic.CurrentDoorState.STOPPED],
|
|
17
|
+
]);
|
|
18
|
+
const currentStateStrings = new Map([
|
|
19
|
+
[dependency.Characteristic.CurrentDoorState.OPEN, strings.garage.stateOpen],
|
|
20
|
+
[dependency.Characteristic.CurrentDoorState.CLOSED, strings.garage.stateClosed],
|
|
21
|
+
[dependency.Characteristic.CurrentDoorState.OPENING, strings.garage.stateOpening],
|
|
22
|
+
[dependency.Characteristic.CurrentDoorState.CLOSING, strings.garage.stateClosing],
|
|
23
|
+
[dependency.Characteristic.CurrentDoorState.STOPPED, strings.garage.stateStopped],
|
|
15
24
|
]);
|
|
16
|
-
const
|
|
25
|
+
const targetStateStrings = new Map([
|
|
26
|
+
[dependency.Characteristic.TargetDoorState.OPEN, strings.garage.stateOpenFuture],
|
|
27
|
+
[dependency.Characteristic.TargetDoorState.CLOSED, strings.garage.stateClosedFuture],
|
|
28
|
+
]);
|
|
29
|
+
const validCurrentStates = Array.from(stateMap.keys()).filter((key) => this.getRawValue(key, false) !== undefined);
|
|
17
30
|
if (validCurrentStates.length === 0) {
|
|
18
31
|
this.log.error(strings.garage.noCurrentStateValues, this.name);
|
|
19
32
|
return;
|
|
20
33
|
}
|
|
21
|
-
this.setup(
|
|
34
|
+
this.setup(HKCharacteristicKey.CurrentDoorState, dependency.Characteristic.CurrentDoorState.CLOSED, 'topicGetCurrentDoorState', this.bindOnUpdateState(HKCharacteristicKey.CurrentDoorState, stateMap, currentStateStrings, strings.garage.unknownValue), true)?.setProps({ validValues: validCurrentStates.map((key) => stateMap.get(key)) });
|
|
22
35
|
const validTargetStates = validCurrentStates.filter((key) => ['valueDoorStateOpen', 'valueDoorStateClosed'].includes(key));
|
|
23
36
|
if (validTargetStates.length === 0) {
|
|
24
37
|
this.log.error(strings.garage.noTargetStateValues, this.name);
|
|
25
38
|
return;
|
|
26
39
|
}
|
|
27
|
-
this.setup(
|
|
28
|
-
this.setup(
|
|
29
|
-
}
|
|
30
|
-
getAccessoryType() {
|
|
31
|
-
return AccessoryType.GarageDoorOpener;
|
|
32
|
-
}
|
|
33
|
-
async onCurrentDoorStateUpdate(topic, value) {
|
|
34
|
-
const current = this.toCVState(value);
|
|
35
|
-
if (current === undefined) {
|
|
36
|
-
return;
|
|
37
|
-
}
|
|
38
|
-
this.onUpdate(CharacteristicKey.CurrentDoorState, current, this.stateStringForCV(current));
|
|
39
|
-
}
|
|
40
|
-
async onTargetDoorStateUpdate(topic, value) {
|
|
41
|
-
const target = this.toCVState(value);
|
|
42
|
-
if (target === undefined) {
|
|
43
|
-
return;
|
|
44
|
-
}
|
|
45
|
-
this.onUpdate(CharacteristicKey.TargetDoorState, target, this.stateStringForCV(target, true));
|
|
46
|
-
}
|
|
47
|
-
async onSetTargetDoorState(value) {
|
|
48
|
-
const target = this.fromCVState(value);
|
|
49
|
-
if (target === undefined) {
|
|
50
|
-
return;
|
|
51
|
-
}
|
|
52
|
-
this.onSet(CharacteristicKey.TargetDoorState, value, target, 'topicSetTargetDoorState', this.stateStringForCV(value, true));
|
|
53
|
-
}
|
|
54
|
-
async onObstructionUpdate(topic, value) {
|
|
55
|
-
const obstructed = value === this.getPrimitiveValue('valueDoorObstructed');
|
|
56
|
-
if (!this.onUpdate(CharacteristicKey.ObstructionDetected, obstructed)) {
|
|
57
|
-
return;
|
|
58
|
-
}
|
|
59
|
-
if (obstructed) {
|
|
60
|
-
this.logIfDesired(LogType.ERROR, strings.garage.obstructed);
|
|
61
|
-
}
|
|
62
|
-
else {
|
|
63
|
-
this.logIfDesired(strings.garage.unobstructed);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
toCVState(value) {
|
|
67
|
-
switch (value) {
|
|
68
|
-
case this.getPrimitiveValue('valueDoorStateOpen', false):
|
|
69
|
-
return this.STATE_MAP.get('valueDoorStateOpen');
|
|
70
|
-
case this.getPrimitiveValue('valueDoorStateClosed', false):
|
|
71
|
-
return this.STATE_MAP.get('valueDoorStateClosed');
|
|
72
|
-
case this.getPrimitiveValue('valueDoorStateOpening', false):
|
|
73
|
-
return this.STATE_MAP.get('valueDoorStateOpening');
|
|
74
|
-
case this.getPrimitiveValue('valueDoorStateClosing', false):
|
|
75
|
-
return this.STATE_MAP.get('valueDoorStateClosing');
|
|
76
|
-
case this.getPrimitiveValue('valueDoorStateStopped', false):
|
|
77
|
-
return this.STATE_MAP.get('valueDoorStateStopped');
|
|
78
|
-
}
|
|
79
|
-
this.logIfDesired(strings.garage.unknownValue, `'${value}'`);
|
|
80
|
-
}
|
|
81
|
-
fromCVState(value) {
|
|
82
|
-
let primative = undefined;
|
|
83
|
-
this.STATE_MAP.forEach((test, key) => {
|
|
84
|
-
if (value === test) {
|
|
85
|
-
primative = this.getPrimitiveValue(key);
|
|
86
|
-
}
|
|
87
|
-
});
|
|
88
|
-
if (primative === undefined) {
|
|
89
|
-
this.log.error(strings.garage.badValue, this.name, `'${value}'`);
|
|
90
|
-
}
|
|
91
|
-
return primative;
|
|
92
|
-
}
|
|
93
|
-
stateStringForCV(state, future = false) {
|
|
94
|
-
switch (state) {
|
|
95
|
-
case this.Characteristic.CurrentDoorState.OPEN:
|
|
96
|
-
return future ? strings.garage.stateOpenFuture : strings.garage.stateOpen;
|
|
97
|
-
case this.Characteristic.CurrentDoorState.CLOSED:
|
|
98
|
-
return future ? strings.garage.stateClosedFuture : strings.garage.stateClosed;
|
|
99
|
-
case this.Characteristic.CurrentDoorState.OPENING:
|
|
100
|
-
return strings.garage.stateOpening;
|
|
101
|
-
case this.Characteristic.CurrentDoorState.CLOSING:
|
|
102
|
-
return strings.garage.stateClosing;
|
|
103
|
-
case this.Characteristic.CurrentDoorState.STOPPED:
|
|
104
|
-
return strings.garage.stateStopped;
|
|
105
|
-
default:
|
|
106
|
-
return strings.garage.stateUnknown;
|
|
107
|
-
}
|
|
40
|
+
this.setup(HKCharacteristicKey.TargetDoorState, dependency.Characteristic.TargetDoorState.CLOSED, 'topicGetTargetDoorState', this.bindOnUpdateState(HKCharacteristicKey.TargetDoorState, stateMap, targetStateStrings, strings.garage.unknownValue), true, 'topicSetTargetDoorState', this.bindOnSetState(HKCharacteristicKey.TargetDoorState, 'topicSetTargetDoorState', stateMap, targetStateStrings, strings.garage.badValue))?.setProps({ validValues: validTargetStates.map((key) => stateMap.get(key)) });
|
|
41
|
+
this.setup(HKCharacteristicKey.ObstructionDetected, false, 'topicGetObstructionDetected', this.bindOnUpdateBooleanSingle(HKCharacteristicKey.ObstructionDetected, 'valueDoorObstructed', strings.garage.obstructed, strings.garage.unobstructed, LogType.ERROR), true);
|
|
108
42
|
}
|
|
109
43
|
}
|
|
110
44
|
//# sourceMappingURL=garage.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"garage.js","sourceRoot":"","sources":["../../src/accessory/garage.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"garage.js","sourceRoot":"","sources":["../../src/accessory/garage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,WAAW,CAAC;AAEnD,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAE1C,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAGvE,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAE1C,MAAM,OAAO,mBAAoB,SAAQ,sBAAwC;IAErE,gBAAgB;QACxB,OAAO,aAAa,CAAC,gBAAgB,CAAC;IACxC,CAAC;IAED,YAAY,UAAqD;QAC/D,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;QAEzB,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAiC;YACvD,CAAC,oBAAoB,EAAE,UAAU,CAAC,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC;YACvE,CAAC,sBAAsB,EAAE,UAAU,CAAC,cAAc,CAAC,gBAAgB,CAAC,MAAM,CAAC;YAC3E,CAAC,uBAAuB,EAAE,UAAU,CAAC,cAAc,CAAC,gBAAgB,CAAC,OAAO,CAAC;YAC7E,CAAC,uBAAuB,EAAE,UAAU,CAAC,cAAc,CAAC,gBAAgB,CAAC,OAAO,CAAC;YAC7E,CAAC,uBAAuB,EAAE,UAAU,CAAC,cAAc,CAAC,gBAAgB,CAAC,OAAO,CAAC;SAC9E,CAAC,CAAC;QAEH,MAAM,mBAAmB,GAAG,IAAI,GAAG,CAAC;YAClC,CAAC,UAAU,CAAC,cAAc,CAAC,gBAAgB,CAAC,IAAI,EAAE,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC;YAC3E,CAAC,UAAU,CAAC,cAAc,CAAC,gBAAgB,CAAC,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC;YAC/E,CAAC,UAAU,CAAC,cAAc,CAAC,gBAAgB,CAAC,OAAO,EAAE,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC;YACjF,CAAC,UAAU,CAAC,cAAc,CAAC,gBAAgB,CAAC,OAAO,EAAE,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC;YACjF,CAAC,UAAU,CAAC,cAAc,CAAC,gBAAgB,CAAC,OAAO,EAAE,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC;SAClF,CAAC,CAAC;QAEH,MAAM,kBAAkB,GAAG,IAAI,GAAG,CAAC;YACjC,CAAC,UAAU,CAAC,cAAc,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC;YAChF,CAAC,UAAU,CAAC,cAAc,CAAC,eAAe,CAAC,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC;SACrF,CAAC,CAAC;QAEH,MAAM,kBAAkB,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,KAAK,CAAC,KAAK,SAAS,CAAC,CAAC;QACnH,IAAI,kBAAkB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACpC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,oBAAoB,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC/D,OAAO;QACT,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,UAAU,CAAC,cAAc,CAAC,gBAAgB,CAAC,MAAM,EAChG,0BAA0B,EAC1B,IAAI,CAAC,iBAAiB,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,QAAQ,EAAE,mBAAmB,EAAE,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,EACxH,IAAI,CACL,EAAE,QAAQ,CAAC,EAAE,WAAW,EAAE,kBAAkB,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAE,CAAC,EAAE,CAAC,CAAC;QAElF,MAAM,iBAAiB,GAAG,kBAAkB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,oBAAoB,EAAE,sBAAsB,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;QAC3H,IAAI,iBAAiB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACnC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,mBAAmB,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC9D,OAAO;QACT,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,eAAe,EAAE,UAAU,CAAC,cAAc,CAAC,eAAe,CAAC,MAAM,EAC9F,yBAAyB,EACzB,IAAI,CAAC,iBAAiB,CAAC,mBAAmB,CAAC,eAAe,EAAE,QAAQ,EAAE,kBAAkB,EAAE,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,EACtH,IAAI,EACJ,yBAAyB,EACzB,IAAI,CAAC,cAAc,CAAC,mBAAmB,CAAC,eAAe,EAAE,yBAAyB,EAAE,QAAQ,EAAE,kBAAkB,EAAE,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAC3I,EAAE,QAAQ,CAAC,EAAE,WAAW,EAAE,iBAAiB,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAE,CAAC,EAAE,CAAC,CAAC;QAEjF,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,mBAAmB,EAAE,KAAK,EACvD,6BAA6B,EAC7B,IAAI,CAAC,yBAAyB,CAAC,mBAAmB,CAAC,mBAAmB,EAAE,qBAAqB,EAC3F,OAAO,CAAC,MAAM,CAAC,UAAU,EAAE,OAAO,CAAC,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC,KAAK,CAAC,EACxE,IAAI,CACL,CAAC;IACJ,CAAC;CACF"}
|
package/dist/accessory/lock.d.ts
CHANGED
|
@@ -1,16 +1,10 @@
|
|
|
1
|
-
import { PlatformAccessory } from 'homebridge';
|
|
2
1
|
import { BaseAccessory } from './abstract/base.js';
|
|
3
2
|
import { AccessoryType } from '../model/enums.js';
|
|
4
|
-
import {
|
|
5
|
-
import { Log } from '../tools/log.js';
|
|
3
|
+
import { LockConfig, MQTTAccessoryDependency } from '../model/types.js';
|
|
6
4
|
export declare class LockMechanismAccessory<C extends LockConfig = LockConfig> extends BaseAccessory<C> {
|
|
7
|
-
constructor(Service: ServiceType, Characteristic: CharacteristicType, accessory: PlatformAccessory, config: C, log: Log, isGrouped: boolean, requireTopics?: boolean);
|
|
8
5
|
protected getAccessoryType(): AccessoryType;
|
|
6
|
+
constructor(dependency: MQTTAccessoryDependency<C>, requireTopics?: boolean);
|
|
9
7
|
private onCurrentStateUpdate;
|
|
10
|
-
private onTargetStateUpdate;
|
|
11
|
-
private onSetTargetState;
|
|
12
8
|
private currentStateFromValue;
|
|
13
|
-
private targetStateFromValue;
|
|
14
|
-
private valueFromTargetState;
|
|
15
9
|
private stringForState;
|
|
16
10
|
}
|
package/dist/accessory/lock.js
CHANGED
|
@@ -1,33 +1,39 @@
|
|
|
1
1
|
import { BaseAccessory } from './abstract/base.js';
|
|
2
2
|
import { strings } from '../i18n/i18n.js';
|
|
3
|
-
import { AccessoryType,
|
|
3
|
+
import { AccessoryType, HKCharacteristicKey } from '../model/enums.js';
|
|
4
4
|
import { LogType } from '../tools/log.js';
|
|
5
5
|
export class LockMechanismAccessory extends BaseAccessory {
|
|
6
|
-
constructor(Service, Characteristic, accessory, config, log, isGrouped, requireTopics = true) {
|
|
7
|
-
super(Service, Characteristic, accessory, config, log, isGrouped);
|
|
8
|
-
const getTopicCurrent = this.config.topicGetLockCurrentState !== undefined && this.config.topicGetCurrentLockState === undefined
|
|
9
|
-
? 'topicGetLockCurrentState' : 'topicGetCurrentLockState';
|
|
10
|
-
this.setup(CharacteristicKey.LockCurrentState, Characteristic.LockCurrentState.UNKNOWN, getTopicCurrent, this.onCurrentStateUpdate.bind(this), requireTopics);
|
|
11
|
-
let getTargetTopic, setTargetTopic;
|
|
12
|
-
if (this.config.topicGetLockTargetState !== undefined && this.config.topicGetTargetLockState === undefined) {
|
|
13
|
-
getTargetTopic = 'topicGetLockTargetState';
|
|
14
|
-
setTargetTopic = 'topicSetTargetState';
|
|
15
|
-
}
|
|
16
|
-
else {
|
|
17
|
-
getTargetTopic = 'topicGetTargetLockState';
|
|
18
|
-
setTargetTopic = 'topicSetTargetLockState';
|
|
19
|
-
}
|
|
20
|
-
this.setup(CharacteristicKey.LockTargetState, Characteristic.LockTargetState.SECURED, getTargetTopic, this.onTargetStateUpdate.bind(this), requireTopics, setTargetTopic, this.onSetTargetState.bind(this));
|
|
21
|
-
}
|
|
22
6
|
getAccessoryType() {
|
|
23
7
|
return AccessoryType.LockMechanism;
|
|
24
8
|
}
|
|
9
|
+
constructor(dependency, requireTopics = true) {
|
|
10
|
+
super(dependency);
|
|
11
|
+
if (this.config.topicGetLockCurrentState !== undefined && this.config.topicGetCurrentLockState === undefined) {
|
|
12
|
+
this.config.topicGetCurrentLockState = this.config.topicGetLockCurrentState;
|
|
13
|
+
}
|
|
14
|
+
if (this.config.topicGetLockTargetState !== undefined && this.config.topicGetTargetLockState === undefined) {
|
|
15
|
+
this.config.topicGetTargetLockState = this.config.topicGetLockTargetState;
|
|
16
|
+
}
|
|
17
|
+
if (this.config.topicSetTargetState !== undefined && this.config.topicSetTargetLockState === undefined) {
|
|
18
|
+
this.config.topicSetTargetLockState = this.config.topicSetTargetState;
|
|
19
|
+
}
|
|
20
|
+
this.setup(HKCharacteristicKey.LockCurrentState, dependency.Characteristic.LockCurrentState.UNKNOWN, 'topicGetCurrentLockState', this.onCurrentStateUpdate.bind(this), requireTopics);
|
|
21
|
+
const targetStates = new Map([
|
|
22
|
+
['valueLockStateSecured', dependency.Characteristic.LockTargetState.SECURED],
|
|
23
|
+
['valueLockStateUnsecured', dependency.Characteristic.LockTargetState.UNSECURED],
|
|
24
|
+
]);
|
|
25
|
+
const targetStrings = new Map([
|
|
26
|
+
[dependency.Characteristic.LockCurrentState.SECURED, strings.lock.stateSecuredFuture],
|
|
27
|
+
[dependency.Characteristic.LockCurrentState.UNSECURED, strings.lock.stateUnsecuredFuture],
|
|
28
|
+
]);
|
|
29
|
+
this.setup(HKCharacteristicKey.LockTargetState, dependency.Characteristic.LockTargetState.SECURED, 'topicGetTargetLockState', this.bindOnUpdateState(HKCharacteristicKey.LockTargetState, targetStates, targetStrings, strings.lock.stateUnknown), requireTopics, 'topicSetTargetLockState', this.bindOnSetState(HKCharacteristicKey.LockTargetState, 'topicSetTargetLockState', targetStates, targetStrings, strings.lock.badValue));
|
|
30
|
+
}
|
|
25
31
|
async onCurrentStateUpdate(topic, value) {
|
|
26
32
|
const current = this.currentStateFromValue(value);
|
|
27
33
|
if (current <= this.Characteristic.LockTargetState.SECURED) {
|
|
28
|
-
this.onUpdate(
|
|
34
|
+
this.onUpdate(HKCharacteristicKey.LockTargetState, current);
|
|
29
35
|
}
|
|
30
|
-
if (!this.onUpdate(
|
|
36
|
+
if (!this.onUpdate(HKCharacteristicKey.LockCurrentState, current)) {
|
|
31
37
|
return;
|
|
32
38
|
}
|
|
33
39
|
if (current === this.Characteristic.LockCurrentState.JAMMED) {
|
|
@@ -37,26 +43,6 @@ export class LockMechanismAccessory extends BaseAccessory {
|
|
|
37
43
|
this.logIfDesired(this.stringForState(current));
|
|
38
44
|
}
|
|
39
45
|
}
|
|
40
|
-
async onTargetStateUpdate(topic, value) {
|
|
41
|
-
const target = this.targetStateFromValue(value);
|
|
42
|
-
this.onUpdate(CharacteristicKey.LockTargetState, target, this.stringForState(target, true));
|
|
43
|
-
}
|
|
44
|
-
async onSetTargetState(value) {
|
|
45
|
-
if (!this.assert('valueLockStateSecured', 'valueLockStateUnsecured')) {
|
|
46
|
-
return;
|
|
47
|
-
}
|
|
48
|
-
const target = this.valueFromTargetState(value);
|
|
49
|
-
if (target === undefined) {
|
|
50
|
-
this.log.error(strings.lock.badValue, this.name, `'${value}'`);
|
|
51
|
-
return;
|
|
52
|
-
}
|
|
53
|
-
if (this.config.topicSetTargetState !== undefined && this.config.topicSetTargetLockState === undefined) {
|
|
54
|
-
this.onSet(CharacteristicKey.LockTargetState, value, target, 'topicSetTargetState', this.stringForState(value, true));
|
|
55
|
-
}
|
|
56
|
-
else {
|
|
57
|
-
this.onSet(CharacteristicKey.LockTargetState, value, target, 'topicSetTargetLockState', this.stringForState(value, true));
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
46
|
currentStateFromValue(value) {
|
|
61
47
|
if (value === undefined) {
|
|
62
48
|
return this.Characteristic.LockCurrentState.UNKNOWN;
|
|
@@ -72,32 +58,12 @@ export class LockMechanismAccessory extends BaseAccessory {
|
|
|
72
58
|
return this.Characteristic.LockCurrentState.UNKNOWN;
|
|
73
59
|
}
|
|
74
60
|
}
|
|
75
|
-
|
|
76
|
-
if (value === undefined) {
|
|
77
|
-
return this.Characteristic.LockTargetState.SECURED;
|
|
78
|
-
}
|
|
79
|
-
switch (value) {
|
|
80
|
-
case this.getPrimitiveValue('valueLockStateUnsecured'):
|
|
81
|
-
return this.Characteristic.LockTargetState.UNSECURED;
|
|
82
|
-
case this.getPrimitiveValue('valueLockStateSecured'):
|
|
83
|
-
default:
|
|
84
|
-
return this.Characteristic.LockTargetState.SECURED;
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
valueFromTargetState(value) {
|
|
88
|
-
switch (value) {
|
|
89
|
-
case this.Characteristic.LockTargetState.SECURED:
|
|
90
|
-
return this.getPrimitiveValue('valueLockStateSecured');
|
|
91
|
-
case this.Characteristic.LockTargetState.UNSECURED:
|
|
92
|
-
return this.getPrimitiveValue('valueLockStateUnsecured');
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
stringForState(state, future = false) {
|
|
61
|
+
stringForState(state) {
|
|
96
62
|
switch (state) {
|
|
97
63
|
case this.Characteristic.LockCurrentState.SECURED:
|
|
98
|
-
return
|
|
64
|
+
return strings.lock.stateSecured;
|
|
99
65
|
case this.Characteristic.LockCurrentState.UNSECURED:
|
|
100
|
-
return
|
|
66
|
+
return strings.lock.stateUnsecured;
|
|
101
67
|
case this.Characteristic.LockCurrentState.JAMMED:
|
|
102
68
|
return strings.lock.stateJammed;
|
|
103
69
|
default:
|