UNPKG

zigbee-herdsman-converters

Version:

Collection of device converters to be used with zigbee-herdsman

672 lines (664 loc) • 31.8 kB
const exposes = require('../lib/exposes'); const fz = {...require('../converters/fromZigbee'), legacy: require('../lib/legacy').fromZigbee}; const tz = require('../converters/toZigbee'); const globalStore = require('../lib/store'); const constants = require('../lib/constants'); const reporting = require('../lib/reporting'); const extend = require('../lib/extend'); const e = exposes.presets; const ea = exposes.access; module.exports = [ { zigbeeModel: ['CO_V15', 'CO_YDLV10', 'CO_V16', '1ccaa94c49a84abaa9e38687913947ba'], model: 'HS1CA-M', description: 'Smart carbon monoxide sensor', vendor: 'HEIMAN', fromZigbee: [fz.ias_carbon_monoxide_alarm_1, fz.battery], toZigbee: [], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint); await reporting.batteryAlarmState(endpoint); }, exposes: [e.carbon_monoxide(), e.battery_low(), e.tamper(), e.battery()], }, { zigbeeModel: ['PIRSensor-N', 'PIRSensor-EM', 'PIRSensor-EF-3.0', 'PIR_TPV13'], model: 'HS3MS', vendor: 'HEIMAN', description: 'Smart motion sensor', fromZigbee: [fz.ias_occupancy_alarm_1], toZigbee: [], exposes: [e.occupancy(), e.battery_low(), e.tamper()], }, { zigbeeModel: ['SmartPlug'], model: 'HS2SK', description: 'Smart metering plug', vendor: 'HEIMAN', fromZigbee: [fz.on_off, fz.electrical_measurement], toZigbee: [tz.on_off], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genOnOff', 'haElectricalMeasurement']); await reporting.onOff(endpoint); await reporting.readEletricalMeasurementMultiplierDivisors(endpoint); await reporting.rmsVoltage(endpoint); await reporting.rmsCurrent(endpoint); await reporting.activePower(endpoint); }, exposes: [e.switch(), e.power(), e.current(), e.voltage()], }, { fingerprint: [{modelID: 'SmartPlug-N', manufacturerName: 'HEIMAN'}], model: 'HS2SK_nxp', description: 'Smart metering plug', vendor: 'HEIMAN', fromZigbee: [fz.on_off, fz.electrical_measurement], toZigbee: [tz.on_off], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genOnOff', 'haElectricalMeasurement']); await reporting.onOff(endpoint); await reporting.readEletricalMeasurementMultiplierDivisors(endpoint); }, onEvent: (type, data, device, options) => { const endpoint = device.getEndpoint(1); if (type === 'stop') { clearInterval(globalStore.getValue(device, 'interval')); globalStore.clearValue(device, 'interval'); } else if (!globalStore.hasValue(device, 'interval')) { const seconds = options && options.measurement_poll_interval ? options.measurement_poll_interval : 60; const interval = setInterval(async () => { try { await endpoint.read('haElectricalMeasurement', ['rmsVoltage', 'rmsCurrent', 'activePower']); } catch (error) {/* Do nothing*/} }, seconds*1000); globalStore.putValue(device, 'interval', interval); } }, exposes: [e.switch(), e.power(), e.current(), e.voltage()], }, { zigbeeModel: ['SMOK_V16', 'SMOK_V15', 'b5db59bfd81e4f1f95dc57fdbba17931', '98293058552c49f38ad0748541ee96ba', 'SMOK_YDLV10', 'FB56-SMF02HM1.4', 'SmokeSensor-N-3.0'], model: 'HS1SA', vendor: 'HEIMAN', description: 'Smoke detector', fromZigbee: [fz.ias_smoke_alarm_1, fz.battery], toZigbee: [], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint); }, exposes: [e.smoke(), e.battery_low(), e.tamper(), e.battery()], }, { zigbeeModel: ['SmokeSensor-N', 'SmokeSensor-EF-3.0', 'SmokeSensor-EM'], model: 'HS3SA', vendor: 'HEIMAN', description: 'Smoke detector', fromZigbee: [fz.ias_smoke_alarm_1, fz.battery], toZigbee: [], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint); }, exposes: [e.smoke(), e.battery_low(), e.tamper(), e.battery()], }, { zigbeeModel: ['GASSensor-N'], model: 'HS3CG', vendor: 'HEIMAN', description: 'Combustible gas sensor', fromZigbee: [fz.ias_gas_alarm_1], toZigbee: [], exposes: [e.gas(), e.battery_low(), e.tamper()], }, { zigbeeModel: ['GASSensor-EN'], model: 'HS1CG-M', vendor: 'HEIMAN', description: 'Combustible gas sensor', fromZigbee: [fz.ias_gas_alarm_1], toZigbee: [], exposes: [e.gas(), e.battery_low(), e.tamper()], }, { zigbeeModel: ['GAS_V15'], model: 'HS1CG_M', vendor: 'HEIMAN', description: 'Combustible gas sensor', fromZigbee: [fz.ias_gas_alarm_2], toZigbee: [], exposes: [e.gas(), e.battery_low(), e.tamper()], }, { zigbeeModel: ['DoorSensor-N', 'DoorSensor-N-3.0'], model: 'HS3DS', vendor: 'HEIMAN', description: 'Door sensor', fromZigbee: [fz.ias_contact_alarm_1, fz.battery], toZigbee: [], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint, {min: constants.repInterval.MINUTES_5, max: constants.repInterval.HOUR}); await endpoint.read('genPowerCfg', ['batteryPercentageRemaining']); }, exposes: [e.contact(), e.battery(), e.battery_low(), e.tamper()], }, { zigbeeModel: ['DoorSensor-EM', 'DoorSensor-EF-3.0'], model: 'HS1DS', vendor: 'HEIMAN', description: 'Door sensor', fromZigbee: [fz.ias_contact_alarm_1, fz.battery], toZigbee: [], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint, {min: constants.repInterval.MINUTES_5, max: constants.repInterval.HOUR}); await endpoint.read('genPowerCfg', ['batteryPercentageRemaining']); }, exposes: [e.contact(), e.battery_low(), e.tamper(), e.battery()], }, { zigbeeModel: ['DOOR_TPV13', 'DOOR_TPV12'], model: 'HEIMAN-M1', vendor: 'HEIMAN', description: 'Door sensor', fromZigbee: [fz.ias_contact_alarm_1], toZigbee: [], exposes: [e.contact(), e.battery_low(), e.tamper()], }, { zigbeeModel: ['WaterSensor-N', 'WaterSensor-EM', 'WaterSensor-N-3.0', 'WaterSensor-EF-3.0'], model: 'HS1WL/HS3WL', vendor: 'HEIMAN', description: 'Water leakage sensor', fromZigbee: [fz.ias_water_leak_alarm_1, fz.battery], toZigbee: [], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint, {min: constants.repInterval.MINUTES_5, max: constants.repInterval.HOUR}); await endpoint.read('genPowerCfg', ['batteryPercentageRemaining']); }, exposes: [e.water_leak(), e.battery_low(), e.tamper(), e.battery()], }, { fingerprint: [{modelID: 'RC-N', manufacturerName: 'HEIMAN'}], model: 'HS1RC-N', vendor: 'HEIMAN', description: 'Smart remote controller', fromZigbee: [fz.battery, fz.legacy.heiman_smart_controller_armmode, fz.command_emergency], toZigbee: [], exposes: [e.battery(), e.action(['emergency', 'disarm', 'arm_partial_zones', 'arm_all_zones'])], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint, {min: constants.repInterval.MINUTES_5, max: constants.repInterval.HOUR}); await endpoint.read('genPowerCfg', ['batteryPercentageRemaining']); }, }, { fingerprint: [{modelID: 'RC-EF-3.0', manufacturerName: 'HEIMAN'}], model: 'HM1RC-2-E', vendor: 'HEIMAN', description: 'Smart remote controller', fromZigbee: [fz.battery, fz.command_arm, fz.command_emergency], toZigbee: [], exposes: [e.battery(), e.action(['emergency', 'disarm', 'arm_partial_zones', 'arm_all_zones'])], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint, {min: constants.repInterval.MINUTES_5, max: constants.repInterval.HOUR}); await endpoint.read('genPowerCfg', ['batteryPercentageRemaining']); }, onEvent: async (type, data, device) => { // Since arm command has a response zigbee-herdsman doesn't send a default response. // This causes the remote to repeat the arm command, so send a default response here. if (data.type === 'commandArm' && data.cluster === 'ssIasAce') { await data.endpoint.defaultResponse(0, 0, 1281, data.meta.zclTransactionSequenceNumber); } }, }, { fingerprint: [{modelID: 'RC-EM', manufacturerName: 'HEIMAN'}], model: 'HS1RC-EM', vendor: 'HEIMAN', description: 'Smart remote controller', fromZigbee: [fz.battery, fz.legacy.heiman_smart_controller_armmode, fz.command_emergency], toZigbee: [], exposes: [e.battery(), e.action(['emergency', 'disarm', 'arm_partial_zones', 'arm_all_zones'])], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint, {min: constants.repInterval.MINUTES_5, max: constants.repInterval.HOUR}); await endpoint.read('genPowerCfg', ['batteryPercentageRemaining']); }, }, { zigbeeModel: ['COSensor-EM', 'COSensor-N', 'COSensor-EF-3.0'], model: 'HS1CA-E', vendor: 'HEIMAN', description: 'Smart carbon monoxide sensor', fromZigbee: [fz.ias_carbon_monoxide_alarm_1, fz.battery], toZigbee: [], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint); }, exposes: [e.carbon_monoxide(), e.battery_low(), e.tamper(), e.battery()], }, { zigbeeModel: ['WarningDevice', 'WarningDevice-EF-3.0', 'SRHMP-I1'], model: 'HS2WD-E', vendor: 'HEIMAN', description: 'Smart siren', fromZigbee: [fz.battery, fz.ignore_basic_report], toZigbee: [tz.warning], meta: {disableDefaultResponse: true}, configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint); }, exposes: [e.battery(), e.warning()], }, { zigbeeModel: ['SOHM-I1'], model: 'SOHM-I1', vendor: 'HEIMAN', description: 'Door contact sensor', fromZigbee: [fz.ias_contact_alarm_1], toZigbee: [], exposes: [e.contact(), e.battery_low(), e.tamper()], }, { zigbeeModel: ['SWHM-I1'], model: 'SWHM-I1', vendor: 'HEIMAN', description: 'Water leakage sensor', fromZigbee: [fz.ias_water_leak_alarm_1], toZigbee: [], exposes: [e.water_leak(), e.battery_low(), e.tamper()], }, { zigbeeModel: ['SMHM-I1', 'PIR_TPV12'], model: 'SMHM-I1', vendor: 'HEIMAN', description: 'Smart motion sensor', fromZigbee: [fz.ias_occupancy_alarm_1], toZigbee: [], exposes: [e.occupancy(), e.battery_low(), e.tamper()], }, { zigbeeModel: ['HT-EM', 'TH-EM', 'TH-T_V14'], model: 'HS1HT', vendor: 'HEIMAN', description: 'Smart temperature & humidity Sensor', exposes: [e.battery(), e.temperature(), e.humidity()], fromZigbee: [fz.temperature, fz.humidity, fz.battery], toZigbee: [], meta: {battery: {voltageToPercentage: '3V_2500'}}, whiteLabel: [{vendor: 'Ferguson', model: 'TH-T_V14'}], configure: async (device, coordinatorEndpoint, logger) => { const endpoint1 = device.getEndpoint(1); await reporting.bind(endpoint1, coordinatorEndpoint, ['msTemperatureMeasurement']); const endpoint2 = device.getEndpoint(2); await reporting.bind(endpoint2, coordinatorEndpoint, ['msRelativeHumidity', 'genPowerCfg']); await reporting.temperature(endpoint1); await reporting.humidity(endpoint2); await reporting.batteryVoltage(endpoint2); await reporting.batteryPercentageRemaining(endpoint2); }, }, { zigbeeModel: ['HT-N', 'HT-EF-3.0'], model: 'HS1HT-N', vendor: 'HEIMAN', description: 'Smart temperature & humidity Sensor', fromZigbee: [fz.temperature, fz.humidity, fz.battery], toZigbee: [], configure: async (device, coordinatorEndpoint, logger) => { const endpoint1 = device.getEndpoint(1); await reporting.bind(endpoint1, coordinatorEndpoint, ['msTemperatureMeasurement', 'genPowerCfg']); await reporting.temperature(endpoint1); await reporting.batteryPercentageRemaining(endpoint1, {min: constants.repInterval.MINUTES_5, max: constants.repInterval.HOUR}); await endpoint1.read('genPowerCfg', ['batteryPercentageRemaining']); const endpoint2 = device.getEndpoint(2); await reporting.bind(endpoint2, coordinatorEndpoint, ['msRelativeHumidity']); await reporting.humidity(endpoint2); }, exposes: [e.temperature(), e.humidity(), e.battery()], }, { zigbeeModel: ['SKHMP30-I1'], model: 'SKHMP30-I1', description: 'Smart metering plug', vendor: 'HEIMAN', fromZigbee: [fz.on_off, fz.electrical_measurement], exposes: [e.switch(), e.power(), e.current(), e.voltage()], toZigbee: [tz.on_off], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genOnOff', 'haElectricalMeasurement']); await reporting.onOff(endpoint); await reporting.rmsVoltage(endpoint); await reporting.rmsCurrent(endpoint); await reporting.activePower(endpoint); endpoint.saveClusterAttributeKeyValue('haElectricalMeasurement', { acVoltageMultiplier: 1, acVoltageDivisor: 100, acCurrentMultiplier: 1, acCurrentDivisor: 100, acPowerMultiplier: 1, acPowerDivisor: 10, }); }, }, { zigbeeModel: ['E_Socket'], model: 'HS2ESK-E', vendor: 'HEIMAN', description: 'Smart in wall plug', fromZigbee: [fz.on_off, fz.electrical_measurement], toZigbee: [tz.on_off], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genOnOff', 'haElectricalMeasurement']); await reporting.onOff(endpoint); await reporting.readEletricalMeasurementMultiplierDivisors(endpoint); await reporting.rmsVoltage(endpoint); await reporting.rmsCurrent(endpoint); await reporting.activePower(endpoint); }, exposes: [e.switch(), e.power(), e.current(), e.voltage()], }, { zigbeeModel: ['SGMHM-I1'], model: 'SGMHM-I1', vendor: 'HEIMAN', description: 'Combustible gas sensor', fromZigbee: [fz.ias_gas_alarm_1], toZigbee: [], exposes: [e.gas(), e.battery_low(), e.tamper()], }, { zigbeeModel: ['STHM-I1H'], model: 'STHM-I1H', vendor: 'HEIMAN', description: 'Heiman temperature & humidity sensor', fromZigbee: [fz.temperature, fz.humidity, fz.battery], toZigbee: [], meta: {battery: {voltageToPercentage: '3V_2500'}}, configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); const bindClusters = ['msTemperatureMeasurement', 'msRelativeHumidity', 'genPowerCfg']; await reporting.bind(endpoint, coordinatorEndpoint, bindClusters); await reporting.temperature(endpoint); await reporting.humidity(endpoint, {min: 0, change: 25}); await reporting.batteryVoltage(endpoint); }, exposes: [e.temperature(), e.humidity(), e.battery()], }, { fingerprint: [{modelID: 'SOS-EM', manufacturerName: 'HEIMAN'}], model: 'HS1EB/HS1EB-E', vendor: 'HEIMAN', description: 'Smart emergency button', fromZigbee: [fz.command_status_change_notification_action, fz.legacy.st_button_state, fz.battery], toZigbee: [], exposes: [e.battery(), e.action(['off', 'single', 'double', 'hold'])], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint, {min: constants.repInterval.MINUTES_5, max: constants.repInterval.HOUR}); await endpoint.read('genPowerCfg', ['batteryPercentageRemaining']); }, }, { fingerprint: [{modelID: 'SceneSwitch-EM-3.0', manufacturerName: 'HEIMAN'}], model: 'HS2SS', vendor: 'HEIMAN', description: 'Smart scene switch', fromZigbee: [fz.battery, fz.heiman_scenes], exposes: [e.battery(), e.action(['cinema', 'at_home', 'sleep', 'go_out', 'repast'])], toZigbee: [], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg', 'heimanSpecificScenes']); await reporting.batteryPercentageRemaining(endpoint, {min: constants.repInterval.MINUTES_5, max: constants.repInterval.HOUR}); }, }, { zigbeeModel: ['GASSensor-EM'], model: 'HS1CG-E', vendor: 'HEIMAN', description: 'Combustible gas sensor', fromZigbee: [fz.ias_gas_alarm_1], toZigbee: [], whiteLabel: [{vendor: 'Piri', model: 'HSIO18008'}], exposes: [e.gas(), e.battery_low(), e.tamper()], }, { zigbeeModel: ['GASSensor-EFR-3.0', 'GASSensor-EF-3.0'], model: 'HS1CG-E_3.0', vendor: 'HEIMAN', description: 'Combustible gas sensor', fromZigbee: [fz.ias_gas_alarm_2], toZigbee: [], exposes: [e.gas(), e.battery_low(), e.tamper()], }, { fingerprint: [{modelID: 'Vibration-N', manufacturerName: 'HEIMAN'}], model: 'HS1VS-N', vendor: 'HEIMAN', description: 'Vibration sensor', fromZigbee: [fz.ias_vibration_alarm_1, fz.battery], toZigbee: [], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint, {min: constants.repInterval.MINUTES_5, max: constants.repInterval.HOUR}); await endpoint.read('genPowerCfg', ['batteryPercentageRemaining']); }, exposes: [e.vibration(), e.battery_low(), e.tamper(), e.battery()], }, { fingerprint: [{modelID: 'Vibration-EF_3.0', manufacturerName: 'HEIMAN'}], model: 'HS1VS-EF', vendor: 'HEIMAN', description: 'Vibration sensor', fromZigbee: [fz.ias_vibration_alarm_1, fz.battery], toZigbee: [], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg']); await reporting.batteryPercentageRemaining(endpoint, {min: constants.repInterval.MINUTES_5, max: constants.repInterval.HOUR}); await endpoint.read('genPowerCfg', ['batteryPercentageRemaining']); }, exposes: [e.vibration(), e.battery_low(), e.tamper(), e.battery()], }, { fingerprint: [{modelID: 'HS2AQ-EM', manufacturerName: 'HEIMAN'}], model: 'HS2AQ-EM', vendor: 'HEIMAN', description: 'Air quality monitor', fromZigbee: [fz.battery, fz.temperature, fz.humidity, fz.heiman_pm25, fz.heiman_hcho, fz.heiman_air_quality], toZigbee: [], configure: async (device, coordinatorEndpoint, logger) => { const heiman = { configureReporting: { pm25MeasuredValue: async (endpoint, overrides) => { const payload = reporting.payload('measuredValue', 0, constants.repInterval.HOUR, 1, overrides); await endpoint.configureReporting('heimanSpecificPM25Measurement', payload); }, formAldehydeMeasuredValue: async (endpoint, overrides) => { const payload = reporting.payload('measuredValue', 0, constants.repInterval.HOUR, 1, overrides); await endpoint.configureReporting('heimanSpecificFormaldehydeMeasurement', payload); }, batteryState: async (endpoint, overrides) => { const payload = reporting.payload('batteryState', 0, constants.repInterval.HOUR, 1, overrides); await endpoint.configureReporting('heimanSpecificAirQuality', payload); }, pm10measuredValue: async (endpoint, overrides) => { const payload = reporting.payload('pm10measuredValue', 0, constants.repInterval.HOUR, 1, overrides); await endpoint.configureReporting('heimanSpecificAirQuality', payload); }, tvocMeasuredValue: async (endpoint, overrides) => { const payload = reporting.payload('tvocMeasuredValue', 0, constants.repInterval.HOUR, 1, overrides); await endpoint.configureReporting('heimanSpecificAirQuality', payload); }, aqiMeasuredValue: async (endpoint, overrides) => { const payload = reporting.payload('aqiMeasuredValue', 0, constants.repInterval.HOUR, 1, overrides); await endpoint.configureReporting('heimanSpecificAirQuality', payload); }, }, }; const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, [ 'genPowerCfg', 'genTime', 'msTemperatureMeasurement', 'msRelativeHumidity', 'heimanSpecificPM25Measurement', 'heimanSpecificFormaldehydeMeasurement', 'heimanSpecificAirQuality']); await reporting.batteryPercentageRemaining(endpoint); await reporting.temperature(endpoint); await reporting.humidity(endpoint); await heiman.configureReporting.pm25MeasuredValue(endpoint); await heiman.configureReporting.formAldehydeMeasuredValue(endpoint); await heiman.configureReporting.batteryState(endpoint); await heiman.configureReporting.pm10measuredValue(endpoint); await heiman.configureReporting.tvocMeasuredValue(endpoint); await heiman.configureReporting.aqiMeasuredValue(endpoint); await endpoint.read('genPowerCfg', ['batteryPercentageRemaining']); // Seems that it is bug in HEIMAN, device does not asks for the time with binding // So, we need to write time during configure const time = Math.round(((new Date()).getTime() - constants.OneJanuary2000) / 1000); // Time-master + synchronised const values = {timeStatus: 3, time: time, timeZone: ((new Date()).getTimezoneOffset() * -1) * 60}; endpoint.write('genTime', values); }, exposes: [e.battery(), e.temperature(), e.humidity(), e.pm25(), e.hcho(), e.voc(), e.aqi(), e.pm10(), exposes.enum('battery_state', ea.STATE, ['not_charging', 'charging', 'charged'])], }, { fingerprint: [{modelID: 'IRControl-EM', manufacturerName: 'HEIMAN'}], model: 'HS2IRC', vendor: 'HEIMAN', description: 'Smart IR Control', fromZigbee: [fz.battery, fz.heiman_ir_remote], toZigbee: [tz.heiman_ir_remote], exposes: [e.battery()], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genPowerCfg', 'heimanSpecificInfraRedRemote']); await reporting.batteryPercentageRemaining(endpoint, {min: constants.repInterval.MINUTES_5, max: constants.repInterval.HOUR}); }, }, { zigbeeModel: ['BDHM8E27W70-I1'], model: 'BDHM8E27W70-I1', vendor: 'GS', // actually it is HEIMAN. description: 'Active light, warm to cool white (E27 & B22)', extend: extend.light_onoff_brightness_colortemp(), }, { zigbeeModel: ['HS2SW1L-EF-3.0', 'HS2SW1L-EFR-3.0', 'HS2SW1A-N'], fingerprint: [ {modelID: 'HS2SW1A-EF-3.0', manufacturerName: 'HEIMAN'}, {modelID: 'HS2SW1A-EFR-3.0', manufacturerName: 'HEIMAN'}, ], model: 'HS2SW1A/HS2SW1A-N', vendor: 'HEIMAN', description: 'Smart switch - 1 gang with neutral wire', fromZigbee: [fz.ignore_basic_report, fz.on_off, fz.device_temperature], toZigbee: [tz.on_off], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genOnOff', 'genDeviceTempCfg']); await reporting.onOff(endpoint); await reporting.deviceTemperature(endpoint); }, exposes: [e.switch(), e.device_temperature()], }, { zigbeeModel: ['HS2SW2L-EF-3.0', 'HS2SW2L-EFR-3.0', 'HS2SW2A-N'], fingerprint: [ {modelID: 'HS2SW2A-EF-3.0', manufacturerName: 'HEIMAN'}, {modelID: 'HS2SW2A-EFR-3.0', manufacturerName: 'HEIMAN'}, ], model: 'HS2SW2A/HS2SW2A-N', vendor: 'HEIMAN', description: 'Smart switch - 2 gang with neutral wire', fromZigbee: [fz.ignore_basic_report, fz.on_off, fz.device_temperature], toZigbee: [tz.on_off], endpoint: (device) => { return {left: 1, right: 2}; }, meta: {multiEndpoint: true}, configure: async (device, coordinatorEndpoint, logger) => { await reporting.bind(device.getEndpoint(1), coordinatorEndpoint, ['genOnOff', 'genDeviceTempCfg']); await reporting.bind(device.getEndpoint(2), coordinatorEndpoint, ['genOnOff']); await reporting.deviceTemperature(device.getEndpoint(1)); }, exposes: [e.switch().withEndpoint('left'), e.switch().withEndpoint('right'), e.device_temperature()], }, { zigbeeModel: ['HS2SW3L-EF-3.0', 'HS2SW3L-EFR-3.0', 'HS2SW3A-N'], fingerprint: [ {modelID: 'HS2SW3A-EF-3.0', manufacturerName: 'HEIMAN'}, {modelID: 'HS2SW3A-EFR-3.0', manufacturerName: 'HEIMAN'}, ], model: 'HS2SW3A/HS2SW3A-N', vendor: 'HEIMAN', description: 'Smart switch - 3 gang with neutral wire', fromZigbee: [fz.ignore_basic_report, fz.on_off, fz.device_temperature], toZigbee: [tz.on_off], endpoint: (device) => { return {left: 1, center: 2, right: 3}; }, meta: {multiEndpoint: true}, configure: async (device, coordinatorEndpoint, logger) => { await reporting.bind(device.getEndpoint(1), coordinatorEndpoint, ['genOnOff', 'genDeviceTempCfg']); await reporting.bind(device.getEndpoint(2), coordinatorEndpoint, ['genOnOff']); await reporting.bind(device.getEndpoint(3), coordinatorEndpoint, ['genOnOff']); await reporting.deviceTemperature(device.getEndpoint(1)); }, exposes: [e.switch().withEndpoint('left'), e.switch().withEndpoint('center'), e.switch().withEndpoint('right'), e.device_temperature()], }, { zigbeeModel: ['CurtainMo-EF-3.0', 'CurtainMo-EF'], model: 'HS2CM-N-DC', vendor: 'HEIMAN', description: 'Gear window shade motor', fromZigbee: [fz.cover_position_via_brightness], toZigbee: [tz.cover_via_brightness], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); await reporting.bind(endpoint, coordinatorEndpoint, ['genLevelCtrl', 'genPowerCfg']); await reporting.brightness(endpoint); }, exposes: [e.cover_position().setAccess('state', ea.ALL)], }, { zigbeeModel: ['PIR_TPV16'], model: 'HS1MS-M', vendor: 'HEIMAN', description: 'Smart motion sensor', fromZigbee: [fz.ias_occupancy_alarm_1], toZigbee: [], exposes: [e.occupancy(), e.battery_low(), e.tamper()], }, { zigbeeModel: ['TY0202'], model: 'HS1MS-EF', vendor: 'HEIMAN', description: 'Smart motion sensor', fromZigbee: [fz.ias_occupancy_alarm_1], toZigbee: [], exposes: [e.occupancy(), e.battery_low(), e.tamper()], }, ];