@willieee802/zigbee-herdsman 0.49.1 → 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/dist/adapter/adapter.d.ts +66 -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.js +646 -0
- package/dist/adapter/adapterDiscovery.js.map +1 -0
- package/dist/adapter/const.d.ts +9 -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.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.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.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.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.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.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.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.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.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.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.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.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.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.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.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.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.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.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.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.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/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.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.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/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.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.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.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/database.d.ts +21 -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/greenPower.d.ts +78 -0
- package/dist/controller/helpers/index.d.ts +2 -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/request.d.ts +22 -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.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/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.js +9 -0
- package/dist/controller/index.js.map +1 -0
- package/dist/controller/model/device.d.ts +150 -0
- package/dist/controller/model/endpoint.d.ts +150 -0
- package/dist/controller/model/entity.d.ts +18 -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/index.d.ts +6 -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.js +11 -0
- package/dist/controller/model/zigbeeEntity.js.map +1 -0
- package/dist/controller/touchlink.d.ts +20 -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/index.d.ts +13 -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/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/definition/cluster.d.ts +3 -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/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/index.d.ts +12 -0
- package/dist/zspec/zcl/utils.d.ts +15 -0
- package/dist/zspec/zcl/zclFrame.d.ts +49 -0
- package/dist/zspec/zcl/zclHeader.d.ts +16 -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 +1 -1
|
@@ -0,0 +1,924 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.ZStackAdapter = void 0;
|
|
40
|
+
const node_assert_1 = __importDefault(require("node:assert"));
|
|
41
|
+
const debounce_1 = __importDefault(require("debounce"));
|
|
42
|
+
const utils_1 = require("../../../utils");
|
|
43
|
+
const logger_1 = require("../../../utils/logger");
|
|
44
|
+
const ZSpec = __importStar(require("../../../zspec"));
|
|
45
|
+
const Zcl = __importStar(require("../../../zspec/zcl"));
|
|
46
|
+
const Zdo = __importStar(require("../../../zspec/zdo"));
|
|
47
|
+
const adapter_1 = __importDefault(require("../../adapter"));
|
|
48
|
+
const Constants = __importStar(require("../constants"));
|
|
49
|
+
const unpi_1 = require("../unpi");
|
|
50
|
+
const znp_1 = require("../znp");
|
|
51
|
+
const definition_1 = __importDefault(require("../znp/definition"));
|
|
52
|
+
const utils_2 = require("../znp/utils");
|
|
53
|
+
const endpoints_1 = require("./endpoints");
|
|
54
|
+
const manager_1 = require("./manager");
|
|
55
|
+
const tstype_1 = require("./tstype");
|
|
56
|
+
const NS = "zh:zstack";
|
|
57
|
+
const Subsystem = unpi_1.Constants.Subsystem;
|
|
58
|
+
const Type = unpi_1.Constants.Type;
|
|
59
|
+
const { ZnpCommandStatus, AddressMode } = Constants.COMMON;
|
|
60
|
+
const DataConfirmTimeout = 9999; // Not an actual code
|
|
61
|
+
class DataConfirmError extends Error {
|
|
62
|
+
code;
|
|
63
|
+
constructor(code) {
|
|
64
|
+
const error = code === DataConfirmTimeout ? "'TIMEOUT'" : `'${ZnpCommandStatus[code]}' (0x${code.toString(16)})`;
|
|
65
|
+
const message = `Data request failed with error: ${error}`;
|
|
66
|
+
super(message);
|
|
67
|
+
this.code = code;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
class ZStackAdapter extends adapter_1.default {
|
|
71
|
+
deviceAnnounceRouteDiscoveryDebouncers;
|
|
72
|
+
znp;
|
|
73
|
+
// @ts-expect-error initialized in `start`
|
|
74
|
+
adapterManager;
|
|
75
|
+
transactionID;
|
|
76
|
+
// @ts-expect-error initialized in `start`
|
|
77
|
+
version;
|
|
78
|
+
closing;
|
|
79
|
+
// @ts-expect-error initialized in `start`
|
|
80
|
+
queue;
|
|
81
|
+
supportsLED;
|
|
82
|
+
interpanLock;
|
|
83
|
+
interpanEndpointRegistered;
|
|
84
|
+
waitress;
|
|
85
|
+
konnextConfig;
|
|
86
|
+
constructor(networkOptions, serialPortOptions, backupPath, adapterOptions, konnextConfig) {
|
|
87
|
+
super(networkOptions, serialPortOptions, backupPath, adapterOptions);
|
|
88
|
+
this.hasZdoMessageOverhead = false;
|
|
89
|
+
this.manufacturerID = Zcl.ManufacturerCode.TEXAS_INSTRUMENTS;
|
|
90
|
+
// biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
|
|
91
|
+
this.znp = new znp_1.Znp(this.serialPortOptions.path, this.serialPortOptions.baudRate, this.serialPortOptions.rtscts, konnextConfig);
|
|
92
|
+
this.konnextConfig = konnextConfig;
|
|
93
|
+
this.transactionID = 0;
|
|
94
|
+
this.deviceAnnounceRouteDiscoveryDebouncers = new Map();
|
|
95
|
+
this.interpanLock = false;
|
|
96
|
+
this.interpanEndpointRegistered = false;
|
|
97
|
+
this.closing = false;
|
|
98
|
+
this.waitress = new utils_1.Waitress(this.waitressValidator, this.waitressTimeoutFormatter);
|
|
99
|
+
this.znp.on("received", this.onZnpRecieved.bind(this));
|
|
100
|
+
this.znp.on("close", this.onZnpClose.bind(this));
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Adapter methods
|
|
104
|
+
*/
|
|
105
|
+
async start() {
|
|
106
|
+
await this.znp.open();
|
|
107
|
+
const attempts = 3;
|
|
108
|
+
for (let i = 0; i < attempts; i++) {
|
|
109
|
+
try {
|
|
110
|
+
await this.znp.request(Subsystem.SYS, "ping", { capabilities: 1 });
|
|
111
|
+
break;
|
|
112
|
+
}
|
|
113
|
+
catch (e) {
|
|
114
|
+
if (attempts - 1 === i) {
|
|
115
|
+
throw new Error(`Failed to connect to the adapter (${e})`);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
// Old firmware did not support version, assume it's Z-Stack 1.2 for now.
|
|
120
|
+
try {
|
|
121
|
+
this.version = (await this.znp.requestWithReply(Subsystem.SYS, "version", {})).payload;
|
|
122
|
+
}
|
|
123
|
+
catch {
|
|
124
|
+
logger_1.logger.debug("Failed to get zStack version, assuming 1.2", NS);
|
|
125
|
+
this.version = { transportrev: 2, product: 0, majorrel: 2, minorrel: 0, maintrel: 0, revision: "" };
|
|
126
|
+
}
|
|
127
|
+
const concurrent = this.adapterOptions?.concurrent ? this.adapterOptions.concurrent : this.version.product === tstype_1.ZnpVersion.ZStack3x0 ? 16 : 2;
|
|
128
|
+
logger_1.logger.debug(`Adapter concurrent: ${concurrent}`, NS);
|
|
129
|
+
this.queue = new utils_1.Queue(concurrent);
|
|
130
|
+
logger_1.logger.debug(() => `Detected znp version '${tstype_1.ZnpVersion[this.version.product]}' (${JSON.stringify(this.version)})`, NS);
|
|
131
|
+
this.adapterManager = new manager_1.ZnpAdapterManager(this, this.znp, {
|
|
132
|
+
backupPath: this.backupPath,
|
|
133
|
+
version: this.version.product,
|
|
134
|
+
greenPowerGroup: ZSpec.GP_GROUP_ID,
|
|
135
|
+
networkOptions: this.networkOptions,
|
|
136
|
+
adapterOptions: this.adapterOptions,
|
|
137
|
+
});
|
|
138
|
+
const startResult = this.adapterManager.start();
|
|
139
|
+
if (this.adapterOptions.disableLED) {
|
|
140
|
+
// Wait a bit for adapter to startup, otherwise led doesn't disable (tested with CC2531)
|
|
141
|
+
await (0, utils_1.wait)(200);
|
|
142
|
+
await this.setLED("disable");
|
|
143
|
+
}
|
|
144
|
+
if (this.adapterOptions.transmitPower != null) {
|
|
145
|
+
await this.znp.request(Subsystem.SYS, "stackTune", { operation: 0, value: this.adapterOptions.transmitPower });
|
|
146
|
+
}
|
|
147
|
+
return await startResult;
|
|
148
|
+
}
|
|
149
|
+
async stop() {
|
|
150
|
+
this.closing = true;
|
|
151
|
+
await this.znp.close();
|
|
152
|
+
}
|
|
153
|
+
async getCoordinatorIEEE() {
|
|
154
|
+
return await this.queue.execute(async () => {
|
|
155
|
+
this.checkInterpanLock();
|
|
156
|
+
const deviceInfo = await this.znp.requestWithReply(Subsystem.UTIL, "getDeviceInfo", {});
|
|
157
|
+
return deviceInfo.payload.ieeeaddr;
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
async getCoordinatorVersion() {
|
|
161
|
+
return await Promise.resolve({ type: tstype_1.ZnpVersion[this.version.product], meta: this.version });
|
|
162
|
+
}
|
|
163
|
+
async permitJoin(seconds, networkAddress) {
|
|
164
|
+
const clusterId = Zdo.ClusterId.PERMIT_JOINING_REQUEST;
|
|
165
|
+
// `authentication`: TC significance always 1 (zb specs)
|
|
166
|
+
const zdoPayload = Zdo.Buffalo.buildRequest(this.hasZdoMessageOverhead, clusterId, seconds, 1, []);
|
|
167
|
+
if (networkAddress === undefined) {
|
|
168
|
+
await this.sendZdo(ZSpec.BLANK_EUI64, ZSpec.BroadcastAddress.DEFAULT, clusterId, zdoPayload, true);
|
|
169
|
+
}
|
|
170
|
+
else {
|
|
171
|
+
// NOTE: `sendZdo` takes care of adjusting the payload as appropriate based on `networkAddress === 0` or not
|
|
172
|
+
const result = await this.sendZdo(ZSpec.BLANK_EUI64, networkAddress, clusterId, zdoPayload, false);
|
|
173
|
+
/* v8 ignore start */
|
|
174
|
+
if (!Zdo.Buffalo.checkStatus(result)) {
|
|
175
|
+
// TODO: will disappear once moved upstream
|
|
176
|
+
throw new Zdo.StatusError(result[0]);
|
|
177
|
+
}
|
|
178
|
+
/* v8 ignore stop */
|
|
179
|
+
}
|
|
180
|
+
await this.queue.execute(async () => {
|
|
181
|
+
this.checkInterpanLock();
|
|
182
|
+
await this.setLED(seconds === 0 ? "off" : "on");
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
async reset(type) {
|
|
186
|
+
if (type === "soft") {
|
|
187
|
+
await this.znp.request(Subsystem.SYS, "resetReq", { type: Constants.SYS.resetType.SOFT });
|
|
188
|
+
}
|
|
189
|
+
else {
|
|
190
|
+
await this.znp.request(Subsystem.SYS, "resetReq", { type: Constants.SYS.resetType.HARD });
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
async setLED(action) {
|
|
194
|
+
if (this.supportsLED == null) {
|
|
195
|
+
// Only zStack3x0 with 20210430 and greater support LED
|
|
196
|
+
const zStack3x0 = this.version.product === tstype_1.ZnpVersion.ZStack3x0;
|
|
197
|
+
this.supportsLED = !zStack3x0 || (zStack3x0 && Number.parseInt(this.version.revision, 10) >= 20210430);
|
|
198
|
+
}
|
|
199
|
+
if (!this.supportsLED || (this.adapterOptions.disableLED && action !== "disable")) {
|
|
200
|
+
return;
|
|
201
|
+
}
|
|
202
|
+
// Firmwares build on and after 20211029 should handle LED themselves
|
|
203
|
+
const firmwareControlsLed = Number.parseInt(this.version.revision, 10) >= 20211029;
|
|
204
|
+
const lookup = {
|
|
205
|
+
disable: firmwareControlsLed ? { ledid: 0xff, mode: 5 } : { ledid: 3, mode: 0 },
|
|
206
|
+
on: firmwareControlsLed ? null : { ledid: 3, mode: 1 },
|
|
207
|
+
off: firmwareControlsLed ? null : { ledid: 3, mode: 0 },
|
|
208
|
+
};
|
|
209
|
+
const payload = lookup[action];
|
|
210
|
+
if (payload) {
|
|
211
|
+
await this.znp.request(Subsystem.UTIL, "ledControl", payload, undefined, 500).catch(() => {
|
|
212
|
+
// We cannot 100% correctly determine if an adapter supports LED. E.g. the zStack 1.2 20190608
|
|
213
|
+
// fw supports led on the CC2531 but not on the CC2530. Therefore if a led request fails never thrown
|
|
214
|
+
// an error but instead mark the led as unsupported.
|
|
215
|
+
// https://github.com/Koenkk/zigbee-herdsman/issues/377
|
|
216
|
+
// https://github.com/Koenkk/zigbee2mqtt/issues/7693
|
|
217
|
+
this.supportsLED = false;
|
|
218
|
+
});
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
async requestNetworkAddress(ieeeAddr) {
|
|
222
|
+
/**
|
|
223
|
+
* NOTE: There are cases where multiple nwkAddrRsp are recevied with different network addresses,
|
|
224
|
+
* this is currently not handled, the first nwkAddrRsp is taken.
|
|
225
|
+
*/
|
|
226
|
+
logger_1.logger.debug(`Request network address of '${ieeeAddr}'`, NS);
|
|
227
|
+
const clusterId = Zdo.ClusterId.NETWORK_ADDRESS_REQUEST;
|
|
228
|
+
const zdoPayload = Zdo.Buffalo.buildRequest(this.hasZdoMessageOverhead, clusterId, ieeeAddr, false, 0);
|
|
229
|
+
const result = await this.sendZdoInternal(ieeeAddr, ZSpec.NULL_NODE_ID, clusterId, zdoPayload, false, true);
|
|
230
|
+
if (Zdo.Buffalo.checkStatus(result)) {
|
|
231
|
+
return result[1].nwkAddress;
|
|
232
|
+
/* v8 ignore start */
|
|
233
|
+
}
|
|
234
|
+
// TODO: will disappear once moved upstream
|
|
235
|
+
throw new Zdo.StatusError(result[0]);
|
|
236
|
+
/* v8 ignore stop */
|
|
237
|
+
}
|
|
238
|
+
supportsAssocRemove() {
|
|
239
|
+
return this.version.product === tstype_1.ZnpVersion.ZStack3x0 && Number.parseInt(this.version.revision, 10) >= 20200805;
|
|
240
|
+
}
|
|
241
|
+
supportsAssocAdd() {
|
|
242
|
+
return this.version.product === tstype_1.ZnpVersion.ZStack3x0 && Number.parseInt(this.version.revision, 10) >= 20201026;
|
|
243
|
+
}
|
|
244
|
+
async discoverRoute(networkAddress, waitSettled = true) {
|
|
245
|
+
logger_1.logger.debug(`Discovering route to ${networkAddress}`, NS);
|
|
246
|
+
const payload = { dstAddr: networkAddress, options: 0, radius: Constants.AF.DEFAULT_RADIUS };
|
|
247
|
+
await this.znp.request(Subsystem.ZDO, "extRouteDisc", payload);
|
|
248
|
+
if (waitSettled) {
|
|
249
|
+
await (0, utils_1.wait)(3000);
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
/**
|
|
253
|
+
* Retrieve all data for AF_INCOMING_MSG_EXT with huge data byte count.
|
|
254
|
+
*
|
|
255
|
+
* @param timestamp
|
|
256
|
+
* @param length full data length
|
|
257
|
+
*
|
|
258
|
+
* @returns Buffer containing the full data or undefined on error
|
|
259
|
+
*/
|
|
260
|
+
async dataRetrieveAll(timestamp, length) {
|
|
261
|
+
const buf = Buffer.alloc(length);
|
|
262
|
+
const blockSize = 240;
|
|
263
|
+
const freeExtMessage = async () => {
|
|
264
|
+
// A length of zero is special and triggers the freeing of
|
|
265
|
+
// the corresponding incoming message.
|
|
266
|
+
await this.znp.requestWithReply(Subsystem.AF, "dataRetrieve", { timestamp: timestamp, index: 0, length: 0 });
|
|
267
|
+
};
|
|
268
|
+
for (let index = 0; index < length; index += blockSize) {
|
|
269
|
+
const chunkSize = Math.min(blockSize, length - index);
|
|
270
|
+
const rsp = await this.znp.requestWithReply(Subsystem.AF, "dataRetrieve", {
|
|
271
|
+
timestamp: timestamp,
|
|
272
|
+
index: index,
|
|
273
|
+
length: chunkSize,
|
|
274
|
+
}, undefined);
|
|
275
|
+
// 0x00 = afStatus_SUCCESS
|
|
276
|
+
if (rsp.payload.status !== 0x00) {
|
|
277
|
+
logger_1.logger.error(`dataRetrieve [timestamp: ${timestamp}, index: ${index}, chunkSize: ${chunkSize}] error status: ${rsp.payload.status}`, NS);
|
|
278
|
+
await freeExtMessage();
|
|
279
|
+
return undefined;
|
|
280
|
+
}
|
|
281
|
+
if (rsp.payload.length !== chunkSize) {
|
|
282
|
+
logger_1.logger.error(`dataRetrieve length mismatch [${chunkSize} requested, ${rsp.payload.length} returned`, NS);
|
|
283
|
+
await freeExtMessage();
|
|
284
|
+
return undefined;
|
|
285
|
+
}
|
|
286
|
+
rsp.payload.data.copy(buf, index);
|
|
287
|
+
}
|
|
288
|
+
await freeExtMessage();
|
|
289
|
+
return buf;
|
|
290
|
+
}
|
|
291
|
+
async sendZdo(ieeeAddress, networkAddress, clusterId, payload, disableResponse) {
|
|
292
|
+
return await this.sendZdoInternal(ieeeAddress, networkAddress, clusterId, payload, disableResponse, false);
|
|
293
|
+
}
|
|
294
|
+
async sendZdoInternal(ieeeAddress, networkAddress, clusterId, payload, disableResponse, skipQueue) {
|
|
295
|
+
const func = async () => {
|
|
296
|
+
this.checkInterpanLock();
|
|
297
|
+
// stack-specific requirements
|
|
298
|
+
switch (clusterId) {
|
|
299
|
+
case Zdo.ClusterId.PERMIT_JOINING_REQUEST: {
|
|
300
|
+
const finalPayload = Buffer.alloc(payload.length + 3);
|
|
301
|
+
finalPayload.writeUInt8(ZSpec.BroadcastAddress[networkAddress] ? AddressMode.ADDR_BROADCAST : AddressMode.ADDR_16BIT, 0);
|
|
302
|
+
// zstack uses AddressMode.ADDR_16BIT + ZSpec.BroadcastAddress.DEFAULT to signal "coordinator-only"
|
|
303
|
+
finalPayload.writeUInt16LE(networkAddress === 0 ? ZSpec.BroadcastAddress.DEFAULT : networkAddress, 1);
|
|
304
|
+
finalPayload.set(payload, 3);
|
|
305
|
+
payload = finalPayload;
|
|
306
|
+
break;
|
|
307
|
+
}
|
|
308
|
+
case Zdo.ClusterId.NWK_UPDATE_REQUEST: {
|
|
309
|
+
// extra zeroes for empty nwkManagerAddr if necessary
|
|
310
|
+
const zeroes = 9 - payload.length - 1; /* zstack doesn't have nwkUpdateId */
|
|
311
|
+
const finalPayload = Buffer.alloc(payload.length + 3 + zeroes);
|
|
312
|
+
finalPayload.writeUInt16LE(networkAddress, 0);
|
|
313
|
+
finalPayload.writeUInt8(ZSpec.BroadcastAddress[networkAddress] ? AddressMode.ADDR_BROADCAST : AddressMode.ADDR_16BIT, 2);
|
|
314
|
+
finalPayload.set(payload, 3);
|
|
315
|
+
payload = finalPayload;
|
|
316
|
+
break;
|
|
317
|
+
}
|
|
318
|
+
case Zdo.ClusterId.BIND_REQUEST:
|
|
319
|
+
case Zdo.ClusterId.UNBIND_REQUEST: {
|
|
320
|
+
// extra zeroes for uint16 (in place of ieee when MULTICAST) and endpoint (not used when MULTICAST)
|
|
321
|
+
const zeroes = 21 - payload.length;
|
|
322
|
+
const finalPayload = Buffer.alloc(payload.length + 2 + zeroes);
|
|
323
|
+
finalPayload.writeUInt16LE(networkAddress, 0);
|
|
324
|
+
finalPayload.set(payload, 2);
|
|
325
|
+
payload = finalPayload;
|
|
326
|
+
break;
|
|
327
|
+
}
|
|
328
|
+
case Zdo.ClusterId.NETWORK_ADDRESS_REQUEST:
|
|
329
|
+
case Zdo.ClusterId.IEEE_ADDRESS_REQUEST: {
|
|
330
|
+
// no modification necessary
|
|
331
|
+
break;
|
|
332
|
+
}
|
|
333
|
+
default: {
|
|
334
|
+
const finalPayload = Buffer.alloc(payload.length + 2);
|
|
335
|
+
finalPayload.writeUInt16LE(networkAddress, 0);
|
|
336
|
+
finalPayload.set(payload, 2);
|
|
337
|
+
payload = finalPayload;
|
|
338
|
+
break;
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
let waiter;
|
|
342
|
+
if (!disableResponse) {
|
|
343
|
+
const responseClusterId = Zdo.Utils.getResponseClusterId(clusterId);
|
|
344
|
+
if (responseClusterId) {
|
|
345
|
+
const cmd = definition_1.default[Subsystem.ZDO].find((c) => (0, utils_2.isMtCmdAreqZdo)(c) && c.zdoClusterId === responseClusterId);
|
|
346
|
+
(0, node_assert_1.default)(cmd, `Response for ZDO cluster ID '${responseClusterId}' not supported.`);
|
|
347
|
+
waiter = this.znp.waitFor(unpi_1.Constants.Type.AREQ, Subsystem.ZDO, cmd.name, responseClusterId === Zdo.ClusterId.NETWORK_ADDRESS_RESPONSE ? ieeeAddress : networkAddress, undefined, undefined);
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
try {
|
|
351
|
+
await this.znp.requestZdo(clusterId, payload, waiter?.ID);
|
|
352
|
+
}
|
|
353
|
+
catch (error) {
|
|
354
|
+
if (clusterId === Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST) {
|
|
355
|
+
// Discover route when node descriptor request fails
|
|
356
|
+
// https://github.com/Koenkk/zigbee2mqtt/issues/3276
|
|
357
|
+
logger_1.logger.debug(`Discover route to '${networkAddress}' because node descriptor request failed`, NS);
|
|
358
|
+
await this.discoverRoute(networkAddress);
|
|
359
|
+
await this.znp.requestZdo(clusterId, payload, /* v8 ignore next */ waiter?.ID);
|
|
360
|
+
}
|
|
361
|
+
else {
|
|
362
|
+
throw error;
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
if (waiter) {
|
|
366
|
+
const response = await waiter.start().promise;
|
|
367
|
+
return response.payload.zdo;
|
|
368
|
+
}
|
|
369
|
+
};
|
|
370
|
+
return skipQueue ? await func() : await this.queue.execute(func, networkAddress);
|
|
371
|
+
}
|
|
372
|
+
async sendZclFrameToEndpoint(ieeeAddr, networkAddress, endpoint, zclFrame, timeout, disableResponse, disableRecovery, sourceEndpoint, profileId) {
|
|
373
|
+
const srcEndpoint = this.selectSourceEndpoint(sourceEndpoint, profileId);
|
|
374
|
+
return await this.queue.execute(async () => {
|
|
375
|
+
this.checkInterpanLock();
|
|
376
|
+
return await this.sendZclFrameToEndpointInternal(ieeeAddr, networkAddress, endpoint, srcEndpoint, zclFrame, timeout, disableResponse, disableRecovery, 0, 0, false, false, false, undefined);
|
|
377
|
+
}, networkAddress);
|
|
378
|
+
}
|
|
379
|
+
async sendZclFrameToEndpointInternal(ieeeAddr, networkAddress, endpoint, sourceEndpoint, zclFrame, timeout, disableResponse, disableRecovery, responseAttempt, dataRequestAttempt, checkedNetworkAddress, discoveredRoute, assocRemove, assocRestore) {
|
|
380
|
+
logger_1.logger.debug(`sendZclFrameToEndpointInternal ${ieeeAddr}:${networkAddress}/${endpoint} ` +
|
|
381
|
+
`(${responseAttempt},${dataRequestAttempt},${this.queue.count()})`, NS);
|
|
382
|
+
let response = null;
|
|
383
|
+
const command = zclFrame.command;
|
|
384
|
+
if (command.response !== undefined && disableResponse === false) {
|
|
385
|
+
response = this.waitForInternal(networkAddress, endpoint, zclFrame.header.frameControl.frameType, Zcl.Direction.SERVER_TO_CLIENT, zclFrame.header.transactionSequenceNumber, zclFrame.cluster.ID, command.response, timeout);
|
|
386
|
+
}
|
|
387
|
+
else if (!zclFrame.header.frameControl.disableDefaultResponse) {
|
|
388
|
+
response = this.waitForInternal(networkAddress, endpoint, Zcl.FrameType.GLOBAL, Zcl.Direction.SERVER_TO_CLIENT, zclFrame.header.transactionSequenceNumber, zclFrame.cluster.ID, Zcl.Foundation.defaultRsp.ID, timeout);
|
|
389
|
+
}
|
|
390
|
+
const dataConfirmResult = await this.dataRequest(networkAddress, endpoint, sourceEndpoint, zclFrame.cluster.ID, Constants.AF.DEFAULT_RADIUS, zclFrame.toBuffer(), timeout);
|
|
391
|
+
if (dataConfirmResult !== ZnpCommandStatus.SUCCESS) {
|
|
392
|
+
// In case dataConfirm timesout (= null) or gives an error, try to recover
|
|
393
|
+
logger_1.logger.debug(`Data confirm error (${ieeeAddr}:${networkAddress},${dataConfirmResult},${dataRequestAttempt})`, NS);
|
|
394
|
+
if (response !== null)
|
|
395
|
+
response.cancel();
|
|
396
|
+
/**
|
|
397
|
+
* In case we did an assocRemove in the previous attempt and it still fails after this, assume that the
|
|
398
|
+
* coordinator is still the parent of the device (but for some reason the device is not available now).
|
|
399
|
+
* Re-add the device to the assoc table, otherwise we will never be able to reach it anymore.
|
|
400
|
+
*/
|
|
401
|
+
if (assocRemove && assocRestore && this.supportsAssocAdd()) {
|
|
402
|
+
logger_1.logger.debug(`assocAdd(${assocRestore.ieeeadr})`, NS);
|
|
403
|
+
await this.znp.request(Subsystem.UTIL, "assocAdd", assocRestore);
|
|
404
|
+
assocRestore = undefined;
|
|
405
|
+
}
|
|
406
|
+
const recoverableErrors = [
|
|
407
|
+
ZnpCommandStatus.NWK_NO_ROUTE,
|
|
408
|
+
ZnpCommandStatus.MAC_NO_ACK,
|
|
409
|
+
ZnpCommandStatus.MAC_CHANNEL_ACCESS_FAILURE,
|
|
410
|
+
ZnpCommandStatus.MAC_TRANSACTION_EXPIRED,
|
|
411
|
+
ZnpCommandStatus.BUFFER_FULL,
|
|
412
|
+
ZnpCommandStatus.MAC_NO_RESOURCES,
|
|
413
|
+
];
|
|
414
|
+
if (dataRequestAttempt >= 4 || !recoverableErrors.includes(dataConfirmResult) || disableRecovery) {
|
|
415
|
+
throw new DataConfirmError(dataConfirmResult);
|
|
416
|
+
}
|
|
417
|
+
if (dataConfirmResult === ZnpCommandStatus.MAC_CHANNEL_ACCESS_FAILURE ||
|
|
418
|
+
dataConfirmResult === ZnpCommandStatus.BUFFER_FULL ||
|
|
419
|
+
dataConfirmResult === ZnpCommandStatus.MAC_NO_RESOURCES) {
|
|
420
|
+
/**
|
|
421
|
+
* MAC_CHANNEL_ACCESS_FAILURE: When many commands at once are executed we can end up in a MAC
|
|
422
|
+
* channel access failure error. This is because there is too much traffic on the network.
|
|
423
|
+
* Retry this command once after a cooling down period.
|
|
424
|
+
* BUFFER_FULL: When many commands are executed at once the buffer can get full, wait
|
|
425
|
+
* some time and retry.
|
|
426
|
+
* MAC_NO_RESOURCES: Operation could not be completed because no memory resources are available,
|
|
427
|
+
* wait some time and retry.
|
|
428
|
+
*/
|
|
429
|
+
await (0, utils_1.wait)(2000);
|
|
430
|
+
return await this.sendZclFrameToEndpointInternal(ieeeAddr, networkAddress, endpoint, sourceEndpoint, zclFrame, timeout, disableResponse, disableRecovery, responseAttempt, dataRequestAttempt + 1, checkedNetworkAddress, discoveredRoute, assocRemove, assocRestore);
|
|
431
|
+
}
|
|
432
|
+
let doAssocRemove = false;
|
|
433
|
+
if (!assocRemove &&
|
|
434
|
+
dataConfirmResult === ZnpCommandStatus.MAC_TRANSACTION_EXPIRED &&
|
|
435
|
+
dataRequestAttempt >= 1 &&
|
|
436
|
+
this.supportsAssocRemove()) {
|
|
437
|
+
const match = await this.znp.requestWithReply(Subsystem.UTIL, "assocGetWithAddress", {
|
|
438
|
+
extaddr: ieeeAddr,
|
|
439
|
+
nwkaddr: networkAddress,
|
|
440
|
+
});
|
|
441
|
+
if (match.payload.nwkaddr !== 0xfffe && match.payload.noderelation !== 255) {
|
|
442
|
+
doAssocRemove = true;
|
|
443
|
+
assocRestore = { ieeeadr: ieeeAddr, nwkaddr: networkAddress, noderelation: match.payload.noderelation };
|
|
444
|
+
}
|
|
445
|
+
assocRemove = true;
|
|
446
|
+
}
|
|
447
|
+
// NWK_NO_ROUTE: no network route => rediscover route
|
|
448
|
+
// MAC_NO_ACK: route may be corrupted
|
|
449
|
+
// MAC_TRANSACTION_EXPIRED: Mac layer is sleeping
|
|
450
|
+
if (doAssocRemove) {
|
|
451
|
+
/**
|
|
452
|
+
* Since child aging is disabled on the firmware, when a end device is directly connected
|
|
453
|
+
* to the coordinator and changes parent and the coordinator does not recevie this update,
|
|
454
|
+
* it still thinks it's directly connected.
|
|
455
|
+
* A discoverRoute() is not send out in this case, therefore remove it from the associated device
|
|
456
|
+
* list and try again.
|
|
457
|
+
* Note: assocRemove is a custom command, not available by default, only available on recent
|
|
458
|
+
* z-stack-firmware firmware version. In case it's not supported by the coordinator we will
|
|
459
|
+
* automatically timeout after 60000ms.
|
|
460
|
+
*/
|
|
461
|
+
logger_1.logger.debug(`assocRemove(${ieeeAddr})`, NS);
|
|
462
|
+
await this.znp.request(Subsystem.UTIL, "assocRemove", { ieeeadr: ieeeAddr });
|
|
463
|
+
}
|
|
464
|
+
else if (!discoveredRoute && dataRequestAttempt >= 1) {
|
|
465
|
+
discoveredRoute = true;
|
|
466
|
+
await this.discoverRoute(networkAddress);
|
|
467
|
+
}
|
|
468
|
+
else if (!checkedNetworkAddress && dataRequestAttempt >= 1) {
|
|
469
|
+
// Figure out once if the network address has been changed.
|
|
470
|
+
try {
|
|
471
|
+
checkedNetworkAddress = true;
|
|
472
|
+
const actualNetworkAddress = await this.requestNetworkAddress(ieeeAddr);
|
|
473
|
+
if (networkAddress !== actualNetworkAddress) {
|
|
474
|
+
logger_1.logger.debug("Failed because request was done with wrong network address", NS);
|
|
475
|
+
discoveredRoute = true;
|
|
476
|
+
networkAddress = actualNetworkAddress;
|
|
477
|
+
await this.discoverRoute(actualNetworkAddress);
|
|
478
|
+
}
|
|
479
|
+
else {
|
|
480
|
+
logger_1.logger.debug("Network address did not change", NS);
|
|
481
|
+
}
|
|
482
|
+
/* v8 ignore start */
|
|
483
|
+
}
|
|
484
|
+
catch {
|
|
485
|
+
/* empty */
|
|
486
|
+
}
|
|
487
|
+
/* v8 ignore stop */
|
|
488
|
+
}
|
|
489
|
+
else {
|
|
490
|
+
logger_1.logger.debug("Wait 2000ms", NS);
|
|
491
|
+
await (0, utils_1.wait)(2000);
|
|
492
|
+
}
|
|
493
|
+
return await this.sendZclFrameToEndpointInternal(ieeeAddr, networkAddress, endpoint, sourceEndpoint, zclFrame, timeout, disableResponse, disableRecovery, responseAttempt, dataRequestAttempt + 1, checkedNetworkAddress, discoveredRoute, assocRemove, assocRestore);
|
|
494
|
+
}
|
|
495
|
+
if (response !== null) {
|
|
496
|
+
try {
|
|
497
|
+
const result = await response.start().promise;
|
|
498
|
+
return result;
|
|
499
|
+
}
|
|
500
|
+
catch (error) {
|
|
501
|
+
logger_1.logger.debug(`Response timeout (${ieeeAddr}:${networkAddress},${responseAttempt})`, NS);
|
|
502
|
+
if (responseAttempt < 1 && !disableRecovery) {
|
|
503
|
+
// No response could be because the radio of the end device is turned off:
|
|
504
|
+
// Sometimes the coordinator does not properly set the PENDING flag.
|
|
505
|
+
// Try to rewrite the device entry in the association table, this fixes it sometimes.
|
|
506
|
+
const match = await this.znp.requestWithReply(Subsystem.UTIL, "assocGetWithAddress", {
|
|
507
|
+
extaddr: ieeeAddr,
|
|
508
|
+
nwkaddr: networkAddress,
|
|
509
|
+
});
|
|
510
|
+
logger_1.logger.debug(`Response timeout recovery: Node relation ${match.payload.noderelation} (${ieeeAddr} / ${match.payload.nwkaddr})`, NS);
|
|
511
|
+
if (this.supportsAssocAdd() &&
|
|
512
|
+
this.supportsAssocRemove() &&
|
|
513
|
+
match.payload.nwkaddr !== 0xfffe &&
|
|
514
|
+
match.payload.noderelation === 1) {
|
|
515
|
+
logger_1.logger.debug(`Response timeout recovery: Rewrite association table entry (${ieeeAddr})`, NS);
|
|
516
|
+
await this.znp.request(Subsystem.UTIL, "assocRemove", { ieeeadr: ieeeAddr });
|
|
517
|
+
await this.znp.request(Subsystem.UTIL, "assocAdd", {
|
|
518
|
+
ieeeadr: ieeeAddr,
|
|
519
|
+
nwkaddr: networkAddress,
|
|
520
|
+
noderelation: match.payload.noderelation,
|
|
521
|
+
});
|
|
522
|
+
}
|
|
523
|
+
// No response could be of invalid route, e.g. when message is send to wrong parent of end device.
|
|
524
|
+
await this.discoverRoute(networkAddress);
|
|
525
|
+
return await this.sendZclFrameToEndpointInternal(ieeeAddr, networkAddress, endpoint, sourceEndpoint, zclFrame, timeout, disableResponse, disableRecovery, responseAttempt + 1, dataRequestAttempt, checkedNetworkAddress, discoveredRoute, assocRemove, assocRestore);
|
|
526
|
+
}
|
|
527
|
+
throw error;
|
|
528
|
+
}
|
|
529
|
+
}
|
|
530
|
+
}
|
|
531
|
+
async sendZclFrameToGroup(groupID, zclFrame, sourceEndpoint, profileId) {
|
|
532
|
+
const srcEndpoint = this.selectSourceEndpoint(sourceEndpoint, profileId);
|
|
533
|
+
return await this.queue.execute(async () => {
|
|
534
|
+
this.checkInterpanLock();
|
|
535
|
+
await this.dataRequestExtended(AddressMode.ADDR_GROUP, groupID, 0xff, 0, srcEndpoint, zclFrame.cluster.ID, Constants.AF.DEFAULT_RADIUS, zclFrame.toBuffer(), 3000, true);
|
|
536
|
+
/**
|
|
537
|
+
* As a group command is not confirmed and thus immidiately returns
|
|
538
|
+
* (contrary to network address requests) we will give the
|
|
539
|
+
* command some time to 'settle' in the network.
|
|
540
|
+
*/
|
|
541
|
+
await (0, utils_1.wait)(200);
|
|
542
|
+
});
|
|
543
|
+
}
|
|
544
|
+
async sendZclFrameToAll(endpoint, zclFrame, sourceEndpoint, destination, profileId) {
|
|
545
|
+
const srcEndpoint = this.selectSourceEndpoint(sourceEndpoint, profileId);
|
|
546
|
+
return await this.queue.execute(async () => {
|
|
547
|
+
this.checkInterpanLock();
|
|
548
|
+
await this.dataRequestExtended(AddressMode.ADDR_16BIT, destination, endpoint, 0, srcEndpoint, zclFrame.cluster.ID, Constants.AF.DEFAULT_RADIUS, zclFrame.toBuffer(), 3000, false, 0);
|
|
549
|
+
/**
|
|
550
|
+
* As a broadcast command is not confirmed and thus immidiately returns
|
|
551
|
+
* (contrary to network address requests) we will give the
|
|
552
|
+
* command some time to 'settle' in the network.
|
|
553
|
+
*/
|
|
554
|
+
await (0, utils_1.wait)(200);
|
|
555
|
+
});
|
|
556
|
+
}
|
|
557
|
+
async addInstallCode(ieeeAddress, key, hashed) {
|
|
558
|
+
(0, node_assert_1.default)(this.version.product !== tstype_1.ZnpVersion.ZStack12, "Install code is not supported for ZStack 1.2 adapter");
|
|
559
|
+
// TODO: always use 0x2? => const hashedKey = hashed ? key : ZSpec.Utils.aes128MmoHash(key);
|
|
560
|
+
const payload = { installCodeFormat: hashed ? 0x2 : 0x1, ieeeaddr: ieeeAddress, installCode: key };
|
|
561
|
+
await this.znp.request(Subsystem.APP_CNF, "bdbAddInstallCode", payload);
|
|
562
|
+
}
|
|
563
|
+
/**
|
|
564
|
+
* Event handlers
|
|
565
|
+
*/
|
|
566
|
+
onZnpClose() {
|
|
567
|
+
if (!this.closing) {
|
|
568
|
+
this.emit("disconnected");
|
|
569
|
+
}
|
|
570
|
+
}
|
|
571
|
+
onZnpRecieved(object) {
|
|
572
|
+
if (object.type !== unpi_1.Constants.Type.AREQ) {
|
|
573
|
+
return;
|
|
574
|
+
}
|
|
575
|
+
if (object.subsystem === Subsystem.ZDO) {
|
|
576
|
+
if ((0, utils_2.isMtCmdAreqZdo)(object.command)) {
|
|
577
|
+
this.emit("zdoResponse", object.command.zdoClusterId, object.payload.zdo);
|
|
578
|
+
}
|
|
579
|
+
if (object.command.name === "tcDeviceInd") {
|
|
580
|
+
const payload = {
|
|
581
|
+
networkAddress: object.payload.nwkaddr,
|
|
582
|
+
ieeeAddr: object.payload.extaddr,
|
|
583
|
+
};
|
|
584
|
+
this.emit("deviceJoined", payload);
|
|
585
|
+
}
|
|
586
|
+
else if (object.command.name === "endDeviceAnnceInd") {
|
|
587
|
+
// TODO: better way???
|
|
588
|
+
if (Zdo.Buffalo.checkStatus(object.payload.zdo)) {
|
|
589
|
+
const zdoPayload = object.payload.zdo[1];
|
|
590
|
+
// Only discover routes to end devices, if bit 1 of capabilities === 0 it's an end device.
|
|
591
|
+
const isEndDevice = zdoPayload.capabilities.deviceType === 0;
|
|
592
|
+
if (isEndDevice) {
|
|
593
|
+
if (!this.deviceAnnounceRouteDiscoveryDebouncers.has(zdoPayload.nwkAddress)) {
|
|
594
|
+
// If a device announces multiple times in a very short time, it makes no sense
|
|
595
|
+
// to rediscover the route every time.
|
|
596
|
+
const debouncer = (0, debounce_1.default)(() => {
|
|
597
|
+
this.queue
|
|
598
|
+
.execute(async () => {
|
|
599
|
+
await this.discoverRoute(zdoPayload.nwkAddress, false).catch(() => { });
|
|
600
|
+
}, zdoPayload.nwkAddress)
|
|
601
|
+
.catch(() => { });
|
|
602
|
+
}, 60 * 1000, { immediate: true });
|
|
603
|
+
this.deviceAnnounceRouteDiscoveryDebouncers.set(zdoPayload.nwkAddress, debouncer);
|
|
604
|
+
}
|
|
605
|
+
const debouncer = this.deviceAnnounceRouteDiscoveryDebouncers.get(zdoPayload.nwkAddress);
|
|
606
|
+
(0, node_assert_1.default)(debouncer);
|
|
607
|
+
debouncer();
|
|
608
|
+
}
|
|
609
|
+
}
|
|
610
|
+
}
|
|
611
|
+
else if (object.command.name === "concentratorIndCb") {
|
|
612
|
+
// Some routers may change short addresses and the announcement
|
|
613
|
+
// is missed by the coordinator. This can happen when there are
|
|
614
|
+
// power outages or other interruptions in service. They may
|
|
615
|
+
// not send additional announcements, causing the device to go
|
|
616
|
+
// offline. However, those devices may instead send
|
|
617
|
+
// Concentrator Indicator Callback commands, which contain both
|
|
618
|
+
// the short and the long address allowing us to update our own
|
|
619
|
+
// mappings.
|
|
620
|
+
// https://e2e.ti.com/cfs-file/__key/communityserver-discussions-components-files/158/4403.zstacktask.c
|
|
621
|
+
// https://github.com/Koenkk/zigbee-herdsman/issues/74
|
|
622
|
+
this.emit("zdoResponse", Zdo.ClusterId.NETWORK_ADDRESS_RESPONSE, [
|
|
623
|
+
Zdo.Status.SUCCESS,
|
|
624
|
+
{
|
|
625
|
+
eui64: object.payload.extaddr,
|
|
626
|
+
nwkAddress: object.payload.srcaddr,
|
|
627
|
+
startIndex: 0,
|
|
628
|
+
assocDevList: [],
|
|
629
|
+
},
|
|
630
|
+
]);
|
|
631
|
+
}
|
|
632
|
+
else {
|
|
633
|
+
if (object.command.name === "leaveInd") {
|
|
634
|
+
if (object.payload.rejoin) {
|
|
635
|
+
logger_1.logger.debug("Device leave: Got leave indication with rejoin=true, nothing to do", NS);
|
|
636
|
+
}
|
|
637
|
+
else {
|
|
638
|
+
const payload = {
|
|
639
|
+
networkAddress: object.payload.srcaddr,
|
|
640
|
+
ieeeAddr: object.payload.extaddr,
|
|
641
|
+
};
|
|
642
|
+
this.emit("deviceLeave", payload);
|
|
643
|
+
}
|
|
644
|
+
}
|
|
645
|
+
}
|
|
646
|
+
}
|
|
647
|
+
else {
|
|
648
|
+
if (object.subsystem === Subsystem.AF) {
|
|
649
|
+
if (object.command.name === "incomingMsg" || object.command.name === "incomingMsgExt") {
|
|
650
|
+
// TI ZNP API docs
|
|
651
|
+
// ---------------
|
|
652
|
+
// AF_INCOMING_MSG_EXT - SrcAddrMode
|
|
653
|
+
// A value of 3 (i.e. the enumeration value for ‘afAddr64Bit’) indicates 8-
|
|
654
|
+
// byte/64-bit address mode; otherwise, only the 2 LSB’s of the 8 bytes are
|
|
655
|
+
// used to form a 2-byte short address.
|
|
656
|
+
// Addr is currently parsed by Buffalo as Eui64 (`0x${string}`), but it's
|
|
657
|
+
// possible future changes could read srcaddrmode and parse accordingly.
|
|
658
|
+
// Prior tests also passed an integer (e.g. 2), so best to handle all cases.
|
|
659
|
+
// If type is not a string, we assume a 16-bit address.
|
|
660
|
+
const isEui64Addr = typeof object.payload.srcaddr === "string";
|
|
661
|
+
const srcaddr = object.command.name === "incomingMsgExt" && object.payload.srcaddrmode !== 0x03
|
|
662
|
+
? isEui64Addr
|
|
663
|
+
? Number.parseInt(object.payload.srcaddr.slice(-4), 16)
|
|
664
|
+
: object.payload.srcaddr
|
|
665
|
+
: object.payload.srcaddr;
|
|
666
|
+
// TI ZNP API docs suggest that payload.data should be zero length for messages
|
|
667
|
+
// with huge data, but testing shows it is 3-bytes, the first two of which are
|
|
668
|
+
// the 16-bit srcAddr.
|
|
669
|
+
// Possibly zh is not parsing incomingMsgExt correctly. Just compare len with
|
|
670
|
+
// payload length for now.
|
|
671
|
+
//if (object.command.name === "incomingMsgExt" && object.payload.len > 0 && object.payload.data.length === 0) {
|
|
672
|
+
if (object.command.name === "incomingMsgExt" && object.payload.data.length < object.payload.len) {
|
|
673
|
+
// The ZNP will send incomingMsgExt (AF_INCOMING_MSG_EXT)
|
|
674
|
+
// when data length is > about 223 bytes (or if INTER_PAN network
|
|
675
|
+
// is used).
|
|
676
|
+
//
|
|
677
|
+
// In the first case, the data is not included in the payload, but
|
|
678
|
+
// must be retrieved block by block from the ZNP buffer using the
|
|
679
|
+
// AF_DATA_RETRIEVE message.
|
|
680
|
+
this.queue
|
|
681
|
+
.execute(async () => {
|
|
682
|
+
const data = await this.dataRetrieveAll(object.payload.timestamp, object.payload.len);
|
|
683
|
+
if (data === undefined) {
|
|
684
|
+
logger_1.logger.error("Failed to retrieve chunked payload for incomingMsgExt", NS);
|
|
685
|
+
}
|
|
686
|
+
else {
|
|
687
|
+
logger_1.logger.debug(`Retrieved ${data.length} bytes from huge data buffer for msg with timestamp ${object.payload.timestamp}`, NS);
|
|
688
|
+
const payload = {
|
|
689
|
+
clusterID: object.payload.clusterid,
|
|
690
|
+
data: data,
|
|
691
|
+
header: Zcl.Header.fromBuffer(data),
|
|
692
|
+
address: srcaddr,
|
|
693
|
+
endpoint: object.payload.srcendpoint,
|
|
694
|
+
linkquality: object.payload.linkquality,
|
|
695
|
+
groupID: object.payload.groupid,
|
|
696
|
+
wasBroadcast: object.payload.wasbroadcast === 1,
|
|
697
|
+
destinationEndpoint: object.payload.dstendpoint,
|
|
698
|
+
};
|
|
699
|
+
this.waitress.resolve(payload);
|
|
700
|
+
this.emit("zclPayload", payload);
|
|
701
|
+
}
|
|
702
|
+
})
|
|
703
|
+
.catch(() => { });
|
|
704
|
+
}
|
|
705
|
+
else {
|
|
706
|
+
// incomingMsg OR incomingMsgExt with data
|
|
707
|
+
// in the payload (i.e. INTER_PAN network)
|
|
708
|
+
const payload = {
|
|
709
|
+
clusterID: object.payload.clusterid,
|
|
710
|
+
data: object.payload.data,
|
|
711
|
+
header: Zcl.Header.fromBuffer(object.payload.data),
|
|
712
|
+
address: srcaddr,
|
|
713
|
+
endpoint: object.payload.srcendpoint,
|
|
714
|
+
linkquality: object.payload.linkquality,
|
|
715
|
+
groupID: object.payload.groupid,
|
|
716
|
+
wasBroadcast: object.payload.wasbroadcast === 1,
|
|
717
|
+
destinationEndpoint: object.payload.dstendpoint,
|
|
718
|
+
};
|
|
719
|
+
this.waitress.resolve(payload);
|
|
720
|
+
this.emit("zclPayload", payload);
|
|
721
|
+
}
|
|
722
|
+
}
|
|
723
|
+
}
|
|
724
|
+
}
|
|
725
|
+
}
|
|
726
|
+
async getNetworkParameters() {
|
|
727
|
+
const result = await this.znp.requestWithReply(Subsystem.ZDO, "extNwkInfo", {});
|
|
728
|
+
return {
|
|
729
|
+
panID: result.payload.panid,
|
|
730
|
+
extendedPanID: result.payload.extendedpanid, // read as IEEEADDR, so `0x${string}`
|
|
731
|
+
channel: result.payload.channel,
|
|
732
|
+
/**
|
|
733
|
+
* Return a dummy nwkUpdateId of 0, the nwkUpdateId is used when changing channels however the
|
|
734
|
+
* zstack API does not allow to set this value. Instead it automatically increments the nwkUpdateId
|
|
735
|
+
* based on the value in the NIB.
|
|
736
|
+
* https://github.com/Koenkk/zigbee-herdsman/pull/1280#discussion_r1947815987
|
|
737
|
+
*/
|
|
738
|
+
nwkUpdateID: 0,
|
|
739
|
+
};
|
|
740
|
+
}
|
|
741
|
+
async supportsBackup() {
|
|
742
|
+
return await Promise.resolve(true);
|
|
743
|
+
}
|
|
744
|
+
async backup(ieeeAddressesInDatabase) {
|
|
745
|
+
return await this.adapterManager.backup.createBackup(ieeeAddressesInDatabase);
|
|
746
|
+
}
|
|
747
|
+
async setChannelInterPAN(channel) {
|
|
748
|
+
return await this.queue.execute(async () => {
|
|
749
|
+
this.interpanLock = true;
|
|
750
|
+
await this.znp.request(Subsystem.AF, "interPanCtl", { cmd: 1, data: [channel] });
|
|
751
|
+
if (!this.interpanEndpointRegistered) {
|
|
752
|
+
// Make sure that endpoint 12 is registered to proxy the InterPAN messages.
|
|
753
|
+
await this.znp.request(Subsystem.AF, "interPanCtl", { cmd: 2, data: [12] });
|
|
754
|
+
this.interpanEndpointRegistered = true;
|
|
755
|
+
}
|
|
756
|
+
});
|
|
757
|
+
}
|
|
758
|
+
async sendZclFrameInterPANToIeeeAddr(zclFrame, ieeeAddr) {
|
|
759
|
+
return await this.queue.execute(async () => {
|
|
760
|
+
await this.dataRequestExtended(AddressMode.ADDR_64BIT, ieeeAddr, 0xfe, 0xffff, 12, zclFrame.cluster.ID, 30, zclFrame.toBuffer(), 10000, false);
|
|
761
|
+
});
|
|
762
|
+
}
|
|
763
|
+
async sendZclFrameInterPANBroadcast(zclFrame, timeout, disableResponse) {
|
|
764
|
+
return await this.queue.execute(async () => {
|
|
765
|
+
const command = zclFrame.command;
|
|
766
|
+
if (!disableResponse && command.response === undefined) {
|
|
767
|
+
throw new Error(`Command '${command.name}' has no response, cannot wait for response`);
|
|
768
|
+
}
|
|
769
|
+
let response;
|
|
770
|
+
if (!disableResponse && command.response !== undefined) {
|
|
771
|
+
response = this.waitForInternal(undefined, 0xfe, zclFrame.header.frameControl.frameType, Zcl.Direction.SERVER_TO_CLIENT, undefined, zclFrame.cluster.ID, command.response, timeout);
|
|
772
|
+
}
|
|
773
|
+
try {
|
|
774
|
+
await this.dataRequestExtended(AddressMode.ADDR_16BIT, 0xffff, 0xfe, 0xffff, 12, zclFrame.cluster.ID, 30, zclFrame.toBuffer(), 10000, false);
|
|
775
|
+
}
|
|
776
|
+
catch (error) {
|
|
777
|
+
response?.cancel();
|
|
778
|
+
throw error;
|
|
779
|
+
}
|
|
780
|
+
if (response) {
|
|
781
|
+
return await response.start().promise;
|
|
782
|
+
}
|
|
783
|
+
});
|
|
784
|
+
}
|
|
785
|
+
async restoreChannelInterPAN() {
|
|
786
|
+
return await this.queue.execute(async () => {
|
|
787
|
+
await this.znp.request(Subsystem.AF, "interPanCtl", { cmd: 0, data: [] });
|
|
788
|
+
// Give adapter some time to restore, otherwise stuff crashes
|
|
789
|
+
await (0, utils_1.wait)(3000);
|
|
790
|
+
this.interpanLock = false;
|
|
791
|
+
});
|
|
792
|
+
}
|
|
793
|
+
waitForInternal(networkAddress, endpoint, frameType, direction, transactionSequenceNumber, clusterID, commandIdentifier, timeout) {
|
|
794
|
+
const payload = {
|
|
795
|
+
address: networkAddress,
|
|
796
|
+
endpoint,
|
|
797
|
+
clusterID,
|
|
798
|
+
commandIdentifier,
|
|
799
|
+
frameType,
|
|
800
|
+
direction,
|
|
801
|
+
transactionSequenceNumber,
|
|
802
|
+
};
|
|
803
|
+
const waiter = this.waitress.waitFor(payload, timeout);
|
|
804
|
+
const cancel = () => this.waitress.remove(waiter.ID);
|
|
805
|
+
return { start: waiter.start, cancel };
|
|
806
|
+
}
|
|
807
|
+
waitFor(networkAddress, endpoint, frameType, direction, transactionSequenceNumber, clusterID, commandIdentifier, timeout) {
|
|
808
|
+
const waiter = this.waitForInternal(networkAddress, endpoint, frameType, direction, transactionSequenceNumber, clusterID, commandIdentifier, timeout);
|
|
809
|
+
return { cancel: waiter.cancel, promise: waiter.start().promise };
|
|
810
|
+
}
|
|
811
|
+
/**
|
|
812
|
+
* Private methods
|
|
813
|
+
*/
|
|
814
|
+
async dataRequest(destinationAddress, destinationEndpoint, sourceEndpoint, clusterID, radius, data, timeout) {
|
|
815
|
+
const transactionID = this.nextTransactionID();
|
|
816
|
+
const response = this.znp.waitFor(Type.AREQ, Subsystem.AF, "dataConfirm", undefined, transactionID, undefined, timeout);
|
|
817
|
+
await this.znp.request(Subsystem.AF, "dataRequest", {
|
|
818
|
+
dstaddr: destinationAddress,
|
|
819
|
+
destendpoint: destinationEndpoint,
|
|
820
|
+
srcendpoint: sourceEndpoint,
|
|
821
|
+
clusterid: clusterID,
|
|
822
|
+
transid: transactionID,
|
|
823
|
+
options: 0,
|
|
824
|
+
radius: radius,
|
|
825
|
+
len: data.length,
|
|
826
|
+
data: data,
|
|
827
|
+
}, response.ID);
|
|
828
|
+
let result = null;
|
|
829
|
+
try {
|
|
830
|
+
const dataConfirm = await response.start().promise;
|
|
831
|
+
result = dataConfirm.payload.status;
|
|
832
|
+
}
|
|
833
|
+
catch {
|
|
834
|
+
result = DataConfirmTimeout;
|
|
835
|
+
}
|
|
836
|
+
return result;
|
|
837
|
+
}
|
|
838
|
+
async dataRequestExtended(addressMode, destinationAddressOrGroupID, destinationEndpoint, panID, sourceEndpoint, clusterID, radius, data, timeout, confirmation, attemptsLeft = 5) {
|
|
839
|
+
const transactionID = this.nextTransactionID();
|
|
840
|
+
const response = confirmation
|
|
841
|
+
? this.znp.waitFor(Type.AREQ, Subsystem.AF, "dataConfirm", undefined, transactionID, undefined, timeout)
|
|
842
|
+
: undefined;
|
|
843
|
+
await this.znp.request(Subsystem.AF, "dataRequestExt", {
|
|
844
|
+
dstaddrmode: addressMode,
|
|
845
|
+
dstaddr: this.toAddressString(destinationAddressOrGroupID),
|
|
846
|
+
destendpoint: destinationEndpoint,
|
|
847
|
+
dstpanid: panID,
|
|
848
|
+
srcendpoint: sourceEndpoint,
|
|
849
|
+
clusterid: clusterID,
|
|
850
|
+
transid: transactionID,
|
|
851
|
+
options: 0, // TODO: why was this here? Constants.AF.options.DISCV_ROUTE,
|
|
852
|
+
radius,
|
|
853
|
+
len: data.length,
|
|
854
|
+
data: data,
|
|
855
|
+
}, response?.ID);
|
|
856
|
+
if (confirmation && response) {
|
|
857
|
+
const dataConfirm = await response.start().promise;
|
|
858
|
+
if (dataConfirm.payload.status !== ZnpCommandStatus.SUCCESS) {
|
|
859
|
+
if (attemptsLeft > 0 &&
|
|
860
|
+
(dataConfirm.payload.status === ZnpCommandStatus.MAC_CHANNEL_ACCESS_FAILURE ||
|
|
861
|
+
dataConfirm.payload.status === ZnpCommandStatus.BUFFER_FULL)) {
|
|
862
|
+
/**
|
|
863
|
+
* 225: When many commands at once are executed we can end up in a MAC channel access failure
|
|
864
|
+
* error. This is because there is too much traffic on the network.
|
|
865
|
+
* Retry this command once after a cooling down period.
|
|
866
|
+
*/
|
|
867
|
+
await (0, utils_1.wait)(2000);
|
|
868
|
+
return await this.dataRequestExtended(addressMode, destinationAddressOrGroupID, destinationEndpoint, panID, sourceEndpoint, clusterID, radius, data, timeout, confirmation, attemptsLeft - 1);
|
|
869
|
+
}
|
|
870
|
+
throw new DataConfirmError(dataConfirm.payload.status);
|
|
871
|
+
}
|
|
872
|
+
return dataConfirm;
|
|
873
|
+
}
|
|
874
|
+
}
|
|
875
|
+
nextTransactionID() {
|
|
876
|
+
this.transactionID++;
|
|
877
|
+
if (this.transactionID > 255) {
|
|
878
|
+
this.transactionID = 1;
|
|
879
|
+
}
|
|
880
|
+
return this.transactionID;
|
|
881
|
+
}
|
|
882
|
+
toAddressString(address) {
|
|
883
|
+
return typeof address === "number" ? `0x${address.toString(16).padStart(16, "0")}` : address.toString();
|
|
884
|
+
}
|
|
885
|
+
waitressTimeoutFormatter(matcher, timeout) {
|
|
886
|
+
return (`Timeout - ${matcher.address} - ${matcher.endpoint}` +
|
|
887
|
+
` - ${matcher.transactionSequenceNumber} - ${matcher.clusterID}` +
|
|
888
|
+
` - ${matcher.commandIdentifier} after ${timeout}ms`);
|
|
889
|
+
}
|
|
890
|
+
waitressValidator(payload, matcher) {
|
|
891
|
+
return Boolean(payload.header &&
|
|
892
|
+
(!matcher.address || payload.address === matcher.address) &&
|
|
893
|
+
payload.endpoint === matcher.endpoint &&
|
|
894
|
+
(matcher.transactionSequenceNumber === undefined || payload.header.transactionSequenceNumber === matcher.transactionSequenceNumber) &&
|
|
895
|
+
payload.clusterID === matcher.clusterID &&
|
|
896
|
+
matcher.frameType === payload.header.frameControl.frameType &&
|
|
897
|
+
matcher.commandIdentifier === payload.header.commandIdentifier &&
|
|
898
|
+
matcher.direction === payload.header.frameControl.direction);
|
|
899
|
+
}
|
|
900
|
+
checkInterpanLock() {
|
|
901
|
+
if (this.interpanLock) {
|
|
902
|
+
throw new Error("Cannot execute command, in Inter-PAN mode");
|
|
903
|
+
}
|
|
904
|
+
}
|
|
905
|
+
selectSourceEndpoint(sourceEndpoint, profileId) {
|
|
906
|
+
// Use provided sourceEndpoint as the highest priority
|
|
907
|
+
let srcEndpoint = sourceEndpoint;
|
|
908
|
+
// If sourceEndpoint is not provided, try to select the source endpoint based on the profileId.
|
|
909
|
+
if (srcEndpoint === undefined && profileId !== undefined) {
|
|
910
|
+
srcEndpoint = endpoints_1.Endpoints.find((e) => e.appprofid === profileId)?.endpoint;
|
|
911
|
+
}
|
|
912
|
+
//If no profileId is provided, or if no corresponding endpoint exists, use endpoint 1.
|
|
913
|
+
if (srcEndpoint === undefined) {
|
|
914
|
+
srcEndpoint = 1;
|
|
915
|
+
}
|
|
916
|
+
// Validate that the requested profileId can be satisfied by the adapter.
|
|
917
|
+
if (profileId !== undefined && endpoints_1.Endpoints.find((e) => e.endpoint === srcEndpoint)?.appprofid !== profileId) {
|
|
918
|
+
throw new Error(`Profile ID ${profileId} is not supported by this adapter.`);
|
|
919
|
+
}
|
|
920
|
+
return srcEndpoint;
|
|
921
|
+
}
|
|
922
|
+
}
|
|
923
|
+
exports.ZStackAdapter = ZStackAdapter;
|
|
924
|
+
//# sourceMappingURL=zStackAdapter.js.map
|