homebridge-smartthings-oauth 1.0.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/.devcontainer/Dockerfile +16 -0
- package/.devcontainer/devcontainer.json +36 -0
- package/LICENSE +176 -0
- package/README.md +114 -0
- package/config.schema.json +134 -0
- package/dist/auth/auth.d.ts +23 -0
- package/dist/auth/auth.d.ts.map +1 -0
- package/dist/auth/auth.js +168 -0
- package/dist/auth/auth.js.map +1 -0
- package/dist/auth/tokenManager.d.ts +36 -0
- package/dist/auth/tokenManager.d.ts.map +1 -0
- package/dist/auth/tokenManager.js +180 -0
- package/dist/auth/tokenManager.js.map +1 -0
- package/dist/basePlatformAccessory.d.ts +49 -0
- package/dist/basePlatformAccessory.d.ts.map +1 -0
- package/dist/basePlatformAccessory.js +209 -0
- package/dist/basePlatformAccessory.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/keyValues.d.ts +4 -0
- package/dist/keyValues.d.ts.map +1 -0
- package/dist/keyValues.js +12 -0
- package/dist/keyValues.js.map +1 -0
- package/dist/multiServiceAccessory.d.ts +60 -0
- package/dist/multiServiceAccessory.d.ts.map +1 -0
- package/dist/multiServiceAccessory.js +398 -0
- package/dist/multiServiceAccessory.js.map +1 -0
- package/dist/platform.d.ts +42 -0
- package/dist/platform.d.ts.map +1 -0
- package/dist/platform.js +302 -0
- package/dist/platform.js.map +1 -0
- package/dist/services/airConditionerService.d.ts +52 -0
- package/dist/services/airConditionerService.d.ts.map +1 -0
- package/dist/services/airConditionerService.js +438 -0
- package/dist/services/airConditionerService.js.map +1 -0
- package/dist/services/baseService.d.ts +21 -0
- package/dist/services/baseService.d.ts.map +1 -0
- package/dist/services/baseService.js +63 -0
- package/dist/services/baseService.js.map +1 -0
- package/dist/services/batteryService.d.ts +10 -0
- package/dist/services/batteryService.d.ts.map +1 -0
- package/dist/services/batteryService.js +71 -0
- package/dist/services/batteryService.js.map +1 -0
- package/dist/services/carbonMonoxideDetector.d.ts +11 -0
- package/dist/services/carbonMonoxideDetector.d.ts.map +1 -0
- package/dist/services/carbonMonoxideDetector.js +28 -0
- package/dist/services/carbonMonoxideDetector.js.map +1 -0
- package/dist/services/contactSensorService.d.ts +10 -0
- package/dist/services/contactSensorService.d.ts.map +1 -0
- package/dist/services/contactSensorService.js +28 -0
- package/dist/services/contactSensorService.js.map +1 -0
- package/dist/services/doorService.d.ts +16 -0
- package/dist/services/doorService.d.ts.map +1 -0
- package/dist/services/doorService.js +138 -0
- package/dist/services/doorService.js.map +1 -0
- package/dist/services/fanSpeedService.d.ts +15 -0
- package/dist/services/fanSpeedService.d.ts.map +1 -0
- package/dist/services/fanSpeedService.js +153 -0
- package/dist/services/fanSpeedService.js.map +1 -0
- package/dist/services/fanSwitchLevelService.d.ts +14 -0
- package/dist/services/fanSwitchLevelService.d.ts.map +1 -0
- package/dist/services/fanSwitchLevelService.js +121 -0
- package/dist/services/fanSwitchLevelService.js.map +1 -0
- package/dist/services/humidityService.d.ts +10 -0
- package/dist/services/humidityService.d.ts.map +1 -0
- package/dist/services/humidityService.js +23 -0
- package/dist/services/humidityService.js.map +1 -0
- package/dist/services/leakDetector.d.ts +10 -0
- package/dist/services/leakDetector.d.ts.map +1 -0
- package/dist/services/leakDetector.js +27 -0
- package/dist/services/leakDetector.js.map +1 -0
- package/dist/services/lightSensorService.d.ts +10 -0
- package/dist/services/lightSensorService.d.ts.map +1 -0
- package/dist/services/lightSensorService.js +24 -0
- package/dist/services/lightSensorService.js.map +1 -0
- package/dist/services/lightService.d.ts +26 -0
- package/dist/services/lightService.d.ts.map +1 -0
- package/dist/services/lightService.js +340 -0
- package/dist/services/lightService.js.map +1 -0
- package/dist/services/lockService.d.ts +16 -0
- package/dist/services/lockService.d.ts.map +1 -0
- package/dist/services/lockService.js +128 -0
- package/dist/services/lockService.js.map +1 -0
- package/dist/services/motionService.d.ts +10 -0
- package/dist/services/motionService.d.ts.map +1 -0
- package/dist/services/motionService.js +23 -0
- package/dist/services/motionService.js.map +1 -0
- package/dist/services/occupancySensorService.d.ts +10 -0
- package/dist/services/occupancySensorService.d.ts.map +1 -0
- package/dist/services/occupancySensorService.js +23 -0
- package/dist/services/occupancySensorService.js.map +1 -0
- package/dist/services/sensorService.d.ts +15 -0
- package/dist/services/sensorService.d.ts.map +1 -0
- package/dist/services/sensorService.js +69 -0
- package/dist/services/sensorService.js.map +1 -0
- package/dist/services/smartThingsCommand.d.ts +7 -0
- package/dist/services/smartThingsCommand.d.ts.map +1 -0
- package/dist/services/smartThingsCommand.js +12 -0
- package/dist/services/smartThingsCommand.js.map +1 -0
- package/dist/services/smokeDetector.d.ts +10 -0
- package/dist/services/smokeDetector.d.ts.map +1 -0
- package/dist/services/smokeDetector.js +27 -0
- package/dist/services/smokeDetector.js.map +1 -0
- package/dist/services/statelessProgrammableSwitchService.d.ts +12 -0
- package/dist/services/statelessProgrammableSwitchService.d.ts.map +1 -0
- package/dist/services/statelessProgrammableSwitchService.js +94 -0
- package/dist/services/statelessProgrammableSwitchService.js.map +1 -0
- package/dist/services/switchService.d.ts +12 -0
- package/dist/services/switchService.d.ts.map +1 -0
- package/dist/services/switchService.js +72 -0
- package/dist/services/switchService.js.map +1 -0
- package/dist/services/temperatureService.d.ts +11 -0
- package/dist/services/temperatureService.d.ts.map +1 -0
- package/dist/services/temperatureService.js +32 -0
- package/dist/services/temperatureService.js.map +1 -0
- package/dist/services/thermostatService.d.ts +22 -0
- package/dist/services/thermostatService.d.ts.map +1 -0
- package/dist/services/thermostatService.js +273 -0
- package/dist/services/thermostatService.js.map +1 -0
- package/dist/services/valveService.d.ts +12 -0
- package/dist/services/valveService.d.ts.map +1 -0
- package/dist/services/valveService.js +59 -0
- package/dist/services/valveService.js.map +1 -0
- package/dist/services/windowCoveringService.d.ts +36 -0
- package/dist/services/windowCoveringService.d.ts.map +1 -0
- package/dist/services/windowCoveringService.js +158 -0
- package/dist/services/windowCoveringService.js.map +1 -0
- package/dist/settings.d.ts +9 -0
- package/dist/settings.d.ts.map +1 -0
- package/dist/settings.js +12 -0
- package/dist/settings.js.map +1 -0
- package/dist/webhook/subscriptionHandler.d.ts +32 -0
- package/dist/webhook/subscriptionHandler.d.ts.map +1 -0
- package/dist/webhook/subscriptionHandler.js +68 -0
- package/dist/webhook/subscriptionHandler.js.map +1 -0
- package/dist/webhook/webhookServer.d.ts +19 -0
- package/dist/webhook/webhookServer.d.ts.map +1 -0
- package/dist/webhook/webhookServer.js +125 -0
- package/dist/webhook/webhookServer.js.map +1 -0
- package/package.json +57 -0
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { PlatformAccessory, CharacteristicValue, WithUUID, Characteristic, Service } from 'homebridge';
|
|
3
|
+
import { IKHomeBridgeHomebridgePlatform } from '../platform';
|
|
4
|
+
import { BaseService } from './baseService';
|
|
5
|
+
import { MultiServiceAccessory } from '../multiServiceAccessory';
|
|
6
|
+
export declare abstract class SensorService extends BaseService {
|
|
7
|
+
statusFailureCount: number;
|
|
8
|
+
statusTranslation: (status: any) => CharacteristicValue | null;
|
|
9
|
+
pollingTimer: NodeJS.Timer | void | undefined;
|
|
10
|
+
characteristic: WithUUID<new () => Characteristic> | undefined;
|
|
11
|
+
constructor(platform: IKHomeBridgeHomebridgePlatform, accessory: PlatformAccessory, componentId: string, capabilities: string[], multiServiceAccessory: MultiServiceAccessory, name: string, deviceStatus: any);
|
|
12
|
+
protected initService(sensorService: WithUUID<typeof Service>, sensorCharacteristic: WithUUID<new () => Characteristic>, statusTranslation: (status: any) => CharacteristicValue): void;
|
|
13
|
+
getSensorState(): Promise<CharacteristicValue>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=sensorService.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sensorService.d.ts","sourceRoot":"","sources":["../../src/services/sensorService.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,QAAQ,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACvG,OAAO,EAAE,8BAA8B,EAAE,MAAM,aAAa,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AAEjE,8BAAsB,aAAc,SAAQ,WAAW;IACrD,kBAAkB,SAAK;IACvB,iBAAiB,EAAE,CAAC,MAAM,KAAA,KAAK,mBAAmB,GAAG,IAAI,CAEvD;IAEF,YAAY,EAAE,MAAM,CAAC,KAAK,GAAG,IAAI,GAAG,SAAS,CAAC;IAE9C,cAAc,EAAE,QAAQ,CAAC,UAAU,cAAc,CAAC,GAAG,SAAS,CAAC;gBAEnD,QAAQ,EAAE,8BAA8B,EAAE,SAAS,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,EAC7H,qBAAqB,EAAE,qBAAqB,EAC5C,IAAI,EAAE,MAAM,EAAE,YAAY,KAAA;IAI5B,SAAS,CAAC,WAAW,CAAC,aAAa,EAAE,QAAQ,CAAC,OAAO,OAAO,CAAC,EAAE,oBAAoB,EAAE,QAAQ,CAAC,UAAU,cAAc,CAAC,EACrH,iBAAiB,EAAE,CAAC,MAAM,KAAA,KAAK,mBAAmB;IAsB9C,cAAc,IAAI,OAAO,CAAC,mBAAmB,CAAC;CA4CrD"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SensorService = void 0;
|
|
4
|
+
const baseService_1 = require("./baseService");
|
|
5
|
+
class SensorService extends baseService_1.BaseService {
|
|
6
|
+
constructor(platform, accessory, componentId, capabilities, multiServiceAccessory, name, deviceStatus) {
|
|
7
|
+
super(platform, accessory, componentId, capabilities, multiServiceAccessory, name, deviceStatus);
|
|
8
|
+
this.statusFailureCount = 0;
|
|
9
|
+
this.statusTranslation = () => {
|
|
10
|
+
return null;
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
initService(sensorService, sensorCharacteristic, statusTranslation) {
|
|
14
|
+
this.statusTranslation = statusTranslation;
|
|
15
|
+
this.setServiceType(sensorService);
|
|
16
|
+
this.characteristic = sensorCharacteristic;
|
|
17
|
+
// Set the event handlers
|
|
18
|
+
this.service.getCharacteristic(sensorCharacteristic)
|
|
19
|
+
.onGet(this.getSensorState.bind(this));
|
|
20
|
+
let pollSensorsSeconds = 10; // default to 10 seconds
|
|
21
|
+
if (this.platform.config.PollSensorsSeconds !== undefined) {
|
|
22
|
+
pollSensorsSeconds = this.platform.config.PollSensorsSeconds;
|
|
23
|
+
}
|
|
24
|
+
if (pollSensorsSeconds > 0) {
|
|
25
|
+
this.pollingTimer = this.multiServiceAccessory.startPollingState(pollSensorsSeconds, this.getSensorState.bind(this), this.service, sensorCharacteristic);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
// Get the current state of the sensor
|
|
29
|
+
async getSensorState() {
|
|
30
|
+
// if you need to return an error to show the device as "Not Responding" in the Home app:
|
|
31
|
+
// throw new this.platform.api.hap.HapStatusError(this.platform.api.hap.HAPStatus.SERVICE_COMMUNICATION_FAILURE);
|
|
32
|
+
this.log.debug('Received getSensorState() event for ' + this.name);
|
|
33
|
+
return new Promise((resolve, reject) => {
|
|
34
|
+
this.getStatus().then(success => {
|
|
35
|
+
if (success) {
|
|
36
|
+
let value;
|
|
37
|
+
try {
|
|
38
|
+
value = this.statusTranslation(this.deviceStatus.status);
|
|
39
|
+
this.statusFailureCount = 0;
|
|
40
|
+
this.log.debug(`State for ${this.name}: ${value}`);
|
|
41
|
+
resolve(value);
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
catch (error) {
|
|
45
|
+
this.statusFailureCount++;
|
|
46
|
+
if (this.statusFailureCount > 5) {
|
|
47
|
+
this.log.error(`Bad status from ${this.name}. Removing this service.`);
|
|
48
|
+
// Stop polling and remove service
|
|
49
|
+
if (this.pollingTimer) {
|
|
50
|
+
clearInterval(this.pollingTimer);
|
|
51
|
+
}
|
|
52
|
+
this.accessory.removeService(this.service);
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
this.log.warn(`Bad status from ${this.name}. Ignoring for now.`);
|
|
56
|
+
}
|
|
57
|
+
reject(new this.platform.api.hap.HapStatusError(-70410 /* this.platform.api.hap.HAPStatus.INVALID_VALUE_IN_REQUEST */));
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
reject(new this.platform.api.hap.HapStatusError(-70402 /* this.platform.api.hap.HAPStatus.SERVICE_COMMUNICATION_FAILURE */));
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
exports.SensorService = SensorService;
|
|
69
|
+
//# sourceMappingURL=sensorService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sensorService.js","sourceRoot":"","sources":["../../src/services/sensorService.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"smartThingsCommand.d.ts","sourceRoot":"","sources":["../../src/services/smartThingsCommand.ts"],"names":[],"mappings":"AAAA,qBAAa,OAAO;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,OAAO,EAAE,CAAC;gBAEV,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,EAAE;CAKlE"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Command = void 0;
|
|
4
|
+
class Command {
|
|
5
|
+
constructor(capability, command, args) {
|
|
6
|
+
this.capability = capability;
|
|
7
|
+
this.command = command;
|
|
8
|
+
this.arguments = args;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.Command = Command;
|
|
12
|
+
//# sourceMappingURL=smartThingsCommand.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"smartThingsCommand.js","sourceRoot":"","sources":["../../src/services/smartThingsCommand.ts"],"names":[],"mappings":";;;AAAA,MAAa,OAAO;IAKlB,YAAY,UAAkB,EAAE,OAAe,EAAE,IAAgB;QAC/D,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IACxB,CAAC;CACF;AAVD,0BAUC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { PlatformAccessory } from 'homebridge';
|
|
2
|
+
import { IKHomeBridgeHomebridgePlatform } from '../platform';
|
|
3
|
+
import { MultiServiceAccessory } from '../multiServiceAccessory';
|
|
4
|
+
import { SensorService } from './sensorService';
|
|
5
|
+
import { ShortEvent } from '../webhook/subscriptionHandler';
|
|
6
|
+
export declare class SmokeDetectorService extends SensorService {
|
|
7
|
+
constructor(platform: IKHomeBridgeHomebridgePlatform, accessory: PlatformAccessory, componentId: string, capabilities: string[], multiServiceAccessory: MultiServiceAccessory, name: string, deviceStatus: any);
|
|
8
|
+
processEvent(event: ShortEvent): void;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=smokeDetector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"smokeDetector.d.ts","sourceRoot":"","sources":["../../src/services/smokeDetector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,8BAA8B,EAAE,MAAM,aAAa,CAAC;AAC7D,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAE5D,qBAAa,oBAAqB,SAAQ,aAAa;gBAEzC,QAAQ,EAAE,8BAA8B,EAAE,SAAS,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,EAC7H,qBAAqB,EAAE,qBAAqB,EAC5C,IAAI,EAAE,MAAM,EAAE,YAAY,KAAA;IAmBrB,YAAY,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;CAQ7C"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SmokeDetectorService = void 0;
|
|
4
|
+
const sensorService_1 = require("./sensorService");
|
|
5
|
+
class SmokeDetectorService extends sensorService_1.SensorService {
|
|
6
|
+
constructor(platform, accessory, componentId, capabilities, multiServiceAccessory, name, deviceStatus) {
|
|
7
|
+
super(platform, accessory, componentId, capabilities, multiServiceAccessory, name, deviceStatus);
|
|
8
|
+
this.initService(platform.Service.SmokeSensor, platform.Characteristic.SmokeDetected, (status) => {
|
|
9
|
+
if (status.smokeDetector.smoke.value === null || status.smokeDetector.smoke.value === undefined) {
|
|
10
|
+
this.log.warn(`${this.name} returned bad value for status`);
|
|
11
|
+
throw ('Bad Value');
|
|
12
|
+
}
|
|
13
|
+
return status.smokeDetector.smoke.value === 'detected' ?
|
|
14
|
+
this.platform.Characteristic.SmokeDetected.SMOKE_DETECTED :
|
|
15
|
+
this.platform.Characteristic.SmokeDetected.SMOKE_NOT_DETECTED;
|
|
16
|
+
});
|
|
17
|
+
this.log.debug(`Adding SmokeDetector Service to ${this.name}`);
|
|
18
|
+
}
|
|
19
|
+
processEvent(event) {
|
|
20
|
+
this.log.debug(`Event updating smoke detected for ${this.name} to ${event.value}`);
|
|
21
|
+
this.service.updateCharacteristic(this.platform.Characteristic.SmokeDetected, event.value === 'detected' ?
|
|
22
|
+
this.platform.Characteristic.SmokeDetected.SMOKE_DETECTED :
|
|
23
|
+
this.platform.Characteristic.SmokeDetected.SMOKE_NOT_DETECTED);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
exports.SmokeDetectorService = SmokeDetectorService;
|
|
27
|
+
//# sourceMappingURL=smokeDetector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"smokeDetector.js","sourceRoot":"","sources":["../../src/services/smokeDetector.ts"],"names":[],"mappings":";;;AAGA,mDAAgD;AAGhD,MAAa,oBAAqB,SAAQ,6BAAa;IAErD,YAAY,QAAwC,EAAE,SAA4B,EAAE,WAAmB,EAAE,YAAsB,EAC7H,qBAA4C,EAC5C,IAAY,EAAE,YAAY;QAE1B,KAAK,CAAC,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,YAAY,EAAE,qBAAqB,EAAE,IAAI,EAAE,YAAY,CAAC,CAAC;QAEjG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,WAAW,EAC3C,QAAQ,CAAC,cAAc,CAAC,aAAa,EACrC,CAAC,MAAM,EAAE,EAAE;YACT,IAAI,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,KAAK,IAAI,IAAI,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,KAAK,SAAS,EAAE;gBAC/F,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,gCAAgC,CAAC,CAAC;gBAC5D,MAAK,CAAC,WAAW,CAAC,CAAC;aACpB;YACD,OAAO,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,KAAK,UAAU,CAAC,CAAC;gBACtD,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC;gBAC3D,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,kBAAkB,CAAC;QAClE,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,mCAAmC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IACjE,CAAC;IAEM,YAAY,CAAC,KAAiB;QACnC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,qCAAqC,IAAI,CAAC,IAAI,OAAO,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;QACnF,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAC/B,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,aAAa,EAC1C,KAAK,CAAC,KAAK,KAAK,UAAU,CAAC,CAAC;YAC1B,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC;YAC3D,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC;IACrE,CAAC;CACF;AA/BD,oDA+BC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { PlatformAccessory, CharacteristicValue } from 'homebridge';
|
|
2
|
+
import { IKHomeBridgeHomebridgePlatform } from '../platform';
|
|
3
|
+
import { BaseService } from './baseService';
|
|
4
|
+
import { MultiServiceAccessory } from '../multiServiceAccessory';
|
|
5
|
+
import { ShortEvent } from '../webhook/subscriptionHandler';
|
|
6
|
+
export declare class StatelessProgrammableSwitchService extends BaseService {
|
|
7
|
+
constructor(platform: IKHomeBridgeHomebridgePlatform, accessory: PlatformAccessory, componentId: string, capabilities: string[], multiServiceAccessory: MultiServiceAccessory, name: string, deviceStatus: any);
|
|
8
|
+
getSwitchState(): Promise<CharacteristicValue>;
|
|
9
|
+
processEvent(event: ShortEvent): void;
|
|
10
|
+
private mapValue;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=statelessProgrammableSwitchService.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"statelessProgrammableSwitchService.d.ts","sourceRoot":"","sources":["../../src/services/statelessProgrammableSwitchService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AACpE,OAAO,EAAE,8BAA8B,EAAE,MAAM,aAAa,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAE5D,qBAAa,kCAAmC,SAAQ,WAAW;gBAErD,QAAQ,EAAE,8BAA8B,EAAE,SAAS,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,EAAC,MAAM,EAAE,EAC5H,qBAAqB,EAAE,qBAAqB,EAC5C,IAAI,EAAE,MAAM,EAAE,YAAY,KAAA;IAuCtB,cAAc,IAAI,OAAO,CAAC,mBAAmB,CAAC;IA4B7C,YAAY,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IAU5C,OAAO,CAAC,QAAQ;CAejB"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StatelessProgrammableSwitchService = void 0;
|
|
4
|
+
const baseService_1 = require("./baseService");
|
|
5
|
+
class StatelessProgrammableSwitchService extends baseService_1.BaseService {
|
|
6
|
+
constructor(platform, accessory, componentId, capabilities, multiServiceAccessory, name, deviceStatus) {
|
|
7
|
+
super(platform, accessory, componentId, capabilities, multiServiceAccessory, name, deviceStatus);
|
|
8
|
+
this.setServiceType(platform.Service.StatelessProgrammableSwitch);
|
|
9
|
+
// Set the event handlers
|
|
10
|
+
this.log.debug(`Adding StatelessProgrammableSwitchService to ${this.name}`);
|
|
11
|
+
this.service.getCharacteristic(platform.Characteristic.ProgrammableSwitchEvent)
|
|
12
|
+
.onGet(this.getSwitchState.bind(this));
|
|
13
|
+
let pollSwitchesAndLightsSeconds = 10; // default to 10 seconds
|
|
14
|
+
if (this.platform.config.PollSwitchesAndLightsSeconds !== undefined) {
|
|
15
|
+
pollSwitchesAndLightsSeconds = this.platform.config.PollSwitchesAndLightsSeconds;
|
|
16
|
+
}
|
|
17
|
+
if (pollSwitchesAndLightsSeconds > 0) {
|
|
18
|
+
multiServiceAccessory.startPollingState(pollSwitchesAndLightsSeconds, this.getSwitchState.bind(this), this.service, platform.Characteristic.ProgrammableSwitchEvent);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
// Set the target state of the lock
|
|
22
|
+
// async setSwitchState(value: CharacteristicValue) {
|
|
23
|
+
// this.log.debug('Received setSwitchState(' + value + ') event for ' + this.name);
|
|
24
|
+
// if (!this.multiServiceAccessory.isOnline) {
|
|
25
|
+
// this.log.error(this.name + ' is offline');
|
|
26
|
+
// throw new this.platform.api.hap.HapStatusError(this.platform.api.hap.HAPStatus.SERVICE_COMMUNICATION_FAILURE);
|
|
27
|
+
// }
|
|
28
|
+
// this.multiServiceAccessory.sendCommand('switch', value ? 'on' : 'off').then((success) => {
|
|
29
|
+
// if (success) {
|
|
30
|
+
// this.log.debug('onSet(' + value + ') SUCCESSFUL for ' + this.name);
|
|
31
|
+
// this.deviceStatus.timestamp = 0; // Force a refresh next query.
|
|
32
|
+
// } else {
|
|
33
|
+
// this.log.error(`Command failed for ${this.name}`);
|
|
34
|
+
// }
|
|
35
|
+
// });
|
|
36
|
+
// }
|
|
37
|
+
// Get the current state of the lock
|
|
38
|
+
async getSwitchState() {
|
|
39
|
+
// if you need to return an error to show the device as "Not Responding" in the Home app:
|
|
40
|
+
// throw new this.platform.api.hap.HapStatusError(this.platform.api.hap.HAPStatus.SERVICE_COMMUNICATION_FAILURE);
|
|
41
|
+
this.log.debug('Received getSwitchState() event for ' + this.name);
|
|
42
|
+
return new Promise((resolve, reject) => {
|
|
43
|
+
this.getStatus().then(success => {
|
|
44
|
+
if (success) {
|
|
45
|
+
let buttonState;
|
|
46
|
+
try {
|
|
47
|
+
buttonState = this.deviceStatus.status.button.button.value;
|
|
48
|
+
this.log.debug(`Button value from ${this.name}: ${buttonState}`);
|
|
49
|
+
const characteristicValue = this.mapValue(buttonState);
|
|
50
|
+
if (characteristicValue) {
|
|
51
|
+
resolve(characteristicValue);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
resolve;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
catch (error) {
|
|
58
|
+
this.log.error(`Missing button status from ${this.name}`);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
reject(new this.platform.api.hap.HapStatusError(-70402 /* this.platform.api.hap.HAPStatus.SERVICE_COMMUNICATION_FAILURE */));
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
processEvent(event) {
|
|
68
|
+
if (event.capability === 'button') {
|
|
69
|
+
this.log.debug(`Event updating button capability for ${this.name} to ${event.value}`);
|
|
70
|
+
const characteristicValue = this.mapValue(event.value);
|
|
71
|
+
if (characteristicValue !== undefined) {
|
|
72
|
+
this.service.updateCharacteristic(this.platform.Characteristic.ProgrammableSwitchEvent, characteristicValue);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
mapValue(inboundValue) {
|
|
77
|
+
switch (inboundValue) {
|
|
78
|
+
case 'pushed':
|
|
79
|
+
case 'down':
|
|
80
|
+
return (this.platform.Characteristic.ProgrammableSwitchEvent.SINGLE_PRESS);
|
|
81
|
+
case 'held':
|
|
82
|
+
return (this.platform.Characteristic.ProgrammableSwitchEvent.LONG_PRESS);
|
|
83
|
+
default:
|
|
84
|
+
if (inboundValue.startsWith('pushed') || inboundValue.startsWith('down')) {
|
|
85
|
+
return (this.platform.Characteristic.ProgrammableSwitchEvent.DOUBLE_PRESS);
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
return undefined;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
exports.StatelessProgrammableSwitchService = StatelessProgrammableSwitchService;
|
|
94
|
+
//# sourceMappingURL=statelessProgrammableSwitchService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"statelessProgrammableSwitchService.js","sourceRoot":"","sources":["../../src/services/statelessProgrammableSwitchService.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { PlatformAccessory, CharacteristicValue } from 'homebridge';
|
|
2
|
+
import { IKHomeBridgeHomebridgePlatform } from '../platform';
|
|
3
|
+
import { BaseService } from './baseService';
|
|
4
|
+
import { MultiServiceAccessory } from '../multiServiceAccessory';
|
|
5
|
+
import { ShortEvent } from '../webhook/subscriptionHandler';
|
|
6
|
+
export declare class SwitchService extends BaseService {
|
|
7
|
+
constructor(platform: IKHomeBridgeHomebridgePlatform, accessory: PlatformAccessory, componentId: string, capabilities: string[], multiServiceAccessory: MultiServiceAccessory, name: string, deviceStatus: any);
|
|
8
|
+
setSwitchState(value: CharacteristicValue): Promise<void>;
|
|
9
|
+
getSwitchState(): Promise<CharacteristicValue>;
|
|
10
|
+
processEvent(event: ShortEvent): void;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=switchService.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"switchService.d.ts","sourceRoot":"","sources":["../../src/services/switchService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AACpE,OAAO,EAAE,8BAA8B,EAAE,MAAM,aAAa,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAE5D,qBAAa,aAAc,SAAQ,WAAW;gBAEhC,QAAQ,EAAE,8BAA8B,EAAE,SAAS,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,EAAC,MAAM,EAAE,EAC5H,qBAAqB,EAAE,qBAAqB,EAC5C,IAAI,EAAE,MAAM,EAAE,YAAY,KAAA;IAsBtB,cAAc,CAAC,KAAK,EAAE,mBAAmB;IAmBzC,cAAc,IAAI,OAAO,CAAC,mBAAmB,CAAC;IAuB7C,YAAY,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;CAM7C"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SwitchService = void 0;
|
|
4
|
+
const baseService_1 = require("./baseService");
|
|
5
|
+
class SwitchService extends baseService_1.BaseService {
|
|
6
|
+
constructor(platform, accessory, componentId, capabilities, multiServiceAccessory, name, deviceStatus) {
|
|
7
|
+
super(platform, accessory, componentId, capabilities, multiServiceAccessory, name, deviceStatus);
|
|
8
|
+
this.setServiceType(platform.Service.Switch);
|
|
9
|
+
// Set the event handlers
|
|
10
|
+
this.log.debug(`Adding SwitchService to ${this.name}`);
|
|
11
|
+
this.service.getCharacteristic(platform.Characteristic.On)
|
|
12
|
+
.onGet(this.getSwitchState.bind(this))
|
|
13
|
+
.onSet(this.setSwitchState.bind(this));
|
|
14
|
+
let pollSwitchesAndLightsSeconds = 10; // default to 10 seconds
|
|
15
|
+
if (this.platform.config.PollSwitchesAndLightsSeconds !== undefined) {
|
|
16
|
+
pollSwitchesAndLightsSeconds = this.platform.config.PollSwitchesAndLightsSeconds;
|
|
17
|
+
}
|
|
18
|
+
if (pollSwitchesAndLightsSeconds > 0) {
|
|
19
|
+
multiServiceAccessory.startPollingState(pollSwitchesAndLightsSeconds, this.getSwitchState.bind(this), this.service, platform.Characteristic.On);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
// Set the target state of the lock
|
|
23
|
+
async setSwitchState(value) {
|
|
24
|
+
this.log.debug('Received setSwitchState(' + value + ') event for ' + this.name);
|
|
25
|
+
if (!this.multiServiceAccessory.isOnline) {
|
|
26
|
+
this.log.error(this.name + ' is offline');
|
|
27
|
+
throw new this.platform.api.hap.HapStatusError(-70402 /* this.platform.api.hap.HAPStatus.SERVICE_COMMUNICATION_FAILURE */);
|
|
28
|
+
}
|
|
29
|
+
this.multiServiceAccessory.sendCommand('switch', value ? 'on' : 'off').then((success) => {
|
|
30
|
+
if (success) {
|
|
31
|
+
this.log.debug('onSet(' + value + ') SUCCESSFUL for ' + this.name);
|
|
32
|
+
this.multiServiceAccessory.forceNextStatusRefresh();
|
|
33
|
+
// this.deviceStatus.timestamp = 0; // Force a refresh next query.
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
this.log.error(`Command failed for ${this.name}`);
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
// Get the current state of the lock
|
|
41
|
+
async getSwitchState() {
|
|
42
|
+
// if you need to return an error to show the device as "Not Responding" in the Home app:
|
|
43
|
+
// throw new this.platform.api.hap.HapStatusError(this.platform.api.hap.HAPStatus.SERVICE_COMMUNICATION_FAILURE);
|
|
44
|
+
this.log.debug('Received getSwitchState() event for ' + this.name);
|
|
45
|
+
return new Promise((resolve, reject) => {
|
|
46
|
+
this.getStatus().then(success => {
|
|
47
|
+
if (success) {
|
|
48
|
+
let switchState;
|
|
49
|
+
try {
|
|
50
|
+
switchState = this.deviceStatus.status.switch.switch.value;
|
|
51
|
+
}
|
|
52
|
+
catch (error) {
|
|
53
|
+
this.log.error(`Missing switch status from ${this.name}`);
|
|
54
|
+
}
|
|
55
|
+
this.log.debug(`Switch value from ${this.name}: ${switchState}`);
|
|
56
|
+
resolve(switchState === 'on');
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
reject(new this.platform.api.hap.HapStatusError(-70402 /* this.platform.api.hap.HAPStatus.SERVICE_COMMUNICATION_FAILURE */));
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
processEvent(event) {
|
|
65
|
+
if (event.capability === 'switch') {
|
|
66
|
+
this.log.debug(`Event updating switch capability for ${this.name} to ${event.value}`);
|
|
67
|
+
this.service.updateCharacteristic(this.platform.Characteristic.On, event.value === 'on');
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
exports.SwitchService = SwitchService;
|
|
72
|
+
//# sourceMappingURL=switchService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"switchService.js","sourceRoot":"","sources":["../../src/services/switchService.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { PlatformAccessory } from 'homebridge';
|
|
2
|
+
import { IKHomeBridgeHomebridgePlatform } from '../platform';
|
|
3
|
+
import { MultiServiceAccessory } from '../multiServiceAccessory';
|
|
4
|
+
import { SensorService } from './sensorService';
|
|
5
|
+
import { ShortEvent } from '../webhook/subscriptionHandler';
|
|
6
|
+
export declare class TemperatureService extends SensorService {
|
|
7
|
+
private unit;
|
|
8
|
+
constructor(platform: IKHomeBridgeHomebridgePlatform, accessory: PlatformAccessory, componentId: string, capabilities: string[], multiServiceAccessory: MultiServiceAccessory, name: string, deviceStatus: any);
|
|
9
|
+
processEvent(event: ShortEvent): void;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=temperatureService.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"temperatureService.d.ts","sourceRoot":"","sources":["../../src/services/temperatureService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,8BAA8B,EAAE,MAAM,aAAa,CAAC;AAC7D,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAE5D,qBAAa,kBAAmB,SAAQ,aAAa;IACnD,OAAO,CAAC,IAAI,CAAO;gBAEP,QAAQ,EAAE,8BAA8B,EAAE,SAAS,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,EAC7H,qBAAqB,EAAE,qBAAqB,EAC5C,IAAI,EAAE,MAAM,EAAE,YAAY,KAAA;IAqBrB,YAAY,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;CAM7C"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TemperatureService = void 0;
|
|
4
|
+
const sensorService_1 = require("./sensorService");
|
|
5
|
+
class TemperatureService extends sensorService_1.SensorService {
|
|
6
|
+
constructor(platform, accessory, componentId, capabilities, multiServiceAccessory, name, deviceStatus) {
|
|
7
|
+
super(platform, accessory, componentId, capabilities, multiServiceAccessory, name, deviceStatus);
|
|
8
|
+
this.unit = 'F';
|
|
9
|
+
this.log.debug(`Adding TemperatureService to ${this.name}`);
|
|
10
|
+
this.initService(platform.Service.TemperatureSensor, platform.Characteristic.CurrentTemperature, (status) => {
|
|
11
|
+
if (status.temperatureMeasurement.temperature.value === null || status.temperatureMeasurement.temperature.value === undefined ||
|
|
12
|
+
status.temperatureMeasurement.temperature.unit === null || status.temperatureMeasurement.temperature.value === undefined) {
|
|
13
|
+
this.log.warn(`${this.name} returned bad value for status`);
|
|
14
|
+
throw ('Bad Value');
|
|
15
|
+
}
|
|
16
|
+
if (status.temperatureMeasurement.temperature.unit === 'F') {
|
|
17
|
+
this.log.debug('Converting temp to celcius');
|
|
18
|
+
return (status.temperatureMeasurement.temperature.value - 32) * (5 / 9); // Convert to Celcius
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
this.unit = 'C';
|
|
22
|
+
return status.temperatureMeasurement.temperature.value;
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
processEvent(event) {
|
|
27
|
+
this.log.debug(`Event updating temperature measurement for ${this.name} to ${event.value}`);
|
|
28
|
+
this.service.updateCharacteristic(this.platform.Characteristic.CurrentTemperature, this.unit === 'F' ? (event.value - 32) * (5 / 9) : event.value);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
exports.TemperatureService = TemperatureService;
|
|
32
|
+
//# sourceMappingURL=temperatureService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"temperatureService.js","sourceRoot":"","sources":["../../src/services/temperatureService.ts"],"names":[],"mappings":";;;AAGA,mDAAgD;AAGhD,MAAa,kBAAmB,SAAQ,6BAAa;IAGnD,YAAY,QAAwC,EAAE,SAA4B,EAAE,WAAmB,EAAE,YAAsB,EAC7H,qBAA4C,EAC5C,IAAY,EAAE,YAAY;QAC1B,KAAK,CAAC,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,YAAY,EAAE,qBAAqB,EAAE,IAAI,EAAE,YAAY,CAAC,CAAC;QAL3F,SAAI,GAAG,GAAG,CAAC;QAOjB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,gCAAgC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QAE5D,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,iBAAiB,EAAE,QAAQ,CAAC,cAAc,CAAC,kBAAkB,EAAE,CAAC,MAAM,EAAE,EAAE;YAC1G,IAAI,MAAM,CAAC,sBAAsB,CAAC,WAAW,CAAC,KAAK,KAAK,IAAI,IAAI,MAAM,CAAC,sBAAsB,CAAC,WAAW,CAAC,KAAK,KAAK,SAAS;gBAC3H,MAAM,CAAC,sBAAsB,CAAC,WAAW,CAAC,IAAI,KAAK,IAAI,IAAI,MAAM,CAAC,sBAAsB,CAAC,WAAW,CAAC,KAAK,KAAK,SAAS,EAAE;gBAC1H,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,gCAAgC,CAAC,CAAC;gBAC5D,MAAK,CAAC,WAAW,CAAC,CAAC;aACpB;YACD,IAAI,MAAM,CAAC,sBAAsB,CAAC,WAAW,CAAC,IAAI,KAAK,GAAG,EAAE;gBAC1D,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;gBAC7C,OAAO,CAAC,MAAM,CAAC,sBAAsB,CAAC,WAAW,CAAC,KAAe,GAAI,EAAE,CAAC,GAAG,CAAC,CAAC,GAAC,CAAC,CAAC,CAAE,CAAC,qBAAqB;aACzG;iBAAM;gBACL,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC;gBAChB,OAAO,MAAM,CAAC,sBAAsB,CAAC,WAAW,CAAC,KAAK,CAAC;aACxD;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,YAAY,CAAC,KAAiB;QACnC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,8CAA8C,IAAI,CAAC,IAAI,OAAO,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;QAC5F,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAC/B,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,kBAAkB,EAC/C,IAAI,CAAC,IAAI,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAe,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,GAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAe,CAAC,CAAC;IACtF,CAAC;CACF;AAhCD,gDAgCC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { PlatformAccessory, CharacteristicValue } from 'homebridge';
|
|
2
|
+
import { IKHomeBridgeHomebridgePlatform } from '../platform';
|
|
3
|
+
import { BaseService } from './baseService';
|
|
4
|
+
import { MultiServiceAccessory } from '../multiServiceAccessory';
|
|
5
|
+
import { ShortEvent } from '../webhook/subscriptionHandler';
|
|
6
|
+
export declare class ThermostatService extends BaseService {
|
|
7
|
+
targetHeatingCoolingState: any;
|
|
8
|
+
targetTemperature: any;
|
|
9
|
+
units: string;
|
|
10
|
+
supportsOperatingState: boolean;
|
|
11
|
+
constructor(platform: IKHomeBridgeHomebridgePlatform, accessory: PlatformAccessory, componentId: string, capabilities: string[], multiServiceAccessory: MultiServiceAccessory, name: string, deviceStatus: any);
|
|
12
|
+
getTargetHeatingCoolingState(): Promise<CharacteristicValue>;
|
|
13
|
+
setTargetHeatingCoolingState(value: CharacteristicValue): Promise<void>;
|
|
14
|
+
getCurrentHeatingCoolingState(): Promise<CharacteristicValue>;
|
|
15
|
+
getCurrentTemperature(): Promise<CharacteristicValue>;
|
|
16
|
+
getTargetTemperature(): Promise<CharacteristicValue>;
|
|
17
|
+
setTargetTemperature(value: CharacteristicValue): Promise<void>;
|
|
18
|
+
getTemperatureDisplayUnits(): CharacteristicValue;
|
|
19
|
+
setTemperatureDisplayUnits(value: CharacteristicValue): void;
|
|
20
|
+
processEvent(event: ShortEvent): void;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=thermostatService.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"thermostatService.d.ts","sourceRoot":"","sources":["../../src/services/thermostatService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AACpE,OAAO,EAAE,8BAA8B,EAAE,MAAM,aAAa,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAE5D,qBAAa,iBAAkB,SAAQ,WAAW;IAChD,yBAAyB,EAAE,GAAG,CAAC;IAC/B,iBAAiB,EAAE,GAAG,CAAC;IACvB,KAAK,SAAO;IACZ,sBAAsB,UAAS;gBAEnB,QAAQ,EAAE,8BAA8B,EAAE,SAAS,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,EAC7H,qBAAqB,EAAE,qBAAqB,EAC5C,IAAI,EAAE,MAAM,EAAE,YAAY,KAAA;IAqDtB,4BAA4B,IAAG,OAAO,CAAC,mBAAmB,CAAC;IA2C3D,4BAA4B,CAAC,KAAK,EAAE,mBAAmB;IA6CvD,6BAA6B,IAAI,OAAO,CAAC,mBAAmB,CAAC;IA6C7D,qBAAqB,IAAI,OAAO,CAAC,mBAAmB,CAAC;IA+BrD,oBAAoB,IAAG,OAAO,CAAC,mBAAmB,CAAC;IAkBnD,oBAAoB,CAAC,KAAK,EAAE,mBAAmB;IAqBrD,0BAA0B,IAAI,mBAAmB;IASjD,0BAA0B,CAAC,KAAK,EAAE,mBAAmB;IAM9C,YAAY,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;CA6B7C"}
|