homebridge-logo-platform
Version:
This is a Siemens LOGO! Platform Plugin.
384 lines • 20.6 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.GaragedoorPlatformAccessory = void 0;
const queue_1 = require("../queue");
const error_1 = require("../error");
const logger_1 = require("../logger");
const md5_1 = require("../md5");
const logo_1 = require("../logo");
const switchPlatformAccessory_1 = require("./switchPlatformAccessory");
const lightbulbPlatformAccessory_1 = require("./lightbulbPlatformAccessory");
const blindPlatformAccessory_1 = require("./blindPlatformAccessory");
const windowPlatformAccessory_1 = require("./windowPlatformAccessory");
const thermostatPlatformAccessory_1 = require("./thermostatPlatformAccessory");
const fanPlatformAccessory_1 = require("./fanPlatformAccessory");
const filterMaintenancePlatformAccessory_1 = require("./filterMaintenancePlatformAccessory");
const outletPlatformAccessory_1 = require("./outletPlatformAccessory");
const lightSensorPlatformAccessory_1 = require("../sensors/lightSensorPlatformAccessory");
const motionSensorPlatformAccessory_1 = require("../sensors/motionSensorPlatformAccessory");
const contactSensorPlatformAccessory_1 = require("../sensors/contactSensorPlatformAccessory");
const smokeSensorPlatformAccessory_1 = require("../sensors/smokeSensorPlatformAccessory");
const temperatureSensorPlatformAccessory_1 = require("../sensors/temperatureSensorPlatformAccessory");
const humiditySensorPlatformAccessory_1 = require("../sensors/humiditySensorPlatformAccessory");
const carbonDioxideSensorPlatformAccessory_1 = require("../sensors/carbonDioxideSensorPlatformAccessory");
const airQualitySensorPlatformAccessory_1 = require("../sensors/airQualitySensorPlatformAccessory");
const leakSensorPlatformAccessory_1 = require("../sensors/leakSensorPlatformAccessory");
const watchdogPlatformAccessory_1 = require("../sensors/watchdogPlatformAccessory");
class GaragedoorPlatformAccessory {
constructor(api, platform, device, parent) {
this.model = "Garagedoor";
this.accStates = {
CurrentDoorState: 1,
TargetDoorState: 1,
ObstructionDetected: false,
};
this.name = device.name;
this.api = api;
this.platform = platform;
this.device = device;
this.pushButton = this.device.pushButton || this.platform.pushButton;
this.logging = this.device.logging || 0;
this.subs = [];
this.services = [];
this.isParentAccessory = false;
this.errorCheck();
this.currentDoorStateIsTargetDoorStateInLogo = this.checkDoorState();
this.service = new this.api.hap.Service.GarageDoorOpener(this.device.name);
if (parent) {
this.service.subtype = 'sub-' + this.model + "-" + this.name.replace(" ", "-");
}
this.service.getCharacteristic(this.platform.Characteristic.CurrentDoorState)
.onGet(this.getCurrentDoorState.bind(this));
this.service.getCharacteristic(this.platform.Characteristic.TargetDoorState)
.onSet(this.setTargetDoorState.bind(this))
.onGet(this.getTargetDoorState.bind(this));
this.service.getCharacteristic(this.platform.Characteristic.TargetPosition)
.onGet(this.getObstructionDetected.bind(this));
this.information = new this.api.hap.Service.AccessoryInformation()
.setCharacteristic(this.api.hap.Characteristic.Manufacturer, this.platform.manufacturer)
.setCharacteristic(this.api.hap.Characteristic.Model, this.model + ' @ ' + this.platform.model)
.setCharacteristic(this.api.hap.Characteristic.SerialNumber, (0, md5_1.md5)(this.device.name + this.model))
.setCharacteristic(this.api.hap.Characteristic.FirmwareRevision, this.platform.firmwareRevision);
const configDevices = this.platform.config.devices;
for (const dev of configDevices) {
if (dev.parentAccessory == this.name) {
this.isParentAccessory = true;
switch (dev.type) {
case logo_1.Accessory.Switch:
this.subs.push(new switchPlatformAccessory_1.SwitchPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.Lightbulb:
this.subs.push(new lightbulbPlatformAccessory_1.LightbulbPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.Blind:
this.subs.push(new blindPlatformAccessory_1.BlindPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.Window:
this.subs.push(new windowPlatformAccessory_1.WindowPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.Garagedoor:
this.subs.push(new GaragedoorPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.Thermostat:
this.subs.push(new thermostatPlatformAccessory_1.ThermostatPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.Fan:
this.subs.push(new fanPlatformAccessory_1.FanPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.FilterMaintenance:
this.subs.push(new filterMaintenancePlatformAccessory_1.FilterMaintenancePlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.Outlet:
this.subs.push(new outletPlatformAccessory_1.OutletPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.LightSensor:
this.subs.push(new lightSensorPlatformAccessory_1.LightSensorPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.MotionSensor:
this.subs.push(new motionSensorPlatformAccessory_1.MotionSensorPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.ContactSensor:
this.subs.push(new contactSensorPlatformAccessory_1.ContactSensorPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.SmokeSensor:
this.subs.push(new smokeSensorPlatformAccessory_1.SmokeSensorPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.TemperatureSensor:
this.subs.push(new temperatureSensorPlatformAccessory_1.TemperatureSensorPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.HumiditySensor:
this.subs.push(new humiditySensorPlatformAccessory_1.HumiditySensorPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.CarbonDioxideSensor:
this.subs.push(new carbonDioxideSensorPlatformAccessory_1.CarbonDioxideSensorPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.AirQualitySensor:
this.subs.push(new airQualitySensorPlatformAccessory_1.AirQualitySensorPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.LeakSensor:
this.subs.push(new leakSensorPlatformAccessory_1.LeakSensorPlatformAccessory(api, platform, dev, this));
break;
case logo_1.Accessory.Watchdog:
this.subs.push(new watchdogPlatformAccessory_1.WatchdogPlatformAccessory(api, platform, dev, this));
break;
}
}
}
if (this.isParentAccessory == true) {
this.service.subtype = 'main-' + this.model + "-" + this.name.replace(" ", "-");
}
this.services.push(this.service, this.information);
if (parent) {
parent.service.addLinkedService(this.service);
parent.services.push(this.service);
}
this.updateCurrentDoorStateAndTargetDoorStateQueued = false;
this.updateCurrentDoorStateQueued = false;
this.updateTargetDoorStateQueued = false;
this.updateObstructionDetectedQueued = false;
if (this.platform.config.updateInterval) {
setInterval(() => {
if (this.currentDoorStateIsTargetDoorStateInLogo == 1) {
this.updateCurrentDoorStateAndTargetDoorState();
}
else {
this.updateCurrentDoorState();
this.updateTargetDoorState();
}
this.updateObstructionDetected();
}, this.platform.config.updateInterval);
}
if (this.logging) {
setInterval(() => {
this.logAccessory();
}, this.platform.loggerInterval);
}
}
errorCheck() {
if (!this.device.garagedoorGetState || !this.device.garagedoorGetTargetState || !this.device.garagedoorSetTargetState) {
this.platform.log.error('[%s] One or more LOGO! Addresses are not correct!', this.device.name);
}
}
checkDoorState() {
if (this.device.garagedoorGetState == this.device.garagedoorGetTargetState) {
return 1;
}
else {
return 0;
}
}
getServices() {
return this.services;
}
async setTargetDoorState(value) {
this.accStates.TargetDoorState = value;
if (this.platform.config.debugMsgLog || this.device.debugMsgLog) {
this.platform.log.info('[%s] Set TargetDoorState <- %i', this.device.name, value);
}
let qItem = new queue_1.QueueSendItem(this.device.garagedoorSetTargetState, this.accStates.TargetDoorState, 0);
this.platform.queue.bequeue(qItem);
}
async getCurrentDoorState() {
const isCurrentDoorState = this.accStates.CurrentDoorState;
this.updateCurrentDoorState();
return isCurrentDoorState;
}
async getTargetDoorState() {
const isTargetDoorState = this.accStates.TargetDoorState;
this.updateTargetDoorState();
return isTargetDoorState;
}
async getObstructionDetected() {
const isObstructionDetected = this.accStates.ObstructionDetected;
this.updateObstructionDetected();
return isObstructionDetected;
}
updateCurrentDoorState() {
if (this.platform.isAnalogLogoAddress(this.device.garagedoorGetState)) {
this.updateAnalogCurrentDoorState();
}
else {
this.updateDigitalCurrentDoorState();
}
}
updateTargetDoorState() {
if (this.platform.isAnalogLogoAddress(this.device.garagedoorGetTargetState)) {
this.updateAnalogTargetDoorState();
}
else {
this.updateDigitalTargetDoorState();
}
}
updateCurrentDoorStateAndTargetDoorState() {
if (this.platform.isAnalogLogoAddress(this.device.garagedoorGetState)) {
this.updateAnalogCurrentDoorStateAndTargetDoorState();
}
else {
this.updateDigitalCurrentDoorStateAndTargetDoorState();
}
}
updateObstructionDetected() {
if (this.device.garagedoorObstruction) {
if (this.updateObstructionDetectedQueued) {
return;
}
let qItem = new queue_1.QueueReceiveItem(this.device.garagedoorObstruction, async (value) => {
if (value != error_1.ErrorNumber.noData) {
this.accStates.ObstructionDetected = (value == 1 ? true : false);
if (this.platform.config.debugMsgLog || this.device.debugMsgLog) {
this.platform.log.info('[%s] Get ObstructionDetected -> %s', this.device.name, this.accStates.ObstructionDetected);
}
this.service.updateCharacteristic(this.api.hap.Characteristic.ObstructionDetected, this.accStates.ObstructionDetected);
}
this.updateObstructionDetectedQueued = false;
});
if (this.platform.queue.enqueue(qItem) === 1) {
this.updateObstructionDetectedQueued = true;
}
;
}
}
updateAnalogCurrentDoorState() {
if (this.updateCurrentDoorStateQueued) {
return;
}
let qItem = new queue_1.QueueReceiveItem(this.device.garagedoorGetState, async (value) => {
if (value != error_1.ErrorNumber.noData) {
this.accStates.CurrentDoorState = value;
if (this.platform.config.debugMsgLog || this.device.debugMsgLog) {
this.platform.log.info('[%s] Get Analog CurrentDoorState -> %i', this.device.name, this.accStates.CurrentDoorState);
}
// HomeKit - 0 = open; 1 = closed; 2 = opening; 3 = closing; 4 = stoppt
this.service.updateCharacteristic(this.api.hap.Characteristic.CurrentDoorState, this.accStates.CurrentDoorState);
}
this.updateCurrentDoorStateQueued = false;
});
if (this.platform.queue.enqueue(qItem) === 1) {
this.updateCurrentDoorStateQueued = true;
}
;
}
updateAnalogTargetDoorState() {
if (this.updateTargetDoorStateQueued) {
return;
}
let qItem = new queue_1.QueueReceiveItem(this.device.garagedoorGetTargetState, async (value) => {
if (value != error_1.ErrorNumber.noData) {
this.accStates.TargetDoorState = value;
if (this.platform.config.debugMsgLog || this.device.debugMsgLog) {
this.platform.log.info('[%s] Get Analog TargetDoorState -> %i', this.device.name, this.accStates.TargetDoorState);
}
// HomeKit - 0 = open; 1 = closed;
this.service.updateCharacteristic(this.api.hap.Characteristic.TargetDoorState, this.accStates.TargetDoorState);
}
this.updateTargetDoorStateQueued = false;
});
if (this.platform.queue.enqueue(qItem) === 1) {
this.updateTargetDoorStateQueued = true;
}
;
}
updateAnalogCurrentDoorStateAndTargetDoorState() {
if (this.updateCurrentDoorStateAndTargetDoorStateQueued) {
return;
}
let qItem = new queue_1.QueueReceiveItem(this.device.garagedoorGetState, async (value) => {
if (value != error_1.ErrorNumber.noData) {
this.accStates.CurrentDoorState = value;
this.accStates.TargetDoorState = value;
if (this.platform.config.debugMsgLog || this.device.debugMsgLog) {
this.platform.log.info('[%s] Get Analog CurrentDoorState and TargetDoorState -> %i', this.device.name, this.accStates.CurrentDoorState);
}
// HomeKit - 0 = open; 1 = closed; 2 = opening; 3 = closing; 4 = stoppt
this.service.updateCharacteristic(this.api.hap.Characteristic.CurrentDoorState, this.accStates.CurrentDoorState);
// HomeKit - 0 = open; 1 = closed;
this.service.updateCharacteristic(this.api.hap.Characteristic.TargetDoorState, this.accStates.TargetDoorState);
}
this.updateCurrentDoorStateAndTargetDoorStateQueued = false;
});
if (this.platform.queue.enqueue(qItem) === 1) {
this.updateCurrentDoorStateAndTargetDoorStateQueued = true;
}
;
}
updateDigitalCurrentDoorState() {
if (this.updateCurrentDoorStateQueued) {
return;
}
let qItem = new queue_1.QueueReceiveItem(this.device.garagedoorGetState, async (value) => {
// Logo return 1 for open !!
if (value != error_1.ErrorNumber.noData) {
this.accStates.CurrentDoorState = (value == 1 ? 0 : 1);
if (this.platform.config.debugMsgLog || this.device.debugMsgLog) {
this.platform.log.info('[%s] Get Digital CurrentDoorState -> %i', this.device.name, this.accStates.CurrentDoorState);
}
// HomeKit - 0 = open; 1 = closed; 2 = opening; 3 = closing; 4 = stoppt
this.service.updateCharacteristic(this.api.hap.Characteristic.CurrentDoorState, this.accStates.CurrentDoorState);
}
this.updateCurrentDoorStateQueued = false;
});
if (this.platform.queue.enqueue(qItem) === 1) {
this.updateCurrentDoorStateQueued = true;
}
;
}
updateDigitalTargetDoorState() {
if (this.updateTargetDoorStateQueued) {
return;
}
let qItem = new queue_1.QueueReceiveItem(this.device.garagedoorGetTargetState, async (value) => {
// Logo return 1 for open !!
if (value != error_1.ErrorNumber.noData) {
this.accStates.TargetDoorState = (value == 1 ? 0 : 1);
if (this.platform.config.debugMsgLog || this.device.debugMsgLog) {
this.platform.log.info('[%s] Get Digital TargetDoorState -> %i', this.device.name, this.accStates.TargetDoorState);
}
// HomeKit - 0 = open; 1 = closed;
this.service.updateCharacteristic(this.api.hap.Characteristic.TargetDoorState, this.accStates.TargetDoorState);
}
this.updateTargetDoorStateQueued = false;
});
if (this.platform.queue.enqueue(qItem) === 1) {
this.updateTargetDoorStateQueued = true;
}
;
}
updateDigitalCurrentDoorStateAndTargetDoorState() {
if (this.updateCurrentDoorStateAndTargetDoorStateQueued) {
return;
}
let qItem = new queue_1.QueueReceiveItem(this.device.garagedoorGetState, async (value) => {
// Logo return 1 for open !!
if (value != error_1.ErrorNumber.noData) {
this.accStates.CurrentDoorState = (value == 1 ? 0 : 1);
this.accStates.TargetDoorState = (value == 1 ? 0 : 1);
if (this.platform.config.debugMsgLog || this.device.debugMsgLog) {
this.platform.log.info('[%s] Get Digital CurrentDoorState and TargetDoorState -> %i', this.device.name, this.accStates.CurrentDoorState);
}
// HomeKit - 0 = open; 1 = closed; 2 = opening; 3 = closing; 4 = stoppt
this.service.updateCharacteristic(this.api.hap.Characteristic.CurrentDoorState, this.accStates.CurrentDoorState);
// HomeKit - 0 = open; 1 = closed;
this.service.updateCharacteristic(this.api.hap.Characteristic.TargetDoorState, this.accStates.TargetDoorState);
}
this.updateCurrentDoorStateAndTargetDoorStateQueued = false;
});
if (this.platform.queue.enqueue(qItem) === 1) {
this.updateCurrentDoorStateAndTargetDoorStateQueued = true;
}
;
}
logAccessory() {
if ((this.platform.loggerType == logger_1.LoggerType.InfluxDB) && this.platform.influxDB.isConfigured) {
let logItems = [];
logItems.push(new logger_1.InfluxDBLogItem("CurrentDoorState", this.accStates.CurrentDoorState, logger_1.InfluxDBFild.Int));
logItems.push(new logger_1.InfluxDBLogItem("TargetDoorState", this.accStates.TargetDoorState, logger_1.InfluxDBFild.Int));
logItems.push(new logger_1.InfluxDBLogItem("ObstructionDetected", this.accStates.ObstructionDetected, logger_1.InfluxDBFild.Bool));
this.platform.influxDB.logMultipleValues(this.device.name, logItems);
}
if (this.platform.loggerType == logger_1.LoggerType.Fakegato) {
// this.fakegatoService.addEntry({time: Math.round(new Date().valueOf() / 1000), temp: this.sensStates.CurrentTemperature});
}
}
}
exports.GaragedoorPlatformAccessory = GaragedoorPlatformAccessory;
//# sourceMappingURL=garagedoorPlatformAccessory.js.map