zigbee-herdsman 3.5.2 → 4.0.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.
Files changed (728) hide show
  1. package/.github/dependabot.yml +4 -0
  2. package/.github/workflows/ci.yml +3 -5
  3. package/.github/workflows/stale.yml +1 -1
  4. package/.github/workflows/typedoc.yaml +1 -1
  5. package/.release-please-manifest.json +1 -1
  6. package/.vscode/extensions.json +3 -0
  7. package/.vscode/settings.json +11 -0
  8. package/CHANGELOG.md +32 -0
  9. package/biome.json +89 -0
  10. package/dist/adapter/adapter.d.ts +11 -11
  11. package/dist/adapter/adapter.d.ts.map +1 -1
  12. package/dist/adapter/adapter.js +14 -14
  13. package/dist/adapter/adapterDiscovery.d.ts +6 -6
  14. package/dist/adapter/adapterDiscovery.d.ts.map +1 -1
  15. package/dist/adapter/adapterDiscovery.js +139 -141
  16. package/dist/adapter/adapterDiscovery.js.map +1 -1
  17. package/dist/adapter/const.d.ts +1 -1
  18. package/dist/adapter/const.js +2 -2
  19. package/dist/adapter/deconz/adapter/deconzAdapter.d.ts +16 -16
  20. package/dist/adapter/deconz/adapter/deconzAdapter.d.ts.map +1 -1
  21. package/dist/adapter/deconz/adapter/deconzAdapter.js +95 -100
  22. package/dist/adapter/deconz/adapter/deconzAdapter.js.map +1 -1
  23. package/dist/adapter/deconz/driver/constants.d.ts +5 -5
  24. package/dist/adapter/deconz/driver/constants.d.ts.map +1 -1
  25. package/dist/adapter/deconz/driver/driver.d.ts +9 -9
  26. package/dist/adapter/deconz/driver/driver.d.ts.map +1 -1
  27. package/dist/adapter/deconz/driver/driver.js +112 -106
  28. package/dist/adapter/deconz/driver/driver.js.map +1 -1
  29. package/dist/adapter/deconz/driver/frame.d.ts +1 -1
  30. package/dist/adapter/deconz/driver/frame.d.ts.map +1 -1
  31. package/dist/adapter/deconz/driver/frame.js +1 -2
  32. package/dist/adapter/deconz/driver/frame.js.map +1 -1
  33. package/dist/adapter/deconz/driver/frameParser.d.ts +1 -1
  34. package/dist/adapter/deconz/driver/frameParser.d.ts.map +1 -1
  35. package/dist/adapter/deconz/driver/frameParser.js +66 -70
  36. package/dist/adapter/deconz/driver/frameParser.js.map +1 -1
  37. package/dist/adapter/deconz/driver/parser.d.ts +1 -1
  38. package/dist/adapter/deconz/driver/parser.d.ts.map +1 -1
  39. package/dist/adapter/deconz/driver/parser.js +2 -2
  40. package/dist/adapter/deconz/driver/parser.js.map +1 -1
  41. package/dist/adapter/deconz/driver/writer.d.ts +2 -2
  42. package/dist/adapter/deconz/driver/writer.d.ts.map +1 -1
  43. package/dist/adapter/deconz/driver/writer.js +1 -1
  44. package/dist/adapter/ember/adapter/emberAdapter.d.ts +19 -19
  45. package/dist/adapter/ember/adapter/emberAdapter.d.ts.map +1 -1
  46. package/dist/adapter/ember/adapter/emberAdapter.js +117 -97
  47. package/dist/adapter/ember/adapter/emberAdapter.js.map +1 -1
  48. package/dist/adapter/ember/adapter/endpoints.d.ts +1 -1
  49. package/dist/adapter/ember/adapter/endpoints.d.ts.map +1 -1
  50. package/dist/adapter/ember/adapter/oneWaitress.d.ts +5 -5
  51. package/dist/adapter/ember/adapter/oneWaitress.d.ts.map +1 -1
  52. package/dist/adapter/ember/adapter/oneWaitress.js +2 -2
  53. package/dist/adapter/ember/adapter/oneWaitress.js.map +1 -1
  54. package/dist/adapter/ember/adapter/tokensManager.d.ts +3 -3
  55. package/dist/adapter/ember/adapter/tokensManager.d.ts.map +1 -1
  56. package/dist/adapter/ember/adapter/tokensManager.js +20 -23
  57. package/dist/adapter/ember/adapter/tokensManager.js.map +1 -1
  58. package/dist/adapter/ember/enums.d.ts +4 -4
  59. package/dist/adapter/ember/enums.d.ts.map +1 -1
  60. package/dist/adapter/ember/enums.js +4 -6
  61. package/dist/adapter/ember/enums.js.map +1 -1
  62. package/dist/adapter/ember/ezsp/buffalo.d.ts +4 -4
  63. package/dist/adapter/ember/ezsp/buffalo.d.ts.map +1 -1
  64. package/dist/adapter/ember/ezsp/buffalo.js +30 -32
  65. package/dist/adapter/ember/ezsp/buffalo.js.map +1 -1
  66. package/dist/adapter/ember/ezsp/ezsp.d.ts +46 -46
  67. package/dist/adapter/ember/ezsp/ezsp.d.ts.map +1 -1
  68. package/dist/adapter/ember/ezsp/ezsp.js +85 -111
  69. package/dist/adapter/ember/ezsp/ezsp.js.map +1 -1
  70. package/dist/adapter/ember/ezspError.d.ts +1 -1
  71. package/dist/adapter/ember/types.d.ts +14 -14
  72. package/dist/adapter/ember/types.d.ts.map +1 -1
  73. package/dist/adapter/ember/uart/ash.d.ts +5 -5
  74. package/dist/adapter/ember/uart/ash.d.ts.map +1 -1
  75. package/dist/adapter/ember/uart/ash.js +80 -71
  76. package/dist/adapter/ember/uart/ash.js.map +1 -1
  77. package/dist/adapter/ember/uart/parser.d.ts +2 -2
  78. package/dist/adapter/ember/uart/parser.d.ts.map +1 -1
  79. package/dist/adapter/ember/uart/parser.js +2 -1
  80. package/dist/adapter/ember/uart/parser.js.map +1 -1
  81. package/dist/adapter/ember/uart/queues.js +27 -29
  82. package/dist/adapter/ember/uart/queues.js.map +1 -1
  83. package/dist/adapter/ember/uart/writer.d.ts +1 -1
  84. package/dist/adapter/ember/uart/writer.d.ts.map +1 -1
  85. package/dist/adapter/ember/uart/writer.js +3 -5
  86. package/dist/adapter/ember/uart/writer.js.map +1 -1
  87. package/dist/adapter/ember/utils/initters.d.ts +2 -2
  88. package/dist/adapter/ember/utils/initters.d.ts.map +1 -1
  89. package/dist/adapter/ember/utils/initters.js +1 -1
  90. package/dist/adapter/ember/utils/math.js +1 -1
  91. package/dist/adapter/events.d.ts +1 -1
  92. package/dist/adapter/events.d.ts.map +1 -1
  93. package/dist/adapter/ezsp/adapter/backup.d.ts +3 -3
  94. package/dist/adapter/ezsp/adapter/backup.d.ts.map +1 -1
  95. package/dist/adapter/ezsp/adapter/backup.js +8 -10
  96. package/dist/adapter/ezsp/adapter/backup.js.map +1 -1
  97. package/dist/adapter/ezsp/adapter/ezspAdapter.d.ts +12 -12
  98. package/dist/adapter/ezsp/adapter/ezspAdapter.d.ts.map +1 -1
  99. package/dist/adapter/ezsp/adapter/ezspAdapter.js +45 -44
  100. package/dist/adapter/ezsp/adapter/ezspAdapter.js.map +1 -1
  101. package/dist/adapter/ezsp/driver/driver.d.ts +12 -12
  102. package/dist/adapter/ezsp/driver/driver.d.ts.map +1 -1
  103. package/dist/adapter/ezsp/driver/driver.js +148 -141
  104. package/dist/adapter/ezsp/driver/driver.js.map +1 -1
  105. package/dist/adapter/ezsp/driver/ezsp.d.ts +7 -7
  106. package/dist/adapter/ezsp/driver/ezsp.d.ts.map +1 -1
  107. package/dist/adapter/ezsp/driver/ezsp.js +61 -59
  108. package/dist/adapter/ezsp/driver/ezsp.js.map +1 -1
  109. package/dist/adapter/ezsp/driver/frame.js +2 -2
  110. package/dist/adapter/ezsp/driver/index.d.ts +2 -2
  111. package/dist/adapter/ezsp/driver/multicast.d.ts +8 -5
  112. package/dist/adapter/ezsp/driver/multicast.d.ts.map +1 -1
  113. package/dist/adapter/ezsp/driver/multicast.js +9 -9
  114. package/dist/adapter/ezsp/driver/multicast.js.map +1 -1
  115. package/dist/adapter/ezsp/driver/parser.d.ts +1 -1
  116. package/dist/adapter/ezsp/driver/parser.js +3 -3
  117. package/dist/adapter/ezsp/driver/types/basic.d.ts +5 -5
  118. package/dist/adapter/ezsp/driver/types/basic.d.ts.map +1 -1
  119. package/dist/adapter/ezsp/driver/types/basic.js +12 -33
  120. package/dist/adapter/ezsp/driver/types/basic.js.map +1 -1
  121. package/dist/adapter/ezsp/driver/types/index.d.ts +3 -3
  122. package/dist/adapter/ezsp/driver/types/index.d.ts.map +1 -1
  123. package/dist/adapter/ezsp/driver/types/index.js +8 -9
  124. package/dist/adapter/ezsp/driver/types/index.js.map +1 -1
  125. package/dist/adapter/ezsp/driver/types/named.d.ts +2 -2
  126. package/dist/adapter/ezsp/driver/types/named.d.ts.map +1 -1
  127. package/dist/adapter/ezsp/driver/types/named.js +8 -11
  128. package/dist/adapter/ezsp/driver/types/named.js.map +1 -1
  129. package/dist/adapter/ezsp/driver/types/struct.d.ts +2 -2
  130. package/dist/adapter/ezsp/driver/types/struct.d.ts.map +1 -1
  131. package/dist/adapter/ezsp/driver/types/struct.js +207 -214
  132. package/dist/adapter/ezsp/driver/types/struct.js.map +1 -1
  133. package/dist/adapter/ezsp/driver/uart.d.ts +2 -2
  134. package/dist/adapter/ezsp/driver/uart.d.ts.map +1 -1
  135. package/dist/adapter/ezsp/driver/uart.js +48 -37
  136. package/dist/adapter/ezsp/driver/uart.js.map +1 -1
  137. package/dist/adapter/ezsp/driver/utils/crc16ccitt.d.ts +3 -3
  138. package/dist/adapter/ezsp/driver/utils/crc16ccitt.d.ts.map +1 -1
  139. package/dist/adapter/ezsp/driver/utils/crc16ccitt.js +16 -34
  140. package/dist/adapter/ezsp/driver/utils/crc16ccitt.js.map +1 -1
  141. package/dist/adapter/ezsp/driver/utils/index.d.ts +4 -4
  142. package/dist/adapter/ezsp/driver/utils/index.d.ts.map +1 -1
  143. package/dist/adapter/ezsp/driver/utils/index.js +4 -4
  144. package/dist/adapter/ezsp/driver/utils/index.js.map +1 -1
  145. package/dist/adapter/ezsp/driver/writer.d.ts +1 -1
  146. package/dist/adapter/ezsp/driver/writer.js +2 -2
  147. package/dist/adapter/index.d.ts +3 -3
  148. package/dist/adapter/serialPort.d.ts +3 -3
  149. package/dist/adapter/serialPort.d.ts.map +1 -1
  150. package/dist/adapter/serialPort.js +1 -0
  151. package/dist/adapter/serialPort.js.map +1 -1
  152. package/dist/adapter/socketPortUtils.js +3 -3
  153. package/dist/adapter/tstype.d.ts +6 -6
  154. package/dist/adapter/z-stack/adapter/adapter-backup.d.ts +4 -4
  155. package/dist/adapter/z-stack/adapter/adapter-backup.d.ts.map +1 -1
  156. package/dist/adapter/z-stack/adapter/adapter-backup.js +106 -119
  157. package/dist/adapter/z-stack/adapter/adapter-backup.js.map +1 -1
  158. package/dist/adapter/z-stack/adapter/adapter-nv-memory.d.ts +10 -10
  159. package/dist/adapter/z-stack/adapter/adapter-nv-memory.d.ts.map +1 -1
  160. package/dist/adapter/z-stack/adapter/adapter-nv-memory.js +23 -24
  161. package/dist/adapter/z-stack/adapter/adapter-nv-memory.js.map +1 -1
  162. package/dist/adapter/z-stack/adapter/manager.d.ts +6 -6
  163. package/dist/adapter/z-stack/adapter/manager.d.ts.map +1 -1
  164. package/dist/adapter/z-stack/adapter/manager.js +116 -127
  165. package/dist/adapter/z-stack/adapter/manager.js.map +1 -1
  166. package/dist/adapter/z-stack/adapter/tstype.d.ts +3 -3
  167. package/dist/adapter/z-stack/adapter/tstype.js +3 -3
  168. package/dist/adapter/z-stack/adapter/zStackAdapter.d.ts +10 -10
  169. package/dist/adapter/z-stack/adapter/zStackAdapter.d.ts.map +1 -1
  170. package/dist/adapter/z-stack/adapter/zStackAdapter.js +125 -137
  171. package/dist/adapter/z-stack/adapter/zStackAdapter.js.map +1 -1
  172. package/dist/adapter/z-stack/constants/common.d.ts.map +1 -1
  173. package/dist/adapter/z-stack/constants/common.js +0 -3
  174. package/dist/adapter/z-stack/constants/common.js.map +1 -1
  175. package/dist/adapter/z-stack/constants/index.d.ts +10 -10
  176. package/dist/adapter/z-stack/constants/index.d.ts.map +1 -1
  177. package/dist/adapter/z-stack/constants/index.js +2 -2
  178. package/dist/adapter/z-stack/constants/index.js.map +1 -1
  179. package/dist/adapter/z-stack/constants/utils.d.ts +1 -1
  180. package/dist/adapter/z-stack/constants/utils.js +2 -2
  181. package/dist/adapter/z-stack/constants/utils.js.map +1 -1
  182. package/dist/adapter/z-stack/models/startup-options.d.ts +2 -2
  183. package/dist/adapter/z-stack/models/startup-options.d.ts.map +1 -1
  184. package/dist/adapter/z-stack/structs/entries/address-manager-entry.d.ts +1 -1
  185. package/dist/adapter/z-stack/structs/entries/address-manager-entry.d.ts.map +1 -1
  186. package/dist/adapter/z-stack/structs/entries/address-manager-entry.js +4 -5
  187. package/dist/adapter/z-stack/structs/entries/address-manager-entry.js.map +1 -1
  188. package/dist/adapter/z-stack/structs/entries/address-manager-table.d.ts +2 -2
  189. package/dist/adapter/z-stack/structs/entries/address-manager-table.d.ts.map +1 -1
  190. package/dist/adapter/z-stack/structs/entries/address-manager-table.js +3 -4
  191. package/dist/adapter/z-stack/structs/entries/address-manager-table.js.map +1 -1
  192. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.d.ts +1 -1
  193. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.d.ts.map +1 -1
  194. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.js +1 -2
  195. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.js.map +1 -1
  196. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.d.ts +2 -2
  197. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.d.ts.map +1 -1
  198. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.js +3 -4
  199. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.js.map +1 -1
  200. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.d.ts +1 -1
  201. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.d.ts.map +1 -1
  202. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.js +6 -7
  203. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.js.map +1 -1
  204. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.d.ts +2 -2
  205. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.d.ts.map +1 -1
  206. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.js +3 -4
  207. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.js.map +1 -1
  208. package/dist/adapter/z-stack/structs/entries/channel-list.d.ts +1 -1
  209. package/dist/adapter/z-stack/structs/entries/channel-list.d.ts.map +1 -1
  210. package/dist/adapter/z-stack/structs/entries/channel-list.js +1 -2
  211. package/dist/adapter/z-stack/structs/entries/channel-list.js.map +1 -1
  212. package/dist/adapter/z-stack/structs/entries/has-configured.d.ts +1 -1
  213. package/dist/adapter/z-stack/structs/entries/has-configured.d.ts.map +1 -1
  214. package/dist/adapter/z-stack/structs/entries/has-configured.js +2 -3
  215. package/dist/adapter/z-stack/structs/entries/has-configured.js.map +1 -1
  216. package/dist/adapter/z-stack/structs/entries/index.d.ts +16 -16
  217. package/dist/adapter/z-stack/structs/entries/nib.d.ts +1 -1
  218. package/dist/adapter/z-stack/structs/entries/nib.d.ts.map +1 -1
  219. package/dist/adapter/z-stack/structs/entries/nib.js +49 -50
  220. package/dist/adapter/z-stack/structs/entries/nib.js.map +1 -1
  221. package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.d.ts +1 -1
  222. package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.d.ts.map +1 -1
  223. package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.js +1 -2
  224. package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.js.map +1 -1
  225. package/dist/adapter/z-stack/structs/entries/nwk-key.d.ts +1 -1
  226. package/dist/adapter/z-stack/structs/entries/nwk-key.d.ts.map +1 -1
  227. package/dist/adapter/z-stack/structs/entries/nwk-key.js +1 -2
  228. package/dist/adapter/z-stack/structs/entries/nwk-key.js.map +1 -1
  229. package/dist/adapter/z-stack/structs/entries/nwk-pan-id.d.ts +1 -1
  230. package/dist/adapter/z-stack/structs/entries/nwk-pan-id.d.ts.map +1 -1
  231. package/dist/adapter/z-stack/structs/entries/nwk-pan-id.js +1 -2
  232. package/dist/adapter/z-stack/structs/entries/nwk-pan-id.js.map +1 -1
  233. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.d.ts +1 -1
  234. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.d.ts.map +1 -1
  235. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.js +3 -4
  236. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.js.map +1 -1
  237. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.d.ts +2 -2
  238. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.d.ts.map +1 -1
  239. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.js +3 -4
  240. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.js.map +1 -1
  241. package/dist/adapter/z-stack/structs/entries/security-manager-entry.d.ts +1 -1
  242. package/dist/adapter/z-stack/structs/entries/security-manager-entry.d.ts.map +1 -1
  243. package/dist/adapter/z-stack/structs/entries/security-manager-entry.js +4 -5
  244. package/dist/adapter/z-stack/structs/entries/security-manager-entry.js.map +1 -1
  245. package/dist/adapter/z-stack/structs/entries/security-manager-table.d.ts +2 -2
  246. package/dist/adapter/z-stack/structs/entries/security-manager-table.d.ts.map +1 -1
  247. package/dist/adapter/z-stack/structs/entries/security-manager-table.js +3 -4
  248. package/dist/adapter/z-stack/structs/entries/security-manager-table.js.map +1 -1
  249. package/dist/adapter/z-stack/structs/index.d.ts +4 -4
  250. package/dist/adapter/z-stack/structs/serializable-memory-object.d.ts +2 -2
  251. package/dist/adapter/z-stack/structs/serializable-memory-object.d.ts.map +1 -1
  252. package/dist/adapter/z-stack/structs/struct.d.ts +8 -8
  253. package/dist/adapter/z-stack/structs/struct.d.ts.map +1 -1
  254. package/dist/adapter/z-stack/structs/struct.js +42 -43
  255. package/dist/adapter/z-stack/structs/struct.js.map +1 -1
  256. package/dist/adapter/z-stack/structs/table.d.ts +3 -3
  257. package/dist/adapter/z-stack/structs/table.d.ts.map +1 -1
  258. package/dist/adapter/z-stack/structs/table.js +10 -10
  259. package/dist/adapter/z-stack/structs/table.js.map +1 -1
  260. package/dist/adapter/z-stack/unpi/frame.d.ts +1 -1
  261. package/dist/adapter/z-stack/unpi/frame.d.ts.map +1 -1
  262. package/dist/adapter/z-stack/unpi/frame.js +2 -4
  263. package/dist/adapter/z-stack/unpi/frame.js.map +1 -1
  264. package/dist/adapter/z-stack/unpi/index.d.ts +4 -4
  265. package/dist/adapter/z-stack/unpi/parser.d.ts +1 -1
  266. package/dist/adapter/z-stack/unpi/parser.js +3 -3
  267. package/dist/adapter/z-stack/unpi/parser.js.map +1 -1
  268. package/dist/adapter/z-stack/unpi/writer.d.ts +2 -2
  269. package/dist/adapter/z-stack/unpi/writer.d.ts.map +1 -1
  270. package/dist/adapter/z-stack/unpi/writer.js +1 -1
  271. package/dist/adapter/z-stack/utils/index.d.ts +2 -2
  272. package/dist/adapter/z-stack/utils/network-options.d.ts +1 -1
  273. package/dist/adapter/z-stack/utils/network-options.d.ts.map +1 -1
  274. package/dist/adapter/z-stack/znp/buffaloZnp.d.ts +3 -3
  275. package/dist/adapter/z-stack/znp/buffaloZnp.d.ts.map +1 -1
  276. package/dist/adapter/z-stack/znp/buffaloZnp.js +34 -20
  277. package/dist/adapter/z-stack/znp/buffaloZnp.js.map +1 -1
  278. package/dist/adapter/z-stack/znp/definition.d.ts +2 -2
  279. package/dist/adapter/z-stack/znp/definition.d.ts.map +1 -1
  280. package/dist/adapter/z-stack/znp/definition.js +1111 -1111
  281. package/dist/adapter/z-stack/znp/index.d.ts +2 -2
  282. package/dist/adapter/z-stack/znp/tstype.d.ts +7 -7
  283. package/dist/adapter/z-stack/znp/tstype.d.ts.map +1 -1
  284. package/dist/adapter/z-stack/znp/utils.d.ts +1 -1
  285. package/dist/adapter/z-stack/znp/utils.d.ts.map +1 -1
  286. package/dist/adapter/z-stack/znp/utils.js +2 -2
  287. package/dist/adapter/z-stack/znp/znp.d.ts +7 -7
  288. package/dist/adapter/z-stack/znp/znp.d.ts.map +1 -1
  289. package/dist/adapter/z-stack/znp/znp.js +46 -45
  290. package/dist/adapter/z-stack/znp/znp.js.map +1 -1
  291. package/dist/adapter/z-stack/znp/zpiObject.d.ts +8 -8
  292. package/dist/adapter/z-stack/znp/zpiObject.d.ts.map +1 -1
  293. package/dist/adapter/z-stack/znp/zpiObject.js +6 -6
  294. package/dist/adapter/z-stack/znp/zpiObject.js.map +1 -1
  295. package/dist/adapter/zboss/adapter/zbossAdapter.d.ts +11 -11
  296. package/dist/adapter/zboss/adapter/zbossAdapter.d.ts.map +1 -1
  297. package/dist/adapter/zboss/adapter/zbossAdapter.js +37 -36
  298. package/dist/adapter/zboss/adapter/zbossAdapter.js.map +1 -1
  299. package/dist/adapter/zboss/commands.d.ts +4 -6
  300. package/dist/adapter/zboss/commands.d.ts.map +1 -1
  301. package/dist/adapter/zboss/commands.js +321 -287
  302. package/dist/adapter/zboss/commands.js.map +1 -1
  303. package/dist/adapter/zboss/driver.d.ts +9 -9
  304. package/dist/adapter/zboss/driver.d.ts.map +1 -1
  305. package/dist/adapter/zboss/driver.js +25 -25
  306. package/dist/adapter/zboss/driver.js.map +1 -1
  307. package/dist/adapter/zboss/frame.d.ts +9 -9
  308. package/dist/adapter/zboss/frame.d.ts.map +1 -1
  309. package/dist/adapter/zboss/frame.js +15 -15
  310. package/dist/adapter/zboss/frame.js.map +1 -1
  311. package/dist/adapter/zboss/reader.d.ts +2 -2
  312. package/dist/adapter/zboss/reader.d.ts.map +1 -1
  313. package/dist/adapter/zboss/reader.js +6 -5
  314. package/dist/adapter/zboss/reader.js.map +1 -1
  315. package/dist/adapter/zboss/uart.d.ts +3 -3
  316. package/dist/adapter/zboss/uart.d.ts.map +1 -1
  317. package/dist/adapter/zboss/uart.js +36 -36
  318. package/dist/adapter/zboss/uart.js.map +1 -1
  319. package/dist/adapter/zboss/writer.d.ts +1 -1
  320. package/dist/adapter/zboss/writer.d.ts.map +1 -1
  321. package/dist/adapter/zboss/writer.js +3 -5
  322. package/dist/adapter/zboss/writer.js.map +1 -1
  323. package/dist/adapter/zigate/adapter/patchZdoBuffaloBE.js +2 -2
  324. package/dist/adapter/zigate/adapter/patchZdoBuffaloBE.js.map +1 -1
  325. package/dist/adapter/zigate/adapter/zigateAdapter.d.ts +14 -14
  326. package/dist/adapter/zigate/adapter/zigateAdapter.d.ts.map +1 -1
  327. package/dist/adapter/zigate/adapter/zigateAdapter.js +52 -53
  328. package/dist/adapter/zigate/adapter/zigateAdapter.js.map +1 -1
  329. package/dist/adapter/zigate/driver/buffaloZiGate.d.ts +6 -6
  330. package/dist/adapter/zigate/driver/buffaloZiGate.d.ts.map +1 -1
  331. package/dist/adapter/zigate/driver/buffaloZiGate.js +41 -23
  332. package/dist/adapter/zigate/driver/buffaloZiGate.js.map +1 -1
  333. package/dist/adapter/zigate/driver/commandType.d.ts +2 -2
  334. package/dist/adapter/zigate/driver/commandType.d.ts.map +1 -1
  335. package/dist/adapter/zigate/driver/commandType.js +37 -37
  336. package/dist/adapter/zigate/driver/commandType.js.map +1 -1
  337. package/dist/adapter/zigate/driver/constants.d.ts +27 -200
  338. package/dist/adapter/zigate/driver/constants.d.ts.map +1 -1
  339. package/dist/adapter/zigate/driver/constants.js +40 -236
  340. package/dist/adapter/zigate/driver/constants.js.map +1 -1
  341. package/dist/adapter/zigate/driver/frame.d.ts.map +1 -1
  342. package/dist/adapter/zigate/driver/frame.js +4 -3
  343. package/dist/adapter/zigate/driver/frame.js.map +1 -1
  344. package/dist/adapter/zigate/driver/messageType.d.ts +1 -1
  345. package/dist/adapter/zigate/driver/messageType.js +76 -76
  346. package/dist/adapter/zigate/driver/ziGateObject.d.ts +3 -3
  347. package/dist/adapter/zigate/driver/ziGateObject.d.ts.map +1 -1
  348. package/dist/adapter/zigate/driver/ziGateObject.js +7 -6
  349. package/dist/adapter/zigate/driver/ziGateObject.js.map +1 -1
  350. package/dist/adapter/zigate/driver/zigate.d.ts +8 -8
  351. package/dist/adapter/zigate/driver/zigate.d.ts.map +1 -1
  352. package/dist/adapter/zigate/driver/zigate.js +59 -54
  353. package/dist/adapter/zigate/driver/zigate.js.map +1 -1
  354. package/dist/adapter/zoh/adapter/utils.js +1 -1
  355. package/dist/adapter/zoh/adapter/zohAdapter.d.ts +13 -13
  356. package/dist/adapter/zoh/adapter/zohAdapter.d.ts.map +1 -1
  357. package/dist/adapter/zoh/adapter/zohAdapter.js +101 -67
  358. package/dist/adapter/zoh/adapter/zohAdapter.js.map +1 -1
  359. package/dist/buffalo/buffalo.d.ts +2 -2
  360. package/dist/buffalo/buffalo.js +4 -4
  361. package/dist/buffalo/buffalo.js.map +1 -1
  362. package/dist/buffalo/index.d.ts +1 -1
  363. package/dist/controller/controller.d.ts +7 -7
  364. package/dist/controller/controller.d.ts.map +1 -1
  365. package/dist/controller/controller.js +94 -98
  366. package/dist/controller/controller.js.map +1 -1
  367. package/dist/controller/database.d.ts +1 -1
  368. package/dist/controller/database.d.ts.map +1 -1
  369. package/dist/controller/database.js +9 -9
  370. package/dist/controller/database.js.map +1 -1
  371. package/dist/controller/events.d.ts +6 -6
  372. package/dist/controller/events.d.ts.map +1 -1
  373. package/dist/controller/greenPower.d.ts +21 -21
  374. package/dist/controller/greenPower.d.ts.map +1 -1
  375. package/dist/controller/greenPower.js +41 -41
  376. package/dist/controller/greenPower.js.map +1 -1
  377. package/dist/controller/helpers/index.d.ts +1 -1
  378. package/dist/controller/helpers/request.d.ts +2 -2
  379. package/dist/controller/helpers/request.d.ts.map +1 -1
  380. package/dist/controller/helpers/request.js +31 -27
  381. package/dist/controller/helpers/request.js.map +1 -1
  382. package/dist/controller/helpers/requestQueue.d.ts +3 -3
  383. package/dist/controller/helpers/requestQueue.d.ts.map +1 -1
  384. package/dist/controller/helpers/requestQueue.js +20 -20
  385. package/dist/controller/helpers/requestQueue.js.map +1 -1
  386. package/dist/controller/helpers/zclFrameConverter.d.ts +2 -2
  387. package/dist/controller/helpers/zclFrameConverter.d.ts.map +1 -1
  388. package/dist/controller/helpers/zclFrameConverter.js +1 -1
  389. package/dist/controller/helpers/zclFrameConverter.js.map +1 -1
  390. package/dist/controller/helpers/zclTransactionSequenceNumber.d.ts +6 -4
  391. package/dist/controller/helpers/zclTransactionSequenceNumber.d.ts.map +1 -1
  392. package/dist/controller/helpers/zclTransactionSequenceNumber.js +6 -5
  393. package/dist/controller/helpers/zclTransactionSequenceNumber.js.map +1 -1
  394. package/dist/controller/index.d.ts +1 -1
  395. package/dist/controller/model/device.d.ts +23 -19
  396. package/dist/controller/model/device.d.ts.map +1 -1
  397. package/dist/controller/model/device.js +153 -128
  398. package/dist/controller/model/device.js.map +1 -1
  399. package/dist/controller/model/endpoint.d.ts +11 -11
  400. package/dist/controller/model/endpoint.d.ts.map +1 -1
  401. package/dist/controller/model/endpoint.js +84 -67
  402. package/dist/controller/model/endpoint.js.map +1 -1
  403. package/dist/controller/model/entity.d.ts +3 -3
  404. package/dist/controller/model/entity.d.ts.map +1 -1
  405. package/dist/controller/model/group.d.ts +4 -4
  406. package/dist/controller/model/group.d.ts.map +1 -1
  407. package/dist/controller/model/group.js +21 -9
  408. package/dist/controller/model/group.js.map +1 -1
  409. package/dist/controller/model/index.d.ts +4 -4
  410. package/dist/controller/touchlink.d.ts +1 -1
  411. package/dist/controller/touchlink.d.ts.map +1 -1
  412. package/dist/controller/touchlink.js +11 -11
  413. package/dist/controller/tstype.d.ts +3 -3
  414. package/dist/index.d.ts +10 -10
  415. package/dist/models/backup-storage-legacy.d.ts +14 -16
  416. package/dist/models/backup-storage-legacy.d.ts.map +1 -1
  417. package/dist/models/backup-storage-unified.d.ts +1 -1
  418. package/dist/models/backup.d.ts +2 -2
  419. package/dist/models/backup.d.ts.map +1 -1
  420. package/dist/models/index.d.ts +4 -4
  421. package/dist/utils/backup.d.ts +1 -1
  422. package/dist/utils/backup.d.ts.map +1 -1
  423. package/dist/utils/backup.js +26 -26
  424. package/dist/utils/backup.js.map +1 -1
  425. package/dist/utils/index.d.ts +5 -5
  426. package/dist/utils/logger.js +3 -3
  427. package/dist/utils/patchBigIntSerialization.js +1 -1
  428. package/dist/utils/patchBigIntSerialization.js.map +1 -1
  429. package/dist/utils/queue.d.ts.map +1 -1
  430. package/dist/utils/queue.js +1 -0
  431. package/dist/utils/queue.js.map +1 -1
  432. package/dist/utils/utils.d.ts.map +1 -1
  433. package/dist/utils/utils.js +5 -4
  434. package/dist/utils/utils.js.map +1 -1
  435. package/dist/utils/waitress.d.ts +1 -1
  436. package/dist/utils/waitress.js +3 -3
  437. package/dist/zspec/consts.d.ts +1 -1
  438. package/dist/zspec/consts.d.ts.map +1 -1
  439. package/dist/zspec/consts.js +1 -1
  440. package/dist/zspec/index.d.ts +3 -3
  441. package/dist/zspec/tstypes.d.ts +1 -1
  442. package/dist/zspec/utils.d.ts +4 -4
  443. package/dist/zspec/utils.d.ts.map +1 -1
  444. package/dist/zspec/utils.js +9 -13
  445. package/dist/zspec/utils.js.map +1 -1
  446. package/dist/zspec/zcl/buffaloZcl.d.ts +3 -3
  447. package/dist/zspec/zcl/buffaloZcl.d.ts.map +1 -1
  448. package/dist/zspec/zcl/buffaloZcl.js +127 -84
  449. package/dist/zspec/zcl/buffaloZcl.js.map +1 -1
  450. package/dist/zspec/zcl/definition/cluster.d.ts +1 -1
  451. package/dist/zspec/zcl/definition/cluster.d.ts.map +1 -1
  452. package/dist/zspec/zcl/definition/cluster.js +1280 -911
  453. package/dist/zspec/zcl/definition/cluster.js.map +1 -1
  454. package/dist/zspec/zcl/definition/consts.js +7 -7
  455. package/dist/zspec/zcl/definition/foundation.d.ts +3 -3
  456. package/dist/zspec/zcl/definition/foundation.d.ts.map +1 -1
  457. package/dist/zspec/zcl/definition/foundation.js +88 -89
  458. package/dist/zspec/zcl/definition/foundation.js.map +1 -1
  459. package/dist/zspec/zcl/definition/manufacturerCode.d.ts +1 -1
  460. package/dist/zspec/zcl/definition/manufacturerCode.js +1 -1
  461. package/dist/zspec/zcl/definition/manufacturerCode.js.map +1 -1
  462. package/dist/zspec/zcl/definition/status.d.ts +3 -3
  463. package/dist/zspec/zcl/definition/status.js +3 -3
  464. package/dist/zspec/zcl/definition/tstype.d.ts +3 -3
  465. package/dist/zspec/zcl/definition/tstype.d.ts.map +1 -1
  466. package/dist/zspec/zcl/index.d.ts +10 -10
  467. package/dist/zspec/zcl/utils.d.ts +3 -3
  468. package/dist/zspec/zcl/utils.d.ts.map +1 -1
  469. package/dist/zspec/zcl/utils.js +18 -21
  470. package/dist/zspec/zcl/utils.js.map +1 -1
  471. package/dist/zspec/zcl/zclFrame.d.ts +7 -7
  472. package/dist/zspec/zcl/zclFrame.d.ts.map +1 -1
  473. package/dist/zspec/zcl/zclFrame.js +38 -41
  474. package/dist/zspec/zcl/zclFrame.js.map +1 -1
  475. package/dist/zspec/zcl/zclHeader.d.ts +2 -2
  476. package/dist/zspec/zcl/zclHeader.d.ts.map +1 -1
  477. package/dist/zspec/zcl/zclHeader.js +3 -3
  478. package/dist/zspec/zcl/zclStatusError.d.ts +1 -1
  479. package/dist/zspec/zdo/buffaloZdo.d.ts +7 -7
  480. package/dist/zspec/zdo/buffaloZdo.d.ts.map +1 -1
  481. package/dist/zspec/zdo/buffaloZdo.js +4 -4
  482. package/dist/zspec/zdo/buffaloZdo.js.map +1 -1
  483. package/dist/zspec/zdo/definition/status.d.ts +1 -1
  484. package/dist/zspec/zdo/definition/status.js +1 -1
  485. package/dist/zspec/zdo/definition/tstypes.d.ts +48 -48
  486. package/dist/zspec/zdo/definition/tstypes.d.ts.map +1 -1
  487. package/dist/zspec/zdo/index.d.ts +7 -7
  488. package/dist/zspec/zdo/utils.d.ts +2 -2
  489. package/dist/zspec/zdo/utils.d.ts.map +1 -1
  490. package/dist/zspec/zdo/utils.js +1 -1
  491. package/dist/zspec/zdo/utils.js.map +1 -1
  492. package/dist/zspec/zdo/zdoStatusError.d.ts +1 -1
  493. package/examples/join-and-log.js +5 -5
  494. package/package.json +4 -11
  495. package/src/adapter/adapter.ts +189 -0
  496. package/src/adapter/adapterDiscovery.ts +653 -0
  497. package/src/adapter/const.ts +12 -0
  498. package/src/adapter/deconz/adapter/deconzAdapter.ts +768 -0
  499. package/src/adapter/deconz/driver/constants.ts +180 -0
  500. package/src/adapter/deconz/driver/driver.ts +900 -0
  501. package/src/adapter/deconz/driver/frame.ts +11 -0
  502. package/src/adapter/deconz/driver/frameParser.ts +557 -0
  503. package/src/adapter/deconz/driver/parser.ts +45 -0
  504. package/src/adapter/deconz/driver/writer.ts +22 -0
  505. package/src/adapter/deconz/types.d.ts +13 -0
  506. package/src/adapter/ember/adapter/emberAdapter.ts +2266 -0
  507. package/src/adapter/ember/adapter/endpoints.ts +86 -0
  508. package/src/adapter/ember/adapter/oneWaitress.ts +322 -0
  509. package/src/adapter/ember/adapter/tokensManager.ts +782 -0
  510. package/src/adapter/ember/consts.ts +178 -0
  511. package/src/adapter/ember/enums.ts +2123 -0
  512. package/src/adapter/ember/ezsp/buffalo.ts +1397 -0
  513. package/src/adapter/ember/ezsp/consts.ts +148 -0
  514. package/src/adapter/ember/ezsp/enums.ts +1087 -0
  515. package/src/adapter/ember/ezsp/ezsp.ts +8985 -0
  516. package/src/adapter/ember/ezspError.ts +10 -0
  517. package/src/adapter/ember/types.ts +866 -0
  518. package/src/adapter/ember/uart/ash.ts +1969 -0
  519. package/src/adapter/ember/uart/consts.ts +109 -0
  520. package/src/adapter/ember/uart/enums.ts +192 -0
  521. package/src/adapter/ember/uart/parser.ts +48 -0
  522. package/src/adapter/ember/uart/queues.ts +247 -0
  523. package/src/adapter/ember/uart/writer.ts +53 -0
  524. package/src/adapter/ember/utils/initters.ts +58 -0
  525. package/src/adapter/ember/utils/math.ts +73 -0
  526. package/src/adapter/events.ts +21 -0
  527. package/src/adapter/ezsp/adapter/backup.ts +109 -0
  528. package/src/adapter/ezsp/adapter/ezspAdapter.ts +614 -0
  529. package/src/adapter/ezsp/driver/commands.ts +2497 -0
  530. package/src/adapter/ezsp/driver/consts.ts +11 -0
  531. package/src/adapter/ezsp/driver/driver.ts +1002 -0
  532. package/src/adapter/ezsp/driver/ezsp.ts +802 -0
  533. package/src/adapter/ezsp/driver/frame.ts +101 -0
  534. package/src/adapter/ezsp/driver/index.ts +4 -0
  535. package/src/adapter/ezsp/driver/multicast.ts +78 -0
  536. package/src/adapter/ezsp/driver/parser.ts +81 -0
  537. package/src/adapter/ezsp/driver/types/basic.ts +201 -0
  538. package/src/adapter/ezsp/driver/types/index.ts +239 -0
  539. package/src/adapter/ezsp/driver/types/named.ts +2330 -0
  540. package/src/adapter/ezsp/driver/types/struct.ts +844 -0
  541. package/src/adapter/ezsp/driver/uart.ts +460 -0
  542. package/src/adapter/ezsp/driver/utils/crc16ccitt.ts +44 -0
  543. package/src/adapter/ezsp/driver/utils/index.ts +32 -0
  544. package/src/adapter/ezsp/driver/writer.ts +64 -0
  545. package/src/adapter/index.ts +3 -0
  546. package/src/adapter/serialPort.ts +58 -0
  547. package/src/adapter/socketPortUtils.ts +16 -0
  548. package/src/adapter/tstype.ts +78 -0
  549. package/src/adapter/z-stack/adapter/adapter-backup.ts +519 -0
  550. package/src/adapter/z-stack/adapter/adapter-nv-memory.ts +457 -0
  551. package/src/adapter/z-stack/adapter/endpoints.ts +57 -0
  552. package/src/adapter/z-stack/adapter/manager.ts +544 -0
  553. package/src/adapter/z-stack/adapter/tstype.ts +6 -0
  554. package/src/adapter/z-stack/adapter/zStackAdapter.ts +1190 -0
  555. package/src/adapter/z-stack/constants/af.ts +27 -0
  556. package/src/adapter/z-stack/constants/common.ts +285 -0
  557. package/src/adapter/z-stack/constants/dbg.ts +23 -0
  558. package/src/adapter/z-stack/constants/index.ts +11 -0
  559. package/src/adapter/z-stack/constants/mac.ts +128 -0
  560. package/src/adapter/z-stack/constants/sapi.ts +25 -0
  561. package/src/adapter/z-stack/constants/sys.ts +72 -0
  562. package/src/adapter/z-stack/constants/util.ts +82 -0
  563. package/src/adapter/z-stack/constants/utils.ts +14 -0
  564. package/src/adapter/z-stack/constants/zdo.ts +103 -0
  565. package/src/adapter/z-stack/models/startup-options.ts +13 -0
  566. package/src/adapter/z-stack/structs/entries/address-manager-entry.ts +44 -0
  567. package/src/adapter/z-stack/structs/entries/address-manager-table.ts +19 -0
  568. package/src/adapter/z-stack/structs/entries/aps-link-key-data-entry.ts +12 -0
  569. package/src/adapter/z-stack/structs/entries/aps-link-key-data-table.ts +21 -0
  570. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-entry.ts +19 -0
  571. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-table.ts +21 -0
  572. package/src/adapter/z-stack/structs/entries/channel-list.ts +8 -0
  573. package/src/adapter/z-stack/structs/entries/has-configured.ts +16 -0
  574. package/src/adapter/z-stack/structs/entries/index.ts +16 -0
  575. package/src/adapter/z-stack/structs/entries/nib.ts +66 -0
  576. package/src/adapter/z-stack/structs/entries/nwk-key-descriptor.ts +15 -0
  577. package/src/adapter/z-stack/structs/entries/nwk-key.ts +13 -0
  578. package/src/adapter/z-stack/structs/entries/nwk-pan-id.ts +8 -0
  579. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.ts +20 -0
  580. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.ts +19 -0
  581. package/src/adapter/z-stack/structs/entries/security-manager-entry.ts +33 -0
  582. package/src/adapter/z-stack/structs/entries/security-manager-table.ts +22 -0
  583. package/src/adapter/z-stack/structs/index.ts +4 -0
  584. package/src/adapter/z-stack/structs/serializable-memory-object.ts +14 -0
  585. package/src/adapter/z-stack/structs/struct.ts +367 -0
  586. package/src/adapter/z-stack/structs/table.ts +198 -0
  587. package/src/adapter/z-stack/unpi/constants.ts +33 -0
  588. package/src/adapter/z-stack/unpi/frame.ts +62 -0
  589. package/src/adapter/z-stack/unpi/index.ts +4 -0
  590. package/src/adapter/z-stack/unpi/parser.ts +56 -0
  591. package/src/adapter/z-stack/unpi/writer.ts +21 -0
  592. package/src/adapter/z-stack/utils/channel-list.ts +40 -0
  593. package/src/adapter/z-stack/utils/index.ts +2 -0
  594. package/src/adapter/z-stack/utils/network-options.ts +26 -0
  595. package/src/adapter/z-stack/znp/buffaloZnp.ts +175 -0
  596. package/src/adapter/z-stack/znp/definition.ts +2713 -0
  597. package/src/adapter/z-stack/znp/index.ts +2 -0
  598. package/src/adapter/z-stack/znp/parameterType.ts +22 -0
  599. package/src/adapter/z-stack/znp/tstype.ts +44 -0
  600. package/src/adapter/z-stack/znp/utils.ts +10 -0
  601. package/src/adapter/z-stack/znp/znp.ts +342 -0
  602. package/src/adapter/z-stack/znp/zpiObject.ts +148 -0
  603. package/src/adapter/zboss/adapter/zbossAdapter.ts +527 -0
  604. package/src/adapter/zboss/commands.ts +1184 -0
  605. package/src/adapter/zboss/consts.ts +9 -0
  606. package/src/adapter/zboss/driver.ts +423 -0
  607. package/src/adapter/zboss/enums.ts +360 -0
  608. package/src/adapter/zboss/frame.ts +227 -0
  609. package/src/adapter/zboss/reader.ts +65 -0
  610. package/src/adapter/zboss/types.ts +0 -0
  611. package/src/adapter/zboss/uart.ts +428 -0
  612. package/src/adapter/zboss/utils.ts +58 -0
  613. package/src/adapter/zboss/writer.ts +49 -0
  614. package/src/adapter/zigate/adapter/patchZdoBuffaloBE.ts +27 -0
  615. package/src/adapter/zigate/adapter/zigateAdapter.ts +618 -0
  616. package/src/adapter/zigate/driver/LICENSE +17 -0
  617. package/src/adapter/zigate/driver/buffaloZiGate.ts +212 -0
  618. package/src/adapter/zigate/driver/commandType.ts +418 -0
  619. package/src/adapter/zigate/driver/constants.ts +150 -0
  620. package/src/adapter/zigate/driver/frame.ts +197 -0
  621. package/src/adapter/zigate/driver/messageType.ts +287 -0
  622. package/src/adapter/zigate/driver/parameterType.ts +32 -0
  623. package/src/adapter/zigate/driver/ziGateObject.ts +146 -0
  624. package/src/adapter/zigate/driver/zigate.ts +426 -0
  625. package/src/adapter/zoh/adapter/utils.ts +27 -0
  626. package/src/adapter/zoh/adapter/zohAdapter.ts +837 -0
  627. package/src/buffalo/buffalo.ts +335 -0
  628. package/src/buffalo/index.ts +1 -0
  629. package/src/controller/controller.ts +1048 -0
  630. package/src/controller/database.ts +124 -0
  631. package/src/controller/events.ts +51 -0
  632. package/src/controller/greenPower.ts +603 -0
  633. package/src/controller/helpers/index.ts +1 -0
  634. package/src/controller/helpers/request.ts +94 -0
  635. package/src/controller/helpers/requestQueue.ts +125 -0
  636. package/src/controller/helpers/zclFrameConverter.ts +51 -0
  637. package/src/controller/helpers/zclTransactionSequenceNumber.ts +19 -0
  638. package/src/controller/index.ts +6 -0
  639. package/src/controller/model/device.ts +1320 -0
  640. package/src/controller/model/endpoint.ts +1040 -0
  641. package/src/controller/model/entity.ts +23 -0
  642. package/src/controller/model/group.ts +333 -0
  643. package/src/controller/model/index.ts +4 -0
  644. package/src/controller/touchlink.ts +189 -0
  645. package/src/controller/tstype.ts +39 -0
  646. package/src/index.ts +12 -0
  647. package/src/models/backup-storage-legacy.ts +48 -0
  648. package/src/models/backup-storage-unified.ts +47 -0
  649. package/src/models/backup.ts +37 -0
  650. package/src/models/index.ts +5 -0
  651. package/src/models/network-options.ts +11 -0
  652. package/src/utils/backup.ts +152 -0
  653. package/src/utils/index.ts +5 -0
  654. package/src/utils/logger.ts +20 -0
  655. package/src/utils/patchBigIntSerialization.ts +8 -0
  656. package/src/utils/queue.ts +76 -0
  657. package/src/utils/types.d.ts +3 -0
  658. package/src/utils/utils.ts +20 -0
  659. package/src/utils/wait.ts +5 -0
  660. package/src/utils/waitress.ts +95 -0
  661. package/src/zspec/consts.ts +84 -0
  662. package/src/zspec/enums.ts +22 -0
  663. package/src/zspec/index.ts +3 -0
  664. package/src/zspec/tstypes.ts +18 -0
  665. package/src/zspec/utils.ts +308 -0
  666. package/src/zspec/zcl/buffaloZcl.ts +1133 -0
  667. package/src/zspec/zcl/definition/cluster.ts +5766 -0
  668. package/src/zspec/zcl/definition/consts.ts +24 -0
  669. package/src/zspec/zcl/definition/enums.ts +194 -0
  670. package/src/zspec/zcl/definition/foundation.ts +301 -0
  671. package/src/zspec/zcl/definition/manufacturerCode.ts +729 -0
  672. package/src/zspec/zcl/definition/status.ts +69 -0
  673. package/src/zspec/zcl/definition/tstype.ts +268 -0
  674. package/src/zspec/zcl/index.ts +10 -0
  675. package/src/zspec/zcl/utils.ts +342 -0
  676. package/src/zspec/zcl/zclFrame.ts +336 -0
  677. package/src/zspec/zcl/zclHeader.ts +102 -0
  678. package/src/zspec/zcl/zclStatusError.ts +10 -0
  679. package/src/zspec/zdo/buffaloZdo.ts +2345 -0
  680. package/src/zspec/zdo/definition/clusters.ts +722 -0
  681. package/src/zspec/zdo/definition/consts.ts +16 -0
  682. package/src/zspec/zdo/definition/enums.ts +99 -0
  683. package/src/zspec/zdo/definition/status.ts +105 -0
  684. package/src/zspec/zdo/definition/tstypes.ts +1062 -0
  685. package/src/zspec/zdo/index.ts +7 -0
  686. package/src/zspec/zdo/utils.ts +76 -0
  687. package/src/zspec/zdo/zdoStatusError.ts +10 -0
  688. package/test/adapter/adapter.test.ts +1062 -0
  689. package/test/adapter/ember/ash.test.ts +337 -0
  690. package/test/adapter/ember/consts.ts +131 -0
  691. package/test/adapter/ember/emberAdapter.test.ts +3449 -0
  692. package/test/adapter/ember/ezsp.test.ts +386 -0
  693. package/test/adapter/ember/ezspBuffalo.test.ts +92 -0
  694. package/test/adapter/ember/ezspError.test.ts +11 -0
  695. package/test/adapter/ember/math.test.ts +205 -0
  696. package/test/adapter/ezsp/frame.test.ts +29 -0
  697. package/test/adapter/ezsp/uart.test.ts +180 -0
  698. package/test/adapter/z-stack/adapter.test.ts +3985 -0
  699. package/test/adapter/z-stack/constants.test.ts +32 -0
  700. package/test/adapter/z-stack/structs.test.ts +114 -0
  701. package/test/adapter/z-stack/unpi.test.ts +212 -0
  702. package/test/adapter/z-stack/znp.test.ts +1284 -0
  703. package/test/adapter/zboss/fixZdoResponse.test.ts +178 -0
  704. package/test/adapter/zigate/patchZdoBuffaloBE.test.ts +80 -0
  705. package/test/adapter/zigate/zdo.test.ts +187 -0
  706. package/test/adapter/zoh/utils.test.ts +35 -0
  707. package/test/adapter/zoh/zohAdapter.test.ts +1306 -0
  708. package/test/buffalo.test.ts +430 -0
  709. package/test/controller.test.ts +10005 -0
  710. package/test/greenpower.test.ts +1421 -0
  711. package/test/mockAdapters.ts +65 -0
  712. package/test/mockDevices.ts +472 -0
  713. package/test/testUtils.ts +20 -0
  714. package/test/tsconfig.json +10 -0
  715. package/test/utils/math.ts +19 -0
  716. package/test/utils.test.ts +227 -0
  717. package/test/vitest.config.mts +25 -0
  718. package/test/zcl.test.ts +2832 -0
  719. package/test/zspec/utils.test.ts +131 -0
  720. package/test/zspec/zcl/buffalo.test.ts +1231 -0
  721. package/test/zspec/zcl/frame.test.ts +925 -0
  722. package/test/zspec/zcl/utils.test.ts +280 -0
  723. package/test/zspec/zdo/buffalo.test.ts +1849 -0
  724. package/test/zspec/zdo/utils.test.ts +240 -0
  725. package/.github/workflows/update-dependencies.yml +0 -39
  726. package/.prettierignore +0 -2
  727. package/.prettierrc +0 -26
  728. package/eslint.config.mjs +0 -32
@@ -0,0 +1,1002 @@
1
+ /* v8 ignore start */
2
+
3
+ import {EventEmitter} from "node:events";
4
+
5
+ import equals from "fast-deep-equal/es6";
6
+
7
+ import type {Backup} from "src/models/backup";
8
+ import {Waitress, wait} from "../../../utils";
9
+ import {logger} from "../../../utils/logger";
10
+ import * as ZSpec from "../../../zspec";
11
+ import {Clusters} from "../../../zspec/zcl/definition/cluster";
12
+ import * as Zdo from "../../../zspec/zdo";
13
+ import type {GenericZdoResponse} from "../../../zspec/zdo/definition/tstypes";
14
+ import {EZSPAdapterBackup} from "../adapter/backup";
15
+ import type * as TsType from "./../../tstype";
16
+ import type {ParamsDesc} from "./commands";
17
+ import {type EZSPFrameData, Ezsp} from "./ezsp";
18
+ import {Multicast} from "./multicast";
19
+ import {EmberApsOption, EmberJoinDecision, EmberKeyData, EmberNodeType, EmberStatus, uint8_t, uint16_t} from "./types";
20
+ import {
21
+ EmberDerivedKeyType,
22
+ EmberDeviceUpdate,
23
+ EmberEUI64,
24
+ EmberInitialSecurityBitmask,
25
+ EmberJoinMethod,
26
+ EmberKeyType,
27
+ EmberNetworkStatus,
28
+ EmberOutgoingMessageType,
29
+ type EmberStackError,
30
+ EzspDecisionBitmask,
31
+ EzspPolicyId,
32
+ EzspValueId,
33
+ SLStatus,
34
+ } from "./types/named";
35
+ import {
36
+ EmberApsFrame,
37
+ EmberIeeeRawFrame,
38
+ type EmberInitialSecurityState,
39
+ type EmberKeyStruct,
40
+ EmberNetworkParameters,
41
+ EmberRawFrame,
42
+ EmberSecurityManagerContext,
43
+ } from "./types/struct";
44
+ import {emberSecurity} from "./utils";
45
+
46
+ const NS = "zh:ezsp:driv";
47
+
48
+ interface AddEndpointParameters {
49
+ endpoint?: number;
50
+ profileId?: number;
51
+ deviceId?: number;
52
+ appFlags?: number;
53
+ inputClusters?: number[];
54
+ outputClusters?: number[];
55
+ }
56
+
57
+ type EmberFrame = {
58
+ address: number | string;
59
+ payload: Buffer;
60
+ frame: EmberApsFrame;
61
+ zdoResponse?: GenericZdoResponse;
62
+ };
63
+
64
+ type EmberWaitressMatcher = {
65
+ address: number | string;
66
+ clusterId: number;
67
+ sequence: number;
68
+ };
69
+
70
+ type IeeeMfg = {
71
+ mfgId: number;
72
+ prefix: number[];
73
+ };
74
+
75
+ export interface EmberIncomingMessage {
76
+ messageType: number;
77
+ apsFrame: EmberApsFrame;
78
+ lqi: number;
79
+ rssi: number;
80
+ sender: number;
81
+ bindingIndex: number;
82
+ addressIndex: number;
83
+ message: Buffer;
84
+ senderEui64: EmberEUI64;
85
+ zdoResponse?: GenericZdoResponse;
86
+ }
87
+
88
+ const IEEE_PREFIX_MFG_ID: IeeeMfg[] = [
89
+ {mfgId: 0x115f, prefix: [0x04, 0xcf, 0xfc]},
90
+ {mfgId: 0x115f, prefix: [0x54, 0xef, 0x44]},
91
+ ];
92
+ const DEFAULT_MFG_ID = 0x1049;
93
+ // we make three attempts to send the request
94
+ const REQUEST_ATTEMPT_DELAYS = [500, 1000, 1500];
95
+
96
+ export class Driver extends EventEmitter {
97
+ // @ts-expect-error XXX: init in startup
98
+ public ezsp: Ezsp;
99
+ private nwkOpt: TsType.NetworkOptions;
100
+ // @ts-expect-error XXX: init in startup
101
+ public networkParams: EmberNetworkParameters;
102
+ // @ts-expect-error XXX: init in startup
103
+ public version: {
104
+ product: number;
105
+ majorrel: string;
106
+ minorrel: string;
107
+ maintrel: string;
108
+ revision: string;
109
+ };
110
+ private eui64ToNodeId = new Map<string, number>();
111
+ // private eui64ToRelays = new Map<string, number>();
112
+ // @ts-expect-error XXX: init in startup
113
+ public ieee: EmberEUI64;
114
+ // @ts-expect-error XXX: init in startup
115
+ private multicast: Multicast;
116
+ private waitress: Waitress<EmberFrame, EmberWaitressMatcher>;
117
+ private transactionID = 1;
118
+ private serialOpt: TsType.SerialPortOptions;
119
+ public backupMan: EZSPAdapterBackup;
120
+
121
+ constructor(serialOpt: TsType.SerialPortOptions, nwkOpt: TsType.NetworkOptions, backupPath: string) {
122
+ super();
123
+
124
+ this.nwkOpt = nwkOpt;
125
+ this.serialOpt = serialOpt;
126
+ this.waitress = new Waitress<EmberFrame, EmberWaitressMatcher>(this.waitressValidator, this.waitressTimeoutFormatter);
127
+ this.backupMan = new EZSPAdapterBackup(this, backupPath);
128
+ }
129
+
130
+ /**
131
+ * Requested by the EZSP watchdog after too many failures, or by UART layer after port closed unexpectedly.
132
+ * Tries to stop the layers below and startup again.
133
+ * @returns
134
+ */
135
+ public async reset(): Promise<void> {
136
+ logger.debug("Reset connection.", NS);
137
+
138
+ try {
139
+ // don't emit 'close' on stop since we don't want this to bubble back up as 'disconnected' to the controller.
140
+ await this.stop(false);
141
+ } catch (err) {
142
+ logger.debug(`Stop error ${err}`, NS);
143
+ }
144
+ try {
145
+ await wait(1000);
146
+ logger.debug("Startup again.", NS);
147
+ await this.startup();
148
+ } catch (err) {
149
+ logger.debug(`Reset error ${err}`, NS);
150
+
151
+ try {
152
+ // here we let emit
153
+ await this.stop();
154
+ } catch (stopErr) {
155
+ logger.debug(`Failed to stop after failed reset ${stopErr}`, NS);
156
+ }
157
+ }
158
+ }
159
+
160
+ private async onEzspReset(): Promise<void> {
161
+ logger.debug("onEzspReset()", NS);
162
+ await this.reset();
163
+ }
164
+
165
+ private onEzspClose(): void {
166
+ logger.debug("onEzspClose()", NS);
167
+ this.emit("close");
168
+ }
169
+
170
+ public async stop(emitClose = true): Promise<void> {
171
+ logger.debug("Stopping driver", NS);
172
+
173
+ if (this.ezsp) {
174
+ return await this.ezsp.close(emitClose);
175
+ }
176
+ }
177
+
178
+ public async startup(transmitPower?: number): Promise<TsType.StartResult> {
179
+ let result: TsType.StartResult = "resumed";
180
+ this.transactionID = 1;
181
+ // this.ezsp = undefined;
182
+ this.ezsp = new Ezsp();
183
+ this.ezsp.on("close", this.onEzspClose.bind(this));
184
+
185
+ try {
186
+ await this.ezsp.connect(this.serialOpt);
187
+ } catch (error) {
188
+ logger.debug(`EZSP could not connect: ${error}`, NS);
189
+
190
+ throw error;
191
+ }
192
+
193
+ this.ezsp.on("reset", this.onEzspReset.bind(this));
194
+
195
+ await this.ezsp.version();
196
+ await this.ezsp.updateConfig();
197
+ await this.ezsp.updatePolicies();
198
+ //await this.ezsp.setValue(EzspValueId.VALUE_MAXIMUM_OUTGOING_TRANSFER_SIZE, 82);
199
+ //await this.ezsp.setValue(EzspValueId.VALUE_MAXIMUM_INCOMING_TRANSFER_SIZE, 82);
200
+ await this.ezsp.setValue(EzspValueId.VALUE_END_DEVICE_KEEP_ALIVE_SUPPORT_MODE, 3);
201
+ await this.ezsp.setValue(EzspValueId.VALUE_CCA_THRESHOLD, 0);
202
+ await this.ezsp.setSourceRouting();
203
+ //const count = await ezsp.getConfigurationValue(EzspConfigId.CONFIG_APS_UNICAST_MESSAGE_COUNT);
204
+ //logger.info("APS_UNICAST_MESSAGE_COUNT is set to %s", count, NS);
205
+ await this.addEndpoint({
206
+ inputClusters: [0x0000, 0x0003, 0x0006, 0x000a, 0x0019, 0x001a, 0x0300],
207
+ outputClusters: [
208
+ 0x0000, 0x0003, 0x0004, 0x0005, 0x0006, 0x0008, 0x0020, 0x0300, 0x0400, 0x0402, 0x0405, 0x0406, 0x0500, 0x0b01, 0x0b03, 0x0b04,
209
+ 0x0702, 0x1000, 0xfc01, 0xfc02,
210
+ ],
211
+ });
212
+ await this.addEndpoint({
213
+ endpoint: 242,
214
+ profileId: 0xa1e0,
215
+ deviceId: 0x61,
216
+ outputClusters: [0x0021],
217
+ });
218
+
219
+ // getting MFG_STRING token
220
+ //const mfgName = await ezsp.execCommand('getMfgToken', EzspMfgTokenId.MFG_STRING);
221
+ // getting MFG_BOARD_NAME token
222
+ //const boardName = await ezsp.execCommand('getMfgToken', EzspMfgTokenId.MFG_BOARD_NAME);
223
+ let verInfo = await this.ezsp.getValue(EzspValueId.VALUE_VERSION_INFO);
224
+ // biome-ignore lint/style/useConst: <explanation>
225
+ let build: number;
226
+ // biome-ignore lint/style/useConst: <explanation>
227
+ let major: number;
228
+ // biome-ignore lint/style/useConst: <explanation>
229
+ let minor: number;
230
+ // biome-ignore lint/style/useConst: <explanation>
231
+ let patch: number;
232
+ // biome-ignore lint/style/useConst: <explanation>
233
+ let special: number;
234
+ [build, verInfo] = uint16_t.deserialize(uint16_t, verInfo);
235
+ [major, verInfo] = uint8_t.deserialize(uint8_t, verInfo);
236
+ [minor, verInfo] = uint8_t.deserialize(uint8_t, verInfo);
237
+ [patch, verInfo] = uint8_t.deserialize(uint8_t, verInfo);
238
+ [special, verInfo] = uint8_t.deserialize(uint8_t, verInfo);
239
+ const vers = `${major}.${minor}.${patch}.${special} build ${build}`;
240
+ logger.debug(`EmberZNet version: ${vers}`, NS);
241
+ this.version = {
242
+ product: this.ezsp.ezspV,
243
+ majorrel: `${major}`,
244
+ minorrel: `${minor}`,
245
+ maintrel: `${patch} `,
246
+ revision: vers,
247
+ };
248
+
249
+ if (await this.needsToBeInitialised(this.nwkOpt)) {
250
+ // need to check the backup
251
+ const restore = await this.needsToBeRestore(this.nwkOpt);
252
+
253
+ const res = await this.ezsp.execCommand("networkState");
254
+
255
+ logger.debug(`Network state ${res.status}`, NS);
256
+
257
+ if (res.status === EmberNetworkStatus.JOINED_NETWORK) {
258
+ logger.info("Leaving current network and forming new network", NS);
259
+
260
+ const st = await this.ezsp.leaveNetwork();
261
+
262
+ if (st !== EmberStatus.NETWORK_DOWN) {
263
+ logger.error(`leaveNetwork returned unexpected status: ${st}`, NS);
264
+ }
265
+ }
266
+
267
+ if (restore) {
268
+ // restore
269
+ logger.info("Restore network from backup", NS);
270
+ await this.formNetwork(true, transmitPower);
271
+ result = "restored";
272
+ } else {
273
+ // reset
274
+ logger.info("Form network", NS);
275
+ await this.formNetwork(false, transmitPower);
276
+ result = "reset";
277
+ }
278
+ }
279
+
280
+ const state = (await this.ezsp.execCommand("networkState")).status;
281
+ logger.debug(`Network state ${state}`, NS);
282
+
283
+ const netParams = await this.ezsp.execCommand("getNetworkParameters");
284
+
285
+ if (netParams.status !== EmberStatus.SUCCESS) {
286
+ logger.error(`Command (getNetworkParameters) returned unexpected state: ${netParams.status}`, NS);
287
+ }
288
+
289
+ this.networkParams = netParams.parameters;
290
+ logger.debug(`Node type: ${netParams.nodeType}, Network parameters: ${this.networkParams}`, NS);
291
+
292
+ const nwk = (await this.ezsp.execCommand("getNodeId")).nodeId;
293
+ const ieee = (await this.ezsp.execCommand("getEui64")).eui64;
294
+ this.ieee = new EmberEUI64(ieee);
295
+ logger.debug("Network ready", NS);
296
+ this.ezsp.on("frame", this.handleFrame.bind(this));
297
+ logger.debug(`EZSP nwk=${nwk}, IEEE=0x${this.ieee}`, NS);
298
+ const linkResult = await this.getKey(EmberKeyType.TRUST_CENTER_LINK_KEY);
299
+ logger.debug(`TRUST_CENTER_LINK_KEY: ${JSON.stringify(linkResult)}`, NS);
300
+ const netResult = await this.getKey(EmberKeyType.CURRENT_NETWORK_KEY);
301
+ logger.debug(`CURRENT_NETWORK_KEY: ${JSON.stringify(netResult)}`, NS);
302
+
303
+ await wait(1000);
304
+ await this.ezsp.execCommand("setManufacturerCode", {code: DEFAULT_MFG_ID});
305
+
306
+ this.multicast = new Multicast(this);
307
+ await this.multicast.startup([]);
308
+ await this.multicast.subscribe(ZSpec.GP_GROUP_ID, ZSpec.GP_ENDPOINT);
309
+ // await this.multicast.subscribe(1, 901);
310
+
311
+ if (transmitPower != null && this.networkParams.radioTxPower !== transmitPower) {
312
+ await this.ezsp.execCommand("setRadioPower", {power: transmitPower});
313
+ }
314
+
315
+ return result;
316
+ }
317
+
318
+ private async needsToBeInitialised(options: TsType.NetworkOptions): Promise<boolean> {
319
+ let valid = true;
320
+ valid = valid && (await this.ezsp.networkInit());
321
+ const netParams = await this.ezsp.execCommand("getNetworkParameters");
322
+ const networkParams = netParams.parameters;
323
+ logger.debug(`Current Node type: ${netParams.nodeType}, Network parameters: ${networkParams}`, NS);
324
+ valid = valid && netParams.status === EmberStatus.SUCCESS;
325
+ valid = valid && netParams.nodeType === EmberNodeType.COORDINATOR;
326
+ valid = valid && options.panID === networkParams.panId;
327
+ valid = valid && options.channelList.includes(networkParams.radioChannel);
328
+ valid = valid && equals(options.extendedPanID, networkParams.extendedPanId);
329
+ return !valid;
330
+ }
331
+
332
+ private async formNetwork(restore: boolean, transmitPower?: number): Promise<void> {
333
+ let backup: Backup | undefined;
334
+ await this.ezsp.execCommand("clearTransientLinkKeys");
335
+
336
+ let initialSecurityState: EmberInitialSecurityState;
337
+ if (restore) {
338
+ backup = this.backupMan.getStoredBackup();
339
+
340
+ if (!backup) {
341
+ throw new Error("No valid backup found.");
342
+ }
343
+
344
+ initialSecurityState = emberSecurity(backup.networkOptions.networkKey);
345
+ initialSecurityState.bitmask |= EmberInitialSecurityBitmask.NO_FRAME_COUNTER_RESET;
346
+ initialSecurityState.networkKeySequenceNumber = backup.networkKeyInfo.sequenceNumber;
347
+ // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
348
+ initialSecurityState.preconfiguredKey.contents = backup.ezsp!.hashed_tclk!;
349
+ } else {
350
+ await this.ezsp.execCommand("clearKeyTable");
351
+ // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
352
+ initialSecurityState = emberSecurity(Buffer.from(this.nwkOpt.networkKey!));
353
+ }
354
+ await this.ezsp.setInitialSecurityState(initialSecurityState);
355
+
356
+ const parameters: EmberNetworkParameters = new EmberNetworkParameters();
357
+ parameters.radioTxPower = transmitPower ?? 5;
358
+ parameters.joinMethod = EmberJoinMethod.USE_MAC_ASSOCIATION;
359
+ parameters.nwkManagerId = 0;
360
+ parameters.nwkUpdateId = 0;
361
+ parameters.channels = 0x07fff800; // all channels
362
+ if (restore) {
363
+ // `backup` valid from above
364
+ // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
365
+ parameters.panId = backup!.networkOptions.panId;
366
+ // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
367
+ parameters.extendedPanId = backup!.networkOptions.extendedPanId;
368
+ // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
369
+ parameters.radioChannel = backup!.logicalChannel;
370
+ // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
371
+ parameters.nwkUpdateId = backup!.networkUpdateId;
372
+ } else {
373
+ parameters.radioChannel = this.nwkOpt.channelList[0];
374
+ parameters.panId = this.nwkOpt.panID;
375
+ // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
376
+ parameters.extendedPanId = Buffer.from(this.nwkOpt.extendedPanID!);
377
+ }
378
+
379
+ await this.ezsp.formNetwork(parameters);
380
+ await this.ezsp.setValue(EzspValueId.VALUE_STACK_TOKEN_WRITING, 1);
381
+ }
382
+
383
+ private handleFrame(frameName: string, frame: EZSPFrameData): void {
384
+ switch (true) {
385
+ case frameName === "incomingMessageHandler": {
386
+ const apsFrame: EmberApsFrame = frame.apsFrame;
387
+
388
+ if (apsFrame.profileId === Zdo.ZDO_PROFILE_ID && apsFrame.clusterId >= 0x8000 /* response only */) {
389
+ const zdoResponse = Zdo.Buffalo.readResponse(true, apsFrame.clusterId, frame.message);
390
+
391
+ if (apsFrame.clusterId === Zdo.ClusterId.NETWORK_ADDRESS_RESPONSE) {
392
+ // special case to properly resolve a NETWORK_ADDRESS_RESPONSE following a NETWORK_ADDRESS_REQUEST (based on EUI64 from ZDO payload)
393
+ // NOTE: if response has invalid status (no EUI64 available), response waiter will eventually time out
394
+ if (Zdo.Buffalo.checkStatus<Zdo.ClusterId.NETWORK_ADDRESS_RESPONSE>(zdoResponse)) {
395
+ const eui64 = zdoResponse[1].eui64;
396
+
397
+ // update cache with new network address
398
+ this.eui64ToNodeId.set(eui64, frame.sender);
399
+
400
+ this.waitress.resolve({
401
+ address: eui64,
402
+ payload: frame.message,
403
+ frame: apsFrame,
404
+ zdoResponse,
405
+ });
406
+ }
407
+ } else {
408
+ this.waitress.resolve({
409
+ address: frame.sender,
410
+ payload: frame.message,
411
+ frame: apsFrame,
412
+ zdoResponse,
413
+ });
414
+ }
415
+
416
+ // always pass ZDO to bubble up to controller
417
+ this.emit("incomingMessage", {
418
+ messageType: frame.type,
419
+ apsFrame,
420
+ lqi: frame.lastHopLqi,
421
+ rssi: frame.lastHopRssi,
422
+ sender: frame.sender,
423
+ bindingIndex: frame.bindingIndex,
424
+ addressIndex: frame.addressIndex,
425
+ message: frame.message,
426
+ senderEui64: this.eui64ToNodeId.get(frame.sender),
427
+ zdoResponse,
428
+ });
429
+ } else {
430
+ const handled = this.waitress.resolve({
431
+ address: frame.sender,
432
+ payload: frame.message,
433
+ frame: apsFrame,
434
+ });
435
+
436
+ if (!handled) {
437
+ this.emit("incomingMessage", {
438
+ messageType: frame.type,
439
+ apsFrame,
440
+ lqi: frame.lastHopLqi,
441
+ rssi: frame.lastHopRssi,
442
+ sender: frame.sender,
443
+ bindingIndex: frame.bindingIndex,
444
+ addressIndex: frame.addressIndex,
445
+ message: frame.message,
446
+ senderEui64: this.eui64ToNodeId.get(frame.sender),
447
+ });
448
+ }
449
+ }
450
+ break;
451
+ }
452
+ case frameName === "trustCenterJoinHandler": {
453
+ if (frame.status === EmberDeviceUpdate.DEVICE_LEFT) {
454
+ this.handleNodeLeft(frame.newNodeId, frame.newNodeEui64);
455
+ } else {
456
+ if (frame.policyDecision !== EmberJoinDecision.DENY_JOIN) {
457
+ this.handleNodeJoined(frame.newNodeId, frame.newNodeEui64);
458
+ }
459
+ }
460
+ break;
461
+ }
462
+ case frameName === "incomingRouteRecordHandler": {
463
+ this.handleRouteRecord(frame.source, frame.longId, frame.lastHopLqi, frame.lastHopRssi, frame.relay);
464
+ break;
465
+ }
466
+ case frameName === "incomingRouteErrorHandler": {
467
+ this.handleRouteError(frame.status, frame.target);
468
+ break;
469
+ }
470
+ case frameName === "incomingNetworkStatusHandler": {
471
+ this.handleNetworkStatus(frame.errorCode, frame.target);
472
+ break;
473
+ }
474
+ case frameName === "messageSentHandler": {
475
+ // todo
476
+ const status = frame.status;
477
+ if (status !== 0) {
478
+ // send failure
479
+ logger.debug(() => `Delivery failed for ${JSON.stringify(frame)}.`, NS);
480
+ } else {
481
+ // send success
482
+ // If there was a message to the group and this group is not known,
483
+ // then we will register the coordinator in this group
484
+ // Applicable for IKEA remotes
485
+ const msgType = frame.type;
486
+ if (msgType === EmberOutgoingMessageType.OUTGOING_MULTICAST) {
487
+ const apsFrame = frame.apsFrame;
488
+ if (apsFrame.destinationEndpoint === 255) {
489
+ this.multicast.subscribe(apsFrame.groupId, 1);
490
+ }
491
+ }
492
+ }
493
+ break;
494
+ }
495
+ case frameName === "macFilterMatchMessageHandler": {
496
+ const [rawFrame, data] = EmberIeeeRawFrame.deserialize(EmberIeeeRawFrame, frame.message);
497
+ logger.debug(`macFilterMatchMessageHandler frame message: ${rawFrame}`, NS);
498
+ this.emit("incomingMessage", {
499
+ messageType: null,
500
+ apsFrame: rawFrame,
501
+ lqi: frame.lastHopLqi,
502
+ rssi: frame.lastHopRssi,
503
+ sender: null,
504
+ bindingIndex: null,
505
+ addressIndex: null,
506
+ message: data,
507
+ senderEui64: new EmberEUI64(rawFrame.sourceAddress),
508
+ });
509
+ break;
510
+ }
511
+ case frameName === "stackStatusHandler": {
512
+ logger.debug(`stackStatusHandler: ${EmberStatus.valueToName(EmberStatus, frame.status)}`, NS);
513
+ break;
514
+ }
515
+ // case (frameName === 'childJoinHandler'): {
516
+ // if (!frame.joining) {
517
+ // this.handleNodeLeft(frame.childId, frame.childEui64);
518
+ // } else {
519
+ // this.handleNodeJoined(frame.childId, frame.childEui64);
520
+ // }
521
+ // break;
522
+ // }
523
+ case frameName === "gpepIncomingMessageHandler": {
524
+ let commandIdentifier = Clusters.greenPower.commands.notification.ID;
525
+
526
+ if (frame.gpdCommandId === 0xe0) {
527
+ if (!frame.gpdCommandPayload.length) {
528
+ // XXX: seem to be receiving duplicate commissioningNotification from some devices, second one with empty payload?
529
+ // this will mess with the process no doubt, so dropping them
530
+ return;
531
+ }
532
+
533
+ commandIdentifier = Clusters.greenPower.commands.commissioningNotification.ID;
534
+ }
535
+
536
+ const gpdHeader = Buffer.alloc(15);
537
+ gpdHeader.writeUInt8(0b00000001, 0); // frameControl: FrameType.SPECIFIC + Direction.CLIENT_TO_SERVER + disableDefaultResponse=false
538
+ gpdHeader.writeUInt8(frame.sequenceNumber, 1); // transactionSequenceNumber
539
+ gpdHeader.writeUInt8(commandIdentifier, 2); // commandIdentifier
540
+ gpdHeader.writeUInt16LE(0, 3); // options XXX: bypassed, same as deconz https://github.com/Koenkk/zigbee-herdsman/pull/536
541
+ gpdHeader.writeUInt32LE(frame.srcId, 5); // srcID
542
+ // omitted: gpdIEEEAddr ieeeAddr
543
+ // omitted: gpdEndpoint uint8
544
+ gpdHeader.writeUInt32LE(frame.gpdSecurityFrameCounter, 9); // frameCounter
545
+ gpdHeader.writeUInt8(frame.gpdCommandId, 13); // commandID
546
+ gpdHeader.writeUInt8(frame.gpdCommandPayload.length, 14); // payloadSize
547
+
548
+ const gpdMessage = {
549
+ messageType: frame.gpdCommandId,
550
+ apsFrame: {
551
+ profileId: 0xa1e0,
552
+ sourceEndpoint: 242,
553
+ clusterId: 0x0021,
554
+ sequence: frame.sequenceNumber,
555
+ },
556
+ lqi: frame.gpdLink,
557
+ message: Buffer.concat([gpdHeader, frame.gpdCommandPayload]),
558
+ sender: frame.addr,
559
+ };
560
+ this.emit("incomingMessage", gpdMessage);
561
+ break;
562
+ }
563
+ default:
564
+ // <=== Application frame 35 (childJoinHandler) received: 00013e9c2ebd08feff9ffd9004 +1ms
565
+ // <=== Application frame 35 (childJoinHandler) parsed: 0,1,39998,144,253,159,255,254,8,189,46,4 +1ms
566
+ // Unhandled frame childJoinHandler +2s
567
+ // <=== Application frame 98 (incomingSenderEui64Handler) received: 2ebd08feff9ffd90 +2ms
568
+ // <=== Application frame 98 (incomingSenderEui64Handler) parsed: 144,253,159,255,254,8,189,46 +1ms
569
+ // Unhandled frame incomingSenderEui64Handler
570
+ // <=== Application frame 155 (zigbeeKeyEstablishmentHandler) received: 2ebd08feff9ffd9006 +2ms
571
+ // <=== Application frame 155 (zigbeeKeyEstablishmentHandler) parsed: 144,253,159,255,254,8,189,46,6 +2ms
572
+ // Unhandled frame zigbeeKeyEstablishmentHandler
573
+ logger.debug(`Unhandled frame ${frameName}`, NS);
574
+ }
575
+ }
576
+
577
+ private handleRouteRecord(nwk: number, ieee: EmberEUI64 | number[], lqi: number, rssi: number, relays: number): void {
578
+ // todo
579
+ logger.debug(`handleRouteRecord: nwk=${nwk}, ieee=${ieee.toString()}, lqi=${lqi}, rssi=${rssi}, relays=${relays}`, NS);
580
+
581
+ this.setNode(nwk, ieee);
582
+ // if (ieee && !(ieee instanceof EmberEUI64)) {
583
+ // ieee = new EmberEUI64(ieee);
584
+ // }
585
+ // this.eui64ToRelays.set(ieee.toString(), relays);
586
+ }
587
+
588
+ private handleRouteError(status: EmberStatus, nwk: number): void {
589
+ // todo
590
+ logger.debug(`handleRouteError: nwk=${nwk}, status=${status}`, NS);
591
+ //this.waitress.reject({address: nwk, payload: null, frame: null}, 'Route error');
592
+ // const ieee = await this.networkIdToEUI64(nwk);
593
+ // this.eui64ToRelays.set(ieee.toString(), null);
594
+ }
595
+
596
+ private handleNetworkStatus(errorCode: EmberStackError, nwk: number): void {
597
+ // todo
598
+ // <== Frame: e19401c4000684c5
599
+ // <== 0xc4: {
600
+ // "_cls_":"incomingNetworkStatusHandler",
601
+ // "_id_":196,
602
+ // "_isRequest_":false,
603
+ // "errorCode":6,
604
+ // "target":50564
605
+ // }
606
+ // https://docs.silabs.com/d/zigbee-stack-api/7.4.0/message#ember-incoming-network-status-handler
607
+ logger.debug(`handleNetworkStatus: nwk=${nwk}, errorCode=${errorCode}`, NS);
608
+ }
609
+
610
+ private handleNodeLeft(nwk: number, ieee: EmberEUI64 | number[]): void {
611
+ if (ieee && !(ieee instanceof EmberEUI64)) {
612
+ ieee = new EmberEUI64(ieee);
613
+ }
614
+
615
+ this.eui64ToNodeId.delete(ieee.toString());
616
+ this.emit("deviceLeft", nwk, ieee);
617
+ }
618
+
619
+ private async resetMfgId(mfgId: number): Promise<void> {
620
+ await this.ezsp.execCommand("setManufacturerCode", {code: mfgId});
621
+ // 60 sec for waiting
622
+ await wait(60000);
623
+ await this.ezsp.execCommand("setManufacturerCode", {code: DEFAULT_MFG_ID});
624
+ }
625
+
626
+ public handleNodeJoined(nwk: number, ieee: EmberEUI64 | number[]): void {
627
+ if (ieee && !(ieee instanceof EmberEUI64)) {
628
+ ieee = new EmberEUI64(ieee);
629
+ }
630
+
631
+ for (const rec of IEEE_PREFIX_MFG_ID) {
632
+ if (Buffer.from(ieee.value).indexOf(Buffer.from(rec.prefix)) === 0) {
633
+ // set ManufacturerCode
634
+ logger.debug(`handleNodeJoined: change ManufacturerCode for ieee ${ieee} to ${rec.mfgId}`, NS);
635
+ this.resetMfgId(rec.mfgId);
636
+ break;
637
+ }
638
+ }
639
+
640
+ this.eui64ToNodeId.set(ieee.toString(), nwk);
641
+ this.emit("deviceJoined", nwk, ieee);
642
+ }
643
+
644
+ public setNode(nwk: number, ieee: EmberEUI64 | number[]): void {
645
+ if (ieee && !(ieee instanceof EmberEUI64)) {
646
+ ieee = new EmberEUI64(ieee);
647
+ }
648
+
649
+ this.eui64ToNodeId.set(ieee.toString(), nwk);
650
+ }
651
+
652
+ public async request(nwk: number | EmberEUI64, apsFrame: EmberApsFrame, data: Buffer, extendedTimeout = false): Promise<boolean> {
653
+ let result = false;
654
+
655
+ for (const delay of REQUEST_ATTEMPT_DELAYS) {
656
+ try {
657
+ const seq = (apsFrame.sequence + 1) & 0xff;
658
+ let eui64: EmberEUI64;
659
+
660
+ if (typeof nwk !== "number") {
661
+ eui64 = nwk as EmberEUI64;
662
+ const strEui64 = eui64.toString();
663
+ let nodeId = this.eui64ToNodeId.get(strEui64);
664
+
665
+ if (nodeId === undefined) {
666
+ nodeId = (await this.ezsp.execCommand("lookupNodeIdByEui64", {eui64: eui64})).nodeId;
667
+
668
+ if (nodeId && nodeId !== 0xffff) {
669
+ this.eui64ToNodeId.set(strEui64, nodeId);
670
+ } else {
671
+ throw new Error(`Unknown EUI64:${strEui64}`);
672
+ }
673
+ }
674
+ nwk = nodeId;
675
+ } else {
676
+ eui64 = await this.networkIdToEUI64(nwk);
677
+ }
678
+
679
+ if (this.ezsp.ezspV < 8) {
680
+ // const route = this.eui64ToRelays.get(eui64.toString());
681
+ // if (route) {
682
+ // const = await this.ezsp.execCommand('setSourceRoute', {eui64});
683
+ // // }
684
+ }
685
+
686
+ if (extendedTimeout) {
687
+ await this.ezsp.execCommand("setExtendedTimeout", {remoteEui64: eui64, extendedTimeout: true});
688
+ }
689
+
690
+ const sendResult = await this.ezsp.sendUnicast(EmberOutgoingMessageType.OUTGOING_DIRECT, nwk, apsFrame, seq, data);
691
+
692
+ // repeat only for these statuses
693
+ if ([EmberStatus.MAX_MESSAGE_LIMIT_REACHED, EmberStatus.NO_BUFFERS, EmberStatus.NETWORK_BUSY].includes(sendResult.status)) {
694
+ // need to repeat after pause
695
+ logger.error(`Request send status ${sendResult.status}. Attempt to repeat the request`, NS);
696
+
697
+ await wait(delay);
698
+ } else {
699
+ result = sendResult.status === EmberStatus.SUCCESS;
700
+ break;
701
+ }
702
+ } catch (e) {
703
+ logger.debug(`Request error ${e}`, NS);
704
+ break;
705
+ }
706
+ }
707
+
708
+ return result;
709
+ }
710
+
711
+ public async mrequest(apsFrame: EmberApsFrame, data: Buffer, _timeout = 30000): Promise<boolean> {
712
+ try {
713
+ const seq = (apsFrame.sequence + 1) & 0xff;
714
+ await this.ezsp.sendMulticast(apsFrame, seq, data);
715
+ return true;
716
+ } catch {
717
+ return false;
718
+ }
719
+ }
720
+
721
+ public async rawrequest(rawFrame: EmberRawFrame, data: Buffer, _timeout = 10000): Promise<boolean> {
722
+ try {
723
+ const msgData = Buffer.concat([EmberRawFrame.serialize(EmberRawFrame, rawFrame), data]);
724
+ await this.ezsp.execCommand("sendRawMessage", {message: msgData});
725
+ return true;
726
+ } catch (e) {
727
+ logger.debug(`Request error ${e}`, NS);
728
+ return false;
729
+ }
730
+ }
731
+
732
+ public async ieeerawrequest(rawFrame: EmberIeeeRawFrame, data: Buffer, _timeout = 10000): Promise<boolean> {
733
+ try {
734
+ const msgData = Buffer.concat([EmberIeeeRawFrame.serialize(EmberIeeeRawFrame, rawFrame), data]);
735
+ await this.ezsp.execCommand("sendRawMessage", {message: msgData});
736
+ return true;
737
+ } catch (e) {
738
+ logger.debug(`Request error ${e}`, NS);
739
+ return false;
740
+ }
741
+ }
742
+
743
+ public async brequest(destination: number, apsFrame: EmberApsFrame, data: Buffer): Promise<boolean> {
744
+ try {
745
+ const seq = (apsFrame.sequence + 1) & 0xff;
746
+ await this.ezsp.sendBroadcast(destination, apsFrame, seq, data);
747
+ return true;
748
+ } catch {
749
+ return false;
750
+ }
751
+ }
752
+
753
+ private nextTransactionID(): number {
754
+ this.transactionID = (this.transactionID + 1) & 0xff;
755
+ return this.transactionID;
756
+ }
757
+
758
+ public makeApsFrame(clusterId: number, disableResponse: boolean): EmberApsFrame {
759
+ const frame = new EmberApsFrame();
760
+ frame.clusterId = clusterId;
761
+ frame.profileId = 0;
762
+ frame.sequence = this.nextTransactionID();
763
+ frame.sourceEndpoint = 0;
764
+ frame.destinationEndpoint = 0;
765
+ frame.groupId = 0;
766
+ frame.options = EmberApsOption.APS_OPTION_ENABLE_ROUTE_DISCOVERY || EmberApsOption.APS_OPTION_ENABLE_ADDRESS_DISCOVERY;
767
+
768
+ if (!disableResponse) {
769
+ frame.options ||= EmberApsOption.APS_OPTION_RETRY;
770
+ }
771
+
772
+ return frame;
773
+ }
774
+
775
+ public makeEmberRawFrame(): EmberRawFrame {
776
+ const frame = new EmberRawFrame();
777
+ frame.sequence = this.nextTransactionID();
778
+ return frame;
779
+ }
780
+
781
+ public makeEmberIeeeRawFrame(): EmberIeeeRawFrame {
782
+ const frame = new EmberIeeeRawFrame();
783
+ frame.sequence = this.nextTransactionID();
784
+ return frame;
785
+ }
786
+
787
+ public async networkIdToEUI64(nwk: number): Promise<EmberEUI64> {
788
+ for (const [eUI64, value] of this.eui64ToNodeId) {
789
+ if (value === nwk) return new EmberEUI64(eUI64);
790
+ }
791
+
792
+ const value = await this.ezsp.execCommand("lookupEui64ByNodeId", {nodeId: nwk});
793
+
794
+ if (value.status === EmberStatus.SUCCESS) {
795
+ const eUI64 = new EmberEUI64(value.eui64);
796
+ this.eui64ToNodeId.set(eUI64.toString(), nwk);
797
+
798
+ return eUI64;
799
+ }
800
+ throw new Error(`Unrecognized nodeId:${nwk}`);
801
+ }
802
+
803
+ public async preJoining(seconds: number): Promise<void> {
804
+ if (seconds) {
805
+ const ieee = new EmberEUI64("0xFFFFFFFFFFFFFFFF");
806
+ const linkKey = new EmberKeyData();
807
+ linkKey.contents = Buffer.from("ZigBeeAlliance09");
808
+ const result = await this.addTransientLinkKey(ieee, linkKey);
809
+
810
+ if (result.status !== EmberStatus.SUCCESS) {
811
+ throw new Error(`Add Transient Link Key for '${ieee}' failed`);
812
+ }
813
+
814
+ if (this.ezsp.ezspV >= 8) {
815
+ await this.ezsp.setPolicy(
816
+ EzspPolicyId.TRUST_CENTER_POLICY,
817
+ EzspDecisionBitmask.ALLOW_UNSECURED_REJOINS | EzspDecisionBitmask.ALLOW_JOINS,
818
+ );
819
+ //| EzspDecisionBitmask.JOINS_USE_INSTALL_CODE_KEY
820
+ }
821
+ } else {
822
+ await this.ezsp.execCommand("clearTransientLinkKeys");
823
+ }
824
+ }
825
+
826
+ public async permitJoining(seconds: number): Promise<EZSPFrameData> {
827
+ return await this.ezsp.execCommand("permitJoining", {duration: seconds});
828
+ }
829
+
830
+ public makeZDOframe(name: string | number, params: ParamsDesc): Buffer {
831
+ return this.ezsp.makeZDOframe(name, params);
832
+ }
833
+
834
+ public async addEndpoint({
835
+ endpoint = 1,
836
+ profileId = 260,
837
+ deviceId = 0xbeef,
838
+ appFlags = 0,
839
+ inputClusters = [],
840
+ outputClusters = [],
841
+ }: AddEndpointParameters): Promise<void> {
842
+ const res = await this.ezsp.execCommand("addEndpoint", {
843
+ endpoint: endpoint,
844
+ profileId: profileId,
845
+ deviceId: deviceId,
846
+ appFlags: appFlags,
847
+ inputClusterCount: inputClusters.length,
848
+ outputClusterCount: outputClusters.length,
849
+ inputClusterList: inputClusters,
850
+ outputClusterList: outputClusters,
851
+ });
852
+ logger.debug(() => `Ezsp adding endpoint: ${JSON.stringify(res)}`, NS);
853
+ }
854
+
855
+ public waitFor(
856
+ address: number | string,
857
+ clusterId: number,
858
+ sequence: number,
859
+ timeout = 10000,
860
+ ): ReturnType<typeof this.waitress.waitFor> & {cancel: () => void} {
861
+ const waiter = this.waitress.waitFor({address, clusterId, sequence}, timeout);
862
+
863
+ return {...waiter, cancel: () => this.waitress.remove(waiter.ID)};
864
+ }
865
+
866
+ private waitressTimeoutFormatter(matcher: EmberWaitressMatcher, timeout: number): string {
867
+ return `${JSON.stringify(matcher)} after ${timeout}ms`;
868
+ }
869
+
870
+ private waitressValidator(payload: EmberFrame, matcher: EmberWaitressMatcher): boolean {
871
+ return (
872
+ (!matcher.address || payload.address === matcher.address) &&
873
+ (!payload.frame || payload.frame.clusterId === matcher.clusterId) &&
874
+ (!payload.frame || payload.payload[0] === matcher.sequence)
875
+ );
876
+ }
877
+
878
+ public setChannel(channel: number): Promise<EZSPFrameData> {
879
+ return this.ezsp.execCommand("setLogicalAndRadioChannel", {radioChannel: channel});
880
+ }
881
+
882
+ public addTransientLinkKey(partner: EmberEUI64, transientKey: EmberKeyData): Promise<EZSPFrameData> {
883
+ if (this.ezsp.ezspV < 13) {
884
+ return this.ezsp.execCommand("addTransientLinkKey", {partner, transientKey});
885
+ }
886
+
887
+ return this.ezsp.execCommand("importTransientKey", {partner, transientKey, flags: 0});
888
+ }
889
+
890
+ public async addInstallCode(ieeeAddress: string, key: Buffer, hashed: boolean): Promise<void> {
891
+ const ieee = new EmberEUI64(ieeeAddress);
892
+ const linkKey = new EmberKeyData();
893
+ linkKey.contents = hashed ? key : ZSpec.Utils.aes128MmoHash(key);
894
+ const result = await this.addTransientLinkKey(ieee, linkKey);
895
+
896
+ if (result.status !== EmberStatus.SUCCESS) {
897
+ throw new Error(`Add install code for '${ieeeAddress}' failed`);
898
+ }
899
+ }
900
+
901
+ public async getKey(keyType: EmberKeyType): Promise<EZSPFrameData> {
902
+ if (this.ezsp.ezspV < 13) {
903
+ return await this.ezsp.execCommand("getKey", {keyType});
904
+ }
905
+
906
+ // Mapping EmberKeyType to SecManKeyType (ezsp13)
907
+ const SecManKeyType = {
908
+ [EmberKeyType.TRUST_CENTER_LINK_KEY]: 2,
909
+ [EmberKeyType.CURRENT_NETWORK_KEY]: 1,
910
+ };
911
+ const smc = new EmberSecurityManagerContext();
912
+ smc.type = SecManKeyType[keyType as number];
913
+ smc.index = 0;
914
+ smc.derivedType = EmberDerivedKeyType.NONE;
915
+ smc.eui64 = new EmberEUI64("0x0000000000000000");
916
+ smc.multiNetworkIndex = 0;
917
+ smc.flags = 0;
918
+ smc.psaKeyAlgPermission = 0;
919
+ const keyInfo = await this.ezsp.execCommand("exportKey", {context: smc});
920
+
921
+ if (keyInfo.status !== SLStatus.SL_STATUS_OK) {
922
+ logger.error(`exportKey(${EmberKeyType.valueToName(EmberKeyType, keyType)}) returned unexpected SL status: ${keyInfo.status}`, NS);
923
+ }
924
+ return keyInfo;
925
+ }
926
+
927
+ public async getNetworkKeyInfo(): Promise<EZSPFrameData> {
928
+ if (this.ezsp.ezspV < 13) {
929
+ throw new Error("getNetKeyInfo(): Invalid call on EZSP < 13.");
930
+ }
931
+
932
+ const keyInfo = await this.ezsp.execCommand("getNetworkKeyInfo");
933
+ if (keyInfo.status !== SLStatus.SL_STATUS_OK) {
934
+ logger.error(`getNetworkKeyInfo() returned unexpected SL status: ${keyInfo.status}`, NS);
935
+ }
936
+
937
+ return keyInfo;
938
+ }
939
+
940
+ private async needsToBeRestore(options: TsType.NetworkOptions): Promise<boolean> {
941
+ // if no backup and the settings have been changed, then need to start a new network
942
+ const backup = this.backupMan.getStoredBackup();
943
+ if (!backup) return false;
944
+
945
+ let valid = true;
946
+ //valid = valid && (await this.ezsp.networkInit());
947
+ const netParams = await this.ezsp.execCommand("getNetworkParameters");
948
+ const networkParams = netParams.parameters;
949
+ logger.debug(`Current Node type: ${netParams.nodeType}, Network parameters: ${networkParams}`, NS);
950
+ logger.debug(`Backuped network parameters: ${backup.networkOptions}`, NS);
951
+ const networkKey = await this.getKey(EmberKeyType.CURRENT_NETWORK_KEY);
952
+ let netKey: Buffer;
953
+
954
+ if (this.ezsp.ezspV < 13) {
955
+ netKey = Buffer.from((networkKey.keyStruct as EmberKeyStruct).key.contents);
956
+ } else {
957
+ netKey = Buffer.from((networkKey.keyData as EmberKeyData).contents);
958
+ }
959
+
960
+ // if the settings in the backup match the chip, then need to warn to delete the backup file first
961
+ valid = valid && networkParams.panId === backup.networkOptions.panId;
962
+ valid = valid && networkParams.radioChannel === backup.logicalChannel;
963
+ valid = valid && Buffer.from(networkParams.extendedPanId).equals(backup.networkOptions.extendedPanId);
964
+ valid = valid && Buffer.from(netKey).equals(backup.networkOptions.networkKey);
965
+ if (valid) {
966
+ logger.error("Configuration is not consistent with adapter backup!", NS);
967
+ logger.error(`- PAN ID: configured=${options.panID}, adapter=${networkParams.panId}, backup=${backup.networkOptions.panId}`, NS);
968
+ logger.error(
969
+ `- Extended PAN ID: configured=${
970
+ // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
971
+ Buffer.from(options.extendedPanID!).toString("hex")
972
+ }, ` +
973
+ `adapter=${Buffer.from(networkParams.extendedPanId).toString("hex")}, ` +
974
+ `backup=${Buffer.from(networkParams.extendedPanId).toString("hex")}`,
975
+ NS,
976
+ );
977
+ logger.error(`- Channel: configured=${options.channelList}, adapter=${networkParams.radioChannel}, backup=${backup.logicalChannel}`, NS);
978
+ logger.error(
979
+ `- Network key: configured=${
980
+ // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
981
+ Buffer.from(options.networkKey!).toString("hex")
982
+ }, ` +
983
+ `adapter=${Buffer.from(netKey).toString("hex")}, ` +
984
+ `backup=${backup.networkOptions.networkKey.toString("hex")}`,
985
+ NS,
986
+ );
987
+ logger.error("Please update configuration to prevent further issues.", NS);
988
+ logger.error("If you wish to re-commission your network, please remove coordinator backup.", NS);
989
+ logger.error("Re-commissioning your network will require re-pairing of all devices!", NS);
990
+ throw new Error("startup failed - configuration-adapter mismatch - see logs above for more information");
991
+ }
992
+ valid = true;
993
+ // if the settings in the backup match the config, then the old network is in the chip and needs to be restored
994
+ valid = valid && options.panID === backup.networkOptions.panId;
995
+ valid = valid && options.channelList.includes(backup.logicalChannel);
996
+ // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
997
+ valid = valid && Buffer.from(options.extendedPanID!).equals(backup.networkOptions.extendedPanId);
998
+ // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
999
+ valid = valid && Buffer.from(options.networkKey!).equals(backup.networkOptions.networkKey);
1000
+ return valid;
1001
+ }
1002
+ }