zigpy / zha-device-handlers

ZHA device handlers bridge the functionality gap created when manufacturers deviate from the ZCL specification, handling deviations and exceptions by parsing custom messages to and from Zigbee devices.
Apache License 2.0
734 stars 673 forks source link

[Device Support Request] Modkam.ru ptvo_counter_2ch support for pulse counter #1977

Closed WiktorBuczko closed 1 year ago

WiktorBuczko commented 1 year ago

Is your feature request related to a problem? Please describe. Device pairs using ZHA but pulse counter entities are missing, only water leak, battery and signal strength sensors are present. This device is based on E18-MS1-PCB module

Describe the solution you'd like Add support for pulse counter entities

Device signature ```yaml { "node_descriptor": "NodeDescriptor(logical_type=, complex_descriptor_available=0, user_descriptor_available=0, reserved=0, aps_flags=0, frequency_band=, mac_capability_flags=, manufacturer_code=4447, maximum_buffer_size=80, maximum_incoming_transfer_size=160, server_mask=0, maximum_outgoing_transfer_size=160, descriptor_capability_field=, *allocate_address=True, *is_alternate_pan_coordinator=False, *is_coordinator=False, *is_end_device=True, *is_full_function_device=False, *is_mains_powered=False, *is_receiver_on_when_idle=False, *is_router=False, *is_security_capable=False)", "endpoints": { "1": { "profile_id": 260, "device_type": "0x0100", "in_clusters": [ "0x0000", "0x0001" ], "out_clusters": [ "0x0000", "0x0001" ] }, "3": { "profile_id": 260, "device_type": "0x0100", "in_clusters": [ "0x000c" ], "out_clusters": [] }, "5": { "profile_id": 260, "device_type": "0x0100", "in_clusters": [ "0x000c" ], "out_clusters": [] }, "6": { "profile_id": 260, "device_type": "0x0100", "in_clusters": [ "0x0006" ], "out_clusters": [ "0x0006" ] } }, "manufacturer": "modkam.ru", "model": "ptvo_counter_2ch", "class": "zigpy.device.Device" } ```
Diagnostic information ```yaml { "home_assistant": { "installation_type": "Home Assistant Supervised", "version": "2022.11.5", "dev": false, "hassio": true, "virtualenv": false, "python_version": "3.10.7", "docker": true, "arch": "x86_64", "timezone": "Europe/Warsaw", "os_name": "Linux", "os_version": "5.10.0-19-amd64", "supervisor": "2022.11.2", "host_os": "Debian GNU/Linux 11 (bullseye)", "docker_version": "20.10.21", "chassis": "desktop", "run_as_root": true }, "custom_components": { "garbage_collection": { "version": "4.9.0", "requirements": [ "python-dateutil>=2.8.2" ] }, "scheduler": { "version": "v0.0.0", "requirements": [] }, "blitzortung": { "version": "1.0.1", "requirements": [ "paho-mqtt>=1.5.0" ] }, "car_wash": { "version": "1.5.4", "requirements": [] }, "dwains_dashboard": { "version": "3.3.0", "requirements": [] }, "adaptive_lighting": { "version": "1.2.0", "requirements": [] }, "hacs": { "version": "1.28.4", "requirements": [ "aiogithubapi>=22.2.4" ] }, "pirateweather": { "version": "0.1.0", "requirements": [ "python-forecastio==1.4.0" ] }, "iphonedetect": { "version": "1.4.0", "requirements": [] }, "burze_dzis_net": { "version": "v1.0.4", "requirements": [ "zeep" ] } }, "integration_manifest": { "domain": "zha", "name": "Zigbee Home Automation", "config_flow": true, "documentation": "https://www.home-assistant.io/integrations/zha", "requirements": [ "bellows==0.34.4", "pyserial==3.5", "pyserial-asyncio==0.6", "zha-quirks==0.0.87", "zigpy-deconz==0.19.1", "zigpy==0.51.6", "zigpy-xbee==0.16.2", "zigpy-zigate==0.10.3", "zigpy-znp==0.9.1" ], "usb": [ { "vid": "10C4", "pid": "EA60", "description": "*2652*", "known_devices": [ "slae.sh cc2652rb stick" ] }, { "vid": "1A86", "pid": "55D4", "description": "*sonoff*plus*", "known_devices": [ "sonoff zigbee dongle plus v2" ] }, { "vid": "10C4", "pid": "EA60", "description": "*sonoff*plus*", "known_devices": [ "sonoff zigbee dongle plus" ] }, { "vid": "10C4", "pid": "EA60", "description": "*tubeszb*", "known_devices": [ "TubesZB Coordinator" ] }, { "vid": "1A86", "pid": "7523", "description": "*tubeszb*", "known_devices": [ "TubesZB Coordinator" ] }, { "vid": "1A86", "pid": "7523", "description": "*zigstar*", "known_devices": [ "ZigStar Coordinators" ] }, { "vid": "1CF1", "pid": "0030", "description": "*conbee*", "known_devices": [ "Conbee II" ] }, { "vid": "10C4", "pid": "8A2A", "description": "*zigbee*", "known_devices": [ "Nortek HUSBZB-1" ] }, { "vid": "0403", "pid": "6015", "description": "*zigate*", "known_devices": [ "ZiGate+" ] }, { "vid": "10C4", "pid": "EA60", "description": "*zigate*", "known_devices": [ "ZiGate" ] }, { "vid": "10C4", "pid": "8B34", "description": "*bv 2010/10*", "known_devices": [ "Bitron Video AV2010/10" ] } ], "codeowners": [ "@dmulcahey", "@adminiuga", "@puddly" ], "zeroconf": [ { "type": "_esphomelib._tcp.local.", "name": "tube*" }, { "type": "_zigate-zigbee-gateway._tcp.local.", "name": "*zigate*" }, { "type": "_zigstar_gw._tcp.local.", "name": "*zigstar*" } ], "dependencies": [ "file_upload" ], "after_dependencies": [ "onboarding", "usb", "zeroconf" ], "iot_class": "local_polling", "loggers": [ "aiosqlite", "bellows", "crccheck", "pure_pcapy3", "zhaquirks", "zigpy", "zigpy_deconz", "zigpy_xbee", "zigpy_zigate", "zigpy_znp" ], "is_built_in": true }, "data": { "ieee": "**REDACTED**", "nwk": 29787, "manufacturer": "modkam.ru", "model": "ptvo_counter_2ch", "name": "modkam.ru ptvo_counter_2ch", "quirk_applied": false, "quirk_class": "zigpy.device.Device", "manufacturer_code": 4447, "power_source": "Battery or Unknown", "lqi": 255, "rssi": -42, "last_seen": "2022-12-01T14:38:58", "available": true, "device_type": "EndDevice", "signature": { "node_descriptor": "NodeDescriptor(logical_type=, complex_descriptor_available=0, user_descriptor_available=0, reserved=0, aps_flags=0, frequency_band=, mac_capability_flags=, manufacturer_code=4447, maximum_buffer_size=80, maximum_incoming_transfer_size=160, server_mask=0, maximum_outgoing_transfer_size=160, descriptor_capability_field=, *allocate_address=True, *is_alternate_pan_coordinator=False, *is_coordinator=False, *is_end_device=True, *is_full_function_device=False, *is_mains_powered=False, *is_receiver_on_when_idle=False, *is_router=False, *is_security_capable=False)", "endpoints": { "1": { "profile_id": 260, "device_type": "0x0100", "in_clusters": [ "0x0000", "0x0001" ], "out_clusters": [ "0x0000", "0x0001" ] }, "3": { "profile_id": 260, "device_type": "0x0100", "in_clusters": [ "0x000c" ], "out_clusters": [] }, "5": { "profile_id": 260, "device_type": "0x0100", "in_clusters": [ "0x000c" ], "out_clusters": [] }, "6": { "profile_id": 260, "device_type": "0x0100", "in_clusters": [ "0x0006" ], "out_clusters": [ "0x0006" ] } } }, "active_coordinator": false, "entities": [ { "entity_id": "binary_sensor.modkam_ru_ptvo_counter_2ch_opening", "name": "modkam.ru ptvo_counter_2ch" }, { "entity_id": "light.modkam_ru_ptvo_counter_2ch_light", "name": "modkam.ru ptvo_counter_2ch" }, { "entity_id": "sensor.modkam_ru_ptvo_counter_2ch_battery", "name": "modkam.ru ptvo_counter_2ch" } ], "neighbors": [], "endpoint_names": [ { "name": "ON_OFF_LIGHT" }, { "name": "ON_OFF_LIGHT" }, { "name": "ON_OFF_LIGHT" }, { "name": "ON_OFF_LIGHT" } ], "user_given_name": null, "device_reg_id": "2963234a248f5ab22af2b6c2f3b1438c", "area_id": "na_zewnatrz", "cluster_details": { "6": { "device_type": { "name": "ON_OFF_LIGHT", "id": 256 }, "profile_id": 260, "in_clusters": { "0x0006": { "endpoint_attribute": "on_off", "attributes": { "0x0000": { "attribute_name": "on_off", "value": 0 } }, "unsupported_attributes": { "0x4003": { "attribute_name": "start_up_on_off" } } } }, "out_clusters": { "0x0006": { "endpoint_attribute": "on_off", "attributes": {}, "unsupported_attributes": {} } } }, "5": { "device_type": { "name": "ON_OFF_LIGHT", "id": 256 }, "profile_id": 260, "in_clusters": { "0x000c": { "endpoint_attribute": "analog_input", "attributes": { "0x001c": { "attribute_name": "description", "value": ",0A" }, "0x0055": { "attribute_name": "present_value", "value": 15.0 }, "0x006f": { "attribute_name": "status_flags", "value": 0 } }, "unsupported_attributes": {} } }, "out_clusters": {} }, "3": { "device_type": { "name": "ON_OFF_LIGHT", "id": 256 }, "profile_id": 260, "in_clusters": { "0x000c": { "endpoint_attribute": "analog_input", "attributes": { "0x001c": { "attribute_name": "description", "value": ",0A" }, "0x0055": { "attribute_name": "present_value", "value": 23.0 }, "0x006f": { "attribute_name": "status_flags", "value": 0 } }, "unsupported_attributes": {} } }, "out_clusters": {} }, "1": { "device_type": { "name": "ON_OFF_LIGHT", "id": 256 }, "profile_id": 260, "in_clusters": { "0x0000": { "endpoint_attribute": "basic", "attributes": { "0x0004": { "attribute_name": "manufacturer", "value": "modkam.ru" }, "0x0005": { "attribute_name": "model", "value": "ptvo_counter_2ch" } }, "unsupported_attributes": {} }, "0x0001": { "endpoint_attribute": "power", "attributes": { "0x0020": { "attribute_name": "battery_voltage", "value": 31 }, "0x0021": { "attribute_name": "battery_percentage_remaining", "value": 200 } }, "unsupported_attributes": { "0x0031": { "attribute_name": "battery_size" }, "0x0033": { "attribute_name": "battery_quantity" } } } }, "out_clusters": { "0x0000": { "endpoint_attribute": "basic", "attributes": {}, "unsupported_attributes": {} }, "0x0001": { "endpoint_attribute": "power", "attributes": {}, "unsupported_attributes": {} } } } } } } ```
Additional logs Logs from pairing process ``` [0xA547](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xA547](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=0, dst=AddrModeAddress(addr_mode=, address=), dst_ep=0, source_route=None, extended_timeout=False, tsn=None, profile_id=0, cluster_id=19, data=Serialized[b'\x00[t\xcc\xedC$\x00K\x12\x00\x80'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-46) New device 0x745b (00:12:4b:00:24:43:ed:cc) joined the network [0x745b] Scheduling initialization Received frame on uninitialized device from ep 0 to ep 0, cluster 19: b'\x00[t\xcc\xedC$\x00K\x12\x00\x80' [0x745b:zdo] ZDO request ZDOCmd.Device_annce: [0x745B, 00:12:4b:00:24:43:ed:cc, 128] Tries remaining: 3 [0x745b] Requesting 'Node Descriptor' Tries remaining: 2 [0x745b] Extending timeout for 0x05 request Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=0, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=0, source_route=None, extended_timeout=False, tsn=None, profile_id=0, cluster_id=32770, data=Serialized[b'\x05\x00[t\x02@\x80_\x11P\xa0\x00\x00\x00\xa0\x00\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-46) Received frame on uninitialized device from ep 0 to ep 0, cluster 32770: b'\x05\x00[t\x02@\x80_\x11P\xa0\x00\x00\x00\xa0\x00\x00' [0x745b] Got Node Descriptor: NodeDescriptor(logical_type=, complex_descriptor_available=0, user_descriptor_available=0, reserved=0, aps_flags=0, frequency_band=, mac_capability_flags=, manufacturer_code=4447, maximum_buffer_size=80, maximum_incoming_transfer_size=160, server_mask=0, maximum_outgoing_transfer_size=160, descriptor_capability_field=, *allocate_address=True, *is_alternate_pan_coordinator=False, *is_coordinator=False, *is_end_device=True, *is_full_function_device=False, *is_mains_powered=False, *is_receiver_on_when_idle=False, *is_router=False, *is_security_capable=False) [0x745b] Discovering endpoints Tries remaining: 3 [0x745b] Extending timeout for 0x07 request Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=0, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=0, source_route=None, extended_timeout=False, tsn=None, profile_id=0, cluster_id=32773, data=Serialized[b'\x07\x00[t\x04\x06\x05\x03\x01'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-46) Received frame on uninitialized device from ep 0 to ep 0, cluster 32773: b'\x07\x00[t\x04\x06\x05\x03\x01' [0x745b] Discovered endpoints: [6, 5, 3, 1] [0x745b] Initializing endpoints [>, >, >, >] [0x745b:6] Discovering endpoint information Tries remaining: 3 [0x745b] Extending timeout for 0x09 request Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=0, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=0, source_route=None, extended_timeout=False, tsn=None, profile_id=0, cluster_id=32772, data=Serialized[b'\t\x00[t\x0c\x06\x04\x01\x00\x01\x00\x01\x06\x00\x01\x06\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-46) Received frame on uninitialized device from ep 0 to ep 0, cluster 32772: b'\t\x00[t\x0c\x06\x04\x01\x00\x01\x00\x01\x06\x00\x01\x06\x00' [0x745b:6] Discovered endpoint information: SizePrefixedSimpleDescriptor(endpoint=6, profile=260, device_type=256, device_version=0, input_clusters=[6], output_clusters=[6]) [0x745b:5] Discovering endpoint information Tries remaining: 3 [0x745b] Extending timeout for 0x0b request Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=0, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=0, source_route=None, extended_timeout=False, tsn=None, profile_id=0, cluster_id=32772, data=Serialized[b'\x0b\x00[t\n\x05\x04\x01\x00\x01\x00\x01\x0c\x00\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-46) Received frame on uninitialized device from ep 0 to ep 0, cluster 32772: b'\x0b\x00[t\n\x05\x04\x01\x00\x01\x00\x01\x0c\x00\x00' [0x745b:5] Discovered endpoint information: SizePrefixedSimpleDescriptor(endpoint=5, profile=260, device_type=256, device_version=0, input_clusters=[12], output_clusters=[]) [0x745b:3] Discovering endpoint information Tries remaining: 3 [0x745b] Extending timeout for 0x0d request Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0xA547), src_ep=1, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=64704, data=Serialized[b'\x1c_\x11a\n\xf7\x00A$\x01!\x9b\x0b\x03(\x19\x04!\xa8C\x05!s\x01\x06$\x03\x00\x00\x00\x00\x08!\x11\x01\n!\x00\x00\x0c \x01d\x10\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-66) [0xA547:1:0xfcc0] Received ZCL frame: b'\x1c_\x11a\n\xf7\x00A$\x01!\x9b\x0b\x03(\x19\x04!\xa8C\x05!s\x01\x06$\x03\x00\x00\x00\x00\x08!\x11\x01\n!\x00\x00\x0c \x01d\x10\x00' [0xA547:1:0xfcc0] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=True, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), manufacturer=4447, tsn=97, command_id=10, *direction=, *is_reply=True) [0xA547:1:0xfcc0] Decoded ZCL frame: OppleCluster:Report_Attributes(attribute_reports=[Attribute(attrid=0x00F7, value=TypeValue(type=LVBytes, value=b'\x01!\x9b\x0b\x03(\x19\x04!\xa8C\x05!s\x01\x06$\x03\x00\x00\x00\x00\x08!\x11\x01\n!\x00\x00\x0c \x01d\x10\x00'))]) [0xA547:1:0xfcc0] Received command 0x0A (TSN 97): Report_Attributes(attribute_reports=[Attribute(attrid=0x00F7, value=TypeValue(type=LVBytes, value=b'\x01!\x9b\x0b\x03(\x19\x04!\xa8C\x05!s\x01\x06$\x03\x00\x00\x00\x00\x08!\x11\x01\n!\x00\x00\x0c \x01d\x10\x00'))]) [0xA547:1:0xfcc0] Attribute report received: 0x00F7=b'\x01!\x9b\x0b\x03(\x19\x04!\xa8C\x05!s\x01\x06$\x03\x00\x00\x00\x00\x08!\x11\x01\n!\x00\x00\x0c \x01d\x10\x00' Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=0, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=0, source_route=None, extended_timeout=False, tsn=None, profile_id=0, cluster_id=32772, data=Serialized[b'\r\x00[t\n\x03\x04\x01\x00\x01\x00\x01\x0c\x00\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-46) Received frame on uninitialized device from ep 0 to ep 0, cluster 32772: b'\r\x00[t\n\x03\x04\x01\x00\x01\x00\x01\x0c\x00\x00' [0x745b:3] Discovered endpoint information: SizePrefixedSimpleDescriptor(endpoint=3, profile=260, device_type=256, device_version=0, input_clusters=[12], output_clusters=[]) [0x745b:1] Discovering endpoint information Tries remaining: 3 [0x745b] Extending timeout for 0x0f request Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=0, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=0, source_route=None, extended_timeout=False, tsn=None, profile_id=0, cluster_id=32772, data=Serialized[b'\x0f\x00[t\x10\x01\x04\x01\x00\x01\x00\x02\x00\x00\x01\x00\x02\x00\x00\x01\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-46) Received frame on uninitialized device from ep 0 to ep 0, cluster 32772: b'\x0f\x00[t\x10\x01\x04\x01\x00\x01\x00\x02\x00\x00\x01\x00\x02\x00\x00\x01\x00' [0x745b:1] Discovered endpoint information: SizePrefixedSimpleDescriptor(endpoint=1, profile=260, device_type=256, device_version=0, input_clusters=[0, 1], output_clusters=[0, 1]) [0x745b] Read model None and manufacturer None from > [0x745b] Read model None and manufacturer None from > [0x745b] Read model None and manufacturer None from > [0x745B:1:0x0000] Sending request header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=False, direction=, disable_default_response=0, reserved=0, *is_cluster=False, *is_general=True, *is_reply=False), tsn=17, command_id=, *direction=, *is_reply=False) [0x745B:1:0x0000] Sending request: Read_Attributes(attribute_ids=[4, 5]) [0x745b] Extending timeout for 0x11 request Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=1, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=0, data=Serialized[b'\x18\x11\x01\x04\x00\x00B\tmodkam.ru\x05\x00\x00B\x10ptvo_counter_2ch'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-46) [0x745B:1:0x0000] Received ZCL frame: b'\x18\x11\x01\x04\x00\x00B\tmodkam.ru\x05\x00\x00B\x10ptvo_counter_2ch' [0x745B:1:0x0000] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=17, command_id=1, *direction=, *is_reply=True) [0x745B:1:0x0000] Decoded ZCL frame: Basic:Read_Attributes_rsp(status_records=[ReadAttributeRecord(attrid=0x0004, status=, value=TypeValue(type=CharacterString, value='modkam.ru')), ReadAttributeRecord(attrid=0x0005, status=, value=TypeValue(type=CharacterString, value='ptvo_counter_2ch'))]) [0x745b] Read model 'ptvo_counter_2ch' and manufacturer 'modkam.ru' from > [0x745b] Discovered basic device information for Device is initialized Checking quirks for modkam.ru ptvo_counter_2ch (00:12:4b:00:24:43:ed:cc) Considering Fail because endpoint list mismatch: {1, 2, 242} {1, 3, 5, 6} Considering Fail because endpoint list mismatch: {1, 2, 41, 42, 242, 51, 21, 31} {1, 3, 5, 6} Considering Fail because endpoint list mismatch: {232, 230} {1, 3, 5, 6} Considering Fail because endpoint list mismatch: {232, 230} {1, 3, 5, 6} Considering Fail because endpoint list mismatch: {1} {1, 3, 5, 6} Considering Fail because endpoint list mismatch: {1} {1, 3, 5, 6} Considering Fail because endpoint list mismatch: {1} {1, 3, 5, 6} Considering Fail because endpoint list mismatch: {1} {1, 3, 5, 6} Considering Fail because endpoint list mismatch: {11, 13} {1, 3, 5, 6} 'sensor' component -> 'Battery' using ['power'] 'sensor' component -> 'RSSISensor' using ['basic'] 'sensor' component -> 'LQISensor' using ['basic'] 'select' component -> 'ZHAStartupOnOffSelectEntity' using ['on_off'] device - 0x745B:00:12:4b:00:24:43:ed:cc entering async_device_initialized - is_new_join: True device - 0x745B:00:12:4b:00:24:43:ed:cc has joined the ZHA zigbee network [0x745B](ptvo_counter_2ch): started configuration [0x745B:ZDO](ptvo_counter_2ch): 'async_configure' stage succeeded Error handling '_save_attribute' event with (00:12:4b:00:24:43:ed:cc, 1, 0, 4, 'modkam.ru') params: FOREIGN KEY constraint failed [0x745B:1:0x0000]: Configuring cluster attribute reporting [0x745B:1:0x0000]: finished channel configuration [0x745B:1:0x0001]: Performing cluster binding [0x745b] Extending timeout for 0x13 request [0x745B:6:0x0006]: Performing cluster binding [0x745b] Extending timeout for 0x15 request [0x745B:6:0x0006]: Performing cluster binding [0x745b] Extending timeout for 0x17 request Error handling '_save_attribute' event with (00:12:4b:00:24:43:ed:cc, 1, 0, 5, 'ptvo_counter_2ch') params: FOREIGN KEY constraint failed [0x15CE](lumi.sensor_wleak.aq1): Device seen - marking the device available and resetting counter [0x15CE](lumi.sensor_wleak.aq1): Update device availability - device available: True - new availability: True - changed: False Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=0, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=0, source_route=None, extended_timeout=False, tsn=None, profile_id=0, cluster_id=32801, data=Serialized[b'\x13\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-44) [0x745B:1:0x0001]: bound 'power' cluster: Status.SUCCESS [0x745B:1:0x0001]: Configuring cluster attribute reporting [0x745B:1:0x0001] Sending request header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=False, direction=, disable_default_response=0, reserved=0, *is_cluster=False, *is_general=True, *is_reply=False), tsn=25, command_id=, *direction=, *is_reply=False) [0x745B:1:0x0001] Sending request: Configure_Reporting(config_records=[AttributeReportingConfig(direction=0, attrid=0x0020, datatype=32, min_interval=3600, max_interval=10800, reportable_change=1), AttributeReportingConfig(direction=0, attrid=0x0021, datatype=32, min_interval=3600, max_interval=10800, reportable_change=1)]) [0x745b] Extending timeout for 0x19 request Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=0, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=0, source_route=None, extended_timeout=False, tsn=None, profile_id=0, cluster_id=32801, data=Serialized[b'\x15\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-44) [0x745B:6:0x0006]: bound 'on_off' cluster: Status.SUCCESS [0x745B:6:0x0006]: Configuring cluster attribute reporting [0x745B:6:0x0006] Sending request header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=False, direction=, disable_default_response=0, reserved=0, *is_cluster=False, *is_general=True, *is_reply=False), tsn=27, command_id=, *direction=, *is_reply=False) [0x745B:6:0x0006] Sending request: Configure_Reporting(config_records=[AttributeReportingConfig(direction=0, attrid=0x0000, datatype=16, min_interval=0, max_interval=900, reportable_change=1)]) [0x745b] Extending timeout for 0x1b request Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=0, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=0, source_route=None, extended_timeout=False, tsn=None, profile_id=0, cluster_id=32801, data=Serialized[b'\x17\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-43) [0x745B:6:0x0006]: bound 'on_off' cluster: Status.SUCCESS [0x745B:6:0x0006]: finished channel configuration Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=1, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=1, data=Serialized[b'\x18\x19\x07\x8c\x00 \x00\x8c\x00!\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-44) [0x745B:1:0x0001] Received ZCL frame: b'\x18\x19\x07\x8c\x00 \x00\x8c\x00!\x00' [0x745B:1:0x0001] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=25, command_id=7, *direction=, *is_reply=True) [0x745B:1:0x0001] Decoded ZCL frame: PowerConfiguration:Configure_Reporting_rsp(status_records=[ConfigureReportingResponseRecord(status=, direction=, attrid=32), ConfigureReportingResponseRecord(status=, direction=, attrid=33)]) [0x745B:1:0x0001]: Successfully configured reporting for 'set()' on 'power' cluster [0x745B:1:0x0001]: Failed to configure reporting for '['battery_voltage', 'battery_percentage_remaining']' on 'power' cluster: [ConfigureReportingResponseRecord(status=, direction=, attrid=32), ConfigureReportingResponseRecord(status=, direction=, attrid=33)] [0x745B:1:0x0001]: finished channel configuration [0x745B:1:0x0000]: 'async_configure' stage succeeded [0x745B:1:0x0001]: 'async_configure' stage succeeded Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=6, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=6, data=Serialized[b'\x18\x1b\x07\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-44) [0x745B:6:0x0006] Received ZCL frame: b'\x18\x1b\x07\x00' [0x745B:6:0x0006] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=27, command_id=7, *direction=, *is_reply=True) [0x745B:6:0x0006] Decoded ZCL frame: OnOff:Configure_Reporting_rsp(status_records=[ConfigureReportingResponseRecord(status=)]) [0x745B:6:0x0006]: Successfully configured reporting for '{'on_off': (0, 900, 1)}' on 'on_off' cluster: [ConfigureReportingResponseRecord(status=)] [0x745B:6:0x0006]: finished channel configuration [0x745B:6:0x0006]: 'async_configure' stage succeeded [0x745B:6:0x0006]: 'async_configure' stage succeeded [0x745B](ptvo_counter_2ch): completed configuration [0x745B](ptvo_counter_2ch): started initialization [0x745B:ZDO](ptvo_counter_2ch): 'async_initialize' stage succeeded [0x745B:1:0x0000]: initializing channel: from_cache: False [0x745B:1:0x0000]: finished channel initialization [0x745B:1:0x0001]: initializing channel: from_cache: False [0x745B:1:0x0001]: initializing uncached channel attributes: ['battery_voltage', 'battery_percentage_remaining'] - from cache[False] [0x745B:1:0x0001]: Reading attributes in chunks: ['battery_voltage', 'battery_percentage_remaining'] [0x745B:1:0x0001] Sending request header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=False, direction=, disable_default_response=0, reserved=0, *is_cluster=False, *is_general=True, *is_reply=False), tsn=29, command_id=, *direction=, *is_reply=False) [0x745B:1:0x0001] Sending request: Read_Attributes(attribute_ids=[32, 33]) [0x745b] Extending timeout for 0x1d request [0x745B:6:0x0006]: initializing channel: from_cache: False [0x745B:6:0x0006]: initializing cached channel attributes: ['start_up_on_off'] [0x745B:6:0x0006]: Reading attributes in chunks: ['start_up_on_off'] [0x745B:6:0x0006] Sending request header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=False, direction=, disable_default_response=0, reserved=0, *is_cluster=False, *is_general=True, *is_reply=False), tsn=31, command_id=, *direction=, *is_reply=False) [0x745B:6:0x0006] Sending request: Read_Attributes(attribute_ids=[16387]) [0x745b] Extending timeout for 0x1f request [0x745B:6:0x0006]: initializing channel: from_cache: False [0x745B:6:0x0006]: finished channel initialization Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=1, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=1, data=Serialized[b'\x18\x1d\x01 \x00\x00 \xff!\x00\x00 \xff'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-44) [0x745B:1:0x0001] Received ZCL frame: b'\x18\x1d\x01 \x00\x00 \xff!\x00\x00 \xff' [0x745B:1:0x0001] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=29, command_id=1, *direction=, *is_reply=True) [0x745B:1:0x0001] Decoded ZCL frame: PowerConfiguration:Read_Attributes_rsp(status_records=[ReadAttributeRecord(attrid=0x0020, status=, value=TypeValue(type=uint8_t, value=255)), ReadAttributeRecord(attrid=0x0021, status=, value=TypeValue(type=uint8_t, value=255))]) [0x745B:1:0x0001]: Performing channel specific initialization: ['battery_voltage', 'battery_percentage_remaining'] [0x745B:1:0x0001]: Reading attributes in chunks: ['battery_size', 'battery_quantity'] [0x745B:1:0x0001] Sending request header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=False, direction=, disable_default_response=0, reserved=0, *is_cluster=False, *is_general=True, *is_reply=False), tsn=33, command_id=, *direction=, *is_reply=False) [0x745B:1:0x0001] Sending request: Read_Attributes(attribute_ids=[49, 51]) [0x745b] Extending timeout for 0x21 request Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=6, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=6, data=Serialized[b'\x18\x1f\x01\x03@\x86'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-44) [0x745B:6:0x0006] Received ZCL frame: b'\x18\x1f\x01\x03@\x86' [0x745B:6:0x0006] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=31, command_id=1, *direction=, *is_reply=True) [0x745B:6:0x0006] Decoded ZCL frame: OnOff:Read_Attributes_rsp(status_records=[ReadAttributeRecord(attrid=0x4003, status=)]) [0x745B:6:0x0006]: initializing uncached channel attributes: ['on_off'] - from cache[False] [0x745B:6:0x0006]: Reading attributes in chunks: ['on_off'] [0x745B:6:0x0006] Sending request header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=False, direction=, disable_default_response=0, reserved=0, *is_cluster=False, *is_general=True, *is_reply=False), tsn=35, command_id=, *direction=, *is_reply=False) [0x745B:6:0x0006] Sending request: Read_Attributes(attribute_ids=[0]) [0x745b] Extending timeout for 0x23 request Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=1, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=1, data=Serialized[b'\x18!\x011\x00\x863\x00\x86'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-44) [0x745B:1:0x0001] Received ZCL frame: b'\x18!\x011\x00\x863\x00\x86' [0x745B:1:0x0001] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=33, command_id=1, *direction=, *is_reply=True) [0x745B:1:0x0001] Decoded ZCL frame: PowerConfiguration:Read_Attributes_rsp(status_records=[ReadAttributeRecord(attrid=0x0031, status=), ReadAttributeRecord(attrid=0x0033, status=)]) [0x745B:1:0x0001]: finished channel initialization [0x745B:1:0x0000]: 'async_initialize' stage succeeded [0x745B:1:0x0001]: 'async_initialize' stage succeeded [0xE4C5](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xE4C5](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=6, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=6, data=Serialized[b'\x18#\x01\x00\x00\x00\x10\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-44) [0x745B:6:0x0006] Received ZCL frame: b'\x18#\x01\x00\x00\x00\x10\x00' [0x745B:6:0x0006] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=35, command_id=1, *direction=, *is_reply=True) [0x745B:6:0x0006] Decoded ZCL frame: OnOff:Read_Attributes_rsp(status_records=[ReadAttributeRecord(attrid=0x0000, status=, value=TypeValue(type=Bool, value=))]) [0x745B:6:0x0006]: finished channel initialization [0x745B:6:0x0006]: 'async_initialize' stage succeeded [0x745B:6:0x0006]: 'async_initialize' stage succeeded [0x745B](ptvo_counter_2ch): power source: Battery or Unknown [0x745B](ptvo_counter_2ch): completed initialization start_up_on_off is not supported - skipping ZHAStartupOnOffSelectEntity entity creation [0xC85C](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xC85C](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False [0xFD20](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xFD20](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False [0xE4C5](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xE4C5](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False [0xA547](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xA547](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False [0xC85C](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xC85C](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=1, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=1, data=Serialized[b'\x18\x00\n!\x00 \xc8 \x00 '], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-46) [0x745B:1:0x0001] Received ZCL frame: b'\x18\x00\n!\x00 \xc8 \x00 ' [0x745B:1:0x0001] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=0, command_id=10, *direction=, *is_reply=True) [0x745B:1:0x0001] Decoded ZCL frame: PowerConfiguration:Report_Attributes(attribute_reports=[Attribute(attrid=0x0021, value=TypeValue(type=uint8_t, value=200)), Attribute(attrid=0x0020, value=TypeValue(type=uint8_t, value=32))]) [0x745B:1:0x0001] Received command 0x0A (TSN 0): Report_Attributes(attribute_reports=[Attribute(attrid=0x0021, value=TypeValue(type=uint8_t, value=200)), Attribute(attrid=0x0020, value=TypeValue(type=uint8_t, value=32))]) [0x745B:1:0x0001] Attribute report received: battery_percentage_remaining=200, battery_voltage=32 Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=6, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=6, data=Serialized[b'\x18\x01\n\x00\x00\x10\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-46) [0x745B:6:0x0006] Received ZCL frame: b'\x18\x01\n\x00\x00\x10\x00' [0x745B:6:0x0006] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=1, command_id=10, *direction=, *is_reply=True) [0x745B:6:0x0006] Decoded ZCL frame: OnOff:Report_Attributes(attribute_reports=[Attribute(attrid=0x0000, value=TypeValue(type=Bool, value=))]) [0x745B:6:0x0006] Received command 0x0A (TSN 1): Report_Attributes(attribute_reports=[Attribute(attrid=0x0000, value=TypeValue(type=Bool, value=))]) [0x745B:6:0x0006] Attribute report received: on_off= Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=3, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=12, data=Serialized[b'\x18\x02\nU\x009\x00\x00\xb8Ao\x00\x18\x00\x1c\x00B\x03,0A'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-46) [0x745B:3:0x000c] Received ZCL frame: b'\x18\x02\nU\x009\x00\x00\xb8Ao\x00\x18\x00\x1c\x00B\x03,0A' [0x745B:3:0x000c] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=2, command_id=10, *direction=, *is_reply=True) [0x745B:3:0x000c] Decoded ZCL frame: AnalogInput:Report_Attributes(attribute_reports=[Attribute(attrid=0x0055, value=TypeValue(type=Single, value=23.0)), Attribute(attrid=0x006F, value=TypeValue(type=bitmap8, value=)), Attribute(attrid=0x001C, value=TypeValue(type=CharacterString, value=',0A'))]) [0x745B:3:0x000c] Received command 0x0A (TSN 2): Report_Attributes(attribute_reports=[Attribute(attrid=0x0055, value=TypeValue(type=Single, value=23.0)), Attribute(attrid=0x006F, value=TypeValue(type=bitmap8, value=)), Attribute(attrid=0x001C, value=TypeValue(type=CharacterString, value=',0A'))]) [0x745B:3:0x000c] Attribute report received: present_value=23.0, status_flags=, description=',0A' Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=5, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=12, data=Serialized[b'\x18\x03\nU\x009\x00\x00pAo\x00\x18\x00\x1c\x00B\x03,0A'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-46) [0x745B:5:0x000c] Received ZCL frame: b'\x18\x03\nU\x009\x00\x00pAo\x00\x18\x00\x1c\x00B\x03,0A' [0x745B:5:0x000c] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=3, command_id=10, *direction=, *is_reply=True) [0x745B:5:0x000c] Decoded ZCL frame: AnalogInput:Report_Attributes(attribute_reports=[Attribute(attrid=0x0055, value=TypeValue(type=Single, value=15.0)), Attribute(attrid=0x006F, value=TypeValue(type=bitmap8, value=)), Attribute(attrid=0x001C, value=TypeValue(type=CharacterString, value=',0A'))]) [0x745B:5:0x000c] Received command 0x0A (TSN 3): Report_Attributes(attribute_reports=[Attribute(attrid=0x0055, value=TypeValue(type=Single, value=15.0)), Attribute(attrid=0x006F, value=TypeValue(type=bitmap8, value=)), Attribute(attrid=0x001C, value=TypeValue(type=CharacterString, value=',0A'))]) [0x745B:5:0x000c] Attribute report received: present_value=15.0, status_flags=, description=',0A' [0x15CE](lumi.sensor_wleak.aq1): Device seen - marking the device available and resetting counter [0x15CE](lumi.sensor_wleak.aq1): Update device availability - device available: True - new availability: True - changed: False [0xFD20](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xFD20](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False [0x15CE](lumi.sensor_wleak.aq1): Device seen - marking the device available and resetting counter [0x15CE](lumi.sensor_wleak.aq1): Update device availability - device available: True - new availability: True - changed: False [0x745B](ptvo_counter_2ch): Device seen - marking the device available and resetting counter [0x745B](ptvo_counter_2ch): Update device availability - device available: True - new availability: True - changed: False [0xE4C5](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xE4C5](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False [0xA547](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xA547](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=6, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=6, data=Serialized[b'\x18\x04\n\x00\x00\x10\x01'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-53) [0x745B:6:0x0006] Received ZCL frame: b'\x18\x04\n\x00\x00\x10\x01' [0x745B:6:0x0006] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=4, command_id=10, *direction=, *is_reply=True) [0x745B:6:0x0006] Decoded ZCL frame: OnOff:Report_Attributes(attribute_reports=[Attribute(attrid=0x0000, value=TypeValue(type=Bool, value=))]) [0x745B:6:0x0006] Received command 0x0A (TSN 4): Report_Attributes(attribute_reports=[Attribute(attrid=0x0000, value=TypeValue(type=Bool, value=))]) [0x745B:6:0x0006] Attribute report received: on_off= Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=1, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=1, data=Serialized[b'\x18\x05\n!\x00 \xc8 \x00 \x1f'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-54) [0x745B:1:0x0001] Received ZCL frame: b'\x18\x05\n!\x00 \xc8 \x00 \x1f' [0x745B:1:0x0001] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=5, command_id=10, *direction=, *is_reply=True) [0x745B:1:0x0001] Decoded ZCL frame: PowerConfiguration:Report_Attributes(attribute_reports=[Attribute(attrid=0x0021, value=TypeValue(type=uint8_t, value=200)), Attribute(attrid=0x0020, value=TypeValue(type=uint8_t, value=31))]) [0x745B:1:0x0001] Received command 0x0A (TSN 5): Report_Attributes(attribute_reports=[Attribute(attrid=0x0021, value=TypeValue(type=uint8_t, value=200)), Attribute(attrid=0x0020, value=TypeValue(type=uint8_t, value=31))]) [0x745B:1:0x0001] Attribute report received: battery_percentage_remaining=200, battery_voltage=31 Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=1, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=1, data=Serialized[b'\x18\x06\n!\x00 \xc8 \x00 \x1f'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-54) [0x745B:1:0x0001] Received ZCL frame: b'\x18\x06\n!\x00 \xc8 \x00 \x1f' [0x745B:1:0x0001] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=6, command_id=10, *direction=, *is_reply=True) [0x745B:1:0x0001] Decoded ZCL frame: PowerConfiguration:Report_Attributes(attribute_reports=[Attribute(attrid=0x0021, value=TypeValue(type=uint8_t, value=200)), Attribute(attrid=0x0020, value=TypeValue(type=uint8_t, value=31))]) [0x745B:1:0x0001] Received command 0x0A (TSN 6): Report_Attributes(attribute_reports=[Attribute(attrid=0x0021, value=TypeValue(type=uint8_t, value=200)), Attribute(attrid=0x0020, value=TypeValue(type=uint8_t, value=31))]) [0x745B:1:0x0001] Attribute report received: battery_percentage_remaining=200, battery_voltage=31 Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=6, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=6, data=Serialized[b'\x18\x07\n\x00\x00\x10\x01'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-55) [0x745B:6:0x0006] Received ZCL frame: b'\x18\x07\n\x00\x00\x10\x01' [0x745B:6:0x0006] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=7, command_id=10, *direction=, *is_reply=True) [0x745B:6:0x0006] Decoded ZCL frame: OnOff:Report_Attributes(attribute_reports=[Attribute(attrid=0x0000, value=TypeValue(type=Bool, value=))]) [0x745B:6:0x0006] Received command 0x0A (TSN 7): Report_Attributes(attribute_reports=[Attribute(attrid=0x0000, value=TypeValue(type=Bool, value=))]) [0x745B:6:0x0006] Attribute report received: on_off= Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=3, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=12, data=Serialized[b'\x18\x08\nU\x009\x00\x00\xb8Ao\x00\x18\x00\x1c\x00B\x03,0A'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-55) [0x745B:3:0x000c] Received ZCL frame: b'\x18\x08\nU\x009\x00\x00\xb8Ao\x00\x18\x00\x1c\x00B\x03,0A' [0x745B:3:0x000c] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=8, command_id=10, *direction=, *is_reply=True) [0x745B:3:0x000c] Decoded ZCL frame: AnalogInput:Report_Attributes(attribute_reports=[Attribute(attrid=0x0055, value=TypeValue(type=Single, value=23.0)), Attribute(attrid=0x006F, value=TypeValue(type=bitmap8, value=)), Attribute(attrid=0x001C, value=TypeValue(type=CharacterString, value=',0A'))]) [0x745B:3:0x000c] Received command 0x0A (TSN 8): Report_Attributes(attribute_reports=[Attribute(attrid=0x0055, value=TypeValue(type=Single, value=23.0)), Attribute(attrid=0x006F, value=TypeValue(type=bitmap8, value=)), Attribute(attrid=0x001C, value=TypeValue(type=CharacterString, value=',0A'))]) [0x745B:3:0x000c] Attribute report received: present_value=23.0, status_flags=, description=',0A' [0xE4C5](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xE4C5](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=5, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=12, data=Serialized[b'\x18\t\nU\x009\x00\x00pAo\x00\x18\x00\x1c\x00B\x03,0A'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-54) [0x745B:5:0x000c] Received ZCL frame: b'\x18\t\nU\x009\x00\x00pAo\x00\x18\x00\x1c\x00B\x03,0A' [0x745B:5:0x000c] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=9, command_id=10, *direction=, *is_reply=True) [0x745B:5:0x000c] Decoded ZCL frame: AnalogInput:Report_Attributes(attribute_reports=[Attribute(attrid=0x0055, value=TypeValue(type=Single, value=15.0)), Attribute(attrid=0x006F, value=TypeValue(type=bitmap8, value=)), Attribute(attrid=0x001C, value=TypeValue(type=CharacterString, value=',0A'))]) [0x745B:5:0x000c] Received command 0x0A (TSN 9): Report_Attributes(attribute_reports=[Attribute(attrid=0x0055, value=TypeValue(type=Single, value=15.0)), Attribute(attrid=0x006F, value=TypeValue(type=bitmap8, value=)), Attribute(attrid=0x001C, value=TypeValue(type=CharacterString, value=',0A'))]) [0x745B:5:0x000c] Attribute report received: present_value=15.0, status_flags=, description=',0A' [0xC85C](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xC85C](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False Received a packet: ZigbeePacket(src=AddrModeAddress(addr_mode=, address=0x745B), src_ep=6, dst=AddrModeAddress(addr_mode=, address=0x0000), dst_ep=1, source_route=None, extended_timeout=False, tsn=None, profile_id=260, cluster_id=6, data=Serialized[b'\x18\n\n\x00\x00\x10\x00'], tx_options=, radius=0, non_member_radius=0, lqi=255, rssi=-55) [0x745B:6:0x0006] Received ZCL frame: b'\x18\n\n\x00\x00\x10\x00' [0x745B:6:0x0006] Decoded ZCL frame header: ZCLHeader(frame_control=FrameControl(frame_type=, is_manufacturer_specific=0, direction=, disable_default_response=1, reserved=0, *is_cluster=False, *is_general=True, *is_reply=True), tsn=10, command_id=10, *direction=, *is_reply=True) [0x745B:6:0x0006] Decoded ZCL frame: OnOff:Report_Attributes(attribute_reports=[Attribute(attrid=0x0000, value=TypeValue(type=Bool, value=))]) [0x745B:6:0x0006] Received command 0x0A (TSN 10): Report_Attributes(attribute_reports=[Attribute(attrid=0x0000, value=TypeValue(type=Bool, value=))]) [0x745B:6:0x0006] Attribute report received: on_off= [0xFD20](lumi.remote.b486opcn01): Device seen - marking the device available and resetting counter [0xFD20](lumi.remote.b486opcn01): Update device availability - device available: True - new availability: True - changed: False ```

[Additional context Add any other context or screenshots about the feature request here. Original post https://modkam.ru/2021/04/29/schetchik-impulsov-zigbee/?fbclid=IwAR0WIscexuTcIHgT7jxiSWtjLfeWT2RZ9_4AU9m14UmLeTme0i5xh8A6Y3o

MattWestb commented 1 year ago

Then ptvo have making the firmware the easy way and not making it Zigbee compatible is ZHA only showing the cluster that is OK by Zigbee standard. If ptvo or some other user is making one quirk for correcting it shall the device working OK until that you can only using the standard function from the device.

WiktorBuczko commented 1 year ago

Does it mean I have to flash the module with other firmware from ptvo? How it should be done in order to get the pulse counter to be recognized by ZHA?

WiktorBuczko commented 1 year ago

I have also found external converter file for zigbee2mqtt, maybe that will help.

Code ptvo_counter_2ch.js ```js const zigbeeHerdsmanConverters = require('zigbee-herdsman-converters'); const exposes = zigbeeHerdsmanConverters.exposes; const ea = exposes.access; const e = exposes.presets; const fz = zigbeeHerdsmanConverters.fromZigbeeConverters; const tz = zigbeeHerdsmanConverters.toZigbeeConverters; const ptvo_switch = zigbeeHerdsmanConverters.findByDevice({ modelID: 'ptvo.switch' }); fz.legacy = ptvo_switch.meta.tuyaThermostatPreset; tz.ptvo_config_scale_factor = { options: [exposes.numeric(`scale_factor3`, ea.SET).withValueMin(0).withDescription('Scale factor for counter 1'), exposes.numeric(`scale_factor5`, ea.SET).withValueMin(0).withDescription('Scale factor for counter 2'), ], }; fz.ptvo_switch_analog_input_scaled = { cluster: 'genAnalogInput', type: ['attributeReport', 'readResponse'], convert: (model, msg, publish, options, meta) => { const channel = msg.endpoint.ID; const scaleName = `scale_factor${channel}`; if (options && options.hasOwnProperty(scaleName)) { const scaleFactor = parseFloat(options[scaleName]); if (scaleFactor != 0) { msg.data['presentValue'] *= scaleFactor; } } const payload = fz.ptvo_switch_analog_input.convert(model, msg, publish, options, meta); return payload; }, }; const device = { zigbeeModel: ['ptvo_counter_2ch'], model: 'ptvo_counter_2ch', vendor: 'Custom devices (DiY)', description: '[Configurable firmware](https://ptvo.info/zigbee-configurable-firmware-features/)', fromZigbee: [fz.ignore_basic_report, fz.battery, fz.ptvo_switch_analog_input_scaled, fz.on_off], toZigbee: [tz.ptvo_switch_trigger, tz.ptvo_switch_analog_input, tz.on_off, tz.ptvo_config_scale_factor], exposes: [e.battery(), exposes.numeric('l3', ea.STATE_SET).withValueMax(999999999).withDescription('Counter 1 value. Write zero or positive value to set a counter value. Write a negative value to set a wakeup interval in minutes'), exposes.numeric('l5', ea.STATE_SET).withValueMax(999999999).withDescription('Counter 2 value. Write zero or positive value to set a counter value. Write a negative value to set a wakeup interval in minutes'), e.switch().withEndpoint('l6'), e.battery_voltage(), e.linkquality(), ], meta: { multiEndpoint: true, }, endpoint: (device) => { return { l3: 3, l5: 5, l6: 6, }; }, icon: '', }; module.exports = device; ```
github-actions[bot] commented 1 year ago

There hasn't been any activity on this issue recently. Due to the high number of incoming GitHub notifications, we have to clean some of the old issues, as many of them have already been resolved with the latest updates. Please make sure to update to the latest version and check if that solves the issue. Let us know if that works for you by adding a comment 👍 This issue has now been marked as stale and will be closed if no further activity occurs. Thank you for your contributions.