homebridge-eufy-security
Version:
Control Eufy Security from homebridge.
48 lines • 2.08 kB
JavaScript
import { DeviceAccessory } from './Device.js';
// @ts-ignore
import { PropertyName } from 'eufy-security-client';
import { CHAR, SERV } from '../utils/utils.js';
/**
* MotionSensorAccessory Class
*
* This class represents a motion sensor accessory within a home automation system. It is designed
* to integrate motion sensors into the system, register appropriate characteristics, and provide
* necessary functionality for motion detection.
*
* @class MotionSensorAccessory
* @extends DeviceAccessory
*/
export class MotionSensorAccessory extends DeviceAccessory {
/**
* Constructor for MotionSensorAccessory.
*
* @param {EufySecurityPlatform} platform - The platform instance managing accessories.
* @param {PlatformAccessory} accessory - The platform-specific accessory.
* @param {MotionSensor} device - The motion sensor device being represented.
*/
constructor(platform, accessory, device) {
// Call the constructor of the parent class DeviceAccessory.
super(platform, accessory, device);
// Log a debug message indicating the construction of the Motion Sensor.
this.log.debug(`Constructed Motion Sensor`);
// Check if the device has the 'motionDetected' property.
if (this.device.hasProperty('motionDetected')) {
// Register the Motion Detected characteristic.
this.registerCharacteristic({
serviceType: SERV.MotionSensor,
characteristicType: CHAR.MotionDetected,
getValue: () => this.device.getPropertyValue(PropertyName.DeviceMotionDetected),
onSimpleValue: 'motion detected',
});
// Initialize the sensor service.
this.initSensorService();
}
else {
// Log an error if the 'motionDetected' property is not available for this device.
this.log.error(`has no motionDetected`);
}
// Remove any unused services.
this.pruneUnusedServices();
}
}
//# sourceMappingURL=MotionSensorAccessory.js.map