@willieee802/zigbee-herdsman 0.49.0 → 0.49.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.release-please-manifest.json +1 -1
- package/CHANGELOG.md +38 -0
- package/biome.json +1 -1
- package/dist/adapter/adapter.d.ts +66 -0
- package/dist/adapter/adapter.d.ts.map +1 -0
- package/dist/adapter/adapter.js +110 -0
- package/dist/adapter/adapter.js.map +1 -0
- package/dist/adapter/adapterDiscovery.d.ts +34 -0
- package/dist/adapter/adapterDiscovery.d.ts.map +1 -0
- package/dist/adapter/adapterDiscovery.js +646 -0
- package/dist/adapter/adapterDiscovery.js.map +1 -0
- package/dist/adapter/const.d.ts +9 -0
- package/dist/adapter/const.d.ts.map +1 -0
- package/dist/adapter/const.js +48 -0
- package/dist/adapter/const.js.map +1 -0
- package/dist/adapter/deconz/adapter/deconzAdapter.d.ts +61 -0
- package/dist/adapter/deconz/adapter/deconzAdapter.d.ts.map +1 -0
- package/dist/adapter/deconz/adapter/deconzAdapter.js +719 -0
- package/dist/adapter/deconz/adapter/deconzAdapter.js.map +1 -0
- package/dist/adapter/deconz/driver/constants.d.ts +210 -0
- package/dist/adapter/deconz/driver/constants.d.ts.map +1 -0
- package/dist/adapter/deconz/driver/constants.js +139 -0
- package/dist/adapter/deconz/driver/constants.js.map +1 -0
- package/dist/adapter/deconz/driver/driver.d.ts +111 -0
- package/dist/adapter/deconz/driver/driver.d.ts.map +1 -0
- package/dist/adapter/deconz/driver/driver.js +1362 -0
- package/dist/adapter/deconz/driver/driver.js.map +1 -0
- package/dist/adapter/deconz/driver/frame.d.ts +6 -0
- package/dist/adapter/deconz/driver/frame.d.ts.map +1 -0
- package/dist/adapter/deconz/driver/frame.js +13 -0
- package/dist/adapter/deconz/driver/frame.js.map +1 -0
- package/dist/adapter/deconz/driver/frameParser.d.ts +5 -0
- package/dist/adapter/deconz/driver/frameParser.d.ts.map +1 -0
- package/dist/adapter/deconz/driver/frameParser.js +700 -0
- package/dist/adapter/deconz/driver/frameParser.js.map +1 -0
- package/dist/adapter/deconz/driver/parser.d.ts +10 -0
- package/dist/adapter/deconz/driver/parser.d.ts.map +1 -0
- package/dist/adapter/deconz/driver/parser.js +39 -0
- package/dist/adapter/deconz/driver/parser.js.map +1 -0
- package/dist/adapter/deconz/driver/writer.d.ts +8 -0
- package/dist/adapter/deconz/driver/writer.d.ts.map +1 -0
- package/dist/adapter/deconz/driver/writer.js +53 -0
- package/dist/adapter/deconz/driver/writer.js.map +1 -0
- package/dist/adapter/ember/adapter/emberAdapter.d.ts +338 -0
- package/dist/adapter/ember/adapter/emberAdapter.d.ts.map +1 -0
- package/dist/adapter/ember/adapter/emberAdapter.js +1663 -0
- package/dist/adapter/ember/adapter/emberAdapter.js.map +1 -0
- package/dist/adapter/ember/adapter/endpoints.d.ts +27 -0
- package/dist/adapter/ember/adapter/endpoints.d.ts.map +1 -0
- package/dist/adapter/ember/adapter/endpoints.js +69 -0
- package/dist/adapter/ember/adapter/endpoints.js.map +1 -0
- package/dist/adapter/ember/adapter/oneWaitress.d.ts +112 -0
- package/dist/adapter/ember/adapter/oneWaitress.d.ts.map +1 -0
- package/dist/adapter/ember/adapter/oneWaitress.js +233 -0
- package/dist/adapter/ember/adapter/oneWaitress.js.map +1 -0
- package/dist/adapter/ember/adapter/tokensManager.d.ts +69 -0
- package/dist/adapter/ember/adapter/tokensManager.d.ts.map +1 -0
- package/dist/adapter/ember/adapter/tokensManager.js +684 -0
- package/dist/adapter/ember/adapter/tokensManager.js.map +1 -0
- package/dist/adapter/ember/consts.d.ts +107 -0
- package/dist/adapter/ember/consts.d.ts.map +1 -0
- package/dist/adapter/ember/consts.js +155 -0
- package/dist/adapter/ember/consts.js.map +1 -0
- package/dist/adapter/ember/enums.d.ts +1568 -0
- package/dist/adapter/ember/enums.d.ts.map +1 -0
- package/dist/adapter/ember/enums.js +1697 -0
- package/dist/adapter/ember/enums.js.map +1 -0
- package/dist/adapter/ember/ezsp/buffalo.d.ts +166 -0
- package/dist/adapter/ember/ezsp/buffalo.d.ts.map +1 -0
- package/dist/adapter/ember/ezsp/buffalo.js +1133 -0
- package/dist/adapter/ember/ezsp/buffalo.js.map +1 -0
- package/dist/adapter/ember/ezsp/consts.d.ts +117 -0
- package/dist/adapter/ember/ezsp/consts.d.ts.map +1 -0
- package/dist/adapter/ember/ezsp/consts.js +129 -0
- package/dist/adapter/ember/ezsp/consts.js.map +1 -0
- package/dist/adapter/ember/ezsp/enums.d.ts +1016 -0
- package/dist/adapter/ember/ezsp/enums.d.ts.map +1 -0
- package/dist/adapter/ember/ezsp/enums.js +1103 -0
- package/dist/adapter/ember/ezsp/enums.js.map +1 -0
- package/dist/adapter/ember/ezsp/ezsp.d.ts +2951 -0
- package/dist/adapter/ember/ezsp/ezsp.d.ts.map +1 -0
- package/dist/adapter/ember/ezsp/ezsp.js +7119 -0
- package/dist/adapter/ember/ezsp/ezsp.js.map +1 -0
- package/dist/adapter/ember/ezspError.d.ts +6 -0
- package/dist/adapter/ember/ezspError.d.ts.map +1 -0
- package/dist/adapter/ember/ezspError.js +13 -0
- package/dist/adapter/ember/ezspError.js.map +1 -0
- package/dist/adapter/ember/types.d.ts +787 -0
- package/dist/adapter/ember/types.d.ts.map +1 -0
- package/dist/adapter/ember/types.js +3 -0
- package/dist/adapter/ember/types.js.map +1 -0
- package/dist/adapter/ember/uart/ash.d.ts +434 -0
- package/dist/adapter/ember/uart/ash.d.ts.map +1 -0
- package/dist/adapter/ember/uart/ash.js +1561 -0
- package/dist/adapter/ember/uart/ash.js.map +1 -0
- package/dist/adapter/ember/uart/consts.d.ts +91 -0
- package/dist/adapter/ember/uart/consts.d.ts.map +1 -0
- package/dist/adapter/ember/uart/consts.js +100 -0
- package/dist/adapter/ember/uart/consts.js.map +1 -0
- package/dist/adapter/ember/uart/enums.d.ts +191 -0
- package/dist/adapter/ember/uart/enums.d.ts.map +1 -0
- package/dist/adapter/ember/uart/enums.js +156 -0
- package/dist/adapter/ember/uart/enums.js.map +1 -0
- package/dist/adapter/ember/uart/parser.d.ts +7 -0
- package/dist/adapter/ember/uart/parser.d.ts.map +1 -0
- package/dist/adapter/ember/uart/parser.js +32 -0
- package/dist/adapter/ember/uart/parser.js.map +1 -0
- package/dist/adapter/ember/uart/queues.d.ts +84 -0
- package/dist/adapter/ember/uart/queues.d.ts.map +1 -0
- package/dist/adapter/ember/uart/queues.js +213 -0
- package/dist/adapter/ember/uart/queues.js.map +1 -0
- package/dist/adapter/ember/uart/writer.d.ts +13 -0
- package/dist/adapter/ember/uart/writer.d.ts.map +1 -0
- package/dist/adapter/ember/uart/writer.js +42 -0
- package/dist/adapter/ember/uart/writer.js.map +1 -0
- package/dist/adapter/ember/utils/initters.d.ts +20 -0
- package/dist/adapter/ember/utils/initters.d.ts.map +1 -0
- package/dist/adapter/ember/utils/initters.js +92 -0
- package/dist/adapter/ember/utils/initters.js.map +1 -0
- package/dist/adapter/ember/utils/math.d.ts +41 -0
- package/dist/adapter/ember/utils/math.d.ts.map +1 -0
- package/dist/adapter/ember/utils/math.js +80 -0
- package/dist/adapter/ember/utils/math.js.map +1 -0
- package/dist/adapter/events.d.ts +24 -0
- package/dist/adapter/events.d.ts.map +1 -0
- package/dist/adapter/events.js +3 -0
- package/dist/adapter/events.js.map +1 -0
- package/dist/adapter/ezsp/adapter/backup.d.ts +13 -0
- package/dist/adapter/ezsp/adapter/backup.d.ts.map +1 -0
- package/dist/adapter/ezsp/adapter/backup.js +89 -0
- package/dist/adapter/ezsp/adapter/backup.js.map +1 -0
- package/dist/adapter/ezsp/adapter/ezspAdapter.d.ts +53 -0
- package/dist/adapter/ezsp/adapter/ezspAdapter.d.ts.map +1 -0
- package/dist/adapter/ezsp/adapter/ezspAdapter.js +464 -0
- package/dist/adapter/ezsp/adapter/ezspAdapter.js.map +1 -0
- package/dist/adapter/ezsp/driver/commands.d.ts +37 -0
- package/dist/adapter/ezsp/driver/commands.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/commands.js +2387 -0
- package/dist/adapter/ezsp/driver/commands.js.map +1 -0
- package/dist/adapter/ezsp/driver/consts.d.ts +11 -0
- package/dist/adapter/ezsp/driver/consts.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/consts.js +14 -0
- package/dist/adapter/ezsp/driver/consts.js.map +1 -0
- package/dist/adapter/ezsp/driver/driver.d.ts +96 -0
- package/dist/adapter/ezsp/driver/driver.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/driver.js +852 -0
- package/dist/adapter/ezsp/driver/driver.js.map +1 -0
- package/dist/adapter/ezsp/driver/ezsp.d.ts +104 -0
- package/dist/adapter/ezsp/driver/ezsp.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/ezsp.js +678 -0
- package/dist/adapter/ezsp/driver/ezsp.js.map +1 -0
- package/dist/adapter/ezsp/driver/frame.d.ts +39 -0
- package/dist/adapter/ezsp/driver/frame.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/frame.js +101 -0
- package/dist/adapter/ezsp/driver/frame.js.map +1 -0
- package/dist/adapter/ezsp/driver/index.d.ts +4 -0
- package/dist/adapter/ezsp/driver/index.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/index.js +8 -0
- package/dist/adapter/ezsp/driver/index.js.map +1 -0
- package/dist/adapter/ezsp/driver/multicast.d.ts +16 -0
- package/dist/adapter/ezsp/driver/multicast.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/multicast.js +74 -0
- package/dist/adapter/ezsp/driver/multicast.js.map +1 -0
- package/dist/adapter/ezsp/driver/parser.d.ts +9 -0
- package/dist/adapter/ezsp/driver/parser.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/parser.js +109 -0
- package/dist/adapter/ezsp/driver/parser.js.map +1 -0
- package/dist/adapter/ezsp/driver/types/basic.d.ts +62 -0
- package/dist/adapter/ezsp/driver/types/basic.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/types/basic.js +187 -0
- package/dist/adapter/ezsp/driver/types/basic.js.map +1 -0
- package/dist/adapter/ezsp/driver/types/index.d.ts +9 -0
- package/dist/adapter/ezsp/driver/types/index.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/types/index.js +137 -0
- package/dist/adapter/ezsp/driver/types/index.js.map +1 -0
- package/dist/adapter/ezsp/driver/types/named.d.ts +1287 -0
- package/dist/adapter/ezsp/driver/types/named.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/types/named.js +2337 -0
- package/dist/adapter/ezsp/driver/types/named.js.map +1 -0
- package/dist/adapter/ezsp/driver/types/struct.d.ts +270 -0
- package/dist/adapter/ezsp/driver/types/struct.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/types/struct.js +869 -0
- package/dist/adapter/ezsp/driver/types/struct.js.map +1 -0
- package/dist/adapter/ezsp/driver/uart.d.ts +46 -0
- package/dist/adapter/ezsp/driver/uart.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/uart.js +390 -0
- package/dist/adapter/ezsp/driver/uart.js.map +1 -0
- package/dist/adapter/ezsp/driver/utils/crc16ccitt.d.ts +5 -0
- package/dist/adapter/ezsp/driver/utils/crc16ccitt.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/utils/crc16ccitt.js +37 -0
- package/dist/adapter/ezsp/driver/utils/crc16ccitt.js.map +1 -0
- package/dist/adapter/ezsp/driver/utils/index.d.ts +5 -0
- package/dist/adapter/ezsp/driver/utils/index.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/utils/index.js +35 -0
- package/dist/adapter/ezsp/driver/utils/index.js.map +1 -0
- package/dist/adapter/ezsp/driver/writer.d.ts +12 -0
- package/dist/adapter/ezsp/driver/writer.d.ts.map +1 -0
- package/dist/adapter/ezsp/driver/writer.js +92 -0
- package/dist/adapter/ezsp/driver/writer.js.map +1 -0
- package/dist/adapter/index.d.ts +4 -0
- package/dist/adapter/index.d.ts.map +1 -0
- package/dist/adapter/index.js +41 -0
- package/dist/adapter/index.js.map +1 -0
- package/dist/adapter/serialPort.d.ts +19 -0
- package/dist/adapter/serialPort.d.ts.map +1 -0
- package/dist/adapter/serialPort.js +51 -0
- package/dist/adapter/serialPort.js.map +1 -0
- package/dist/adapter/tstype.d.ts +52 -0
- package/dist/adapter/tstype.d.ts.map +1 -0
- package/dist/adapter/tstype.js +3 -0
- package/dist/adapter/tstype.js.map +1 -0
- package/dist/adapter/utils.d.ts +8 -0
- package/dist/adapter/utils.d.ts.map +1 -0
- package/dist/adapter/utils.js +42 -0
- package/dist/adapter/utils.js.map +1 -0
- package/dist/adapter/z-stack/adapter/adapter-backup.d.ts +62 -0
- package/dist/adapter/z-stack/adapter/adapter-backup.d.ts.map +1 -0
- package/dist/adapter/z-stack/adapter/adapter-backup.js +469 -0
- package/dist/adapter/z-stack/adapter/adapter-backup.js.map +1 -0
- package/dist/adapter/z-stack/adapter/adapter-nv-memory.d.ts +150 -0
- package/dist/adapter/z-stack/adapter/adapter-nv-memory.d.ts.map +1 -0
- package/dist/adapter/z-stack/adapter/adapter-nv-memory.js +279 -0
- package/dist/adapter/z-stack/adapter/adapter-nv-memory.js.map +1 -0
- package/dist/adapter/z-stack/adapter/endpoints.d.ts +12 -0
- package/dist/adapter/z-stack/adapter/endpoints.d.ts.map +1 -0
- package/dist/adapter/z-stack/adapter/endpoints.js +87 -0
- package/dist/adapter/z-stack/adapter/endpoints.js.map +1 -0
- package/dist/adapter/z-stack/adapter/manager.d.ts +86 -0
- package/dist/adapter/z-stack/adapter/manager.d.ts.map +1 -0
- package/dist/adapter/z-stack/adapter/manager.js +493 -0
- package/dist/adapter/z-stack/adapter/manager.js.map +1 -0
- package/dist/adapter/z-stack/adapter/tstype.d.ts +7 -0
- package/dist/adapter/z-stack/adapter/tstype.d.ts.map +1 -0
- package/dist/adapter/z-stack/adapter/tstype.js +10 -0
- package/dist/adapter/z-stack/adapter/tstype.js.map +1 -0
- package/dist/adapter/z-stack/adapter/zStackAdapter.d.ts +85 -0
- package/dist/adapter/z-stack/adapter/zStackAdapter.d.ts.map +1 -0
- package/dist/adapter/z-stack/adapter/zStackAdapter.js +924 -0
- package/dist/adapter/z-stack/adapter/zStackAdapter.js.map +1 -0
- package/dist/adapter/z-stack/constants/af.d.ts +24 -0
- package/dist/adapter/z-stack/constants/af.d.ts.map +1 -0
- package/dist/adapter/z-stack/constants/af.js +28 -0
- package/dist/adapter/z-stack/constants/af.js.map +1 -0
- package/dist/adapter/z-stack/constants/common.d.ts +279 -0
- package/dist/adapter/z-stack/constants/common.d.ts.map +1 -0
- package/dist/adapter/z-stack/constants/common.js +290 -0
- package/dist/adapter/z-stack/constants/common.js.map +1 -0
- package/dist/adapter/z-stack/constants/dbg.d.ts +23 -0
- package/dist/adapter/z-stack/constants/dbg.d.ts.map +1 -0
- package/dist/adapter/z-stack/constants/dbg.js +25 -0
- package/dist/adapter/z-stack/constants/dbg.js.map +1 -0
- package/dist/adapter/z-stack/constants/index.d.ts +11 -0
- package/dist/adapter/z-stack/constants/index.d.ts.map +1 -0
- package/dist/adapter/z-stack/constants/index.js +58 -0
- package/dist/adapter/z-stack/constants/index.js.map +1 -0
- package/dist/adapter/z-stack/constants/mac.d.ts +128 -0
- package/dist/adapter/z-stack/constants/mac.d.ts.map +1 -0
- package/dist/adapter/z-stack/constants/mac.js +130 -0
- package/dist/adapter/z-stack/constants/mac.js.map +1 -0
- package/dist/adapter/z-stack/constants/sapi.d.ts +25 -0
- package/dist/adapter/z-stack/constants/sapi.d.ts.map +1 -0
- package/dist/adapter/z-stack/constants/sapi.js +27 -0
- package/dist/adapter/z-stack/constants/sapi.js.map +1 -0
- package/dist/adapter/z-stack/constants/sys.d.ts +72 -0
- package/dist/adapter/z-stack/constants/sys.d.ts.map +1 -0
- package/dist/adapter/z-stack/constants/sys.js +74 -0
- package/dist/adapter/z-stack/constants/sys.js.map +1 -0
- package/dist/adapter/z-stack/constants/util.d.ts +82 -0
- package/dist/adapter/z-stack/constants/util.d.ts.map +1 -0
- package/dist/adapter/z-stack/constants/util.js +84 -0
- package/dist/adapter/z-stack/constants/util.js.map +1 -0
- package/dist/adapter/z-stack/constants/utils.d.ts +5 -0
- package/dist/adapter/z-stack/constants/utils.d.ts.map +1 -0
- package/dist/adapter/z-stack/constants/utils.js +14 -0
- package/dist/adapter/z-stack/constants/utils.js.map +1 -0
- package/dist/adapter/z-stack/constants/zdo.d.ts +103 -0
- package/dist/adapter/z-stack/constants/zdo.d.ts.map +1 -0
- package/dist/adapter/z-stack/constants/zdo.js +105 -0
- package/dist/adapter/z-stack/constants/zdo.js.map +1 -0
- package/dist/adapter/z-stack/models/startup-options.d.ts +13 -0
- package/dist/adapter/z-stack/models/startup-options.d.ts.map +1 -0
- package/dist/adapter/z-stack/models/startup-options.js +3 -0
- package/dist/adapter/z-stack/models/startup-options.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/address-manager-entry.d.ts +23 -0
- package/dist/adapter/z-stack/structs/entries/address-manager-entry.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/address-manager-entry.js +43 -0
- package/dist/adapter/z-stack/structs/entries/address-manager-entry.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/address-manager-table.d.ts +10 -0
- package/dist/adapter/z-stack/structs/entries/address-manager-table.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/address-manager-table.js +24 -0
- package/dist/adapter/z-stack/structs/entries/address-manager-table.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.d.ts +10 -0
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.js +16 -0
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.d.ts +10 -0
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.js +25 -0
- package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.d.ts +10 -0
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.js +23 -0
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.d.ts +10 -0
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.js +25 -0
- package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/channel-list.d.ts +8 -0
- package/dist/adapter/z-stack/structs/entries/channel-list.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/channel-list.js +12 -0
- package/dist/adapter/z-stack/structs/entries/channel-list.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/has-configured.d.ts +8 -0
- package/dist/adapter/z-stack/structs/entries/has-configured.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/has-configured.js +22 -0
- package/dist/adapter/z-stack/structs/entries/has-configured.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/index.d.ts +17 -0
- package/dist/adapter/z-stack/structs/entries/index.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/index.js +33 -0
- package/dist/adapter/z-stack/structs/entries/index.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/nib.d.ts +10 -0
- package/dist/adapter/z-stack/structs/entries/nib.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/nib.js +72 -0
- package/dist/adapter/z-stack/structs/entries/nib.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.d.ts +10 -0
- package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.js +21 -0
- package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/nwk-key.d.ts +8 -0
- package/dist/adapter/z-stack/structs/entries/nwk-key.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/nwk-key.js +19 -0
- package/dist/adapter/z-stack/structs/entries/nwk-key.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/nwk-pan-id.d.ts +8 -0
- package/dist/adapter/z-stack/structs/entries/nwk-pan-id.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/nwk-pan-id.js +12 -0
- package/dist/adapter/z-stack/structs/entries/nwk-pan-id.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.d.ts +13 -0
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.js +22 -0
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.d.ts +10 -0
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.js +24 -0
- package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/security-manager-entry.d.ts +20 -0
- package/dist/adapter/z-stack/structs/entries/security-manager-entry.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/security-manager-entry.js +35 -0
- package/dist/adapter/z-stack/structs/entries/security-manager-entry.js.map +1 -0
- package/dist/adapter/z-stack/structs/entries/security-manager-table.d.ts +10 -0
- package/dist/adapter/z-stack/structs/entries/security-manager-table.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/entries/security-manager-table.js +25 -0
- package/dist/adapter/z-stack/structs/entries/security-manager-table.js.map +1 -0
- package/dist/adapter/z-stack/structs/index.d.ts +5 -0
- package/dist/adapter/z-stack/structs/index.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/index.js +21 -0
- package/dist/adapter/z-stack/structs/index.js.map +1 -0
- package/dist/adapter/z-stack/structs/serializable-memory-object.d.ts +13 -0
- package/dist/adapter/z-stack/structs/serializable-memory-object.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/serializable-memory-object.js +3 -0
- package/dist/adapter/z-stack/structs/serializable-memory-object.js.map +1 -0
- package/dist/adapter/z-stack/structs/struct.d.ts +99 -0
- package/dist/adapter/z-stack/structs/struct.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/struct.js +308 -0
- package/dist/adapter/z-stack/structs/struct.js.map +1 -0
- package/dist/adapter/z-stack/structs/table.d.ts +94 -0
- package/dist/adapter/z-stack/structs/table.d.ts.map +1 -0
- package/dist/adapter/z-stack/structs/table.js +167 -0
- package/dist/adapter/z-stack/structs/table.js.map +1 -0
- package/dist/adapter/z-stack/unpi/constants.d.ts +29 -0
- package/dist/adapter/z-stack/unpi/constants.d.ts.map +1 -0
- package/dist/adapter/z-stack/unpi/constants.js +40 -0
- package/dist/adapter/z-stack/unpi/constants.js.map +1 -0
- package/dist/adapter/z-stack/unpi/frame.d.ts +15 -0
- package/dist/adapter/z-stack/unpi/frame.d.ts.map +1 -0
- package/dist/adapter/z-stack/unpi/frame.js +53 -0
- package/dist/adapter/z-stack/unpi/frame.js.map +1 -0
- package/dist/adapter/z-stack/unpi/index.d.ts +5 -0
- package/dist/adapter/z-stack/unpi/index.d.ts.map +1 -0
- package/dist/adapter/z-stack/unpi/index.js +44 -0
- package/dist/adapter/z-stack/unpi/index.js.map +1 -0
- package/dist/adapter/z-stack/unpi/parser.d.ts +10 -0
- package/dist/adapter/z-stack/unpi/parser.d.ts.map +1 -0
- package/dist/adapter/z-stack/unpi/parser.js +94 -0
- package/dist/adapter/z-stack/unpi/parser.js.map +1 -0
- package/dist/adapter/z-stack/unpi/writer.d.ts +9 -0
- package/dist/adapter/z-stack/unpi/writer.d.ts.map +1 -0
- package/dist/adapter/z-stack/unpi/writer.js +66 -0
- package/dist/adapter/z-stack/unpi/writer.js.map +1 -0
- package/dist/adapter/z-stack/utils/channel-list.d.ts +21 -0
- package/dist/adapter/z-stack/utils/channel-list.d.ts.map +1 -0
- package/dist/adapter/z-stack/utils/channel-list.js +45 -0
- package/dist/adapter/z-stack/utils/channel-list.js.map +1 -0
- package/dist/adapter/z-stack/utils/index.d.ts +3 -0
- package/dist/adapter/z-stack/utils/index.d.ts.map +1 -0
- package/dist/adapter/z-stack/utils/index.js +19 -0
- package/dist/adapter/z-stack/utils/index.js.map +1 -0
- package/dist/adapter/z-stack/utils/network-options.d.ts +9 -0
- package/dist/adapter/z-stack/utils/network-options.d.ts.map +1 -0
- package/dist/adapter/z-stack/utils/network-options.js +22 -0
- package/dist/adapter/z-stack/utils/network-options.js.map +1 -0
- package/dist/adapter/z-stack/znp/buffaloZnp.d.ts +10 -0
- package/dist/adapter/z-stack/znp/buffaloZnp.d.ts.map +1 -0
- package/dist/adapter/z-stack/znp/buffaloZnp.js +162 -0
- package/dist/adapter/z-stack/znp/buffaloZnp.js.map +1 -0
- package/dist/adapter/z-stack/znp/definition.d.ts +18 -0
- package/dist/adapter/z-stack/znp/definition.d.ts.map +1 -0
- package/dist/adapter/z-stack/znp/definition.js +2703 -0
- package/dist/adapter/z-stack/znp/definition.js.map +1 -0
- package/dist/adapter/z-stack/znp/index.d.ts +3 -0
- package/dist/adapter/z-stack/znp/index.d.ts.map +1 -0
- package/dist/adapter/z-stack/znp/index.js +8 -0
- package/dist/adapter/z-stack/znp/index.js.map +1 -0
- package/dist/adapter/z-stack/znp/parameterType.d.ts +19 -0
- package/dist/adapter/z-stack/znp/parameterType.d.ts.map +1 -0
- package/dist/adapter/z-stack/znp/parameterType.js +22 -0
- package/dist/adapter/z-stack/znp/parameterType.js.map +1 -0
- package/dist/adapter/z-stack/znp/tstype.d.ts +40 -0
- package/dist/adapter/z-stack/znp/tstype.d.ts.map +1 -0
- package/dist/adapter/z-stack/znp/tstype.js +3 -0
- package/dist/adapter/z-stack/znp/tstype.js.map +1 -0
- package/dist/adapter/z-stack/znp/utils.d.ts +4 -0
- package/dist/adapter/z-stack/znp/utils.d.ts.map +1 -0
- package/dist/adapter/z-stack/znp/utils.js +12 -0
- package/dist/adapter/z-stack/znp/utils.js.map +1 -0
- package/dist/adapter/z-stack/znp/znp.d.ts +43 -0
- package/dist/adapter/z-stack/znp/znp.d.ts.map +1 -0
- package/dist/adapter/z-stack/znp/znp.js +295 -0
- package/dist/adapter/z-stack/znp/znp.js.map +1 -0
- package/dist/adapter/z-stack/znp/zpiObject.d.ts +19 -0
- package/dist/adapter/z-stack/znp/zpiObject.d.ts.map +1 -0
- package/dist/adapter/z-stack/znp/zpiObject.js +121 -0
- package/dist/adapter/z-stack/znp/zpiObject.js.map +1 -0
- package/dist/adapter/zboss/adapter/zbossAdapter.d.ts +44 -0
- package/dist/adapter/zboss/adapter/zbossAdapter.d.ts.map +1 -0
- package/dist/adapter/zboss/adapter/zbossAdapter.js +365 -0
- package/dist/adapter/zboss/adapter/zbossAdapter.js.map +1 -0
- package/dist/adapter/zboss/commands.d.ts +20 -0
- package/dist/adapter/zboss/commands.d.ts.map +1 -0
- package/dist/adapter/zboss/commands.js +1141 -0
- package/dist/adapter/zboss/commands.js.map +1 -0
- package/dist/adapter/zboss/consts.d.ts +9 -0
- package/dist/adapter/zboss/consts.d.ts.map +1 -0
- package/dist/adapter/zboss/consts.js +12 -0
- package/dist/adapter/zboss/consts.js.map +1 -0
- package/dist/adapter/zboss/driver.d.ts +55 -0
- package/dist/adapter/zboss/driver.d.ts.map +1 -0
- package/dist/adapter/zboss/driver.js +358 -0
- package/dist/adapter/zboss/driver.js.map +1 -0
- package/dist/adapter/zboss/enums.d.ts +301 -0
- package/dist/adapter/zboss/enums.d.ts.map +1 -0
- package/dist/adapter/zboss/enums.js +359 -0
- package/dist/adapter/zboss/enums.js.map +1 -0
- package/dist/adapter/zboss/frame.d.ts +34 -0
- package/dist/adapter/zboss/frame.d.ts.map +1 -0
- package/dist/adapter/zboss/frame.js +200 -0
- package/dist/adapter/zboss/frame.js.map +1 -0
- package/dist/adapter/zboss/reader.d.ts +8 -0
- package/dist/adapter/zboss/reader.d.ts.map +1 -0
- package/dist/adapter/zboss/reader.js +59 -0
- package/dist/adapter/zboss/reader.js.map +1 -0
- package/dist/adapter/zboss/types.d.ts +2 -0
- package/dist/adapter/zboss/types.d.ts.map +1 -0
- package/dist/adapter/zboss/types.js +3 -0
- package/dist/adapter/zboss/types.js.map +1 -0
- package/dist/adapter/zboss/uart.d.ts +38 -0
- package/dist/adapter/zboss/uart.d.ts.map +1 -0
- package/dist/adapter/zboss/uart.js +373 -0
- package/dist/adapter/zboss/uart.js.map +1 -0
- package/dist/adapter/zboss/utils.d.ts +9 -0
- package/dist/adapter/zboss/utils.d.ts.map +1 -0
- package/dist/adapter/zboss/utils.js +56 -0
- package/dist/adapter/zboss/utils.js.map +1 -0
- package/dist/adapter/zboss/writer.d.ts +14 -0
- package/dist/adapter/zboss/writer.d.ts.map +1 -0
- package/dist/adapter/zboss/writer.js +41 -0
- package/dist/adapter/zboss/writer.js.map +1 -0
- package/dist/adapter/zigate/adapter/patchZdoBuffaloBE.d.ts +5 -0
- package/dist/adapter/zigate/adapter/patchZdoBuffaloBE.d.ts.map +1 -0
- package/dist/adapter/zigate/adapter/patchZdoBuffaloBE.js +26 -0
- package/dist/adapter/zigate/adapter/patchZdoBuffaloBE.js.map +1 -0
- package/dist/adapter/zigate/adapter/zigateAdapter.d.ts +63 -0
- package/dist/adapter/zigate/adapter/zigateAdapter.d.ts.map +1 -0
- package/dist/adapter/zigate/adapter/zigateAdapter.js +462 -0
- package/dist/adapter/zigate/adapter/zigateAdapter.js.map +1 -0
- package/dist/adapter/zigate/driver/buffaloZiGate.d.ts +22 -0
- package/dist/adapter/zigate/driver/buffaloZiGate.d.ts.map +1 -0
- package/dist/adapter/zigate/driver/buffaloZiGate.js +198 -0
- package/dist/adapter/zigate/driver/buffaloZiGate.js.map +1 -0
- package/dist/adapter/zigate/driver/commandType.d.ts +42 -0
- package/dist/adapter/zigate/driver/commandType.d.ts.map +1 -0
- package/dist/adapter/zigate/driver/commandType.js +381 -0
- package/dist/adapter/zigate/driver/commandType.js.map +1 -0
- package/dist/adapter/zigate/driver/constants.d.ts +116 -0
- package/dist/adapter/zigate/driver/constants.d.ts.map +1 -0
- package/dist/adapter/zigate/driver/constants.js +147 -0
- package/dist/adapter/zigate/driver/constants.js.map +1 -0
- package/dist/adapter/zigate/driver/frame.d.ts +26 -0
- package/dist/adapter/zigate/driver/frame.d.ts.map +1 -0
- package/dist/adapter/zigate/driver/frame.js +161 -0
- package/dist/adapter/zigate/driver/frame.js.map +1 -0
- package/dist/adapter/zigate/driver/messageType.d.ts +13 -0
- package/dist/adapter/zigate/driver/messageType.d.ts.map +1 -0
- package/dist/adapter/zigate/driver/messageType.js +281 -0
- package/dist/adapter/zigate/driver/messageType.js.map +1 -0
- package/dist/adapter/zigate/driver/parameterType.d.ts +25 -0
- package/dist/adapter/zigate/driver/parameterType.d.ts.map +1 -0
- package/dist/adapter/zigate/driver/parameterType.js +31 -0
- package/dist/adapter/zigate/driver/parameterType.js.map +1 -0
- package/dist/adapter/zigate/driver/ziGateObject.d.ts +23 -0
- package/dist/adapter/zigate/driver/ziGateObject.d.ts.map +1 -0
- package/dist/adapter/zigate/driver/ziGateObject.js +117 -0
- package/dist/adapter/zigate/driver/ziGateObject.js.map +1 -0
- package/dist/adapter/zigate/driver/zigate.d.ts +47 -0
- package/dist/adapter/zigate/driver/zigate.d.ts.map +1 -0
- package/dist/adapter/zigate/driver/zigate.js +364 -0
- package/dist/adapter/zigate/driver/zigate.js.map +1 -0
- package/dist/adapter/zoh/adapter/utils.d.ts +16 -0
- package/dist/adapter/zoh/adapter/utils.d.ts.map +1 -0
- package/dist/adapter/zoh/adapter/utils.js +31 -0
- package/dist/adapter/zoh/adapter/utils.js.map +1 -0
- package/dist/adapter/zoh/adapter/zohAdapter.d.ts +100 -0
- package/dist/adapter/zoh/adapter/zohAdapter.d.ts.map +1 -0
- package/dist/adapter/zoh/adapter/zohAdapter.js +715 -0
- package/dist/adapter/zoh/adapter/zohAdapter.js.map +1 -0
- package/dist/buffalo/buffalo.d.ts +67 -0
- package/dist/buffalo/buffalo.d.ts.map +1 -0
- package/dist/buffalo/buffalo.js +275 -0
- package/dist/buffalo/buffalo.js.map +1 -0
- package/dist/buffalo/index.d.ts +2 -0
- package/dist/buffalo/index.d.ts.map +1 -0
- package/dist/buffalo/index.js +6 -0
- package/dist/buffalo/index.js.map +1 -0
- package/dist/controller/controller.d.ts +155 -0
- package/dist/controller/controller.d.ts.map +1 -0
- package/dist/controller/controller.js +874 -0
- package/dist/controller/controller.js.map +1 -0
- package/dist/controller/database.d.ts +21 -0
- package/dist/controller/database.d.ts.map +1 -0
- package/dist/controller/database.js +128 -0
- package/dist/controller/database.js.map +1 -0
- package/dist/controller/events.d.ts +44 -0
- package/dist/controller/events.d.ts.map +1 -0
- package/dist/controller/events.js +3 -0
- package/dist/controller/events.js.map +1 -0
- package/dist/controller/greenPower.d.ts +78 -0
- package/dist/controller/greenPower.d.ts.map +1 -0
- package/dist/controller/greenPower.js +425 -0
- package/dist/controller/greenPower.js.map +1 -0
- package/dist/controller/helpers/index.d.ts +2 -0
- package/dist/controller/helpers/index.d.ts.map +1 -0
- package/dist/controller/helpers/index.js +38 -0
- package/dist/controller/helpers/index.js.map +1 -0
- package/dist/controller/helpers/installCodes.d.ts +27 -0
- package/dist/controller/helpers/installCodes.d.ts.map +1 -0
- package/dist/controller/helpers/installCodes.js +90 -0
- package/dist/controller/helpers/installCodes.js.map +1 -0
- package/dist/controller/helpers/ota.d.ts +53 -0
- package/dist/controller/helpers/ota.d.ts.map +1 -0
- package/dist/controller/helpers/ota.js +467 -0
- package/dist/controller/helpers/ota.js.map +1 -0
- package/dist/controller/helpers/request.d.ts +22 -0
- package/dist/controller/helpers/request.d.ts.map +1 -0
- package/dist/controller/helpers/request.js +82 -0
- package/dist/controller/helpers/request.js.map +1 -0
- package/dist/controller/helpers/requestQueue.d.ts +13 -0
- package/dist/controller/helpers/requestQueue.d.ts.map +1 -0
- package/dist/controller/helpers/requestQueue.js +109 -0
- package/dist/controller/helpers/requestQueue.js.map +1 -0
- package/dist/controller/helpers/zclFrameConverter.d.ts +7 -0
- package/dist/controller/helpers/zclFrameConverter.d.ts.map +1 -0
- package/dist/controller/helpers/zclFrameConverter.js +84 -0
- package/dist/controller/helpers/zclFrameConverter.js.map +1 -0
- package/dist/controller/helpers/zclTransactionSequenceNumber.d.ts +8 -0
- package/dist/controller/helpers/zclTransactionSequenceNumber.d.ts.map +1 -0
- package/dist/controller/helpers/zclTransactionSequenceNumber.js +14 -0
- package/dist/controller/helpers/zclTransactionSequenceNumber.js.map +1 -0
- package/dist/controller/index.d.ts +6 -0
- package/dist/controller/index.d.ts.map +1 -0
- package/dist/controller/index.js +9 -0
- package/dist/controller/index.js.map +1 -0
- package/dist/controller/model/device.d.ts +150 -0
- package/dist/controller/model/device.d.ts.map +1 -0
- package/dist/controller/model/device.js +1396 -0
- package/dist/controller/model/device.js.map +1 -0
- package/dist/controller/model/endpoint.d.ts +150 -0
- package/dist/controller/model/endpoint.d.ts.map +1 -0
- package/dist/controller/model/endpoint.js +822 -0
- package/dist/controller/model/endpoint.js.map +1 -0
- package/dist/controller/model/entity.d.ts +18 -0
- package/dist/controller/model/entity.d.ts.map +1 -0
- package/dist/controller/model/entity.js +35 -0
- package/dist/controller/model/entity.js.map +1 -0
- package/dist/controller/model/group.d.ts +50 -0
- package/dist/controller/model/group.d.ts.map +1 -0
- package/dist/controller/model/group.js +343 -0
- package/dist/controller/model/group.js.map +1 -0
- package/dist/controller/model/index.d.ts +6 -0
- package/dist/controller/model/index.d.ts.map +1 -0
- package/dist/controller/model/index.js +14 -0
- package/dist/controller/model/index.js.map +1 -0
- package/dist/controller/model/konnextConfig.d.ts +7 -0
- package/dist/controller/model/konnextConfig.d.ts.map +1 -0
- package/dist/controller/model/konnextConfig.js +3 -0
- package/dist/controller/model/konnextConfig.js.map +1 -0
- package/dist/controller/model/zigbeeEntity.d.ts +8 -0
- package/dist/controller/model/zigbeeEntity.d.ts.map +1 -0
- package/dist/controller/model/zigbeeEntity.js +11 -0
- package/dist/controller/model/zigbeeEntity.js.map +1 -0
- package/dist/controller/touchlink.d.ts +20 -0
- package/dist/controller/touchlink.d.ts.map +1 -0
- package/dist/controller/touchlink.js +169 -0
- package/dist/controller/touchlink.js.map +1 -0
- package/dist/controller/tstype.d.ts +152 -0
- package/dist/controller/tstype.d.ts.map +1 -0
- package/dist/controller/tstype.js +3 -0
- package/dist/controller/tstype.js.map +1 -0
- package/dist/index.d.ts +13 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +54 -0
- package/dist/index.js.map +1 -0
- package/dist/models/backup-storage-legacy.d.ts +25 -0
- package/dist/models/backup-storage-legacy.d.ts.map +1 -0
- package/dist/models/backup-storage-legacy.js +3 -0
- package/dist/models/backup-storage-legacy.js.map +1 -0
- package/dist/models/backup-storage-unified.d.ts +50 -0
- package/dist/models/backup-storage-unified.d.ts.map +1 -0
- package/dist/models/backup-storage-unified.js +3 -0
- package/dist/models/backup-storage-unified.js.map +1 -0
- package/dist/models/backup.d.ts +37 -0
- package/dist/models/backup.d.ts.map +1 -0
- package/dist/models/backup.js +3 -0
- package/dist/models/backup.js.map +1 -0
- package/dist/models/index.d.ts +5 -0
- package/dist/models/index.d.ts.map +1 -0
- package/dist/models/index.js +22 -0
- package/dist/models/index.js.map +1 -0
- package/dist/models/network-options.d.ts +12 -0
- package/dist/models/network-options.d.ts.map +1 -0
- package/dist/models/network-options.js +3 -0
- package/dist/models/network-options.js.map +1 -0
- package/dist/utils/aes.d.ts +40 -0
- package/dist/utils/aes.d.ts.map +1 -0
- package/dist/utils/aes.js +207 -0
- package/dist/utils/aes.js.map +1 -0
- package/dist/utils/async-mutex.d.ts +7 -0
- package/dist/utils/async-mutex.d.ts.map +1 -0
- package/dist/utils/async-mutex.js +31 -0
- package/dist/utils/async-mutex.js.map +1 -0
- package/dist/utils/backup.d.ts +21 -0
- package/dist/utils/backup.d.ts.map +1 -0
- package/dist/utils/backup.js +179 -0
- package/dist/utils/backup.js.map +1 -0
- package/dist/utils/index.d.ts +6 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +45 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/logger.d.ts +9 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +14 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/patchBigIntSerialization.d.ts +2 -0
- package/dist/utils/patchBigIntSerialization.d.ts.map +1 -0
- package/dist/utils/patchBigIntSerialization.js +9 -0
- package/dist/utils/patchBigIntSerialization.js.map +1 -0
- package/dist/utils/queue.d.ts +8 -0
- package/dist/utils/queue.d.ts.map +1 -0
- package/dist/utils/queue.js +67 -0
- package/dist/utils/queue.js.map +1 -0
- package/dist/utils/timeService.d.ts +6 -0
- package/dist/utils/timeService.d.ts.map +1 -0
- package/dist/utils/timeService.js +127 -0
- package/dist/utils/timeService.js.map +1 -0
- package/dist/utils/utils.d.ts +5 -0
- package/dist/utils/utils.d.ts.map +1 -0
- package/dist/utils/utils.js +24 -0
- package/dist/utils/utils.js.map +1 -0
- package/dist/utils/wait.d.ts +2 -0
- package/dist/utils/wait.d.ts.map +1 -0
- package/dist/utils/wait.js +9 -0
- package/dist/utils/wait.js.map +1 -0
- package/dist/utils/waitress.d.ts +23 -0
- package/dist/utils/waitress.d.ts.map +1 -0
- package/dist/utils/waitress.js +76 -0
- package/dist/utils/waitress.js.map +1 -0
- package/dist/zspec/consts.d.ts +75 -0
- package/dist/zspec/consts.d.ts.map +1 -0
- package/dist/zspec/consts.js +79 -0
- package/dist/zspec/consts.js.map +1 -0
- package/dist/zspec/enums.d.ts +19 -0
- package/dist/zspec/enums.d.ts.map +1 -0
- package/dist/zspec/enums.js +27 -0
- package/dist/zspec/enums.js.map +1 -0
- package/dist/zspec/index.d.ts +4 -0
- package/dist/zspec/index.d.ts.map +1 -0
- package/dist/zspec/index.js +43 -0
- package/dist/zspec/index.js.map +1 -0
- package/dist/zspec/tstypes.d.ts +19 -0
- package/dist/zspec/tstypes.d.ts.map +1 -0
- package/dist/zspec/tstypes.js +3 -0
- package/dist/zspec/tstypes.js.map +1 -0
- package/dist/zspec/utils.d.ts +77 -0
- package/dist/zspec/utils.d.ts.map +1 -0
- package/dist/zspec/utils.js +217 -0
- package/dist/zspec/utils.js.map +1 -0
- package/dist/zspec/zcl/buffaloZcl.d.ts +43 -0
- package/dist/zspec/zcl/buffaloZcl.d.ts.map +1 -0
- package/dist/zspec/zcl/buffaloZcl.js +969 -0
- package/dist/zspec/zcl/buffaloZcl.js.map +1 -0
- package/dist/zspec/zcl/definition/cluster.d.ts +3 -0
- package/dist/zspec/zcl/definition/cluster.d.ts.map +1 -0
- package/dist/zspec/zcl/definition/cluster.js +7507 -0
- package/dist/zspec/zcl/definition/cluster.js.map +1 -0
- package/dist/zspec/zcl/definition/clusters-types.d.ts +8135 -0
- package/dist/zspec/zcl/definition/clusters-types.d.ts.map +1 -0
- package/dist/zspec/zcl/definition/clusters-types.js +3 -0
- package/dist/zspec/zcl/definition/clusters-types.js.map +1 -0
- package/dist/zspec/zcl/definition/consts.d.ts +9 -0
- package/dist/zspec/zcl/definition/consts.d.ts.map +1 -0
- package/dist/zspec/zcl/definition/consts.js +27 -0
- package/dist/zspec/zcl/definition/consts.js.map +1 -0
- package/dist/zspec/zcl/definition/datatypes.d.ts +2173 -0
- package/dist/zspec/zcl/definition/datatypes.d.ts.map +1 -0
- package/dist/zspec/zcl/definition/datatypes.js +2315 -0
- package/dist/zspec/zcl/definition/datatypes.js.map +1 -0
- package/dist/zspec/zcl/definition/enums.d.ts +205 -0
- package/dist/zspec/zcl/definition/enums.d.ts.map +1 -0
- package/dist/zspec/zcl/definition/enums.js +218 -0
- package/dist/zspec/zcl/definition/enums.js.map +1 -0
- package/dist/zspec/zcl/definition/foundation.d.ts +10 -0
- package/dist/zspec/zcl/definition/foundation.d.ts.map +1 -0
- package/dist/zspec/zcl/definition/foundation.js +312 -0
- package/dist/zspec/zcl/definition/foundation.js.map +1 -0
- package/dist/zspec/zcl/definition/manufacturerCode.d.ts +729 -0
- package/dist/zspec/zcl/definition/manufacturerCode.d.ts.map +1 -0
- package/dist/zspec/zcl/definition/manufacturerCode.js +734 -0
- package/dist/zspec/zcl/definition/manufacturerCode.js.map +1 -0
- package/dist/zspec/zcl/definition/status.d.ts +69 -0
- package/dist/zspec/zcl/definition/status.d.ts.map +1 -0
- package/dist/zspec/zcl/definition/status.js +74 -0
- package/dist/zspec/zcl/definition/status.js.map +1 -0
- package/dist/zspec/zcl/definition/tstype.d.ts +273 -0
- package/dist/zspec/zcl/definition/tstype.d.ts.map +1 -0
- package/dist/zspec/zcl/definition/tstype.js +3 -0
- package/dist/zspec/zcl/definition/tstype.js.map +1 -0
- package/dist/zspec/zcl/index.d.ts +12 -0
- package/dist/zspec/zcl/index.d.ts.map +1 -0
- package/dist/zspec/zcl/index.js +57 -0
- package/dist/zspec/zcl/index.js.map +1 -0
- package/dist/zspec/zcl/utils.d.ts +15 -0
- package/dist/zspec/zcl/utils.d.ts.map +1 -0
- package/dist/zspec/zcl/utils.js +419 -0
- package/dist/zspec/zcl/utils.js.map +1 -0
- package/dist/zspec/zcl/zclFrame.d.ts +49 -0
- package/dist/zspec/zcl/zclFrame.d.ts.map +1 -0
- package/dist/zspec/zcl/zclFrame.js +328 -0
- package/dist/zspec/zcl/zclFrame.js.map +1 -0
- package/dist/zspec/zcl/zclHeader.d.ts +16 -0
- package/dist/zspec/zcl/zclHeader.d.ts.map +1 -0
- package/dist/zspec/zcl/zclHeader.js +88 -0
- package/dist/zspec/zcl/zclHeader.js.map +1 -0
- package/dist/zspec/zcl/zclStatusError.d.ts +6 -0
- package/dist/zspec/zcl/zclStatusError.d.ts.map +1 -0
- package/dist/zspec/zcl/zclStatusError.js +13 -0
- package/dist/zspec/zcl/zclStatusError.js.map +1 -0
- package/dist/zspec/zdo/buffaloZdo.d.ts +407 -0
- package/dist/zspec/zdo/buffaloZdo.d.ts.map +1 -0
- package/dist/zspec/zdo/buffaloZdo.js +1919 -0
- package/dist/zspec/zdo/buffaloZdo.js.map +1 -0
- package/dist/zspec/zdo/definition/clusters.d.ts +624 -0
- package/dist/zspec/zdo/definition/clusters.d.ts.map +1 -0
- package/dist/zspec/zdo/definition/clusters.js +686 -0
- package/dist/zspec/zdo/definition/clusters.js.map +1 -0
- package/dist/zspec/zdo/definition/consts.d.ts +13 -0
- package/dist/zspec/zdo/definition/consts.d.ts.map +1 -0
- package/dist/zspec/zdo/definition/consts.js +16 -0
- package/dist/zspec/zdo/definition/consts.js.map +1 -0
- package/dist/zspec/zdo/definition/enums.d.ts +85 -0
- package/dist/zspec/zdo/definition/enums.d.ts.map +1 -0
- package/dist/zspec/zdo/definition/enums.js +103 -0
- package/dist/zspec/zdo/definition/enums.js.map +1 -0
- package/dist/zspec/zdo/definition/status.d.ts +99 -0
- package/dist/zspec/zdo/definition/status.d.ts.map +1 -0
- package/dist/zspec/zdo/definition/status.js +108 -0
- package/dist/zspec/zdo/definition/status.js.map +1 -0
- package/dist/zspec/zdo/definition/tstypes.d.ts +955 -0
- package/dist/zspec/zdo/definition/tstypes.d.ts.map +1 -0
- package/dist/zspec/zdo/definition/tstypes.js +4 -0
- package/dist/zspec/zdo/definition/tstypes.js.map +1 -0
- package/dist/zspec/zdo/index.d.ts +8 -0
- package/dist/zspec/zdo/index.d.ts.map +1 -0
- package/dist/zspec/zdo/index.js +51 -0
- package/dist/zspec/zdo/index.js.map +1 -0
- package/dist/zspec/zdo/utils.d.ts +24 -0
- package/dist/zspec/zdo/utils.d.ts.map +1 -0
- package/dist/zspec/zdo/utils.js +74 -0
- package/dist/zspec/zdo/utils.js.map +1 -0
- package/dist/zspec/zdo/zdoStatusError.d.ts +6 -0
- package/dist/zspec/zdo/zdoStatusError.d.ts.map +1 -0
- package/dist/zspec/zdo/zdoStatusError.js +13 -0
- package/dist/zspec/zdo/zdoStatusError.js.map +1 -0
- package/package.json +90 -83
- package/src/controller/helpers/ota.ts +5 -2
- package/src/zspec/zcl/definition/cluster.ts +3 -294
- package/src/zspec/zcl/definition/clusters-types.ts +6 -355
- package/src/zspec/zcl/definition/tstype.ts +0 -14
- package/src/zspec/zcl/utils.ts +14 -31
- package/test/controller.test.ts +16 -8
- package/test/zcl.test.ts +36 -7
|
@@ -0,0 +1,719 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/* v8 ignore start */
|
|
3
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
+
if (k2 === undefined) k2 = k;
|
|
5
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
+
}
|
|
9
|
+
Object.defineProperty(o, k2, desc);
|
|
10
|
+
}) : (function(o, m, k, k2) {
|
|
11
|
+
if (k2 === undefined) k2 = k;
|
|
12
|
+
o[k2] = m[k];
|
|
13
|
+
}));
|
|
14
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
15
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
16
|
+
}) : function(o, v) {
|
|
17
|
+
o["default"] = v;
|
|
18
|
+
});
|
|
19
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
20
|
+
var ownKeys = function(o) {
|
|
21
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
22
|
+
var ar = [];
|
|
23
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
24
|
+
return ar;
|
|
25
|
+
};
|
|
26
|
+
return ownKeys(o);
|
|
27
|
+
};
|
|
28
|
+
return function (mod) {
|
|
29
|
+
if (mod && mod.__esModule) return mod;
|
|
30
|
+
var result = {};
|
|
31
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
32
|
+
__setModuleDefault(result, mod);
|
|
33
|
+
return result;
|
|
34
|
+
};
|
|
35
|
+
})();
|
|
36
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
37
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
38
|
+
};
|
|
39
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
40
|
+
exports.DeconzAdapter = void 0;
|
|
41
|
+
//import Device from "../../../controller/model/device";
|
|
42
|
+
const node_fs_1 = require("node:fs");
|
|
43
|
+
const node_path_1 = require("node:path");
|
|
44
|
+
const utils_1 = require("../../../utils");
|
|
45
|
+
const logger_1 = require("../../../utils/logger");
|
|
46
|
+
const ZSpec = __importStar(require("../../../zspec"));
|
|
47
|
+
const Zcl = __importStar(require("../../../zspec/zcl"));
|
|
48
|
+
const Zdo = __importStar(require("../../../zspec/zdo"));
|
|
49
|
+
const adapter_1 = __importDefault(require("../../adapter"));
|
|
50
|
+
const utils_2 = require("../../utils");
|
|
51
|
+
const constants_1 = __importStar(require("../driver/constants"));
|
|
52
|
+
const driver_1 = __importDefault(require("../driver/driver"));
|
|
53
|
+
const frameParser_1 = __importStar(require("../driver/frameParser"));
|
|
54
|
+
const NS = "zh:deconz";
|
|
55
|
+
class DeconzAdapter extends adapter_1.default {
|
|
56
|
+
driver;
|
|
57
|
+
openRequestsQueue;
|
|
58
|
+
frameParserEvent = frameParser_1.frameParserEvents;
|
|
59
|
+
// biome-ignore lint/correctness/noUnusedPrivateClassMembers: ignore
|
|
60
|
+
fwVersion;
|
|
61
|
+
waitress;
|
|
62
|
+
joinPermitted = false;
|
|
63
|
+
constructor(networkOptions, serialPortOptions, backupPath, adapterOptions) {
|
|
64
|
+
super(networkOptions, serialPortOptions, backupPath, adapterOptions);
|
|
65
|
+
this.hasZdoMessageOverhead = true;
|
|
66
|
+
this.manufacturerID = Zcl.ManufacturerCode.DRESDEN_ELEKTRONIK_INGENIEURTECHNIK_GMBH;
|
|
67
|
+
this.waitress = new utils_1.Waitress(this.waitressValidator, this.waitressTimeoutFormatter);
|
|
68
|
+
const firmwareLog = [];
|
|
69
|
+
if (backupPath) {
|
|
70
|
+
// optional: get extra logs from the firmware (debug builds)
|
|
71
|
+
const dirPath = (0, node_path_1.dirname)(backupPath);
|
|
72
|
+
const configPath = `${dirPath}/deconz_options.json`;
|
|
73
|
+
if ((0, node_fs_1.existsSync)(configPath)) {
|
|
74
|
+
try {
|
|
75
|
+
const data = JSON.parse((0, node_fs_1.readFileSync)(configPath).toString());
|
|
76
|
+
const log = data.firmware_log || [];
|
|
77
|
+
if (Array.isArray(log)) {
|
|
78
|
+
for (const level of log) {
|
|
79
|
+
if (level === "APS" || level === "APS_L2") {
|
|
80
|
+
firmwareLog.push(level);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
catch (_err) { }
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
this.driver = new driver_1.default(serialPortOptions, networkOptions, this.getStoredBackup(), firmwareLog);
|
|
89
|
+
this.driver.on("rxFrame", (frame) => (0, frameParser_1.default)(frame));
|
|
90
|
+
this.openRequestsQueue = [];
|
|
91
|
+
this.fwVersion = undefined;
|
|
92
|
+
this.frameParserEvent.on("receivedDataPayload", (data) => this.checkReceivedDataPayload(data));
|
|
93
|
+
this.frameParserEvent.on("receivedGreenPowerIndication", (data) => this.checkReceivedGreenPowerIndication(data));
|
|
94
|
+
setInterval(() => {
|
|
95
|
+
// Need to have a try/catch block here since promised can be rejected which don't
|
|
96
|
+
// have a handler waiting for them anymore.
|
|
97
|
+
try {
|
|
98
|
+
this.checkWaitForDataRequestTimeouts();
|
|
99
|
+
}
|
|
100
|
+
catch (_err) { }
|
|
101
|
+
}, 1000);
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Adapter methods
|
|
105
|
+
*/
|
|
106
|
+
start() {
|
|
107
|
+
// wait here until driver is connected and has queried all firmware parameters
|
|
108
|
+
return new Promise((resolve, reject) => {
|
|
109
|
+
const start = Date.now();
|
|
110
|
+
const iv = setInterval(() => {
|
|
111
|
+
if (this.driver.started()) {
|
|
112
|
+
clearInterval(iv);
|
|
113
|
+
if (this.driver.restoredFromBackup) {
|
|
114
|
+
resolve("restored");
|
|
115
|
+
}
|
|
116
|
+
else {
|
|
117
|
+
resolve("resumed");
|
|
118
|
+
}
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
if (20000 < Date.now() - start) {
|
|
122
|
+
clearInterval(iv);
|
|
123
|
+
reject(new Error("failed to start adapter connection to firmware"));
|
|
124
|
+
return;
|
|
125
|
+
}
|
|
126
|
+
}, 50);
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
async stop() {
|
|
130
|
+
await this.driver.close();
|
|
131
|
+
}
|
|
132
|
+
getCoordinatorIEEE() {
|
|
133
|
+
logger_1.logger.debug("-------- z2m:getCoordinatorIEEE() ----------------", NS);
|
|
134
|
+
if (this.driver.paramMacAddress === 0n) {
|
|
135
|
+
return Promise.reject(new Error("Failed to query coordinator MAC address"));
|
|
136
|
+
}
|
|
137
|
+
return Promise.resolve(`0x${this.driver.paramMacAddress.toString(16).padStart(16, "0")}`);
|
|
138
|
+
}
|
|
139
|
+
async permitJoin(seconds, networkAddress) {
|
|
140
|
+
const clusterId = Zdo.ClusterId.PERMIT_JOINING_REQUEST;
|
|
141
|
+
if (networkAddress) {
|
|
142
|
+
// `authentication`: TC significance always 1 (zb specs)
|
|
143
|
+
const zdoPayload = Zdo.Buffalo.buildRequest(this.hasZdoMessageOverhead, clusterId, seconds, 1, []);
|
|
144
|
+
const result = await this.sendZdo(ZSpec.BLANK_EUI64, networkAddress, clusterId, zdoPayload, false);
|
|
145
|
+
if (!Zdo.Buffalo.checkStatus(result)) {
|
|
146
|
+
// TODO: will disappear once moved upstream
|
|
147
|
+
throw new Zdo.StatusError(result[0]);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
else {
|
|
151
|
+
await this.driver.writeParameterRequest(constants_1.ParamId.STK_PERMIT_JOIN, seconds);
|
|
152
|
+
logger_1.logger.debug(`Permit joining on coordinator for ${seconds} sec.`, NS);
|
|
153
|
+
// broadcast permit joining ZDO
|
|
154
|
+
if (networkAddress === undefined) {
|
|
155
|
+
// `authentication`: TC significance always 1 (zb specs)
|
|
156
|
+
const zdoPayload = Zdo.Buffalo.buildRequest(this.hasZdoMessageOverhead, clusterId, seconds, 1, []);
|
|
157
|
+
await this.sendZdo(ZSpec.BLANK_EUI64, ZSpec.BroadcastAddress.DEFAULT, clusterId, zdoPayload, true);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
this.joinPermitted = seconds !== 0;
|
|
161
|
+
}
|
|
162
|
+
getCoordinatorVersion() {
|
|
163
|
+
logger_1.logger.debug("-------- z2m:getCoordinatorVersion() ----------------", NS);
|
|
164
|
+
// product: number; transportrev: number; majorrel: number; minorrel: number; maintrel: number; revision: string;
|
|
165
|
+
const fw = this.driver.paramFirmwareVersion;
|
|
166
|
+
if (fw === 0) {
|
|
167
|
+
return Promise.reject(new Error("Failed to query coordinator firmware version"));
|
|
168
|
+
}
|
|
169
|
+
const fwString = `0x${fw.toString(16).padStart(8, "0")}`;
|
|
170
|
+
logger_1.logger.debug(`Firmware version: ${fwString}`, NS);
|
|
171
|
+
let type = "Unknown";
|
|
172
|
+
const platform = (fw >> 8) & 0xff;
|
|
173
|
+
if (platform === 5) {
|
|
174
|
+
type = "ConBee/RaspBee";
|
|
175
|
+
}
|
|
176
|
+
else if (platform === 7) {
|
|
177
|
+
type = "ConBee2/RaspBee2";
|
|
178
|
+
}
|
|
179
|
+
else if (platform === 9) {
|
|
180
|
+
type = "ConBee3";
|
|
181
|
+
}
|
|
182
|
+
// 0x26780700 -> 2.6.78.7.00
|
|
183
|
+
const major = (fw >> 28) & 0xf;
|
|
184
|
+
const minor = (fw >> 24) & 0xf;
|
|
185
|
+
const patch = (fw >> 16) & 0xff;
|
|
186
|
+
const meta = { transportrev: 0, product: 0, majorrel: major, minorrel: minor, maintrel: patch, revision: fwString };
|
|
187
|
+
this.fwVersion = { type: type, meta: meta };
|
|
188
|
+
return Promise.resolve({ type: type, meta: meta });
|
|
189
|
+
}
|
|
190
|
+
async addInstallCode(ieeeAddress, key, hashed) {
|
|
191
|
+
await this.driver.writeLinkKey(ieeeAddress, hashed ? key : ZSpec.Utils.aes128MmoHash(key));
|
|
192
|
+
}
|
|
193
|
+
async reset(_type) {
|
|
194
|
+
return await Promise.reject(new Error("Reset is not supported"));
|
|
195
|
+
}
|
|
196
|
+
waitFor(networkAddress, endpoint, frameType, direction, transactionSequenceNumber, clusterID, commandIdentifier, timeout) {
|
|
197
|
+
const payload = {
|
|
198
|
+
address: networkAddress,
|
|
199
|
+
endpoint,
|
|
200
|
+
clusterID,
|
|
201
|
+
commandIdentifier,
|
|
202
|
+
frameType,
|
|
203
|
+
direction,
|
|
204
|
+
transactionSequenceNumber,
|
|
205
|
+
};
|
|
206
|
+
logger_1.logger.debug(() => `waitFor() called ${JSON.stringify(payload)}`, NS);
|
|
207
|
+
const waiter = this.waitress.waitFor(payload, timeout);
|
|
208
|
+
const cancel = () => this.waitress.remove(waiter.ID);
|
|
209
|
+
return { promise: waiter.start().promise, cancel };
|
|
210
|
+
}
|
|
211
|
+
async sendZdo(ieeeAddress, networkAddress, clusterId, payload, disableResponse) {
|
|
212
|
+
const transactionID = this.nextTransactionID();
|
|
213
|
+
payload[0] = transactionID;
|
|
214
|
+
const txOptions = 0;
|
|
215
|
+
// TODO(mpi): Disable APS ACKs for now until we find a better solution to not block queues.
|
|
216
|
+
//if (networkAddress < NwkBroadcastAddress.BroadcastLowPowerRouters) {
|
|
217
|
+
// txOptions = 0x4; // enable APS ACKs for unicast addresses
|
|
218
|
+
//}
|
|
219
|
+
const isNwkAddrRequest = clusterId === Zdo.ClusterId.NETWORK_ADDRESS_REQUEST;
|
|
220
|
+
const req = {
|
|
221
|
+
requestId: transactionID,
|
|
222
|
+
destAddrMode: constants_1.ApsAddressMode.Nwk,
|
|
223
|
+
destAddr16: networkAddress,
|
|
224
|
+
destAddr64: isNwkAddrRequest ? ieeeAddress : undefined,
|
|
225
|
+
destEndpoint: Zdo.ZDO_ENDPOINT,
|
|
226
|
+
profileId: Zdo.ZDO_PROFILE_ID,
|
|
227
|
+
clusterId,
|
|
228
|
+
srcEndpoint: Zdo.ZDO_ENDPOINT,
|
|
229
|
+
asduLength: payload.length,
|
|
230
|
+
asduPayload: payload,
|
|
231
|
+
txOptions,
|
|
232
|
+
radius: constants_1.default.PARAM.txRadius.DEFAULT_RADIUS,
|
|
233
|
+
timeout: 10000,
|
|
234
|
+
};
|
|
235
|
+
const responseClusterId = Zdo.Utils.getResponseClusterId(clusterId);
|
|
236
|
+
const confirm = this.driver.enqueueApsDataRequest(req);
|
|
237
|
+
let indication;
|
|
238
|
+
if (!disableResponse) {
|
|
239
|
+
if (responseClusterId) {
|
|
240
|
+
indication = this.waitForData(isNwkAddrRequest ? ieeeAddress : networkAddress, Zdo.ZDO_PROFILE_ID, responseClusterId, transactionID, req.timeout);
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
try {
|
|
244
|
+
await confirm;
|
|
245
|
+
// biome-ignore lint/nursery/noMisusedPromises: ignore
|
|
246
|
+
if (indication) {
|
|
247
|
+
const indicationIndex = this.openRequestsQueue.findIndex((x) => x.clusterId === responseClusterId && x.transactionSequenceNumber === transactionID);
|
|
248
|
+
if (indicationIndex !== -1) {
|
|
249
|
+
this.openRequestsQueue[indicationIndex].confirmed = true;
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
catch (err) {
|
|
254
|
+
// no need to wait for indication, remove waiter from queue
|
|
255
|
+
// biome-ignore lint/nursery/noMisusedPromises: ignore
|
|
256
|
+
if (indication) {
|
|
257
|
+
const indicationIndex = this.openRequestsQueue.findIndex((x) => x.clusterId === responseClusterId && x.transactionSequenceNumber === transactionID);
|
|
258
|
+
if (indicationIndex !== -1) {
|
|
259
|
+
this.openRequestsQueue.splice(indicationIndex, 1);
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
throw new Error(`failed to send ZDO request seq: (${transactionID}) ${err}`);
|
|
263
|
+
}
|
|
264
|
+
// biome-ignore lint/nursery/noMisusedPromises: ignore
|
|
265
|
+
if (indication) {
|
|
266
|
+
try {
|
|
267
|
+
const data = await indication;
|
|
268
|
+
// biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
|
|
269
|
+
return data.zdo;
|
|
270
|
+
}
|
|
271
|
+
catch (error) {
|
|
272
|
+
if (responseClusterId === Zdo.ClusterId.ACTIVE_ENDPOINTS_RESPONSE && networkAddress === 0) {
|
|
273
|
+
// TODO(mpi): Check following statement on older firmware versions.
|
|
274
|
+
// If it is true we can always query firmware parameters for endpoints.
|
|
275
|
+
logger_1.logger.warning("Failed to determine active endpoints of coordinator, falling back to [1]", NS);
|
|
276
|
+
// Some Conbee adapaters don't provide a response to an active endpoint request of the coordinator, always return
|
|
277
|
+
// an endpoint here. Before an active endpoint request was done to determine the endpoints, they were hardcoded:
|
|
278
|
+
// https://github.com/Koenkk/zigbee-herdsman/blob/d855b3bf85a066cb7c325fe3ef0006873c735add/src/adapter/deconz/adapter/deconzAdapter.ts#L105
|
|
279
|
+
const response = [
|
|
280
|
+
Zdo.Status.SUCCESS,
|
|
281
|
+
{ endpointList: [1], nwkAddress: 0 },
|
|
282
|
+
];
|
|
283
|
+
return response;
|
|
284
|
+
}
|
|
285
|
+
throw error;
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
async sendZclFrameToEndpoint(_ieeeAddr, networkAddress, endpoint, zclFrame, timeout, disableResponse,
|
|
290
|
+
// TODO(mpi): in ember driver this means keep going enqueue request to firmware (up to 3 times).
|
|
291
|
+
// In our case this a little different: The firmware may reject the requests because no free APS slots are available,
|
|
292
|
+
// this is the only case where "recovery" makes sense. Other cases mean the request will never succeed (network offline, invalid request, ...).
|
|
293
|
+
_disableRecovery, sourceEndpoint, profileId) {
|
|
294
|
+
const transactionID = this.nextTransactionID();
|
|
295
|
+
const payload = zclFrame.toBuffer();
|
|
296
|
+
// TODO(mpi): Enable APS ACKs for tricky devices, maintain a list of those, or keep at least a few slots free for non APS ACK requests.
|
|
297
|
+
//const txOptions = 0x4; // 0x00 normal, 0x04 APS ACK
|
|
298
|
+
// TODO(mpi): Disable APS ACKs for now until we find a better solution to not block queues.
|
|
299
|
+
const txOptions = 0;
|
|
300
|
+
const request = {
|
|
301
|
+
requestId: transactionID,
|
|
302
|
+
destAddrMode: constants_1.ApsAddressMode.Nwk,
|
|
303
|
+
destAddr16: networkAddress,
|
|
304
|
+
destEndpoint: endpoint,
|
|
305
|
+
profileId: profileId ?? (sourceEndpoint === 242 && endpoint === 242 ? 0xa1e0 : 0x104),
|
|
306
|
+
clusterId: zclFrame.cluster.ID,
|
|
307
|
+
srcEndpoint: sourceEndpoint || 1,
|
|
308
|
+
asduLength: payload.length,
|
|
309
|
+
asduPayload: payload,
|
|
310
|
+
// TODO(mpi): This must not be a global option.
|
|
311
|
+
// Since z2m doesn't provide it, ideally the driver figures this out on its own.
|
|
312
|
+
// deCONZ keeps an error count for each device, if devices work fine without APS ACKs don't use them.
|
|
313
|
+
// But if errors occur enable them..
|
|
314
|
+
//
|
|
315
|
+
// ember driver enables ACKs based on 'commandResponseId' which imho doesn't make sense at all:
|
|
316
|
+
//
|
|
317
|
+
// don't RETRY if no response expected
|
|
318
|
+
// if (commandResponseId === undefined)
|
|
319
|
+
// apsFrame.options &= ~EmberApsOption.RETRY;
|
|
320
|
+
//
|
|
321
|
+
txOptions,
|
|
322
|
+
radius: constants_1.default.PARAM.txRadius.DEFAULT_RADIUS,
|
|
323
|
+
// TODO(mpi): We could treat _disableRecovery = true, to retry if enqueue (valid) requests or APS-confirms fail within timeout period?
|
|
324
|
+
timeout: timeout,
|
|
325
|
+
};
|
|
326
|
+
if (timeout < 1000) {
|
|
327
|
+
throw new Error("Unexpected small timeout");
|
|
328
|
+
}
|
|
329
|
+
const command = zclFrame.command;
|
|
330
|
+
// NOTE(mpi): 'disableResponse' is not working as expected?
|
|
331
|
+
// For now use the same logic as Ember adapter since 'disableResponse === false' alone isn't correct in some cases.
|
|
332
|
+
//
|
|
333
|
+
// E.g. when replying to an Query Next Image Request the following parameters where passed from z2m:
|
|
334
|
+
// { command.response: undefined, zcl.disableDefaultResponse: true, z2m.disableResponse: false }
|
|
335
|
+
// This resulted in waiting for a response which never arrives and a timeout error thrown.
|
|
336
|
+
let needWaitResponse = false;
|
|
337
|
+
if (command.response !== undefined && disableResponse === false) {
|
|
338
|
+
needWaitResponse = true;
|
|
339
|
+
}
|
|
340
|
+
else if (!zclFrame.header.frameControl.disableDefaultResponse) {
|
|
341
|
+
needWaitResponse = true;
|
|
342
|
+
}
|
|
343
|
+
const confirm = this.driver.enqueueApsDataRequest(request);
|
|
344
|
+
logger_1.logger.debug(`ZCL request sent with transactionSequenceNumber.: ${zclFrame.header.transactionSequenceNumber}`, NS);
|
|
345
|
+
logger_1.logger.debug(`command.response: ${command.response}, zcl.disableDefaultResponse: ${zclFrame.header.frameControl.disableDefaultResponse}, z2m.disableResponse: ${disableResponse}, request.timeout: ${request.timeout}`, NS);
|
|
346
|
+
let indication;
|
|
347
|
+
if (needWaitResponse) {
|
|
348
|
+
indication = this.waitForData(networkAddress, ZSpec.HA_PROFILE_ID, zclFrame.cluster.ID, zclFrame.header.transactionSequenceNumber, request.timeout);
|
|
349
|
+
}
|
|
350
|
+
try {
|
|
351
|
+
await confirm;
|
|
352
|
+
// biome-ignore lint/nursery/noMisusedPromises: ignore
|
|
353
|
+
if (indication) {
|
|
354
|
+
const indicationIndex = this.openRequestsQueue.findIndex((x) => x.clusterId === zclFrame.cluster.ID && x.transactionSequenceNumber === zclFrame.header.transactionSequenceNumber);
|
|
355
|
+
if (indicationIndex !== -1) {
|
|
356
|
+
this.openRequestsQueue[indicationIndex].confirmed = true;
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
catch (err) {
|
|
361
|
+
// no need to wait for indication, remove waiter from queue
|
|
362
|
+
// biome-ignore lint/nursery/noMisusedPromises: ignore
|
|
363
|
+
if (indication) {
|
|
364
|
+
const indicationIndex = this.openRequestsQueue.findIndex((x) => x.clusterId === zclFrame.cluster.ID && x.transactionSequenceNumber === zclFrame.header.transactionSequenceNumber);
|
|
365
|
+
if (indicationIndex !== -1) {
|
|
366
|
+
this.openRequestsQueue.splice(indicationIndex, 1);
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
throw new Error(`failed to send ZCL request (${zclFrame.header.transactionSequenceNumber}) ${err}`);
|
|
370
|
+
}
|
|
371
|
+
// biome-ignore lint/nursery/noMisusedPromises: ignore
|
|
372
|
+
if (indication) {
|
|
373
|
+
try {
|
|
374
|
+
const data = await indication;
|
|
375
|
+
// TODO(mpi): This is nuts. Need to make sure that srcAddr16 is always valid.
|
|
376
|
+
let addr;
|
|
377
|
+
if (data.srcAddr16 !== undefined)
|
|
378
|
+
addr = data.srcAddr16;
|
|
379
|
+
else if (data.srcAddr64 !== undefined)
|
|
380
|
+
addr = `0x${data.srcAddr64}`;
|
|
381
|
+
else
|
|
382
|
+
throw new Error("Unexpected waitForData() didn't contain valid address");
|
|
383
|
+
const groupId = 0;
|
|
384
|
+
const wasBroadCast = false;
|
|
385
|
+
const response = {
|
|
386
|
+
address: addr,
|
|
387
|
+
data: data.asduPayload,
|
|
388
|
+
clusterID: zclFrame.cluster.ID,
|
|
389
|
+
header: Zcl.Header.fromBuffer(data.asduPayload),
|
|
390
|
+
endpoint: data.srcEndpoint,
|
|
391
|
+
linkquality: data.lqi,
|
|
392
|
+
groupID: groupId,
|
|
393
|
+
wasBroadcast: wasBroadCast,
|
|
394
|
+
destinationEndpoint: data.destEndpoint,
|
|
395
|
+
};
|
|
396
|
+
logger_1.logger.debug(`Response received transactionSequenceNumber: ${zclFrame.header.transactionSequenceNumber}`, NS);
|
|
397
|
+
return response;
|
|
398
|
+
}
|
|
399
|
+
catch (err) {
|
|
400
|
+
throw new Error(`No ZCL response received for (${zclFrame.header.transactionSequenceNumber}) ${err}`);
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
async sendZclFrameToGroup(groupID, zclFrame, sourceEndpoint, profileId) {
|
|
405
|
+
const transactionID = this.nextTransactionID();
|
|
406
|
+
const payload = zclFrame.toBuffer();
|
|
407
|
+
logger_1.logger.debug(`zclFrame to group - ${groupID}`, NS);
|
|
408
|
+
const request = {
|
|
409
|
+
requestId: transactionID,
|
|
410
|
+
destAddrMode: constants_1.ApsAddressMode.Group,
|
|
411
|
+
destAddr16: groupID,
|
|
412
|
+
profileId: profileId ?? 0x104,
|
|
413
|
+
clusterId: zclFrame.cluster.ID,
|
|
414
|
+
srcEndpoint: sourceEndpoint ?? 1,
|
|
415
|
+
asduLength: payload.length,
|
|
416
|
+
asduPayload: payload,
|
|
417
|
+
txOptions: 0,
|
|
418
|
+
radius: constants_1.default.PARAM.txRadius.UNLIMITED,
|
|
419
|
+
timeout: constants_1.default.PARAM.APS.MAX_SEND_TIMEOUT,
|
|
420
|
+
};
|
|
421
|
+
logger_1.logger.debug("sendZclFrameToGroup - message send", NS);
|
|
422
|
+
return await this.driver.enqueueApsDataRequest(request);
|
|
423
|
+
}
|
|
424
|
+
async sendZclFrameToAll(endpoint, zclFrame, sourceEndpoint, destination, profileId) {
|
|
425
|
+
const transactionID = this.nextTransactionID();
|
|
426
|
+
const payload = zclFrame.toBuffer();
|
|
427
|
+
logger_1.logger.debug(`zclFrame to all - ${endpoint}`, NS);
|
|
428
|
+
const request = {
|
|
429
|
+
requestId: transactionID,
|
|
430
|
+
destAddrMode: constants_1.ApsAddressMode.Nwk,
|
|
431
|
+
destAddr16: destination,
|
|
432
|
+
destEndpoint: endpoint,
|
|
433
|
+
profileId: profileId ?? (sourceEndpoint === 242 && endpoint === 242 ? 0xa1e0 : 0x104),
|
|
434
|
+
clusterId: zclFrame.cluster.ID,
|
|
435
|
+
srcEndpoint: sourceEndpoint,
|
|
436
|
+
asduLength: payload.length,
|
|
437
|
+
asduPayload: payload,
|
|
438
|
+
txOptions: 0,
|
|
439
|
+
radius: constants_1.default.PARAM.txRadius.UNLIMITED,
|
|
440
|
+
timeout: constants_1.default.PARAM.APS.MAX_SEND_TIMEOUT,
|
|
441
|
+
};
|
|
442
|
+
logger_1.logger.debug("sendZclFrameToAll - message send", NS);
|
|
443
|
+
return await this.driver.enqueueApsDataRequest(request);
|
|
444
|
+
}
|
|
445
|
+
async supportsBackup() {
|
|
446
|
+
return await Promise.resolve(true);
|
|
447
|
+
}
|
|
448
|
+
/**
|
|
449
|
+
* Loads currently stored backup and returns it in internal backup model.
|
|
450
|
+
*/
|
|
451
|
+
getStoredBackup() {
|
|
452
|
+
const data = (0, utils_2.readBackup)(this.backupPath);
|
|
453
|
+
if (!data)
|
|
454
|
+
return undefined;
|
|
455
|
+
if ("metadata" in data && data.metadata?.format === "zigpy/open-coordinator-backup" && data.metadata?.version) {
|
|
456
|
+
if (data.metadata?.version !== 1) {
|
|
457
|
+
throw new Error(`[BACKUP] Unsupported open coordinator backup version (version=${data.metadata?.version}).`);
|
|
458
|
+
}
|
|
459
|
+
// if (data.metadata.internal.ezspVersion < BACKUP_OLDEST_SUPPORTED_EZSP_VERSION) {
|
|
460
|
+
// renameSync(this.backupPath, `${this.backupPath}.old`);
|
|
461
|
+
// logger.warning("[BACKUP] Current backup file is from an unsupported EZSP version. Renaming and ignoring.", NS);
|
|
462
|
+
// return undefined;
|
|
463
|
+
// }
|
|
464
|
+
return utils_1.BackupUtils.fromUnifiedBackup(data);
|
|
465
|
+
}
|
|
466
|
+
throw new Error("[BACKUP] Unknown backup format.");
|
|
467
|
+
}
|
|
468
|
+
async backup() {
|
|
469
|
+
if (!this.driver.started()) {
|
|
470
|
+
throw new Error("Can't create backup while driver isn't connected");
|
|
471
|
+
}
|
|
472
|
+
// NOTE(mpi): The U64 values are put as big endian format into the buffer, same as string (0x001234...)
|
|
473
|
+
const extendedPanId = Buffer.alloc(8);
|
|
474
|
+
extendedPanId.writeBigUint64BE(this.driver.paramApsUseExtPanid);
|
|
475
|
+
const channelList = [this.driver.paramCurrentChannel]; // Utils.unpackChannelList(nib.channelList)
|
|
476
|
+
const networkKey = this.driver.paramNwkKey;
|
|
477
|
+
const coordinatorIeeeAddress = Buffer.alloc(8);
|
|
478
|
+
coordinatorIeeeAddress.writeBigUint64BE(this.driver.paramMacAddress);
|
|
479
|
+
/* return backup structure */
|
|
480
|
+
const backup = {
|
|
481
|
+
networkOptions: {
|
|
482
|
+
panId: this.driver.paramNwkPanid,
|
|
483
|
+
extendedPanId,
|
|
484
|
+
channelList,
|
|
485
|
+
networkKey,
|
|
486
|
+
networkKeyDistribute: false,
|
|
487
|
+
},
|
|
488
|
+
logicalChannel: this.driver.paramCurrentChannel,
|
|
489
|
+
networkKeyInfo: {
|
|
490
|
+
sequenceNumber: 0, // TODO(mpi): on newer firmware versions we can read it
|
|
491
|
+
frameCounter: this.driver.paramFrameCounter,
|
|
492
|
+
},
|
|
493
|
+
securityLevel: 0x05, // AES-CCM-32 (fixed)
|
|
494
|
+
networkUpdateId: this.driver.paramNwkUpdateId,
|
|
495
|
+
coordinatorIeeeAddress,
|
|
496
|
+
devices: [], // TODO(mpi): we currently don't have this, but it will be added once install codes get a proper interface
|
|
497
|
+
};
|
|
498
|
+
return await Promise.resolve(backup);
|
|
499
|
+
}
|
|
500
|
+
getNetworkParameters() {
|
|
501
|
+
// TODO(mpi): This works with 0x26780700, needs more investigation with older firmware versions.
|
|
502
|
+
const panID = this.driver.paramNwkPanid;
|
|
503
|
+
const extendedPanID = this.driver.paramApsUseExtPanid;
|
|
504
|
+
const channel = this.driver.paramCurrentChannel;
|
|
505
|
+
const nwkUpdateID = this.driver.paramNwkUpdateId;
|
|
506
|
+
if (channel === 0 || extendedPanID === 0n) {
|
|
507
|
+
return Promise.reject(new Error("Failed to query network parameters"));
|
|
508
|
+
}
|
|
509
|
+
// TODO(mpi): check this statement, this should work
|
|
510
|
+
// For some reason, reading NWK_UPDATE_ID always returns `null` (tested with `0x26780700` on Conbee II)
|
|
511
|
+
// 0x24 was taken from https://github.com/zigpy/zigpy-deconz/blob/70910bc6a63e607332b4f12754ba470651eb878c/zigpy_deconz/api.py#L152
|
|
512
|
+
// const nwkUpdateId = await this.driver.readParameterRequest(0x24 /*PARAM.PARAM.Network.NWK_UPDATE_ID*/);
|
|
513
|
+
return Promise.resolve({ panID, extendedPanID: `0x${extendedPanID.toString(16).padStart(16, "0")}`, channel, nwkUpdateID });
|
|
514
|
+
}
|
|
515
|
+
async restoreChannelInterPAN() {
|
|
516
|
+
await Promise.reject(new Error("not supported"));
|
|
517
|
+
}
|
|
518
|
+
async sendZclFrameInterPANToIeeeAddr(_zclFrame, _ieeeAddr) {
|
|
519
|
+
await Promise.reject(new Error("not supported"));
|
|
520
|
+
}
|
|
521
|
+
async sendZclFrameInterPANBroadcast(_zclFrame, _timeout, _disableResponse) {
|
|
522
|
+
return await Promise.reject(new Error("not supported"));
|
|
523
|
+
}
|
|
524
|
+
async sendZclFrameInterPANBroadcastWithResponse(_zclFrame, _timeout) {
|
|
525
|
+
return await Promise.reject(new Error("not supported"));
|
|
526
|
+
}
|
|
527
|
+
async setChannelInterPAN(_channel) {
|
|
528
|
+
await Promise.reject(new Error("not supported"));
|
|
529
|
+
}
|
|
530
|
+
async sendZclFrameInterPANIeeeAddr(_zclFrame, _ieeeAddr) {
|
|
531
|
+
await Promise.reject(new Error("not supported"));
|
|
532
|
+
}
|
|
533
|
+
/**
|
|
534
|
+
* Private methods
|
|
535
|
+
*/
|
|
536
|
+
waitForData(addr, profileId, clusterId, transactionSequenceNumber, timeout) {
|
|
537
|
+
return new Promise((resolve, reject) => {
|
|
538
|
+
const ts = Date.now();
|
|
539
|
+
if (!timeout) {
|
|
540
|
+
timeout = 60000;
|
|
541
|
+
}
|
|
542
|
+
const confirmed = false;
|
|
543
|
+
const req = { addr, profileId, clusterId, transactionSequenceNumber, resolve, reject, confirmed, ts, timeout };
|
|
544
|
+
this.openRequestsQueue.push(req);
|
|
545
|
+
});
|
|
546
|
+
}
|
|
547
|
+
checkReceivedGreenPowerIndication(ind) {
|
|
548
|
+
const gpdHeader = Buffer.alloc(15); // applicationId === IEEE_ADDRESS ? 20 : 15
|
|
549
|
+
gpdHeader.writeUInt8(0b00000001, 0); // frameControl: FrameType.SPECIFIC + Direction.CLIENT_TO_SERVER + disableDefaultResponse=false
|
|
550
|
+
gpdHeader.writeUInt8(ind.seqNr, 1);
|
|
551
|
+
gpdHeader.writeUInt8(ind.id, 2); // commandIdentifier
|
|
552
|
+
gpdHeader.writeUInt16LE(ind.options, 3); // options
|
|
553
|
+
gpdHeader.writeUInt32LE(ind.srcId, 5);
|
|
554
|
+
// omitted: gpdIEEEAddr (ieeeAddr)
|
|
555
|
+
// omitted: gpdEndpoint (uint8)
|
|
556
|
+
gpdHeader.writeUInt32LE(ind.frameCounter, 9);
|
|
557
|
+
gpdHeader.writeUInt8(ind.commandId, 13);
|
|
558
|
+
gpdHeader.writeUInt8(ind.commandFrameSize, 14);
|
|
559
|
+
const payBuf = Buffer.concat([gpdHeader, ind.commandFrame]);
|
|
560
|
+
const payload = {
|
|
561
|
+
header: Zcl.Header.fromBuffer(payBuf),
|
|
562
|
+
data: payBuf,
|
|
563
|
+
clusterID: Zcl.Clusters.greenPower.ID,
|
|
564
|
+
address: ind.srcId & 0xffff,
|
|
565
|
+
endpoint: ZSpec.GP_ENDPOINT,
|
|
566
|
+
linkquality: 0xff, // bogus
|
|
567
|
+
groupID: ZSpec.GP_GROUP_ID,
|
|
568
|
+
wasBroadcast: true, // Take the codepath that doesn't require `gppNwkAddr` as its not present in the payload
|
|
569
|
+
destinationEndpoint: ZSpec.GP_ENDPOINT,
|
|
570
|
+
};
|
|
571
|
+
this.waitress.resolve(payload);
|
|
572
|
+
this.emit("zclPayload", payload);
|
|
573
|
+
}
|
|
574
|
+
checkWaitForDataRequestTimeouts() {
|
|
575
|
+
if (this.openRequestsQueue.length === 0) {
|
|
576
|
+
return;
|
|
577
|
+
}
|
|
578
|
+
const now = Date.now();
|
|
579
|
+
const req = this.openRequestsQueue[0];
|
|
580
|
+
if (req.confirmed && req.timeout < now - req.ts) {
|
|
581
|
+
this.openRequestsQueue.shift();
|
|
582
|
+
logger_1.logger.debug(`Timeout for request in openRequestsQueue addr: ${req.addr}, clusterId: ${req.clusterId.toString(16)}, profileId: ${req.profileId.toString(16)}, seq: ${req.transactionSequenceNumber}`, NS);
|
|
583
|
+
req.reject(new Error("waiting for response TIMEOUT"));
|
|
584
|
+
}
|
|
585
|
+
}
|
|
586
|
+
checkReceivedDataPayload(resp) {
|
|
587
|
+
//let srcAddr: number | undefined;
|
|
588
|
+
//let srcEUI64: string | undefined;
|
|
589
|
+
let header;
|
|
590
|
+
//srcAddr = resp.srcAddr16;
|
|
591
|
+
// TODO(mpi): The following shouldn't be needed anymore.
|
|
592
|
+
// if (resp.srcAddr16 != null) {
|
|
593
|
+
//
|
|
594
|
+
// } else {
|
|
595
|
+
// // For some devices srcAddr64 is reported by ConBee 3, even if the frame contains both
|
|
596
|
+
// // srcAddr16 and srcAddr64. This happens even if the request was sent to a short address.
|
|
597
|
+
// // At least some parts, e.g. the while loop below, only work with srcAddr16 (i.e. the network
|
|
598
|
+
// // address) being set. So we try to look up the network address in the list of know devices.
|
|
599
|
+
// if (resp.srcAddr64 != null) {
|
|
600
|
+
// logger.debug(`Try to find network address of ${resp.srcAddr64}`, NS);
|
|
601
|
+
// // Note: Device expects addresses with a 0x prefix...
|
|
602
|
+
// srcAddr = Device.byIeeeAddr(`0x${resp.srcAddr64}`, false)?.networkAddress;
|
|
603
|
+
// // apperantly some functions furhter up in the protocol stack expect this to be set.
|
|
604
|
+
// // so let's make sure they get the network address
|
|
605
|
+
// // Note: srcAddr16 can be undefined after this and this is intended behavior
|
|
606
|
+
// // there are zigbee frames which do not contain a 16 bit address, e.g. during joining.
|
|
607
|
+
// // So any code that relies on srcAddr16 must handle this in some way.
|
|
608
|
+
// resp.srcAddr16 = srcAddr;
|
|
609
|
+
// }
|
|
610
|
+
// }
|
|
611
|
+
//
|
|
612
|
+
// ---------------------------------------------------------------------
|
|
613
|
+
// if (resp.srcAddr16) { // temp test
|
|
614
|
+
// const dev = Device.byNetworkAddress(resp.srcAddr16);
|
|
615
|
+
//
|
|
616
|
+
// if (dev) {
|
|
617
|
+
// logger.debug(`APS-DATA.indication from ${dev.ieeeAddr}, ${dev.modelID} ${dev.manufacturerID}`, NS);
|
|
618
|
+
// }
|
|
619
|
+
// }
|
|
620
|
+
if (resp.profileId === Zdo.ZDO_PROFILE_ID) {
|
|
621
|
+
if (resp.zdo) {
|
|
622
|
+
if (resp.clusterId === Zdo.ClusterId.NETWORK_ADDRESS_RESPONSE) {
|
|
623
|
+
// if (Zdo.Buffalo.checkStatus<Zdo.ClusterId.NETWORK_ADDRESS_RESPONSE>(resp.zdo)) {
|
|
624
|
+
// srcEUI64 = resp.zdo[1].eui64;
|
|
625
|
+
// }
|
|
626
|
+
}
|
|
627
|
+
else if (resp.clusterId === Zdo.ClusterId.END_DEVICE_ANNOUNCE) {
|
|
628
|
+
// XXX: using same response for announce (handled by controller) or joined depending on permit join status?
|
|
629
|
+
// TODO(mpi): Clarify with core devs, I don't think the adapter should do this?!
|
|
630
|
+
if (this.joinPermitted === true && Zdo.Buffalo.checkStatus(resp.zdo)) {
|
|
631
|
+
const payload = resp.zdo[1];
|
|
632
|
+
this.emit("deviceJoined", { networkAddress: payload.nwkAddress, ieeeAddr: payload.eui64 });
|
|
633
|
+
}
|
|
634
|
+
}
|
|
635
|
+
// TODO(mpi) it seems that the controller is only interested in NWK, IEEE and DeviceAnnounce command
|
|
636
|
+
// So maybe we should filter here?
|
|
637
|
+
this.emit("zdoResponse", resp.clusterId, resp.zdo);
|
|
638
|
+
}
|
|
639
|
+
}
|
|
640
|
+
else {
|
|
641
|
+
header = Zcl.Header.fromBuffer(resp.asduPayload);
|
|
642
|
+
if (!header) {
|
|
643
|
+
logger_1.logger.debug("Failed tp parse ZCL header of non ZDO command", NS);
|
|
644
|
+
}
|
|
645
|
+
}
|
|
646
|
+
let i = this.openRequestsQueue.length;
|
|
647
|
+
while (i--) {
|
|
648
|
+
const req = this.openRequestsQueue[i];
|
|
649
|
+
if (req.profileId !== resp.profileId) {
|
|
650
|
+
continue;
|
|
651
|
+
}
|
|
652
|
+
if (req.profileId === Zdo.ZDO_PROFILE_ID) {
|
|
653
|
+
if (req.clusterId !== resp.clusterId) {
|
|
654
|
+
continue;
|
|
655
|
+
}
|
|
656
|
+
if (req.transactionSequenceNumber !== resp.asduPayload[0]) {
|
|
657
|
+
continue; // ZDP sequence number in first byte
|
|
658
|
+
}
|
|
659
|
+
}
|
|
660
|
+
else if (header) {
|
|
661
|
+
if (header.transactionSequenceNumber !== req.transactionSequenceNumber) {
|
|
662
|
+
continue;
|
|
663
|
+
}
|
|
664
|
+
if (req.clusterId !== resp.clusterId) {
|
|
665
|
+
continue;
|
|
666
|
+
}
|
|
667
|
+
}
|
|
668
|
+
else {
|
|
669
|
+
continue; // We should always have a valid transactionId (ZDO and ZCL)
|
|
670
|
+
}
|
|
671
|
+
this.openRequestsQueue.splice(i, 1);
|
|
672
|
+
req.resolve(resp);
|
|
673
|
+
}
|
|
674
|
+
if (resp.profileId !== Zdo.ZDO_PROFILE_ID) {
|
|
675
|
+
let groupID = 0;
|
|
676
|
+
let wasBroadCast = false;
|
|
677
|
+
if (resp.destAddrMode === constants_1.ApsAddressMode.Group) {
|
|
678
|
+
groupID = resp.destAddr16;
|
|
679
|
+
wasBroadCast = true;
|
|
680
|
+
}
|
|
681
|
+
else if (resp.destAddrMode === constants_1.ApsAddressMode.Nwk && resp.destAddr16 >= constants_1.NwkBroadcastAddress.BroadcastLowPowerRouters) {
|
|
682
|
+
wasBroadCast = true;
|
|
683
|
+
}
|
|
684
|
+
const payload = {
|
|
685
|
+
clusterID: resp.clusterId,
|
|
686
|
+
header,
|
|
687
|
+
data: resp.asduPayload,
|
|
688
|
+
address: resp.srcAddr16,
|
|
689
|
+
endpoint: resp.srcEndpoint,
|
|
690
|
+
linkquality: resp.lqi,
|
|
691
|
+
groupID: groupID,
|
|
692
|
+
wasBroadcast: wasBroadCast,
|
|
693
|
+
destinationEndpoint: resp.destEndpoint,
|
|
694
|
+
};
|
|
695
|
+
this.waitress.resolve(payload);
|
|
696
|
+
this.emit("zclPayload", payload);
|
|
697
|
+
}
|
|
698
|
+
}
|
|
699
|
+
nextTransactionID() {
|
|
700
|
+
return this.driver.nextTransactionID();
|
|
701
|
+
}
|
|
702
|
+
waitressTimeoutFormatter(matcher, timeout) {
|
|
703
|
+
return (`Timeout - ${matcher.address} - ${matcher.endpoint}` +
|
|
704
|
+
` - ${matcher.transactionSequenceNumber} - ${matcher.clusterID}` +
|
|
705
|
+
` - ${matcher.commandIdentifier} after ${timeout}ms`);
|
|
706
|
+
}
|
|
707
|
+
waitressValidator(payload, matcher) {
|
|
708
|
+
return Boolean(payload.header &&
|
|
709
|
+
(!matcher.address || payload.address === matcher.address) &&
|
|
710
|
+
payload.endpoint === matcher.endpoint &&
|
|
711
|
+
(matcher.transactionSequenceNumber === undefined || payload.header.transactionSequenceNumber === matcher.transactionSequenceNumber) &&
|
|
712
|
+
payload.clusterID === matcher.clusterID &&
|
|
713
|
+
matcher.frameType === payload.header.frameControl.frameType &&
|
|
714
|
+
matcher.commandIdentifier === payload.header.commandIdentifier &&
|
|
715
|
+
matcher.direction === payload.header.frameControl.direction);
|
|
716
|
+
}
|
|
717
|
+
}
|
|
718
|
+
exports.DeconzAdapter = DeconzAdapter;
|
|
719
|
+
//# sourceMappingURL=deconzAdapter.js.map
|