homebridge-luxor
Version:
Homebridge Plug-in for the FX Luminaire (Luxor) lighting controller
163 lines • 29.3 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.ILightType = exports.ZD_Light = void 0;
class ZD_Light {
constructor(platform, accessory) {
this.controller = platform.controller;
this.accessory = accessory;
this.log = platform.log;
this.platform = platform;
this.context = this.accessory.context;
this.log.info(`Initializing ${this.accessory.displayName}.`);
this.setServices();
}
setServices() {
// Make sure you provided a name for service otherwise it may not visible in some HomeKit apps.
// if (this.context.status === 'new') {
try {
this.accessory.getService(this.platform.Service.AccessoryInformation)
.setCharacteristic(this.platform.Characteristic.Manufacturer, "Luxor")
.setCharacteristic(this.platform.Characteristic.Model, this.context.type)
.setCharacteristic(this.platform.Characteristic.SerialNumber, this.accessory.UUID);
this.service = this.accessory.getService(this.platform.Service.Lightbulb) || this.accessory.addService(this.platform.Service.Lightbulb);
this.service.setCharacteristic(this.platform.Characteristic.Name, this.accessory.displayName);
this.service.getCharacteristic(this.platform.Characteristic.On)
.on('get', this.getOn.bind(this))
.on('set', this.setOn.bind(this));
this.service.getCharacteristic(this.platform.Characteristic.Brightness)
.on('set', this.setBrightness.bind(this))
.on('get', this.getBrightness.bind(this));
this.context.status = 'current';
this.getCurrentStateAsync().then(() => {
this.setCharacteristics();
}).catch((err) => {
this.log.error(`${this.accessory.displayName} setServices error: ${err}`);
});
}
catch (err) {
this.log.error(`setServices ${err}`);
}
this.accessory.on('identify', async () => {
this.log.info(`Identifying ${this.accessory.displayName}. Lights will flash thrice.`);
await this.illuminateGroupAsync(100);
await this.sleep(3000);
await this.illuminateGroupAsync(0);
await this.sleep(3000);
await this.illuminateGroupAsync(100);
await this.sleep(3000);
await this.illuminateGroupAsync(0);
});
this.controller.registerCallback(this.accessory.UUID, this.context.type, this.context.groupNumber, this.platform.Characteristic.Brightness, this.callbackBrightness.bind(this));
}
async sleep(ms) {
return new Promise(resolve => setTimeout(resolve, ms));
}
getOn(callback) {
this.log.debug("Getting power state for: ", this.accessory.displayName);
this.getCurrentStateAsync().then(() => {
callback(null, this.context.isOn);
}).catch((err) => {
this.log.error(`${this.accessory.displayName} error: ${err}`);
this.context.isOn = false;
callback(-70412 /* NOT_ALLOWED_IN_CURRENT_STATE */, false);
});
}
setOn(desiredState, callback) {
if (this.context.isOn === desiredState) {
this.log.debug('Not changing power to %s because it is already %s', desiredState ? 'On' : 'Off', this.context.isOn ? 'On' : 'Off');
callback(null);
}
else {
this.illuminateGroupAsync(desiredState ? this.context.brightness || 100 : 0).then(() => {
callback(null);
}).catch((err) => {
this.log.error(`${this.accessory.displayName} setOn error: ${err}`);
callback(-70412 /* NOT_ALLOWED_IN_CURRENT_STATE */);
});
}
}
getBrightness(callback) {
this.getCurrentStateAsync().then(() => {
callback(null, this.context.brightness);
}).catch((err) => {
this.log.error(`${this.accessory.displayName} getBrightness error: ${err}`);
callback(-70412 /* NOT_ALLOWED_IN_CURRENT_STATE */, false);
});
}
setBrightness(desiredBrightness, callback) {
if (this.context.brightness === desiredBrightness) {
this.log.debug('Not changing brightness to %s because it is already %s', desiredBrightness, this.context.brightness);
callback(null);
}
else {
this.illuminateGroupAsync(desiredBrightness).then(() => {
callback(null);
}).catch((err) => {
this.log.error(`${this.accessory.displayName} setBrightness error: ${err}`);
callback(-70412 /* NOT_ALLOWED_IN_CURRENT_STATE */, false);
});
}
}
async illuminateGroupAsync(desiredIntensity) {
return new Promise(async (resolve, reject) => {
try {
this.log.info(`${this.accessory.displayName} turning ${desiredIntensity > 0 ? 'on' : 'off'} with brightness ${desiredIntensity}`);
let result = await this.controller.IlluminateGroupAsync(this.context.groupNumber, desiredIntensity);
if (result.StatusStr === 'Ok') {
this.context.brightness = desiredIntensity;
this.context.isOn = this.context.brightness > 0;
this.service.updateCharacteristic(this.platform.Characteristic.On, desiredIntensity > 0);
this.service.updateCharacteristic(this.platform.Characteristic.Brightness, desiredIntensity);
resolve();
}
else {
this.log.error(`${this.accessory.displayName} returned ${result.StatusStr} trying to set intensity ${desiredIntensity}.`);
reject();
}
}
catch (err) {
this.log.error(`${this.accessory.displayName} illuminateGroupAsync error: ${err}`);
reject(err);
}
;
});
}
setCharacteristics() {
this.service.updateCharacteristic(this.platform.Characteristic.On, typeof this.context.isOn !== 'undefined' ? this.context.isOn : false);
this.service.updateCharacteristic(this.platform.Characteristic.Brightness, typeof this.context.brightness !== 'undefined' ? this.context.brightness : 0);
}
// this method used for event handling
async getCurrentStateAsync() {
return new Promise(async (resolve, reject) => {
try {
let group = await this.controller.GetGroupAsync(this.context.groupNumber);
this.context.brightness = group.Intensity;
this.context.isOn = this.context.brightness > 0;
resolve();
}
catch (err) {
this.log.error(`${this.accessory.displayName} getCurrentStateAsync error: ${err}`);
reject(err);
}
;
});
}
// this method used for callbacks
callbackBrightness(intensity) {
if (intensity !== this.context.brightness) {
this.context.brightness = intensity;
this.context.isOn = intensity > 0;
this.log.debug(`${this.accessory.displayName} updated isOn to ${intensity > 0} and brightness ${intensity}.`);
this.service.updateCharacteristic(this.platform.Characteristic.On, intensity > 0);
this.service.updateCharacteristic(this.platform.Characteristic.Brightness, intensity);
}
}
}
exports.ZD_Light = ZD_Light;
var ILightType;
(function (ILightType) {
ILightType["ZD"] = "ZD";
ILightType["ZDC"] = "ZDC";
ILightType["THEME"] = "Theme";
})(ILightType = exports.ILightType || (exports.ILightType = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ZD_Light.js","sourceRoot":"","sources":["../../src/lights/ZD_Light.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport { Service, PlatformAccessory, CharacteristicValue, CharacteristicSetCallback, CharacteristicGetCallback, Logger, HAPStatus } from 'homebridge';\nimport { IContext, LuxorPlatform } from '../LuxorPlatform';\nimport { BaseController } from '../controller/BaseController';\n\nexport class ZD_Light {\n    protected accessory: PlatformAccessory;\n    protected log: Logger;\n    protected service: Service;\n    protected controller: BaseController;\n    protected platform: LuxorPlatform;\n    protected context: IContext;\n    constructor(platform: LuxorPlatform, accessory: PlatformAccessory) {\n        this.controller = platform.controller;\n        this.accessory = accessory;\n        this.log = platform.log;\n        this.platform = platform;\n        this.context = this.accessory.context as IContext;\n        this.log.info(`Initializing ${this.accessory.displayName}.`);\n        this.setServices();\n    }\n    setServices() {\n        // Make sure you provided a name for service otherwise it may not visible in some HomeKit apps.\n        // if (this.context.status === 'new') {\n\n        try {\n\n            this.accessory.getService(this.platform.Service.AccessoryInformation)\n            .setCharacteristic(this.platform.Characteristic.Manufacturer, \"Luxor\")\n            .setCharacteristic(this.platform.Characteristic.Model, this.context.type)\n            .setCharacteristic(this.platform.Characteristic.SerialNumber, this.accessory.UUID);\n            \n            this.service = this.accessory.getService(this.platform.Service.Lightbulb) || this.accessory.addService(this.platform.Service.Lightbulb);\n            this.service.setCharacteristic(this.platform.Characteristic.Name, this.accessory.displayName);\n            this.service.getCharacteristic(this.platform.Characteristic.On)\n            .on('get', this.getOn.bind(this))\n            .on('set', this.setOn.bind(this));\n            \n            this.service.getCharacteristic(this.platform.Characteristic.Brightness)\n            .on('set', this.setBrightness.bind(this))\n            .on('get', this.getBrightness.bind(this));\n            \n            this.context.status = 'current';\n            this.getCurrentStateAsync().then(() => {\n                this.setCharacteristics();\n            }).catch((err) => {    \n                this.log.error(`${this.accessory.displayName} setServices error: ${err}`)        \n            });\n        }\n        catch (err){\n            this.log.error(`setServices ${err}`)\n        }\n\n\n        this.accessory.on('identify', async () => {\n            this.log.info(`Identifying ${this.accessory.displayName}.  Lights will flash thrice.`);\n            await this.illuminateGroupAsync(100);\n            await this.sleep(3000);\n            await this.illuminateGroupAsync(0);\n            await this.sleep(3000);\n            await this.illuminateGroupAsync(100);\n            await this.sleep(3000)\n            await this.illuminateGroupAsync(0);\n        });\n        this.controller.registerCallback(this.accessory.UUID, this.context.type, this.context.groupNumber, this.platform.Characteristic.Brightness, this.callbackBrightness.bind(this));\n    }\n    async sleep(ms) {\n        return new Promise(resolve => setTimeout(resolve, ms));\n    }\n    getOn(callback: CharacteristicGetCallback): void {\n        this.log.debug(\"Getting power state for: \", this.accessory.displayName);\n\n        this.getCurrentStateAsync().then(() => {\n            callback(null, this.context.isOn);\n        }).catch((err) => {   \n            this.log.error(`${this.accessory.displayName} error: ${err}`)\n            this.context.isOn = false;\n            callback(HAPStatus.NOT_ALLOWED_IN_CURRENT_STATE, false);\n        });\n    }\n    setOn(desiredState: boolean, callback: CharacteristicSetCallback): void {\n        if (this.context.isOn === desiredState) {\n            this.log.debug('Not changing power to %s because it is already %s', desiredState ? 'On' : 'Off', this.context.isOn ? 'On' : 'Off');\n            callback(null);\n        } else {\n            this.illuminateGroupAsync(desiredState ? this.context.brightness || 100 : 0).then(() => {\n                callback(null);\n            }).catch((err) => {  \n                this.log.error(`${this.accessory.displayName} setOn error: ${err}`)\n                callback(HAPStatus.NOT_ALLOWED_IN_CURRENT_STATE);\n            });\n        }\n    }\n    getBrightness(callback: CharacteristicGetCallback): void {\n        this.getCurrentStateAsync().then(() => {\n            callback(null, this.context.brightness);\n        }).catch((err) => {  \n            this.log.error(`${this.accessory.displayName} getBrightness error: ${err}`)\n            callback(HAPStatus.NOT_ALLOWED_IN_CURRENT_STATE, false);\n        });\n    }\n    setBrightness(desiredBrightness: number, callback: CharacteristicSetCallback): void {\n        if (this.context.brightness === desiredBrightness) {\n            this.log.debug('Not changing brightness to %s because it is already %s', desiredBrightness, this.context.brightness);\n            callback(null);\n        } else {\n            this.illuminateGroupAsync(desiredBrightness).then(() => {\n                callback(null);\n            }).catch((err) => {  \n                this.log.error(`${this.accessory.displayName} setBrightness error: ${err}`)\n                callback(HAPStatus.NOT_ALLOWED_IN_CURRENT_STATE, false);\n            });\n        }\n    }\n\n    async illuminateGroupAsync(desiredIntensity: number): Promise<void> {\n        return new Promise(async(resolve, reject)=>{\n            try {\n                this.log.info(`${this.accessory.displayName} turning ${desiredIntensity > 0 ? 'on' : 'off'} with brightness ${desiredIntensity}`);\n                let result = await this.controller.IlluminateGroupAsync(this.context.groupNumber, desiredIntensity);\n                if (result.StatusStr === 'Ok') {\n                    this.context.brightness = desiredIntensity;\n                    this.context.isOn = this.context.brightness > 0;\n                    this.service.updateCharacteristic(this.platform.Characteristic.On, desiredIntensity > 0);\n                    this.service.updateCharacteristic(this.platform.Characteristic.Brightness, desiredIntensity);\n                    resolve();\n                }\n                else {\n                    this.log.error(`${this.accessory.displayName} returned ${result.StatusStr} trying to set intensity ${desiredIntensity}.`)\n                    reject();\n                }\n            }\n            catch (err) {\n                this.log.error(`${this.accessory.displayName} illuminateGroupAsync error: ${err}`)\n                reject(err);\n            };\n        })\n        }\n    setCharacteristics(): void {\n        this.service.updateCharacteristic(this.platform.Characteristic.On, typeof this.context.isOn !== 'undefined' ? this.context.isOn : false);\n        this.service.updateCharacteristic(this.platform.Characteristic.Brightness, typeof this.context.brightness !== 'undefined' ? this.context.brightness : 0);\n    }\n    // this method used for event handling\n    async getCurrentStateAsync(): Promise<void> {\n        return new Promise(async (resolve, reject) => {\n            try {\n                let group = await this.controller.GetGroupAsync(this.context.groupNumber);\n                this.context.brightness = group.Intensity;\n                this.context.isOn = this.context.brightness > 0;\n                resolve();\n            }\n            catch (err) {\n                this.log.error(`${this.accessory.displayName} getCurrentStateAsync error: ${err}`)\n                reject(err)\n            };\n        })\n    }\n    // this method used for callbacks\n    callbackBrightness(intensity: number): void {\n\n        if (intensity !== this.context.brightness) {\n            this.context.brightness = intensity;\n            this.context.isOn = intensity > 0;\n            this.log.debug(`${this.accessory.displayName} updated isOn to ${intensity > 0} and brightness ${intensity}.`);\n            this.service.updateCharacteristic(this.platform.Characteristic.On, intensity > 0);\n            this.service.updateCharacteristic(this.platform.Characteristic.Brightness, intensity);\n        }\n    }\n}\n\nexport enum ILightType {\n    ZD = 'ZD', ZDC = 'ZDC', THEME = 'Theme'\n}"]}