zigbee-herdsman 3.5.1 → 4.0.0

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 (726) hide show
  1. package/.github/dependabot.yml +9 -3
  2. package/.github/workflows/ci.yml +2 -4
  3. package/.github/workflows/stale.yml +1 -1
  4. package/.release-please-manifest.json +1 -1
  5. package/.vscode/extensions.json +3 -0
  6. package/.vscode/settings.json +11 -0
  7. package/CHANGELOG.md +25 -0
  8. package/biome.json +89 -0
  9. package/dist/adapter/adapter.d.ts +11 -11
  10. package/dist/adapter/adapter.d.ts.map +1 -1
  11. package/dist/adapter/adapter.js +14 -14
  12. package/dist/adapter/adapterDiscovery.d.ts +6 -6
  13. package/dist/adapter/adapterDiscovery.d.ts.map +1 -1
  14. package/dist/adapter/adapterDiscovery.js +139 -141
  15. package/dist/adapter/adapterDiscovery.js.map +1 -1
  16. package/dist/adapter/const.d.ts +1 -1
  17. package/dist/adapter/const.js +2 -2
  18. package/dist/adapter/deconz/adapter/deconzAdapter.d.ts +16 -16
  19. package/dist/adapter/deconz/adapter/deconzAdapter.d.ts.map +1 -1
  20. package/dist/adapter/deconz/adapter/deconzAdapter.js +95 -100
  21. package/dist/adapter/deconz/adapter/deconzAdapter.js.map +1 -1
  22. package/dist/adapter/deconz/driver/constants.d.ts +5 -5
  23. package/dist/adapter/deconz/driver/constants.d.ts.map +1 -1
  24. package/dist/adapter/deconz/driver/driver.d.ts +9 -9
  25. package/dist/adapter/deconz/driver/driver.d.ts.map +1 -1
  26. package/dist/adapter/deconz/driver/driver.js +112 -106
  27. package/dist/adapter/deconz/driver/driver.js.map +1 -1
  28. package/dist/adapter/deconz/driver/frame.d.ts +1 -1
  29. package/dist/adapter/deconz/driver/frame.d.ts.map +1 -1
  30. package/dist/adapter/deconz/driver/frame.js +1 -2
  31. package/dist/adapter/deconz/driver/frame.js.map +1 -1
  32. package/dist/adapter/deconz/driver/frameParser.d.ts +1 -1
  33. package/dist/adapter/deconz/driver/frameParser.d.ts.map +1 -1
  34. package/dist/adapter/deconz/driver/frameParser.js +66 -70
  35. package/dist/adapter/deconz/driver/frameParser.js.map +1 -1
  36. package/dist/adapter/deconz/driver/parser.d.ts +1 -1
  37. package/dist/adapter/deconz/driver/parser.d.ts.map +1 -1
  38. package/dist/adapter/deconz/driver/parser.js +2 -2
  39. package/dist/adapter/deconz/driver/parser.js.map +1 -1
  40. package/dist/adapter/deconz/driver/writer.d.ts +2 -2
  41. package/dist/adapter/deconz/driver/writer.d.ts.map +1 -1
  42. package/dist/adapter/deconz/driver/writer.js +1 -1
  43. package/dist/adapter/ember/adapter/emberAdapter.d.ts +19 -19
  44. package/dist/adapter/ember/adapter/emberAdapter.d.ts.map +1 -1
  45. package/dist/adapter/ember/adapter/emberAdapter.js +117 -97
  46. package/dist/adapter/ember/adapter/emberAdapter.js.map +1 -1
  47. package/dist/adapter/ember/adapter/endpoints.d.ts +1 -1
  48. package/dist/adapter/ember/adapter/endpoints.d.ts.map +1 -1
  49. package/dist/adapter/ember/adapter/oneWaitress.d.ts +5 -5
  50. package/dist/adapter/ember/adapter/oneWaitress.d.ts.map +1 -1
  51. package/dist/adapter/ember/adapter/oneWaitress.js +2 -2
  52. package/dist/adapter/ember/adapter/oneWaitress.js.map +1 -1
  53. package/dist/adapter/ember/adapter/tokensManager.d.ts +3 -3
  54. package/dist/adapter/ember/adapter/tokensManager.d.ts.map +1 -1
  55. package/dist/adapter/ember/adapter/tokensManager.js +20 -23
  56. package/dist/adapter/ember/adapter/tokensManager.js.map +1 -1
  57. package/dist/adapter/ember/enums.d.ts +4 -4
  58. package/dist/adapter/ember/enums.d.ts.map +1 -1
  59. package/dist/adapter/ember/enums.js +4 -6
  60. package/dist/adapter/ember/enums.js.map +1 -1
  61. package/dist/adapter/ember/ezsp/buffalo.d.ts +4 -4
  62. package/dist/adapter/ember/ezsp/buffalo.d.ts.map +1 -1
  63. package/dist/adapter/ember/ezsp/buffalo.js +30 -32
  64. package/dist/adapter/ember/ezsp/buffalo.js.map +1 -1
  65. package/dist/adapter/ember/ezsp/ezsp.d.ts +46 -46
  66. package/dist/adapter/ember/ezsp/ezsp.d.ts.map +1 -1
  67. package/dist/adapter/ember/ezsp/ezsp.js +85 -111
  68. package/dist/adapter/ember/ezsp/ezsp.js.map +1 -1
  69. package/dist/adapter/ember/ezspError.d.ts +1 -1
  70. package/dist/adapter/ember/types.d.ts +14 -14
  71. package/dist/adapter/ember/types.d.ts.map +1 -1
  72. package/dist/adapter/ember/uart/ash.d.ts +5 -5
  73. package/dist/adapter/ember/uart/ash.d.ts.map +1 -1
  74. package/dist/adapter/ember/uart/ash.js +80 -71
  75. package/dist/adapter/ember/uart/ash.js.map +1 -1
  76. package/dist/adapter/ember/uart/parser.d.ts +2 -2
  77. package/dist/adapter/ember/uart/parser.d.ts.map +1 -1
  78. package/dist/adapter/ember/uart/parser.js +2 -1
  79. package/dist/adapter/ember/uart/parser.js.map +1 -1
  80. package/dist/adapter/ember/uart/queues.js +27 -29
  81. package/dist/adapter/ember/uart/queues.js.map +1 -1
  82. package/dist/adapter/ember/uart/writer.d.ts +1 -1
  83. package/dist/adapter/ember/uart/writer.d.ts.map +1 -1
  84. package/dist/adapter/ember/uart/writer.js +3 -5
  85. package/dist/adapter/ember/uart/writer.js.map +1 -1
  86. package/dist/adapter/ember/utils/initters.d.ts +2 -2
  87. package/dist/adapter/ember/utils/initters.d.ts.map +1 -1
  88. package/dist/adapter/ember/utils/initters.js +1 -1
  89. package/dist/adapter/ember/utils/math.js +1 -1
  90. package/dist/adapter/events.d.ts +1 -1
  91. package/dist/adapter/events.d.ts.map +1 -1
  92. package/dist/adapter/ezsp/adapter/backup.d.ts +3 -3
  93. package/dist/adapter/ezsp/adapter/backup.d.ts.map +1 -1
  94. package/dist/adapter/ezsp/adapter/backup.js +8 -10
  95. package/dist/adapter/ezsp/adapter/backup.js.map +1 -1
  96. package/dist/adapter/ezsp/adapter/ezspAdapter.d.ts +12 -12
  97. package/dist/adapter/ezsp/adapter/ezspAdapter.d.ts.map +1 -1
  98. package/dist/adapter/ezsp/adapter/ezspAdapter.js +45 -44
  99. package/dist/adapter/ezsp/adapter/ezspAdapter.js.map +1 -1
  100. package/dist/adapter/ezsp/driver/driver.d.ts +12 -12
  101. package/dist/adapter/ezsp/driver/driver.d.ts.map +1 -1
  102. package/dist/adapter/ezsp/driver/driver.js +148 -141
  103. package/dist/adapter/ezsp/driver/driver.js.map +1 -1
  104. package/dist/adapter/ezsp/driver/ezsp.d.ts +7 -7
  105. package/dist/adapter/ezsp/driver/ezsp.d.ts.map +1 -1
  106. package/dist/adapter/ezsp/driver/ezsp.js +61 -59
  107. package/dist/adapter/ezsp/driver/ezsp.js.map +1 -1
  108. package/dist/adapter/ezsp/driver/frame.js +2 -2
  109. package/dist/adapter/ezsp/driver/index.d.ts +2 -2
  110. package/dist/adapter/ezsp/driver/multicast.d.ts +8 -5
  111. package/dist/adapter/ezsp/driver/multicast.d.ts.map +1 -1
  112. package/dist/adapter/ezsp/driver/multicast.js +9 -9
  113. package/dist/adapter/ezsp/driver/multicast.js.map +1 -1
  114. package/dist/adapter/ezsp/driver/parser.d.ts +1 -1
  115. package/dist/adapter/ezsp/driver/parser.js +3 -3
  116. package/dist/adapter/ezsp/driver/types/basic.d.ts +5 -5
  117. package/dist/adapter/ezsp/driver/types/basic.d.ts.map +1 -1
  118. package/dist/adapter/ezsp/driver/types/basic.js +12 -33
  119. package/dist/adapter/ezsp/driver/types/basic.js.map +1 -1
  120. package/dist/adapter/ezsp/driver/types/index.d.ts +3 -3
  121. package/dist/adapter/ezsp/driver/types/index.d.ts.map +1 -1
  122. package/dist/adapter/ezsp/driver/types/index.js +8 -9
  123. package/dist/adapter/ezsp/driver/types/index.js.map +1 -1
  124. package/dist/adapter/ezsp/driver/types/named.d.ts +2 -2
  125. package/dist/adapter/ezsp/driver/types/named.d.ts.map +1 -1
  126. package/dist/adapter/ezsp/driver/types/named.js +8 -11
  127. package/dist/adapter/ezsp/driver/types/named.js.map +1 -1
  128. package/dist/adapter/ezsp/driver/types/struct.d.ts +2 -2
  129. package/dist/adapter/ezsp/driver/types/struct.d.ts.map +1 -1
  130. package/dist/adapter/ezsp/driver/types/struct.js +207 -214
  131. package/dist/adapter/ezsp/driver/types/struct.js.map +1 -1
  132. package/dist/adapter/ezsp/driver/uart.d.ts +2 -2
  133. package/dist/adapter/ezsp/driver/uart.d.ts.map +1 -1
  134. package/dist/adapter/ezsp/driver/uart.js +48 -37
  135. package/dist/adapter/ezsp/driver/uart.js.map +1 -1
  136. package/dist/adapter/ezsp/driver/utils/crc16ccitt.d.ts +3 -3
  137. package/dist/adapter/ezsp/driver/utils/crc16ccitt.d.ts.map +1 -1
  138. package/dist/adapter/ezsp/driver/utils/crc16ccitt.js +16 -34
  139. package/dist/adapter/ezsp/driver/utils/crc16ccitt.js.map +1 -1
  140. package/dist/adapter/ezsp/driver/utils/index.d.ts +4 -4
  141. package/dist/adapter/ezsp/driver/utils/index.d.ts.map +1 -1
  142. package/dist/adapter/ezsp/driver/utils/index.js +4 -4
  143. package/dist/adapter/ezsp/driver/utils/index.js.map +1 -1
  144. package/dist/adapter/ezsp/driver/writer.d.ts +1 -1
  145. package/dist/adapter/ezsp/driver/writer.js +2 -2
  146. package/dist/adapter/index.d.ts +3 -3
  147. package/dist/adapter/serialPort.d.ts +3 -3
  148. package/dist/adapter/serialPort.d.ts.map +1 -1
  149. package/dist/adapter/serialPort.js +1 -0
  150. package/dist/adapter/serialPort.js.map +1 -1
  151. package/dist/adapter/socketPortUtils.js +3 -3
  152. package/dist/adapter/tstype.d.ts +6 -6
  153. package/dist/adapter/z-stack/adapter/adapter-backup.d.ts +4 -4
  154. package/dist/adapter/z-stack/adapter/adapter-backup.d.ts.map +1 -1
  155. package/dist/adapter/z-stack/adapter/adapter-backup.js +106 -119
  156. package/dist/adapter/z-stack/adapter/adapter-backup.js.map +1 -1
  157. package/dist/adapter/z-stack/adapter/adapter-nv-memory.d.ts +10 -10
  158. package/dist/adapter/z-stack/adapter/adapter-nv-memory.d.ts.map +1 -1
  159. package/dist/adapter/z-stack/adapter/adapter-nv-memory.js +23 -24
  160. package/dist/adapter/z-stack/adapter/adapter-nv-memory.js.map +1 -1
  161. package/dist/adapter/z-stack/adapter/manager.d.ts +6 -6
  162. package/dist/adapter/z-stack/adapter/manager.d.ts.map +1 -1
  163. package/dist/adapter/z-stack/adapter/manager.js +115 -127
  164. package/dist/adapter/z-stack/adapter/manager.js.map +1 -1
  165. package/dist/adapter/z-stack/adapter/tstype.d.ts +3 -3
  166. package/dist/adapter/z-stack/adapter/tstype.js +3 -3
  167. package/dist/adapter/z-stack/adapter/zStackAdapter.d.ts +10 -10
  168. package/dist/adapter/z-stack/adapter/zStackAdapter.d.ts.map +1 -1
  169. package/dist/adapter/z-stack/adapter/zStackAdapter.js +125 -137
  170. package/dist/adapter/z-stack/adapter/zStackAdapter.js.map +1 -1
  171. package/dist/adapter/z-stack/constants/common.d.ts.map +1 -1
  172. package/dist/adapter/z-stack/constants/common.js +0 -3
  173. package/dist/adapter/z-stack/constants/common.js.map +1 -1
  174. package/dist/adapter/z-stack/constants/index.d.ts +10 -10
  175. package/dist/adapter/z-stack/constants/index.d.ts.map +1 -1
  176. package/dist/adapter/z-stack/constants/index.js +2 -2
  177. package/dist/adapter/z-stack/constants/index.js.map +1 -1
  178. package/dist/adapter/z-stack/constants/utils.d.ts +1 -1
  179. package/dist/adapter/z-stack/constants/utils.js +2 -2
  180. package/dist/adapter/z-stack/constants/utils.js.map +1 -1
  181. package/dist/adapter/z-stack/models/startup-options.d.ts +2 -2
  182. package/dist/adapter/z-stack/models/startup-options.d.ts.map +1 -1
  183. package/dist/adapter/z-stack/structs/entries/address-manager-entry.d.ts +1 -1
  184. package/dist/adapter/z-stack/structs/entries/address-manager-entry.d.ts.map +1 -1
  185. package/dist/adapter/z-stack/structs/entries/address-manager-entry.js +4 -5
  186. package/dist/adapter/z-stack/structs/entries/address-manager-entry.js.map +1 -1
  187. package/dist/adapter/z-stack/structs/entries/address-manager-table.d.ts +2 -2
  188. package/dist/adapter/z-stack/structs/entries/address-manager-table.d.ts.map +1 -1
  189. package/dist/adapter/z-stack/structs/entries/address-manager-table.js +3 -4
  190. package/dist/adapter/z-stack/structs/entries/address-manager-table.js.map +1 -1
  191. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.d.ts +1 -1
  192. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.d.ts.map +1 -1
  193. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.js +1 -2
  194. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.js.map +1 -1
  195. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.d.ts +2 -2
  196. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.d.ts.map +1 -1
  197. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.js +3 -4
  198. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.js.map +1 -1
  199. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.d.ts +1 -1
  200. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.d.ts.map +1 -1
  201. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.js +6 -7
  202. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.js.map +1 -1
  203. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.d.ts +2 -2
  204. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.d.ts.map +1 -1
  205. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.js +3 -4
  206. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.js.map +1 -1
  207. package/dist/adapter/z-stack/structs/entries/channel-list.d.ts +1 -1
  208. package/dist/adapter/z-stack/structs/entries/channel-list.d.ts.map +1 -1
  209. package/dist/adapter/z-stack/structs/entries/channel-list.js +1 -2
  210. package/dist/adapter/z-stack/structs/entries/channel-list.js.map +1 -1
  211. package/dist/adapter/z-stack/structs/entries/has-configured.d.ts +1 -1
  212. package/dist/adapter/z-stack/structs/entries/has-configured.d.ts.map +1 -1
  213. package/dist/adapter/z-stack/structs/entries/has-configured.js +2 -3
  214. package/dist/adapter/z-stack/structs/entries/has-configured.js.map +1 -1
  215. package/dist/adapter/z-stack/structs/entries/index.d.ts +16 -16
  216. package/dist/adapter/z-stack/structs/entries/nib.d.ts +1 -1
  217. package/dist/adapter/z-stack/structs/entries/nib.d.ts.map +1 -1
  218. package/dist/adapter/z-stack/structs/entries/nib.js +49 -50
  219. package/dist/adapter/z-stack/structs/entries/nib.js.map +1 -1
  220. package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.d.ts +1 -1
  221. package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.d.ts.map +1 -1
  222. package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.js +1 -2
  223. package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.js.map +1 -1
  224. package/dist/adapter/z-stack/structs/entries/nwk-key.d.ts +1 -1
  225. package/dist/adapter/z-stack/structs/entries/nwk-key.d.ts.map +1 -1
  226. package/dist/adapter/z-stack/structs/entries/nwk-key.js +1 -2
  227. package/dist/adapter/z-stack/structs/entries/nwk-key.js.map +1 -1
  228. package/dist/adapter/z-stack/structs/entries/nwk-pan-id.d.ts +1 -1
  229. package/dist/adapter/z-stack/structs/entries/nwk-pan-id.d.ts.map +1 -1
  230. package/dist/adapter/z-stack/structs/entries/nwk-pan-id.js +1 -2
  231. package/dist/adapter/z-stack/structs/entries/nwk-pan-id.js.map +1 -1
  232. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.d.ts +1 -1
  233. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.d.ts.map +1 -1
  234. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.js +3 -4
  235. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.js.map +1 -1
  236. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.d.ts +2 -2
  237. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.d.ts.map +1 -1
  238. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.js +3 -4
  239. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.js.map +1 -1
  240. package/dist/adapter/z-stack/structs/entries/security-manager-entry.d.ts +1 -1
  241. package/dist/adapter/z-stack/structs/entries/security-manager-entry.d.ts.map +1 -1
  242. package/dist/adapter/z-stack/structs/entries/security-manager-entry.js +4 -5
  243. package/dist/adapter/z-stack/structs/entries/security-manager-entry.js.map +1 -1
  244. package/dist/adapter/z-stack/structs/entries/security-manager-table.d.ts +2 -2
  245. package/dist/adapter/z-stack/structs/entries/security-manager-table.d.ts.map +1 -1
  246. package/dist/adapter/z-stack/structs/entries/security-manager-table.js +3 -4
  247. package/dist/adapter/z-stack/structs/entries/security-manager-table.js.map +1 -1
  248. package/dist/adapter/z-stack/structs/index.d.ts +4 -4
  249. package/dist/adapter/z-stack/structs/serializable-memory-object.d.ts +2 -2
  250. package/dist/adapter/z-stack/structs/serializable-memory-object.d.ts.map +1 -1
  251. package/dist/adapter/z-stack/structs/struct.d.ts +8 -8
  252. package/dist/adapter/z-stack/structs/struct.d.ts.map +1 -1
  253. package/dist/adapter/z-stack/structs/struct.js +42 -43
  254. package/dist/adapter/z-stack/structs/struct.js.map +1 -1
  255. package/dist/adapter/z-stack/structs/table.d.ts +3 -3
  256. package/dist/adapter/z-stack/structs/table.d.ts.map +1 -1
  257. package/dist/adapter/z-stack/structs/table.js +10 -10
  258. package/dist/adapter/z-stack/structs/table.js.map +1 -1
  259. package/dist/adapter/z-stack/unpi/frame.d.ts +1 -1
  260. package/dist/adapter/z-stack/unpi/frame.d.ts.map +1 -1
  261. package/dist/adapter/z-stack/unpi/frame.js +2 -4
  262. package/dist/adapter/z-stack/unpi/frame.js.map +1 -1
  263. package/dist/adapter/z-stack/unpi/index.d.ts +4 -4
  264. package/dist/adapter/z-stack/unpi/parser.d.ts +1 -1
  265. package/dist/adapter/z-stack/unpi/parser.js +3 -3
  266. package/dist/adapter/z-stack/unpi/parser.js.map +1 -1
  267. package/dist/adapter/z-stack/unpi/writer.d.ts +2 -2
  268. package/dist/adapter/z-stack/unpi/writer.d.ts.map +1 -1
  269. package/dist/adapter/z-stack/unpi/writer.js +1 -1
  270. package/dist/adapter/z-stack/utils/index.d.ts +2 -2
  271. package/dist/adapter/z-stack/utils/network-options.d.ts +1 -1
  272. package/dist/adapter/z-stack/utils/network-options.d.ts.map +1 -1
  273. package/dist/adapter/z-stack/znp/buffaloZnp.d.ts +3 -3
  274. package/dist/adapter/z-stack/znp/buffaloZnp.d.ts.map +1 -1
  275. package/dist/adapter/z-stack/znp/buffaloZnp.js +34 -20
  276. package/dist/adapter/z-stack/znp/buffaloZnp.js.map +1 -1
  277. package/dist/adapter/z-stack/znp/definition.d.ts +2 -2
  278. package/dist/adapter/z-stack/znp/definition.d.ts.map +1 -1
  279. package/dist/adapter/z-stack/znp/definition.js +1111 -1111
  280. package/dist/adapter/z-stack/znp/index.d.ts +2 -2
  281. package/dist/adapter/z-stack/znp/tstype.d.ts +7 -7
  282. package/dist/adapter/z-stack/znp/tstype.d.ts.map +1 -1
  283. package/dist/adapter/z-stack/znp/utils.d.ts +1 -1
  284. package/dist/adapter/z-stack/znp/utils.d.ts.map +1 -1
  285. package/dist/adapter/z-stack/znp/utils.js +2 -2
  286. package/dist/adapter/z-stack/znp/znp.d.ts +7 -7
  287. package/dist/adapter/z-stack/znp/znp.d.ts.map +1 -1
  288. package/dist/adapter/z-stack/znp/znp.js +46 -45
  289. package/dist/adapter/z-stack/znp/znp.js.map +1 -1
  290. package/dist/adapter/z-stack/znp/zpiObject.d.ts +8 -8
  291. package/dist/adapter/z-stack/znp/zpiObject.d.ts.map +1 -1
  292. package/dist/adapter/z-stack/znp/zpiObject.js +6 -6
  293. package/dist/adapter/z-stack/znp/zpiObject.js.map +1 -1
  294. package/dist/adapter/zboss/adapter/zbossAdapter.d.ts +11 -11
  295. package/dist/adapter/zboss/adapter/zbossAdapter.d.ts.map +1 -1
  296. package/dist/adapter/zboss/adapter/zbossAdapter.js +37 -36
  297. package/dist/adapter/zboss/adapter/zbossAdapter.js.map +1 -1
  298. package/dist/adapter/zboss/commands.d.ts +4 -6
  299. package/dist/adapter/zboss/commands.d.ts.map +1 -1
  300. package/dist/adapter/zboss/commands.js +321 -287
  301. package/dist/adapter/zboss/commands.js.map +1 -1
  302. package/dist/adapter/zboss/driver.d.ts +9 -9
  303. package/dist/adapter/zboss/driver.d.ts.map +1 -1
  304. package/dist/adapter/zboss/driver.js +25 -25
  305. package/dist/adapter/zboss/driver.js.map +1 -1
  306. package/dist/adapter/zboss/frame.d.ts +9 -9
  307. package/dist/adapter/zboss/frame.d.ts.map +1 -1
  308. package/dist/adapter/zboss/frame.js +15 -15
  309. package/dist/adapter/zboss/frame.js.map +1 -1
  310. package/dist/adapter/zboss/reader.d.ts +2 -2
  311. package/dist/adapter/zboss/reader.d.ts.map +1 -1
  312. package/dist/adapter/zboss/reader.js +6 -5
  313. package/dist/adapter/zboss/reader.js.map +1 -1
  314. package/dist/adapter/zboss/uart.d.ts +3 -3
  315. package/dist/adapter/zboss/uart.d.ts.map +1 -1
  316. package/dist/adapter/zboss/uart.js +36 -36
  317. package/dist/adapter/zboss/uart.js.map +1 -1
  318. package/dist/adapter/zboss/writer.d.ts +1 -1
  319. package/dist/adapter/zboss/writer.d.ts.map +1 -1
  320. package/dist/adapter/zboss/writer.js +3 -5
  321. package/dist/adapter/zboss/writer.js.map +1 -1
  322. package/dist/adapter/zigate/adapter/patchZdoBuffaloBE.js +2 -2
  323. package/dist/adapter/zigate/adapter/patchZdoBuffaloBE.js.map +1 -1
  324. package/dist/adapter/zigate/adapter/zigateAdapter.d.ts +14 -14
  325. package/dist/adapter/zigate/adapter/zigateAdapter.d.ts.map +1 -1
  326. package/dist/adapter/zigate/adapter/zigateAdapter.js +52 -53
  327. package/dist/adapter/zigate/adapter/zigateAdapter.js.map +1 -1
  328. package/dist/adapter/zigate/driver/buffaloZiGate.d.ts +6 -6
  329. package/dist/adapter/zigate/driver/buffaloZiGate.d.ts.map +1 -1
  330. package/dist/adapter/zigate/driver/buffaloZiGate.js +41 -23
  331. package/dist/adapter/zigate/driver/buffaloZiGate.js.map +1 -1
  332. package/dist/adapter/zigate/driver/commandType.d.ts +2 -2
  333. package/dist/adapter/zigate/driver/commandType.d.ts.map +1 -1
  334. package/dist/adapter/zigate/driver/commandType.js +37 -37
  335. package/dist/adapter/zigate/driver/commandType.js.map +1 -1
  336. package/dist/adapter/zigate/driver/constants.d.ts +27 -200
  337. package/dist/adapter/zigate/driver/constants.d.ts.map +1 -1
  338. package/dist/adapter/zigate/driver/constants.js +40 -236
  339. package/dist/adapter/zigate/driver/constants.js.map +1 -1
  340. package/dist/adapter/zigate/driver/frame.d.ts.map +1 -1
  341. package/dist/adapter/zigate/driver/frame.js +4 -3
  342. package/dist/adapter/zigate/driver/frame.js.map +1 -1
  343. package/dist/adapter/zigate/driver/messageType.d.ts +1 -1
  344. package/dist/adapter/zigate/driver/messageType.js +76 -76
  345. package/dist/adapter/zigate/driver/ziGateObject.d.ts +3 -3
  346. package/dist/adapter/zigate/driver/ziGateObject.d.ts.map +1 -1
  347. package/dist/adapter/zigate/driver/ziGateObject.js +7 -6
  348. package/dist/adapter/zigate/driver/ziGateObject.js.map +1 -1
  349. package/dist/adapter/zigate/driver/zigate.d.ts +8 -8
  350. package/dist/adapter/zigate/driver/zigate.d.ts.map +1 -1
  351. package/dist/adapter/zigate/driver/zigate.js +59 -54
  352. package/dist/adapter/zigate/driver/zigate.js.map +1 -1
  353. package/dist/adapter/zoh/adapter/utils.js +1 -1
  354. package/dist/adapter/zoh/adapter/zohAdapter.d.ts +13 -13
  355. package/dist/adapter/zoh/adapter/zohAdapter.d.ts.map +1 -1
  356. package/dist/adapter/zoh/adapter/zohAdapter.js +101 -67
  357. package/dist/adapter/zoh/adapter/zohAdapter.js.map +1 -1
  358. package/dist/buffalo/buffalo.d.ts +2 -2
  359. package/dist/buffalo/buffalo.js +4 -4
  360. package/dist/buffalo/buffalo.js.map +1 -1
  361. package/dist/buffalo/index.d.ts +1 -1
  362. package/dist/controller/controller.d.ts +7 -7
  363. package/dist/controller/controller.d.ts.map +1 -1
  364. package/dist/controller/controller.js +94 -98
  365. package/dist/controller/controller.js.map +1 -1
  366. package/dist/controller/database.d.ts +1 -1
  367. package/dist/controller/database.d.ts.map +1 -1
  368. package/dist/controller/database.js +9 -9
  369. package/dist/controller/database.js.map +1 -1
  370. package/dist/controller/events.d.ts +6 -6
  371. package/dist/controller/events.d.ts.map +1 -1
  372. package/dist/controller/greenPower.d.ts +21 -21
  373. package/dist/controller/greenPower.d.ts.map +1 -1
  374. package/dist/controller/greenPower.js +41 -41
  375. package/dist/controller/greenPower.js.map +1 -1
  376. package/dist/controller/helpers/index.d.ts +1 -1
  377. package/dist/controller/helpers/request.d.ts +2 -2
  378. package/dist/controller/helpers/request.d.ts.map +1 -1
  379. package/dist/controller/helpers/request.js +31 -27
  380. package/dist/controller/helpers/request.js.map +1 -1
  381. package/dist/controller/helpers/requestQueue.d.ts +3 -3
  382. package/dist/controller/helpers/requestQueue.d.ts.map +1 -1
  383. package/dist/controller/helpers/requestQueue.js +20 -20
  384. package/dist/controller/helpers/requestQueue.js.map +1 -1
  385. package/dist/controller/helpers/zclFrameConverter.d.ts +2 -2
  386. package/dist/controller/helpers/zclFrameConverter.d.ts.map +1 -1
  387. package/dist/controller/helpers/zclFrameConverter.js +1 -1
  388. package/dist/controller/helpers/zclFrameConverter.js.map +1 -1
  389. package/dist/controller/helpers/zclTransactionSequenceNumber.d.ts +6 -4
  390. package/dist/controller/helpers/zclTransactionSequenceNumber.d.ts.map +1 -1
  391. package/dist/controller/helpers/zclTransactionSequenceNumber.js +6 -5
  392. package/dist/controller/helpers/zclTransactionSequenceNumber.js.map +1 -1
  393. package/dist/controller/index.d.ts +1 -1
  394. package/dist/controller/model/device.d.ts +23 -19
  395. package/dist/controller/model/device.d.ts.map +1 -1
  396. package/dist/controller/model/device.js +153 -128
  397. package/dist/controller/model/device.js.map +1 -1
  398. package/dist/controller/model/endpoint.d.ts +11 -11
  399. package/dist/controller/model/endpoint.d.ts.map +1 -1
  400. package/dist/controller/model/endpoint.js +84 -67
  401. package/dist/controller/model/endpoint.js.map +1 -1
  402. package/dist/controller/model/entity.d.ts +3 -3
  403. package/dist/controller/model/entity.d.ts.map +1 -1
  404. package/dist/controller/model/group.d.ts +4 -4
  405. package/dist/controller/model/group.d.ts.map +1 -1
  406. package/dist/controller/model/group.js +21 -9
  407. package/dist/controller/model/group.js.map +1 -1
  408. package/dist/controller/model/index.d.ts +4 -4
  409. package/dist/controller/touchlink.d.ts +1 -1
  410. package/dist/controller/touchlink.d.ts.map +1 -1
  411. package/dist/controller/touchlink.js +11 -11
  412. package/dist/controller/tstype.d.ts +3 -3
  413. package/dist/index.d.ts +10 -10
  414. package/dist/models/backup-storage-legacy.d.ts +14 -16
  415. package/dist/models/backup-storage-legacy.d.ts.map +1 -1
  416. package/dist/models/backup-storage-unified.d.ts +1 -1
  417. package/dist/models/backup.d.ts +2 -2
  418. package/dist/models/backup.d.ts.map +1 -1
  419. package/dist/models/index.d.ts +4 -4
  420. package/dist/utils/backup.d.ts +1 -1
  421. package/dist/utils/backup.d.ts.map +1 -1
  422. package/dist/utils/backup.js +26 -26
  423. package/dist/utils/backup.js.map +1 -1
  424. package/dist/utils/index.d.ts +5 -5
  425. package/dist/utils/logger.js +3 -3
  426. package/dist/utils/patchBigIntSerialization.js +1 -1
  427. package/dist/utils/patchBigIntSerialization.js.map +1 -1
  428. package/dist/utils/queue.d.ts.map +1 -1
  429. package/dist/utils/queue.js +1 -0
  430. package/dist/utils/queue.js.map +1 -1
  431. package/dist/utils/utils.d.ts.map +1 -1
  432. package/dist/utils/utils.js +5 -4
  433. package/dist/utils/utils.js.map +1 -1
  434. package/dist/utils/waitress.d.ts +1 -1
  435. package/dist/utils/waitress.js +3 -3
  436. package/dist/zspec/consts.d.ts +1 -1
  437. package/dist/zspec/consts.d.ts.map +1 -1
  438. package/dist/zspec/consts.js +1 -1
  439. package/dist/zspec/index.d.ts +3 -3
  440. package/dist/zspec/tstypes.d.ts +1 -1
  441. package/dist/zspec/utils.d.ts +4 -4
  442. package/dist/zspec/utils.d.ts.map +1 -1
  443. package/dist/zspec/utils.js +9 -13
  444. package/dist/zspec/utils.js.map +1 -1
  445. package/dist/zspec/zcl/buffaloZcl.d.ts +3 -3
  446. package/dist/zspec/zcl/buffaloZcl.d.ts.map +1 -1
  447. package/dist/zspec/zcl/buffaloZcl.js +127 -84
  448. package/dist/zspec/zcl/buffaloZcl.js.map +1 -1
  449. package/dist/zspec/zcl/definition/cluster.d.ts +1 -1
  450. package/dist/zspec/zcl/definition/cluster.d.ts.map +1 -1
  451. package/dist/zspec/zcl/definition/cluster.js +894 -893
  452. package/dist/zspec/zcl/definition/cluster.js.map +1 -1
  453. package/dist/zspec/zcl/definition/consts.js +7 -7
  454. package/dist/zspec/zcl/definition/foundation.d.ts +3 -3
  455. package/dist/zspec/zcl/definition/foundation.d.ts.map +1 -1
  456. package/dist/zspec/zcl/definition/foundation.js +88 -89
  457. package/dist/zspec/zcl/definition/foundation.js.map +1 -1
  458. package/dist/zspec/zcl/definition/manufacturerCode.d.ts +1 -1
  459. package/dist/zspec/zcl/definition/manufacturerCode.js +1 -1
  460. package/dist/zspec/zcl/definition/manufacturerCode.js.map +1 -1
  461. package/dist/zspec/zcl/definition/status.d.ts +3 -3
  462. package/dist/zspec/zcl/definition/status.js +3 -3
  463. package/dist/zspec/zcl/definition/tstype.d.ts +3 -3
  464. package/dist/zspec/zcl/definition/tstype.d.ts.map +1 -1
  465. package/dist/zspec/zcl/index.d.ts +10 -10
  466. package/dist/zspec/zcl/utils.d.ts +3 -3
  467. package/dist/zspec/zcl/utils.d.ts.map +1 -1
  468. package/dist/zspec/zcl/utils.js +18 -21
  469. package/dist/zspec/zcl/utils.js.map +1 -1
  470. package/dist/zspec/zcl/zclFrame.d.ts +7 -7
  471. package/dist/zspec/zcl/zclFrame.d.ts.map +1 -1
  472. package/dist/zspec/zcl/zclFrame.js +38 -41
  473. package/dist/zspec/zcl/zclFrame.js.map +1 -1
  474. package/dist/zspec/zcl/zclHeader.d.ts +2 -2
  475. package/dist/zspec/zcl/zclHeader.d.ts.map +1 -1
  476. package/dist/zspec/zcl/zclHeader.js +3 -3
  477. package/dist/zspec/zcl/zclStatusError.d.ts +1 -1
  478. package/dist/zspec/zdo/buffaloZdo.d.ts +7 -7
  479. package/dist/zspec/zdo/buffaloZdo.d.ts.map +1 -1
  480. package/dist/zspec/zdo/buffaloZdo.js +4 -4
  481. package/dist/zspec/zdo/buffaloZdo.js.map +1 -1
  482. package/dist/zspec/zdo/definition/status.d.ts +1 -1
  483. package/dist/zspec/zdo/definition/status.js +1 -1
  484. package/dist/zspec/zdo/definition/tstypes.d.ts +48 -48
  485. package/dist/zspec/zdo/definition/tstypes.d.ts.map +1 -1
  486. package/dist/zspec/zdo/index.d.ts +7 -7
  487. package/dist/zspec/zdo/utils.d.ts +2 -2
  488. package/dist/zspec/zdo/utils.d.ts.map +1 -1
  489. package/dist/zspec/zdo/utils.js +1 -1
  490. package/dist/zspec/zdo/utils.js.map +1 -1
  491. package/dist/zspec/zdo/zdoStatusError.d.ts +1 -1
  492. package/examples/join-and-log.js +5 -5
  493. package/package.json +6 -13
  494. package/src/adapter/adapter.ts +189 -0
  495. package/src/adapter/adapterDiscovery.ts +653 -0
  496. package/src/adapter/const.ts +12 -0
  497. package/src/adapter/deconz/adapter/deconzAdapter.ts +768 -0
  498. package/src/adapter/deconz/driver/constants.ts +180 -0
  499. package/src/adapter/deconz/driver/driver.ts +900 -0
  500. package/src/adapter/deconz/driver/frame.ts +11 -0
  501. package/src/adapter/deconz/driver/frameParser.ts +557 -0
  502. package/src/adapter/deconz/driver/parser.ts +45 -0
  503. package/src/adapter/deconz/driver/writer.ts +22 -0
  504. package/src/adapter/deconz/types.d.ts +13 -0
  505. package/src/adapter/ember/adapter/emberAdapter.ts +2266 -0
  506. package/src/adapter/ember/adapter/endpoints.ts +86 -0
  507. package/src/adapter/ember/adapter/oneWaitress.ts +322 -0
  508. package/src/adapter/ember/adapter/tokensManager.ts +782 -0
  509. package/src/adapter/ember/consts.ts +178 -0
  510. package/src/adapter/ember/enums.ts +2123 -0
  511. package/src/adapter/ember/ezsp/buffalo.ts +1397 -0
  512. package/src/adapter/ember/ezsp/consts.ts +148 -0
  513. package/src/adapter/ember/ezsp/enums.ts +1087 -0
  514. package/src/adapter/ember/ezsp/ezsp.ts +8985 -0
  515. package/src/adapter/ember/ezspError.ts +10 -0
  516. package/src/adapter/ember/types.ts +866 -0
  517. package/src/adapter/ember/uart/ash.ts +1969 -0
  518. package/src/adapter/ember/uart/consts.ts +109 -0
  519. package/src/adapter/ember/uart/enums.ts +192 -0
  520. package/src/adapter/ember/uart/parser.ts +48 -0
  521. package/src/adapter/ember/uart/queues.ts +247 -0
  522. package/src/adapter/ember/uart/writer.ts +53 -0
  523. package/src/adapter/ember/utils/initters.ts +58 -0
  524. package/src/adapter/ember/utils/math.ts +73 -0
  525. package/src/adapter/events.ts +21 -0
  526. package/src/adapter/ezsp/adapter/backup.ts +109 -0
  527. package/src/adapter/ezsp/adapter/ezspAdapter.ts +614 -0
  528. package/src/adapter/ezsp/driver/commands.ts +2497 -0
  529. package/src/adapter/ezsp/driver/consts.ts +11 -0
  530. package/src/adapter/ezsp/driver/driver.ts +1002 -0
  531. package/src/adapter/ezsp/driver/ezsp.ts +802 -0
  532. package/src/adapter/ezsp/driver/frame.ts +101 -0
  533. package/src/adapter/ezsp/driver/index.ts +4 -0
  534. package/src/adapter/ezsp/driver/multicast.ts +78 -0
  535. package/src/adapter/ezsp/driver/parser.ts +81 -0
  536. package/src/adapter/ezsp/driver/types/basic.ts +201 -0
  537. package/src/adapter/ezsp/driver/types/index.ts +239 -0
  538. package/src/adapter/ezsp/driver/types/named.ts +2330 -0
  539. package/src/adapter/ezsp/driver/types/struct.ts +844 -0
  540. package/src/adapter/ezsp/driver/uart.ts +460 -0
  541. package/src/adapter/ezsp/driver/utils/crc16ccitt.ts +44 -0
  542. package/src/adapter/ezsp/driver/utils/index.ts +32 -0
  543. package/src/adapter/ezsp/driver/writer.ts +64 -0
  544. package/src/adapter/index.ts +3 -0
  545. package/src/adapter/serialPort.ts +58 -0
  546. package/src/adapter/socketPortUtils.ts +16 -0
  547. package/src/adapter/tstype.ts +78 -0
  548. package/src/adapter/z-stack/adapter/adapter-backup.ts +519 -0
  549. package/src/adapter/z-stack/adapter/adapter-nv-memory.ts +457 -0
  550. package/src/adapter/z-stack/adapter/endpoints.ts +57 -0
  551. package/src/adapter/z-stack/adapter/manager.ts +543 -0
  552. package/src/adapter/z-stack/adapter/tstype.ts +6 -0
  553. package/src/adapter/z-stack/adapter/zStackAdapter.ts +1190 -0
  554. package/src/adapter/z-stack/constants/af.ts +27 -0
  555. package/src/adapter/z-stack/constants/common.ts +285 -0
  556. package/src/adapter/z-stack/constants/dbg.ts +23 -0
  557. package/src/adapter/z-stack/constants/index.ts +11 -0
  558. package/src/adapter/z-stack/constants/mac.ts +128 -0
  559. package/src/adapter/z-stack/constants/sapi.ts +25 -0
  560. package/src/adapter/z-stack/constants/sys.ts +72 -0
  561. package/src/adapter/z-stack/constants/util.ts +82 -0
  562. package/src/adapter/z-stack/constants/utils.ts +14 -0
  563. package/src/adapter/z-stack/constants/zdo.ts +103 -0
  564. package/src/adapter/z-stack/models/startup-options.ts +13 -0
  565. package/src/adapter/z-stack/structs/entries/address-manager-entry.ts +44 -0
  566. package/src/adapter/z-stack/structs/entries/address-manager-table.ts +19 -0
  567. package/src/adapter/z-stack/structs/entries/aps-link-key-data-entry.ts +12 -0
  568. package/src/adapter/z-stack/structs/entries/aps-link-key-data-table.ts +21 -0
  569. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-entry.ts +19 -0
  570. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-table.ts +21 -0
  571. package/src/adapter/z-stack/structs/entries/channel-list.ts +8 -0
  572. package/src/adapter/z-stack/structs/entries/has-configured.ts +16 -0
  573. package/src/adapter/z-stack/structs/entries/index.ts +16 -0
  574. package/src/adapter/z-stack/structs/entries/nib.ts +66 -0
  575. package/src/adapter/z-stack/structs/entries/nwk-key-descriptor.ts +15 -0
  576. package/src/adapter/z-stack/structs/entries/nwk-key.ts +13 -0
  577. package/src/adapter/z-stack/structs/entries/nwk-pan-id.ts +8 -0
  578. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.ts +20 -0
  579. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.ts +19 -0
  580. package/src/adapter/z-stack/structs/entries/security-manager-entry.ts +33 -0
  581. package/src/adapter/z-stack/structs/entries/security-manager-table.ts +22 -0
  582. package/src/adapter/z-stack/structs/index.ts +4 -0
  583. package/src/adapter/z-stack/structs/serializable-memory-object.ts +14 -0
  584. package/src/adapter/z-stack/structs/struct.ts +367 -0
  585. package/src/adapter/z-stack/structs/table.ts +198 -0
  586. package/src/adapter/z-stack/unpi/constants.ts +33 -0
  587. package/src/adapter/z-stack/unpi/frame.ts +62 -0
  588. package/src/adapter/z-stack/unpi/index.ts +4 -0
  589. package/src/adapter/z-stack/unpi/parser.ts +56 -0
  590. package/src/adapter/z-stack/unpi/writer.ts +21 -0
  591. package/src/adapter/z-stack/utils/channel-list.ts +40 -0
  592. package/src/adapter/z-stack/utils/index.ts +2 -0
  593. package/src/adapter/z-stack/utils/network-options.ts +26 -0
  594. package/src/adapter/z-stack/znp/buffaloZnp.ts +175 -0
  595. package/src/adapter/z-stack/znp/definition.ts +2713 -0
  596. package/src/adapter/z-stack/znp/index.ts +2 -0
  597. package/src/adapter/z-stack/znp/parameterType.ts +22 -0
  598. package/src/adapter/z-stack/znp/tstype.ts +44 -0
  599. package/src/adapter/z-stack/znp/utils.ts +10 -0
  600. package/src/adapter/z-stack/znp/znp.ts +342 -0
  601. package/src/adapter/z-stack/znp/zpiObject.ts +148 -0
  602. package/src/adapter/zboss/adapter/zbossAdapter.ts +527 -0
  603. package/src/adapter/zboss/commands.ts +1184 -0
  604. package/src/adapter/zboss/consts.ts +9 -0
  605. package/src/adapter/zboss/driver.ts +423 -0
  606. package/src/adapter/zboss/enums.ts +360 -0
  607. package/src/adapter/zboss/frame.ts +227 -0
  608. package/src/adapter/zboss/reader.ts +65 -0
  609. package/src/adapter/zboss/types.ts +0 -0
  610. package/src/adapter/zboss/uart.ts +428 -0
  611. package/src/adapter/zboss/utils.ts +58 -0
  612. package/src/adapter/zboss/writer.ts +49 -0
  613. package/src/adapter/zigate/adapter/patchZdoBuffaloBE.ts +27 -0
  614. package/src/adapter/zigate/adapter/zigateAdapter.ts +618 -0
  615. package/src/adapter/zigate/driver/LICENSE +17 -0
  616. package/src/adapter/zigate/driver/buffaloZiGate.ts +212 -0
  617. package/src/adapter/zigate/driver/commandType.ts +418 -0
  618. package/src/adapter/zigate/driver/constants.ts +150 -0
  619. package/src/adapter/zigate/driver/frame.ts +197 -0
  620. package/src/adapter/zigate/driver/messageType.ts +287 -0
  621. package/src/adapter/zigate/driver/parameterType.ts +32 -0
  622. package/src/adapter/zigate/driver/ziGateObject.ts +146 -0
  623. package/src/adapter/zigate/driver/zigate.ts +426 -0
  624. package/src/adapter/zoh/adapter/utils.ts +27 -0
  625. package/src/adapter/zoh/adapter/zohAdapter.ts +837 -0
  626. package/src/buffalo/buffalo.ts +335 -0
  627. package/src/buffalo/index.ts +1 -0
  628. package/src/controller/controller.ts +1048 -0
  629. package/src/controller/database.ts +124 -0
  630. package/src/controller/events.ts +51 -0
  631. package/src/controller/greenPower.ts +603 -0
  632. package/src/controller/helpers/index.ts +1 -0
  633. package/src/controller/helpers/request.ts +94 -0
  634. package/src/controller/helpers/requestQueue.ts +125 -0
  635. package/src/controller/helpers/zclFrameConverter.ts +51 -0
  636. package/src/controller/helpers/zclTransactionSequenceNumber.ts +19 -0
  637. package/src/controller/index.ts +6 -0
  638. package/src/controller/model/device.ts +1320 -0
  639. package/src/controller/model/endpoint.ts +1040 -0
  640. package/src/controller/model/entity.ts +23 -0
  641. package/src/controller/model/group.ts +333 -0
  642. package/src/controller/model/index.ts +4 -0
  643. package/src/controller/touchlink.ts +189 -0
  644. package/src/controller/tstype.ts +39 -0
  645. package/src/index.ts +12 -0
  646. package/src/models/backup-storage-legacy.ts +48 -0
  647. package/src/models/backup-storage-unified.ts +47 -0
  648. package/src/models/backup.ts +37 -0
  649. package/src/models/index.ts +5 -0
  650. package/src/models/network-options.ts +11 -0
  651. package/src/utils/backup.ts +152 -0
  652. package/src/utils/index.ts +5 -0
  653. package/src/utils/logger.ts +20 -0
  654. package/src/utils/patchBigIntSerialization.ts +8 -0
  655. package/src/utils/queue.ts +76 -0
  656. package/src/utils/types.d.ts +3 -0
  657. package/src/utils/utils.ts +20 -0
  658. package/src/utils/wait.ts +5 -0
  659. package/src/utils/waitress.ts +95 -0
  660. package/src/zspec/consts.ts +84 -0
  661. package/src/zspec/enums.ts +22 -0
  662. package/src/zspec/index.ts +3 -0
  663. package/src/zspec/tstypes.ts +18 -0
  664. package/src/zspec/utils.ts +308 -0
  665. package/src/zspec/zcl/buffaloZcl.ts +1133 -0
  666. package/src/zspec/zcl/definition/cluster.ts +5398 -0
  667. package/src/zspec/zcl/definition/consts.ts +24 -0
  668. package/src/zspec/zcl/definition/enums.ts +194 -0
  669. package/src/zspec/zcl/definition/foundation.ts +301 -0
  670. package/src/zspec/zcl/definition/manufacturerCode.ts +729 -0
  671. package/src/zspec/zcl/definition/status.ts +69 -0
  672. package/src/zspec/zcl/definition/tstype.ts +236 -0
  673. package/src/zspec/zcl/index.ts +10 -0
  674. package/src/zspec/zcl/utils.ts +342 -0
  675. package/src/zspec/zcl/zclFrame.ts +336 -0
  676. package/src/zspec/zcl/zclHeader.ts +102 -0
  677. package/src/zspec/zcl/zclStatusError.ts +10 -0
  678. package/src/zspec/zdo/buffaloZdo.ts +2345 -0
  679. package/src/zspec/zdo/definition/clusters.ts +722 -0
  680. package/src/zspec/zdo/definition/consts.ts +16 -0
  681. package/src/zspec/zdo/definition/enums.ts +99 -0
  682. package/src/zspec/zdo/definition/status.ts +105 -0
  683. package/src/zspec/zdo/definition/tstypes.ts +1062 -0
  684. package/src/zspec/zdo/index.ts +7 -0
  685. package/src/zspec/zdo/utils.ts +76 -0
  686. package/src/zspec/zdo/zdoStatusError.ts +10 -0
  687. package/test/adapter/adapter.test.ts +1062 -0
  688. package/test/adapter/ember/ash.test.ts +337 -0
  689. package/test/adapter/ember/consts.ts +131 -0
  690. package/test/adapter/ember/emberAdapter.test.ts +3449 -0
  691. package/test/adapter/ember/ezsp.test.ts +386 -0
  692. package/test/adapter/ember/ezspBuffalo.test.ts +92 -0
  693. package/test/adapter/ember/ezspError.test.ts +11 -0
  694. package/test/adapter/ember/math.test.ts +205 -0
  695. package/test/adapter/ezsp/frame.test.ts +29 -0
  696. package/test/adapter/ezsp/uart.test.ts +180 -0
  697. package/test/adapter/z-stack/adapter.test.ts +3985 -0
  698. package/test/adapter/z-stack/constants.test.ts +32 -0
  699. package/test/adapter/z-stack/structs.test.ts +114 -0
  700. package/test/adapter/z-stack/unpi.test.ts +212 -0
  701. package/test/adapter/z-stack/znp.test.ts +1284 -0
  702. package/test/adapter/zboss/fixZdoResponse.test.ts +178 -0
  703. package/test/adapter/zigate/patchZdoBuffaloBE.test.ts +80 -0
  704. package/test/adapter/zigate/zdo.test.ts +187 -0
  705. package/test/adapter/zoh/utils.test.ts +35 -0
  706. package/test/adapter/zoh/zohAdapter.test.ts +1306 -0
  707. package/test/buffalo.test.ts +430 -0
  708. package/test/controller.test.ts +10005 -0
  709. package/test/greenpower.test.ts +1421 -0
  710. package/test/mockAdapters.ts +65 -0
  711. package/test/mockDevices.ts +472 -0
  712. package/test/testUtils.ts +20 -0
  713. package/test/tsconfig.json +10 -0
  714. package/test/utils/math.ts +19 -0
  715. package/test/utils.test.ts +227 -0
  716. package/test/vitest.config.mts +25 -0
  717. package/test/zcl.test.ts +2832 -0
  718. package/test/zspec/utils.test.ts +131 -0
  719. package/test/zspec/zcl/buffalo.test.ts +1231 -0
  720. package/test/zspec/zcl/frame.test.ts +925 -0
  721. package/test/zspec/zcl/utils.test.ts +280 -0
  722. package/test/zspec/zdo/buffalo.test.ts +1849 -0
  723. package/test/zspec/zdo/utils.test.ts +240 -0
  724. package/.prettierignore +0 -2
  725. package/.prettierrc +0 -26
  726. package/eslint.config.mjs +0 -32
@@ -0,0 +1,1284 @@
1
+ import type {MockInstance} from "vitest";
2
+
3
+ import {SerialPort} from "../../../src/adapter/serialPort";
4
+ import {Constants as UnpiConstants, Frame as UnpiFrame} from "../../../src/adapter/z-stack/unpi";
5
+ import {Znp, ZpiObject} from "../../../src/adapter/z-stack/znp";
6
+ import BuffaloZnp from "../../../src/adapter/z-stack/znp/buffaloZnp";
7
+ import ParameterType from "../../../src/adapter/z-stack/znp/parameterType";
8
+ import {logger} from "../../../src/utils/logger";
9
+ import * as Zdo from "../../../src/zspec/zdo";
10
+ import {duplicateArray, ieeeaAddr1, ieeeaAddr2} from "../../testUtils";
11
+
12
+ const consoleLogger = logger;
13
+ const mockSerialPortClose = vi.fn().mockImplementation((cb) => (cb ? cb() : null));
14
+ const mockSerialPortFlush = vi.fn().mockImplementation((cb) => cb());
15
+ const mockSerialPortAsyncFlushAndClose = vi.fn();
16
+ const mockSerialPortPipe = vi.fn();
17
+ const mockSerialPortList = vi.fn().mockReturnValue([]);
18
+ const mockSerialPortOpen = vi.fn().mockImplementation((cb) => cb());
19
+ const mockSerialPortAsyncOpen = vi.fn();
20
+ const mockSerialPortConstructor = vi.fn();
21
+ const mockSerialPortOnce = vi.fn();
22
+ const mockSerialPortAsyncSet = vi.fn();
23
+ const mockSerialPortWrite = vi.fn((_buffer, cb) => cb());
24
+ let mockSerialPortIsOpen = false;
25
+
26
+ vi.mock("../../../src/utils/wait", () => ({
27
+ wait: vi.fn(() => {
28
+ return new Promise<void>((resolve) => resolve());
29
+ }),
30
+ }));
31
+
32
+ vi.mock("../../../src/adapter/serialPort", () => ({
33
+ SerialPort: vi.fn(() => ({
34
+ close: mockSerialPortClose,
35
+ constructor: mockSerialPortConstructor,
36
+ emit: () => {},
37
+ on: () => {},
38
+ once: mockSerialPortOnce,
39
+ open: mockSerialPortOpen,
40
+ pipe: mockSerialPortPipe,
41
+ write: mockSerialPortWrite,
42
+ flush: mockSerialPortFlush,
43
+ isOpen: mockSerialPortIsOpen,
44
+ asyncOpen: mockSerialPortAsyncOpen,
45
+ asyncFlushAndClose: mockSerialPortAsyncFlushAndClose,
46
+ asyncSet: mockSerialPortAsyncSet,
47
+ })),
48
+ }));
49
+
50
+ const mockSocketSetNoDelay = vi.fn();
51
+ const mockSocketSetKeepAlive = vi.fn();
52
+ const mockSocketPipe = vi.fn();
53
+ const mockSocketOnce = vi.fn();
54
+ const mockSocketCallbacks = {};
55
+ const mockSocketConnect = vi.fn(() => {
56
+ mockSocketCallbacks.connect();
57
+ mockSocketCallbacks.ready();
58
+ });
59
+ const mockSocketDestroy = vi.fn();
60
+ let requestSpy: MockInstance;
61
+
62
+ vi.mock("node:net", async () => ({
63
+ Socket: vi.fn(() => ({
64
+ setNoDelay: mockSocketSetNoDelay,
65
+ pipe: mockSocketPipe,
66
+ connect: mockSocketConnect,
67
+ on: (event, cb) => {
68
+ mockSocketCallbacks[event] = cb;
69
+ },
70
+ once: mockSocketOnce,
71
+ destroy: mockSocketDestroy,
72
+ setKeepAlive: mockSocketSetKeepAlive,
73
+ })),
74
+ }));
75
+
76
+ SerialPort.list = mockSerialPortList;
77
+
78
+ const mockUnpiParserOn = vi.fn();
79
+
80
+ vi.mock("../../../src/adapter/z-stack/unpi/parser", () => ({
81
+ Parser: vi.fn(() => ({
82
+ on: mockUnpiParserOn,
83
+ })),
84
+ }));
85
+
86
+ const mockUnpiWriterWriteFrame = vi.fn();
87
+ const mockUnpiWriterWriteBuffer = vi.fn();
88
+
89
+ vi.mock("../../../src/adapter/z-stack/unpi/writer", () => ({
90
+ Writer: vi.fn(() => ({
91
+ writeFrame: mockUnpiWriterWriteFrame,
92
+ writeBuffer: mockUnpiWriterWriteBuffer,
93
+ pipe: vi.fn(),
94
+ })),
95
+ }));
96
+
97
+ const mocks = [
98
+ mockSerialPortClose,
99
+ mockSerialPortPipe,
100
+ mockSerialPortConstructor,
101
+ mockSerialPortOpen,
102
+ mockSerialPortOnce,
103
+ mockSerialPortWrite,
104
+ SerialPort,
105
+ mockUnpiParserOn,
106
+ mockUnpiWriterWriteFrame,
107
+ mockUnpiWriterWriteBuffer,
108
+ mockSerialPortFlush,
109
+ mockSerialPortAsyncFlushAndClose,
110
+ mockSerialPortAsyncOpen,
111
+ ];
112
+
113
+ describe("ZNP", () => {
114
+ let znp: Znp;
115
+
116
+ beforeAll(() => {
117
+ vi.useFakeTimers();
118
+ });
119
+
120
+ afterAll(() => {
121
+ vi.useRealTimers();
122
+ });
123
+
124
+ beforeEach(() => {
125
+ for (const mock of mocks) {
126
+ // @ts-ignore
127
+ mock.mockClear();
128
+ }
129
+
130
+ // @ts-ignore; make sure we always get a new instance
131
+ znp = new Znp("/dev/ttyACM0", 100, true);
132
+ requestSpy = vi.spyOn(znp, "request").mockImplementation(() => {});
133
+ });
134
+
135
+ afterEach(() => {
136
+ requestSpy.mockRestore();
137
+ });
138
+
139
+ it("Open", async () => {
140
+ await znp.open();
141
+
142
+ expect(SerialPort).toHaveBeenCalledTimes(1);
143
+ expect(SerialPort).toHaveBeenCalledWith({path: "/dev/ttyACM0", autoOpen: false, baudRate: 100, rtscts: true});
144
+
145
+ expect(mockSerialPortPipe).toHaveBeenCalledTimes(1);
146
+ expect(mockSerialPortAsyncOpen).toHaveBeenCalledTimes(1);
147
+ expect(mockSerialPortOnce).toHaveBeenCalledTimes(2);
148
+ expect(mockUnpiWriterWriteBuffer).toHaveBeenCalledTimes(0);
149
+ });
150
+
151
+ it("Open - first ping fails should send reset bootloader", async () => {
152
+ requestSpy.mockImplementation(() => {
153
+ throw new Error("failed");
154
+ });
155
+ await znp.open();
156
+
157
+ expect(SerialPort).toHaveBeenCalledTimes(1);
158
+ expect(SerialPort).toHaveBeenCalledWith({path: "/dev/ttyACM0", autoOpen: false, baudRate: 100, rtscts: true});
159
+
160
+ expect(mockSerialPortPipe).toHaveBeenCalledTimes(1);
161
+ expect(mockSerialPortAsyncOpen).toHaveBeenCalledTimes(1);
162
+ expect(mockUnpiWriterWriteBuffer).toHaveBeenCalledTimes(1);
163
+ expect(mockSerialPortOnce).toHaveBeenCalledTimes(2);
164
+ });
165
+
166
+ it("Open with defaults", async () => {
167
+ znp = new Znp("/dev/ttyACM0", undefined, undefined);
168
+ requestSpy = vi.spyOn(znp, "request").mockImplementation(() => {});
169
+ await znp.open();
170
+
171
+ expect(SerialPort).toHaveBeenCalledTimes(1);
172
+ expect(SerialPort).toHaveBeenCalledWith({path: "/dev/ttyACM0", autoOpen: false, baudRate: 115200, rtscts: false});
173
+
174
+ expect(mockSerialPortPipe).toHaveBeenCalledTimes(1);
175
+ expect(mockSerialPortAsyncOpen).toHaveBeenCalledTimes(1);
176
+ expect(mockSerialPortOnce).toHaveBeenCalledTimes(2);
177
+ });
178
+
179
+ it("Open and close tcp port", async () => {
180
+ znp = new Znp("tcp://localhost:8080", 100, false);
181
+ await znp.open();
182
+ expect(mockSocketConnect).toBeCalledTimes(1);
183
+ expect(mockSocketConnect).toBeCalledWith(8080, "localhost");
184
+ expect(znp.isInitialized()).toBeTruthy();
185
+ expect(mockUnpiWriterWriteBuffer).toHaveBeenCalledTimes(1);
186
+
187
+ await znp.close();
188
+ expect(mockSocketDestroy).toHaveBeenCalledTimes(1);
189
+ });
190
+
191
+ it("Open tcp port with socket error", async () => {
192
+ mockSocketConnect.mockImplementationOnce(() => {
193
+ mockSocketCallbacks.error();
194
+ });
195
+
196
+ znp = new Znp("tcp://localhost:666", 100, false);
197
+
198
+ let error = false;
199
+ try {
200
+ await znp.open();
201
+ } catch (e) {
202
+ error = e;
203
+ }
204
+
205
+ expect(error).toStrictEqual(new Error("Error while opening socket"));
206
+ expect(znp.isInitialized()).toBeFalsy();
207
+ });
208
+
209
+ it("Open with error", async () => {
210
+ mockSerialPortAsyncOpen.mockImplementationOnce(() => {
211
+ return new Promise((_resolve, reject) => {
212
+ reject("failed!");
213
+ });
214
+ });
215
+ mockSerialPortIsOpen = true;
216
+
217
+ let error = false;
218
+
219
+ try {
220
+ await znp.open();
221
+ } catch (e) {
222
+ error = e;
223
+ }
224
+
225
+ expect(SerialPort).toHaveBeenCalledTimes(1);
226
+ expect(SerialPort).toHaveBeenCalledWith({path: "/dev/ttyACM0", autoOpen: false, baudRate: 100, rtscts: true});
227
+
228
+ expect(error).toEqual("failed!");
229
+ expect(mockSerialPortPipe).toHaveBeenCalledTimes(1);
230
+ expect(mockSerialPortAsyncOpen).toHaveBeenCalledTimes(1);
231
+ expect(mockSerialPortClose).toHaveBeenCalledTimes(1);
232
+ expect(mockUnpiWriterWriteBuffer).toHaveBeenCalledTimes(0);
233
+ expect(mockSerialPortOnce).toHaveBeenCalledTimes(0);
234
+ });
235
+
236
+ it("Open with error when serialport is not open", async () => {
237
+ mockSerialPortAsyncOpen.mockImplementationOnce(() => {
238
+ return new Promise((_resolve, reject) => {
239
+ reject("failed!");
240
+ });
241
+ });
242
+ mockSerialPortIsOpen = false;
243
+
244
+ let error = false;
245
+
246
+ try {
247
+ await znp.open();
248
+ } catch (e) {
249
+ error = e;
250
+ }
251
+
252
+ expect(SerialPort).toHaveBeenCalledTimes(1);
253
+ expect(SerialPort).toHaveBeenCalledWith({path: "/dev/ttyACM0", autoOpen: false, baudRate: 100, rtscts: true});
254
+
255
+ expect(error).toEqual("failed!");
256
+ expect(mockSerialPortPipe).toHaveBeenCalledTimes(1);
257
+ expect(mockSerialPortAsyncOpen).toHaveBeenCalledTimes(1);
258
+ expect(mockSerialPortClose).toHaveBeenCalledTimes(0);
259
+ expect(mockUnpiWriterWriteBuffer).toHaveBeenCalledTimes(0);
260
+ expect(mockSerialPortOnce).toHaveBeenCalledTimes(0);
261
+ });
262
+
263
+ it("Open and close", async () => {
264
+ const close = vi.fn();
265
+ znp.on("close", close);
266
+ expect(znp.isInitialized()).toBeFalsy();
267
+ await znp.open();
268
+ expect(znp.isInitialized()).toBeTruthy();
269
+ await znp.close();
270
+ expect(znp.isInitialized()).toBeFalsy();
271
+
272
+ expect(mockSerialPortAsyncFlushAndClose).toHaveBeenCalledTimes(1);
273
+ expect(close).toHaveBeenCalledTimes(1);
274
+ });
275
+
276
+ it("Open and close error", async () => {
277
+ const close = vi.fn();
278
+ znp.on("close", close);
279
+ mockSerialPortAsyncFlushAndClose.mockImplementationOnce(() => {
280
+ return new Promise((_resolve, reject) => {
281
+ reject("failed!");
282
+ });
283
+ });
284
+ await znp.open();
285
+
286
+ let error;
287
+ try {
288
+ await znp.close();
289
+ } catch (e) {
290
+ error = e;
291
+ }
292
+
293
+ expect(mockSerialPortAsyncFlushAndClose).toHaveBeenCalledTimes(1);
294
+ expect(error).toEqual("failed!");
295
+ expect(close).toHaveBeenCalledTimes(1);
296
+ });
297
+
298
+ it("Close without initialization", async () => {
299
+ const close = vi.fn();
300
+ znp.on("close", close);
301
+ mockSerialPortAsyncFlushAndClose.mockImplementationOnce(() => {
302
+ return new Promise((_resolve, reject) => {
303
+ reject("failed!");
304
+ });
305
+ });
306
+ await znp.close();
307
+
308
+ expect(mockSerialPortAsyncFlushAndClose).toHaveBeenCalledTimes(0);
309
+ expect(close).toHaveBeenCalledTimes(1);
310
+ });
311
+
312
+ it("Open and close by serialport event", async () => {
313
+ let closeCb;
314
+
315
+ mockSerialPortOnce.mockImplementation((event, cb) => {
316
+ if (event === "close") {
317
+ closeCb = cb;
318
+ }
319
+ });
320
+
321
+ const close = vi.fn();
322
+ znp.on("close", close);
323
+ await znp.open();
324
+ closeCb();
325
+
326
+ expect(close).toHaveBeenCalledTimes(1);
327
+ });
328
+
329
+ it("Serialport error (do nothing)", async () => {
330
+ let errorCb;
331
+
332
+ mockSerialPortOnce.mockImplementation((event, cb) => {
333
+ if (event === "error") {
334
+ errorCb = cb;
335
+ }
336
+ });
337
+
338
+ await znp.open();
339
+ errorCb();
340
+ });
341
+
342
+ it("znp receive", async () => {
343
+ let parsedCb;
344
+ const received = vi.fn();
345
+
346
+ znp.on("received", received);
347
+
348
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
349
+ if (event === "parsed") {
350
+ parsedCb = cb;
351
+ }
352
+ });
353
+
354
+ znp.open();
355
+ parsedCb(
356
+ new UnpiFrame(
357
+ UnpiConstants.Type.SRSP,
358
+ UnpiConstants.Subsystem.SYS,
359
+ 0x02,
360
+ Buffer.from([0x01, 0x02, 0x03, 0x04, 0x05, 0x01, 0x01, 0x01, 0x01]),
361
+ ),
362
+ );
363
+
364
+ expect(received).toHaveBeenCalledTimes(1);
365
+
366
+ const obj = received.mock.calls[0][0];
367
+ expect(obj.command.name).toBe("version");
368
+ expect(obj.command.ID).toBe(2);
369
+ expect(obj.payload).toStrictEqual({maintrel: 5, majorrel: 3, minorrel: 4, product: 2, revision: 16843009, transportrev: 1});
370
+ expect(obj.subsystem).toBe(UnpiConstants.Subsystem.SYS);
371
+ expect(obj.type).toBe(UnpiConstants.Type.SRSP);
372
+ });
373
+
374
+ it("znp receive malformed", async () => {
375
+ let parsedCb;
376
+ const received = vi.fn();
377
+
378
+ znp.on("received", received);
379
+
380
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
381
+ if (event === "parsed") {
382
+ parsedCb = cb;
383
+ }
384
+ });
385
+
386
+ znp.open();
387
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x02, Buffer.from([0x01, 0x02, 0x03, 0x04])));
388
+
389
+ expect(received).toHaveBeenCalledTimes(0);
390
+ });
391
+
392
+ it("znp request SREQ", async () => {
393
+ let parsedCb;
394
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
395
+ if (event === "parsed") {
396
+ parsedCb = cb;
397
+ }
398
+ });
399
+
400
+ mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
401
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x00, 0x02, 0x01, 0x02])));
402
+ });
403
+
404
+ await znp.open();
405
+ requestSpy.mockRestore();
406
+
407
+ const result = await znp.requestWithReply(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2});
408
+
409
+ const frame = mockUnpiWriterWriteFrame.mock.calls[0][0];
410
+ expect(mockUnpiWriterWriteFrame).toHaveBeenCalledTimes(1);
411
+ expect(frame.commandID).toBe(8);
412
+ expect(frame.subsystem).toBe(UnpiConstants.Subsystem.SYS);
413
+ expect(frame.type).toBe(UnpiConstants.Type.SREQ);
414
+ expect(frame.data).toStrictEqual(Buffer.from([0x01, 0x00, 0x02]));
415
+
416
+ expect(result.command.name).toBe("osalNvRead");
417
+ expect(result.command.ID).toBe(0x08);
418
+ expect(result.payload).toStrictEqual({status: 0, len: 2, value: Buffer.from([0x01, 0x02])});
419
+ expect(result.subsystem).toBe(UnpiConstants.Subsystem.SYS);
420
+ expect(result.type).toBe(UnpiConstants.Type.SRSP);
421
+ });
422
+
423
+ it("znp request SREQ failed", async () => {
424
+ let parsedCb;
425
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
426
+ if (event === "parsed") {
427
+ parsedCb = cb;
428
+ }
429
+ });
430
+
431
+ mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
432
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x01, 0x02, 0x01, 0x02])));
433
+ });
434
+
435
+ await znp.open();
436
+ requestSpy.mockRestore();
437
+
438
+ expect(znp.waitress.waiters.size).toBe(0);
439
+
440
+ let error;
441
+ try {
442
+ await znp.request(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2});
443
+ } catch (e) {
444
+ expect(znp.waitress.waiters.size).toBe(0);
445
+ error = e;
446
+ }
447
+
448
+ expect(error).toStrictEqual(
449
+ new Error("--> 'SREQ: SYS - osalNvRead - {\"id\":1,\"offset\":2}' failed with status '(0x01: FAILURE)' (expected '(0x00: SUCCESS)')"),
450
+ );
451
+ });
452
+
453
+ it("znp request SREQ failed should cancel waiter when provided", async () => {
454
+ let parsedCb;
455
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
456
+ if (event === "parsed") {
457
+ parsedCb = cb;
458
+ }
459
+ });
460
+
461
+ mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
462
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x01, 0x02, 0x01, 0x02])));
463
+ });
464
+
465
+ await znp.open();
466
+ requestSpy.mockRestore();
467
+
468
+ expect(znp.waitress.waiters.size).toBe(0);
469
+ const waiter = znp.waitFor(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, "osalNvRead");
470
+ expect(znp.waitress.waiters.size).toBe(1);
471
+
472
+ let error;
473
+ try {
474
+ await znp.request(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2}, waiter.ID);
475
+ } catch (e) {
476
+ expect(znp.waitress.waiters.size).toBe(0);
477
+ error = e;
478
+ }
479
+
480
+ expect(error).toStrictEqual(
481
+ new Error("--> 'SREQ: SYS - osalNvRead - {\"id\":1,\"offset\":2}' failed with status '(0x01: FAILURE)' (expected '(0x00: SUCCESS)')"),
482
+ );
483
+ });
484
+
485
+ it("znp request SREQ with parsed in between", async () => {
486
+ let parsedCb;
487
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
488
+ if (event === "parsed") {
489
+ parsedCb = cb;
490
+ }
491
+ });
492
+
493
+ mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
494
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.AF, 0x00, Buffer.from([0x00])));
495
+
496
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x00, 0x02, 0x01, 0x02])));
497
+ });
498
+
499
+ await znp.open();
500
+ requestSpy.mockRestore();
501
+
502
+ const result = await znp.request(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2});
503
+
504
+ const frame = mockUnpiWriterWriteFrame.mock.calls[0][0];
505
+ expect(mockUnpiWriterWriteFrame).toHaveBeenCalledTimes(1);
506
+ expect(frame.commandID).toBe(8);
507
+ expect(frame.subsystem).toBe(UnpiConstants.Subsystem.SYS);
508
+ expect(frame.type).toBe(UnpiConstants.Type.SREQ);
509
+ expect(frame.data).toStrictEqual(Buffer.from([0x01, 0x00, 0x02]));
510
+
511
+ expect(result.command.name).toBe("osalNvRead");
512
+ expect(result.command.ID).toBe(0x08);
513
+ expect(result.payload).toStrictEqual({status: 0, len: 2, value: Buffer.from([0x01, 0x02])});
514
+ expect(result.subsystem).toBe(UnpiConstants.Subsystem.SYS);
515
+ expect(result.type).toBe(UnpiConstants.Type.SRSP);
516
+ });
517
+
518
+ it("znp request AREQ reset", async () => {
519
+ let parsedCb;
520
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
521
+ if (event === "parsed") {
522
+ parsedCb = cb;
523
+ }
524
+ });
525
+
526
+ mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
527
+ parsedCb(new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.SYS, 0x80, Buffer.from([0x01, 0x02, 0x03, 0x04, 0x05, 0x06])));
528
+ });
529
+
530
+ await znp.open();
531
+ requestSpy.mockRestore();
532
+
533
+ const result = await znp.request(UnpiConstants.Subsystem.SYS, "resetReq", {type: 1});
534
+
535
+ const frame = mockUnpiWriterWriteFrame.mock.calls[0][0];
536
+ expect(mockUnpiWriterWriteFrame).toHaveBeenCalledTimes(1);
537
+ expect(frame.commandID).toBe(0);
538
+ expect(frame.subsystem).toBe(UnpiConstants.Subsystem.SYS);
539
+ expect(frame.type).toBe(UnpiConstants.Type.AREQ);
540
+ expect(frame.data).toStrictEqual(Buffer.from([1]));
541
+
542
+ expect(result.command.name).toBe("resetInd");
543
+ expect(result.command.ID).toBe(0x80);
544
+ expect(result.payload).toStrictEqual({reason: 1, transportrev: 2, productid: 3, majorrel: 4, minorrel: 5, hwrev: 6});
545
+ expect(result.subsystem).toBe(UnpiConstants.Subsystem.SYS);
546
+ expect(result.type).toBe(UnpiConstants.Type.AREQ);
547
+ });
548
+
549
+ it("znp request AREQ", async () => {
550
+ await znp.open();
551
+ requestSpy.mockRestore();
552
+
553
+ const result = await znp.request(UnpiConstants.Subsystem.SAPI, "startConfirm", {status: 1});
554
+
555
+ const frame = mockUnpiWriterWriteFrame.mock.calls[0][0];
556
+ expect(mockUnpiWriterWriteFrame).toHaveBeenCalledTimes(1);
557
+ expect(frame.commandID).toBe(128);
558
+ expect(frame.subsystem).toBe(UnpiConstants.Subsystem.SAPI);
559
+ expect(frame.type).toBe(UnpiConstants.Type.AREQ);
560
+ expect(frame.data).toStrictEqual(Buffer.from([1]));
561
+
562
+ expect(result).toBe(undefined);
563
+ });
564
+
565
+ it("znp request without init", async () => {
566
+ let error;
567
+ requestSpy.mockRestore();
568
+
569
+ try {
570
+ await znp.request(UnpiConstants.Subsystem.SAPI, "startConfirm", {status: 1});
571
+ } catch (e) {
572
+ error = e;
573
+ }
574
+
575
+ expect(error).toEqual(new Error("Cannot request when znp has not been initialized yet"));
576
+ });
577
+
578
+ it("znp request with non-existing subsystem", async () => {
579
+ await znp.open();
580
+ requestSpy.mockRestore();
581
+ let error;
582
+
583
+ try {
584
+ await znp.request(999, "startConfirm", {status: 1});
585
+ } catch (e) {
586
+ error = e;
587
+ }
588
+
589
+ expect(error).toEqual(new Error("Subsystem '999' does not exist"));
590
+ });
591
+
592
+ it("znp request with non-existing cmd", async () => {
593
+ await znp.open();
594
+ requestSpy.mockRestore();
595
+ let error;
596
+
597
+ try {
598
+ await znp.request(UnpiConstants.Subsystem.SAPI, "nonExisting", {status: 1});
599
+ } catch (e) {
600
+ error = e;
601
+ }
602
+
603
+ expect(error).toEqual(new Error("Command request 'nonExisting' from subsystem '6' not found"));
604
+ });
605
+
606
+ it("znp request timeout", async () => {
607
+ await znp.open();
608
+ requestSpy.mockRestore();
609
+
610
+ const result = znp.request(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2});
611
+ vi.runAllTimers();
612
+
613
+ let error;
614
+ try {
615
+ await result;
616
+ } catch (e) {
617
+ error = e;
618
+ }
619
+
620
+ expect(error).toStrictEqual(new Error("SRSP - SYS - osalNvRead after 6000ms"));
621
+ });
622
+
623
+ it("znp request timeout for startupFromApp is longer", async () => {
624
+ await znp.open();
625
+ requestSpy.mockRestore();
626
+
627
+ const result = znp.request(UnpiConstants.Subsystem.ZDO, "startupFromApp", {startdelay: 100});
628
+ vi.advanceTimersByTime(30000);
629
+
630
+ let error;
631
+ try {
632
+ vi.advanceTimersByTime(15000);
633
+ await result;
634
+ } catch (e) {
635
+ error = e;
636
+ }
637
+
638
+ expect(error).toStrictEqual(new Error("SRSP - ZDO - startupFromApp after 40000ms"));
639
+ });
640
+
641
+ it("znp request, responses comes after timeout", async () => {
642
+ let parsedCb;
643
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
644
+ if (event === "parsed") {
645
+ parsedCb = cb;
646
+ }
647
+ });
648
+
649
+ await znp.open();
650
+ requestSpy.mockRestore();
651
+
652
+ let result = znp.request(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2});
653
+ vi.runAllTimers();
654
+
655
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x00, 0x02, 0x01, 0x02])));
656
+
657
+ let error;
658
+ try {
659
+ result = await result;
660
+ } catch (e) {
661
+ error = e;
662
+ }
663
+
664
+ expect(error).toStrictEqual(new Error("SRSP - SYS - osalNvRead after 6000ms"));
665
+ });
666
+
667
+ it("znp request, waitFor", async () => {
668
+ let parsedCb;
669
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
670
+ if (event === "parsed") {
671
+ parsedCb = cb;
672
+ }
673
+ });
674
+
675
+ await znp.open();
676
+ requestSpy.mockRestore();
677
+
678
+ const waiter = znp.waitFor(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, "osalNvRead");
679
+ znp.request(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2});
680
+
681
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x00, 0x02, 0x01, 0x02])));
682
+
683
+ const object = await waiter.start().promise;
684
+ expect(object.payload).toStrictEqual({len: 2, status: 0, value: Buffer.from([1, 2])});
685
+ });
686
+
687
+ it("znp request ZDO", async () => {
688
+ let parsedCb;
689
+
690
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
691
+ if (event === "parsed") {
692
+ parsedCb = cb;
693
+ }
694
+ });
695
+ mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
696
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.ZDO, 2, Buffer.from([0x00])));
697
+ });
698
+
699
+ await znp.open();
700
+
701
+ const zdoPayload = Buffer.from([2 & 0xff, (2 >> 8) & 0xff, ...Zdo.Buffalo.buildRequest(false, Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, 2)]);
702
+ const result = await znp.requestZdo(Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, zdoPayload, 1);
703
+
704
+ const frame = mockUnpiWriterWriteFrame.mock.calls[0][0];
705
+ expect(mockUnpiWriterWriteFrame).toHaveBeenCalledTimes(1);
706
+ expect(frame.commandID).toBe(2);
707
+ expect(frame.subsystem).toBe(UnpiConstants.Subsystem.ZDO);
708
+ expect(frame.type).toBe(UnpiConstants.Type.SREQ);
709
+ expect(frame.data).toStrictEqual(zdoPayload);
710
+
711
+ expect(result).toBe(undefined);
712
+ });
713
+
714
+ it("znp request ZDO SUCCESS", async () => {
715
+ let parsedCb;
716
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
717
+ if (event === "parsed") {
718
+ parsedCb = cb;
719
+ }
720
+ });
721
+
722
+ await znp.open();
723
+
724
+ const waiter = znp.waitFor(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.ZDO, "nodeDescReq");
725
+ const zdoPayload = Buffer.from([2 & 0xff, (2 >> 8) & 0xff, ...Zdo.Buffalo.buildRequest(false, Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, 2)]);
726
+ znp.requestZdo(Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, zdoPayload, 1);
727
+
728
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.ZDO, 2, Buffer.from([0x00])));
729
+
730
+ const object = await waiter.start().promise;
731
+ expect(object.payload).toStrictEqual({status: 0x00});
732
+ });
733
+
734
+ it("znp request ZDO FAILURE", async () => {
735
+ let parsedCb;
736
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
737
+ if (event === "parsed") {
738
+ parsedCb = cb;
739
+ }
740
+ });
741
+
742
+ mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
743
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.ZDO, 2, Buffer.from([0x01])));
744
+ });
745
+
746
+ await znp.open();
747
+
748
+ const zdoPayload = Buffer.from([2 & 0xff, (2 >> 8) & 0xff, ...Zdo.Buffalo.buildRequest(false, Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, 2)]);
749
+ let error;
750
+ try {
751
+ await znp.requestZdo(Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, zdoPayload, undefined);
752
+ } catch (e) {
753
+ error = e;
754
+ }
755
+
756
+ expect(error).toStrictEqual(
757
+ new Error(`--> 'SREQ: ZDO - NODE_DESCRIPTOR_REQUEST - ${zdoPayload.toString("hex")}' failed with status '(0x01: FAILURE)'`),
758
+ );
759
+ });
760
+
761
+ it("znp request ZDO failed should cancel waiter when provided", async () => {
762
+ let parsedCb;
763
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
764
+ if (event === "parsed") {
765
+ parsedCb = cb;
766
+ }
767
+ });
768
+
769
+ mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
770
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.ZDO, 2, Buffer.from([0x01])));
771
+ });
772
+
773
+ await znp.open();
774
+
775
+ expect(znp.waitress.waiters.size).toBe(0);
776
+ const waiter = znp.waitFor(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, "nodeDescRsp");
777
+ expect(znp.waitress.waiters.size).toBe(1);
778
+
779
+ const zdoPayload = Buffer.from([2 & 0xff, (2 >> 8) & 0xff, ...Zdo.Buffalo.buildRequest(false, Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, 2)]);
780
+ let error;
781
+ try {
782
+ await znp.requestZdo(Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, zdoPayload, waiter.ID);
783
+ } catch (e) {
784
+ expect(znp.waitress.waiters.size).toBe(0);
785
+ error = e;
786
+ }
787
+
788
+ expect(error).toStrictEqual(
789
+ new Error(`--> 'SREQ: ZDO - NODE_DESCRIPTOR_REQUEST - ${zdoPayload.toString("hex")}' failed with status '(0x01: FAILURE)'`),
790
+ );
791
+ });
792
+
793
+ it("znp waitFor with transid", async () => {
794
+ let parsedCb;
795
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
796
+ if (event === "parsed") {
797
+ parsedCb = cb;
798
+ }
799
+ });
800
+
801
+ await znp.open();
802
+ requestSpy.mockRestore();
803
+
804
+ const waiter = znp.waitFor(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.AF, "dataConfirm", undefined, 123);
805
+
806
+ parsedCb(new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.AF, 128, Buffer.from([0, 1, 123])));
807
+
808
+ const object = await waiter.start().promise;
809
+ expect(object.payload).toStrictEqual({status: 0, endpoint: 1, transid: 123});
810
+ });
811
+
812
+ it("znp waitFor with target as network address", async () => {
813
+ let parsedCb;
814
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
815
+ if (event === "parsed") {
816
+ parsedCb = cb;
817
+ }
818
+ });
819
+
820
+ await znp.open();
821
+ requestSpy.mockRestore();
822
+
823
+ const waiter = znp.waitFor(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, "activeEpRsp", 0x1234);
824
+
825
+ parsedCb(new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, 133, Buffer.from([0x34, 0x12, 0x00, 0x34, 0x12, 0x00])));
826
+
827
+ const object = await waiter.start().promise;
828
+ expect(object.payload.zdo).toStrictEqual([
829
+ Zdo.Status.SUCCESS,
830
+ {
831
+ nwkAddress: 0x1234,
832
+ endpointList: [],
833
+ },
834
+ ]);
835
+ });
836
+
837
+ it("znp waitFor with target as IEEE", async () => {
838
+ let parsedCb;
839
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
840
+ if (event === "parsed") {
841
+ parsedCb = cb;
842
+ }
843
+ });
844
+
845
+ await znp.open();
846
+ requestSpy.mockRestore();
847
+
848
+ const waiter = znp.waitFor(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, "nwkAddrRsp", "0x0807060504030201");
849
+
850
+ parsedCb(
851
+ new UnpiFrame(
852
+ UnpiConstants.Type.AREQ,
853
+ UnpiConstants.Subsystem.ZDO,
854
+ 128,
855
+ Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x01, 0x01, 0x00, 0x02, 0x10, 0x10, 0x11, 0x11]),
856
+ ),
857
+ );
858
+
859
+ const object = await waiter.start().promise;
860
+ expect(object.payload.zdo).toStrictEqual([
861
+ Zdo.Status.SUCCESS,
862
+ {
863
+ assocDevList: [4112, 4369],
864
+ eui64: "0x0807060504030201",
865
+ // numassocdev: 2,
866
+ nwkAddress: 257,
867
+ startIndex: 0,
868
+ },
869
+ ]);
870
+ });
871
+
872
+ it("znp waitFor with target as IEEE forced to timeout because invalid ZDO status (no payload to match against)", async () => {
873
+ let parsedCb;
874
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
875
+ if (event === "parsed") {
876
+ parsedCb = cb;
877
+ }
878
+ });
879
+
880
+ await znp.open();
881
+ requestSpy.mockRestore();
882
+
883
+ const waiter = znp.waitFor(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, "nwkAddrRsp", "0x0807060504030201").start();
884
+
885
+ parsedCb(new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, 128, Buffer.from([Zdo.Status.INVALID_INDEX])));
886
+
887
+ vi.advanceTimersByTime(11000);
888
+ await expect(waiter.promise).rejects.toThrow("AREQ - ZDO - nwkAddrRsp after 10000ms");
889
+ });
890
+
891
+ it("znp waitFor with state", async () => {
892
+ let parsedCb;
893
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
894
+ if (event === "parsed") {
895
+ parsedCb = cb;
896
+ }
897
+ });
898
+
899
+ await znp.open();
900
+ requestSpy.mockRestore();
901
+
902
+ const waiter = znp.waitFor(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, "stateChangeInd", undefined, undefined, 9);
903
+
904
+ parsedCb(new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, 192, Buffer.from([9])));
905
+
906
+ const object = await waiter.start().promise;
907
+ expect(object.payload).toStrictEqual({state: 9});
908
+ });
909
+
910
+ it("znp waitFor with payload mismatch", async () => {
911
+ let parsedCb;
912
+ mockUnpiParserOn.mockImplementationOnce((event, cb) => {
913
+ if (event === "parsed") {
914
+ parsedCb = cb;
915
+ }
916
+ });
917
+
918
+ await znp.open();
919
+ requestSpy.mockRestore();
920
+
921
+ const waiter = znp.waitFor(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, "osalNvRead", "abcd").start();
922
+
923
+ parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x00, 0x02, 0x01, 0x02])));
924
+
925
+ vi.advanceTimersByTime(11000);
926
+ await expect(waiter.promise).rejects.toThrow("SRSP - SYS - osalNvRead after 10000ms");
927
+ });
928
+
929
+ it("znp requestWithReply should throw error when request as no reply", async () => {
930
+ await znp.open();
931
+
932
+ try {
933
+ await znp.requestWithReply(UnpiConstants.Subsystem.ZDO, "autoFindDestination", {});
934
+ fail("Should throw error");
935
+ } catch (error) {
936
+ expect(error).toStrictEqual(new Error("Command autoFindDestination has no reply"));
937
+ }
938
+ });
939
+
940
+ it("ZpiObject throw error on missing write parser", async () => {
941
+ // @ts-ignore; make sure we always get a new instance
942
+ const obj = new ZpiObject(0, 0, "dummy", 0, {}, [{name: "nonExisting", parameterType: 9999999}]);
943
+ expect(() => {
944
+ obj.createPayloadBuffer();
945
+ }).toThrow();
946
+ });
947
+
948
+ it("ZpiObject throw error on unknown command", async () => {
949
+ const frame = new UnpiFrame(UnpiConstants.Type.SREQ, UnpiConstants.Subsystem.AF, 99999, Buffer.alloc(0));
950
+ expect(() => {
951
+ ZpiObject.fromUnpiFrame(frame);
952
+ }).toThrow();
953
+ });
954
+
955
+ it("ZpiObject throw error on unknown parameters", async () => {
956
+ const frame = new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.AF, 128, Buffer.alloc(0));
957
+ expect(() => {
958
+ ZpiObject.fromUnpiFrame(frame);
959
+ }).toThrow();
960
+ });
961
+
962
+ it("ZpiObject with cmd and non sapi is not reset command", () => {
963
+ // @ts-ignore; make sure we always get a new instance
964
+ const obj = new ZpiObject(UnpiConstants.Type.SREQ, UnpiConstants.Subsystem.AF, "systemReset", 0, {}, []);
965
+ expect(obj.isResetCommand()).toBeFalsy();
966
+ });
967
+
968
+ it("ZpiObject parse payload for endDeviceAnnceInd", () => {
969
+ const buffer = Buffer.from([0, 0, 0, 1, 1, 2, 3, 4, 5, 6, 7, 8, 5]);
970
+ const frame = new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, 193, buffer);
971
+ const obj = ZpiObject.fromUnpiFrame(frame);
972
+ expect(obj.payload.zdo).toStrictEqual([
973
+ Zdo.Status.SUCCESS,
974
+ {
975
+ capabilities: {
976
+ allocateAddress: 0,
977
+ alternatePANCoordinator: 1,
978
+ deviceType: 0,
979
+ powerSource: 1,
980
+ reserved1: 0,
981
+ reserved2: 0,
982
+ rxOnWhenIdle: 0,
983
+ securityCapability: 0,
984
+ },
985
+ eui64: "0x0807060504030201",
986
+ nwkAddress: 256,
987
+ },
988
+ ]);
989
+ });
990
+
991
+ it("ZpiObject parse payload for nwkAddrRsp", () => {
992
+ const buffer = Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x01, 0x01, 0x00, 0x02, 0x10, 0x10, 0x11, 0x11]);
993
+ const frame = new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, 128, buffer);
994
+ const obj = ZpiObject.fromUnpiFrame(frame);
995
+ expect(obj.payload.zdo).toStrictEqual([
996
+ Zdo.Status.SUCCESS,
997
+ {
998
+ assocDevList: [4112, 4369],
999
+ eui64: "0x0807060504030201",
1000
+ // numassocdev: 2,
1001
+ nwkAddress: 257,
1002
+ startIndex: 0,
1003
+ },
1004
+ ]);
1005
+ });
1006
+
1007
+ it("Cant read unsupported type", () => {
1008
+ expect(() => {
1009
+ const buffalo = new BuffaloZnp(Buffer.alloc(0));
1010
+ // @ts-expect-error invalid typing
1011
+ buffalo.read(9999, {});
1012
+ }).toThrow(new Error("Read for '9999' not available"));
1013
+ });
1014
+
1015
+ it("UINT8 write", () => {
1016
+ const buffalo = new BuffaloZnp(Buffer.alloc(3), 1);
1017
+ buffalo.write(ParameterType.UINT8, 240, {});
1018
+ expect(buffalo.getPosition()).toEqual(2);
1019
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, 0xf0, 0x00]));
1020
+ });
1021
+
1022
+ it("UINT8 read", () => {
1023
+ const buffalo = new BuffaloZnp(Buffer.from([0x00, 0x03, 0x00, 0x00]), 1);
1024
+ const value = buffalo.read(ParameterType.UINT8, {});
1025
+ expect(buffalo.getPosition()).toEqual(2);
1026
+ expect(value).toStrictEqual(3);
1027
+ });
1028
+
1029
+ it("INT8 write", () => {
1030
+ const buffalo = new BuffaloZnp(Buffer.alloc(3), 1);
1031
+ buffalo.write(ParameterType.INT8, 127, {});
1032
+ expect(buffalo.getPosition()).toEqual(2);
1033
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, 0x7f, 0x00]));
1034
+ });
1035
+
1036
+ it("INT8 read", () => {
1037
+ const buffalo = new BuffaloZnp(Buffer.from([0x00, 0xf0, 0x00, 0x00]), 1);
1038
+ const value = buffalo.read(ParameterType.INT8, {});
1039
+ expect(buffalo.getPosition()).toEqual(2);
1040
+ expect(value).toStrictEqual(-16);
1041
+ });
1042
+
1043
+ it("UINT16 write", () => {
1044
+ const buffalo = new BuffaloZnp(Buffer.alloc(3), 1);
1045
+ buffalo.write(ParameterType.UINT16, 1020, {});
1046
+ expect(buffalo.getPosition()).toEqual(3);
1047
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, 0xfc, 0x03]));
1048
+ });
1049
+
1050
+ it("UINT16 read", () => {
1051
+ const buffalo = new BuffaloZnp(Buffer.from([0x00, 0x03, 0xff, 0x00]), 1);
1052
+ const value = buffalo.read(ParameterType.UINT16, {});
1053
+ expect(buffalo.getPosition()).toEqual(3);
1054
+ expect(value).toStrictEqual(65283);
1055
+ });
1056
+
1057
+ it("UINT32 write", () => {
1058
+ const buffalo = new BuffaloZnp(Buffer.alloc(6), 2);
1059
+ buffalo.write(ParameterType.UINT32, 1065283, {});
1060
+ expect(buffalo.getPosition()).toEqual(6);
1061
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, 0x00, 0x43, 0x41, 0x10, 0x00]));
1062
+ });
1063
+
1064
+ it("UINT32 read", () => {
1065
+ const buffalo = new BuffaloZnp(Buffer.from([0x01, 0x03, 0xff, 0xff]));
1066
+ const value = buffalo.read(ParameterType.UINT32, {});
1067
+ expect(buffalo.getPosition()).toEqual(4);
1068
+ expect(value).toStrictEqual(4294902529);
1069
+ });
1070
+
1071
+ it("LIST_UINT8 write", () => {
1072
+ const buffalo = new BuffaloZnp(Buffer.alloc(4), 1);
1073
+ const payload = [200, 100];
1074
+ buffalo.write(ParameterType.LIST_UINT8, payload, {});
1075
+ expect(buffalo.getPosition()).toStrictEqual(3);
1076
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, 0xc8, 0x64, 0x00]));
1077
+ });
1078
+
1079
+ it("LIST_UINT8 read", () => {
1080
+ const buffalo = new BuffaloZnp(Buffer.from([0x00, 0x00, 0x04, 0x08]), 2);
1081
+ const value = buffalo.read(ParameterType.LIST_UINT8, {length: 2});
1082
+ expect(buffalo.getPosition()).toStrictEqual(4);
1083
+ expect(value).toStrictEqual([4, 8]);
1084
+ });
1085
+
1086
+ it("LIST_UINT16 write", () => {
1087
+ const buffalo = new BuffaloZnp(Buffer.alloc(5), 1);
1088
+ const payload = [1024, 2048];
1089
+ buffalo.write(ParameterType.LIST_UINT16, payload, {});
1090
+ expect(buffalo.getPosition()).toStrictEqual(5);
1091
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, 0x00, 0x04, 0x00, 0x08]));
1092
+ });
1093
+
1094
+ it("LIST_UINT16 read", () => {
1095
+ const buffalo = new BuffaloZnp(Buffer.from([0x00, 0x00, 0x04, 0x00, 0x08]), 1);
1096
+ const value = buffalo.read(ParameterType.LIST_UINT16, {length: 2});
1097
+ expect(buffalo.getPosition()).toStrictEqual(5);
1098
+ expect(value).toStrictEqual([1024, 2048]);
1099
+ });
1100
+
1101
+ it("LIST_NETWORK write", () => {
1102
+ expect(() => {
1103
+ const buffalo = new BuffaloZnp(Buffer.alloc(10));
1104
+ buffalo.write(ParameterType.LIST_NETWORK, [], {});
1105
+ }).toThrow();
1106
+ });
1107
+
1108
+ it("LIST_NETWORK read", () => {
1109
+ const buffer = Buffer.from([0x05, 0x10, 0x10, 0x09, 0x31, 0x13, 0x01, 0x10, 0x10, 0x09, 0x31, 0x13, 0x00, 0x01]);
1110
+
1111
+ const buffalo = new BuffaloZnp(buffer, 1);
1112
+ const value = buffalo.read(ParameterType.LIST_NETWORK, {length: 2});
1113
+ expect(buffalo.getPosition()).toStrictEqual(13);
1114
+ expect(value).toStrictEqual([
1115
+ {
1116
+ beaconOrder: 3,
1117
+ logicalChannel: 9,
1118
+ neightborPanId: 4112,
1119
+ permitJoin: 1,
1120
+ stackProfile: 1,
1121
+ superFrameOrder: 1,
1122
+ zigbeeVersion: 3,
1123
+ },
1124
+ {
1125
+ beaconOrder: 3,
1126
+ logicalChannel: 9,
1127
+ neightborPanId: 4112,
1128
+ permitJoin: 0,
1129
+ stackProfile: 1,
1130
+ superFrameOrder: 1,
1131
+ zigbeeVersion: 3,
1132
+ },
1133
+ ]);
1134
+ });
1135
+
1136
+ it("BUFFER8 write", () => {
1137
+ const buffalo = new BuffaloZnp(Buffer.alloc(9), 1);
1138
+ const payload = Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07]);
1139
+ buffalo.write(ParameterType.BUFFER8, payload, {});
1140
+ expect(buffalo.getPosition()).toStrictEqual(9);
1141
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, ...payload]));
1142
+ });
1143
+
1144
+ it("BUFFER8 write length consistent", () => {
1145
+ const buffalo = new BuffaloZnp(Buffer.alloc(9));
1146
+ const payload = Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08]);
1147
+ expect(() => {
1148
+ buffalo.write(ParameterType.BUFFER8, payload, {});
1149
+ }).toThrow();
1150
+ });
1151
+
1152
+ it("BUFFER8 read", () => {
1153
+ const buffer = Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09]);
1154
+ const buffalo = new BuffaloZnp(buffer, 2);
1155
+ const value = buffalo.read(ParameterType.BUFFER8, {});
1156
+ expect(buffalo.getPosition()).toEqual(10);
1157
+ expect(value).toStrictEqual(buffer.subarray(2, 11));
1158
+ });
1159
+
1160
+ it("BUFFER16 write", () => {
1161
+ const buffalo = new BuffaloZnp(Buffer.alloc(20), 1);
1162
+ const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07];
1163
+ buffalo.write(ParameterType.BUFFER16, Buffer.from([...payload, ...payload]), {});
1164
+ expect(buffalo.getPosition()).toStrictEqual(17);
1165
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, ...payload, ...payload, 0x00, 0x00, 0x00]));
1166
+ });
1167
+
1168
+ it("BUFFER16 read", () => {
1169
+ const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07];
1170
+ const buffalo = new BuffaloZnp(Buffer.from([0x00, ...payload, ...payload]), 1);
1171
+ const value = buffalo.read(ParameterType.BUFFER16, {});
1172
+ expect(buffalo.getPosition()).toEqual(17);
1173
+ expect(value).toStrictEqual(Buffer.from([...payload, ...payload]));
1174
+ });
1175
+
1176
+ it("BUFFER18 write", () => {
1177
+ const buffalo = new BuffaloZnp(Buffer.alloc(20), 1);
1178
+ const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08];
1179
+ buffalo.write(ParameterType.BUFFER18, Buffer.from([...payload, ...payload]), {});
1180
+ expect(buffalo.getPosition()).toStrictEqual(19);
1181
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, ...payload, ...payload, 0x00]));
1182
+ });
1183
+
1184
+ it("BUFFER18 read", () => {
1185
+ const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08];
1186
+ const buffalo = new BuffaloZnp(Buffer.from([0x00, ...payload, ...payload]), 1);
1187
+ const value = buffalo.read(ParameterType.BUFFER18, {});
1188
+ expect(buffalo.getPosition()).toStrictEqual(19);
1189
+ expect(value).toStrictEqual(Buffer.from([...payload, ...payload]));
1190
+ });
1191
+
1192
+ it("BUFFER32 write", () => {
1193
+ const buffalo = new BuffaloZnp(Buffer.alloc(34), 1);
1194
+ const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07];
1195
+ buffalo.write(ParameterType.BUFFER32, Buffer.from([...payload, ...payload, ...payload, ...payload]), {});
1196
+ expect(buffalo.getPosition()).toStrictEqual(33);
1197
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, ...payload, ...payload, ...payload, ...payload, 0x00]));
1198
+ });
1199
+
1200
+ it("BUFFER32 read", () => {
1201
+ const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07];
1202
+ const buffalo = new BuffaloZnp(Buffer.from([0x00, ...payload, ...payload, ...payload, ...payload]), 1);
1203
+ const value = buffalo.read(ParameterType.BUFFER32, {});
1204
+ expect(buffalo.getPosition()).toStrictEqual(33);
1205
+ expect(value).toStrictEqual(Buffer.from([...payload, ...payload, ...payload, ...payload]));
1206
+ });
1207
+
1208
+ it("BUFFER42 write", () => {
1209
+ const buffalo = new BuffaloZnp(Buffer.alloc(44), 1);
1210
+ const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07];
1211
+ buffalo.write(ParameterType.BUFFER42, Buffer.from([...payload, ...payload, ...payload, ...payload, ...payload, 0x01, 0xff]), {});
1212
+ expect(buffalo.getPosition()).toStrictEqual(43);
1213
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, ...payload, ...payload, ...payload, ...payload, ...payload, 0x01, 0xff, 0x00]));
1214
+ });
1215
+
1216
+ it("BUFFER42 read", () => {
1217
+ const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07];
1218
+ const buffalo = new BuffaloZnp(Buffer.from([0x00, ...payload, ...payload, ...payload, ...payload, ...payload, 0x08, 0x09]), 1);
1219
+ const value = buffalo.read(ParameterType.BUFFER42, {});
1220
+ expect(buffalo.getPosition()).toStrictEqual(43);
1221
+ expect(value).toStrictEqual(Buffer.from([...payload, ...payload, ...payload, ...payload, ...payload, 0x08, 0x09]));
1222
+ });
1223
+
1224
+ it("BUFFER100 write", () => {
1225
+ const buffalo = new BuffaloZnp(Buffer.alloc(100), 0);
1226
+ const payload = duplicateArray(20, [0x00, 0x01, 0x02, 0x03, 0x04]);
1227
+ buffalo.write(ParameterType.BUFFER100, Buffer.from(payload), {});
1228
+ expect(buffalo.getPosition()).toStrictEqual(100);
1229
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from(payload));
1230
+ });
1231
+
1232
+ it("BUFFER100 read", () => {
1233
+ const payload = duplicateArray(20, [0x00, 0x01, 0x02, 0x03, 0x04]);
1234
+ const buffalo = new BuffaloZnp(Buffer.from([0x00, ...payload]), 1);
1235
+ const value = buffalo.read(ParameterType.BUFFER100, {});
1236
+ expect(buffalo.getPosition()).toStrictEqual(101);
1237
+ expect(value).toStrictEqual(Buffer.from(payload));
1238
+ });
1239
+
1240
+ it("BUFFER write", () => {
1241
+ const buffalo = new BuffaloZnp(Buffer.alloc(9), 1);
1242
+ const payload = Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07]);
1243
+ buffalo.write(ParameterType.BUFFER, payload, {});
1244
+ expect(buffalo.getPosition()).toStrictEqual(9);
1245
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, ...payload]));
1246
+ });
1247
+
1248
+ it("BUFFER read", () => {
1249
+ const buffer = Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09]);
1250
+ const buffalo = new BuffaloZnp(buffer, 2);
1251
+ const value = buffalo.read(ParameterType.BUFFER, {length: 1});
1252
+ expect(buffalo.getPosition()).toEqual(3);
1253
+ expect(value).toStrictEqual(buffer.subarray(2, 3));
1254
+ });
1255
+
1256
+ it("IEEEADDR write", () => {
1257
+ const buffalo = new BuffaloZnp(Buffer.alloc(8));
1258
+ buffalo.write(ParameterType.IEEEADDR, ieeeaAddr1.string, {});
1259
+ expect(buffalo.getPosition()).toEqual(8);
1260
+ expect(buffalo.getBuffer()).toStrictEqual(Buffer.from(ieeeaAddr1.hex));
1261
+ });
1262
+
1263
+ it("IEEEADDR read", () => {
1264
+ const buffalo = new BuffaloZnp(Buffer.from(ieeeaAddr2.hex));
1265
+ const value = buffalo.read(ParameterType.IEEEADDR, {});
1266
+ expect(buffalo.getPosition()).toEqual(8);
1267
+ expect(value).toStrictEqual(ieeeaAddr2.string);
1268
+ });
1269
+
1270
+ it.each([ParameterType.BUFFER, ParameterType.LIST_UINT8, ParameterType.LIST_UINT16, ParameterType.LIST_NETWORK])(
1271
+ "Throws when read is missing required length option - param %s",
1272
+ (type) => {
1273
+ expect(() => {
1274
+ const buffalo = new BuffaloZnp(Buffer.alloc(1));
1275
+ buffalo.read(type, {});
1276
+ }).toThrow(`Cannot read ${ParameterType[type]} without length option specified`);
1277
+ },
1278
+ );
1279
+
1280
+ it("Coverage logger", async () => {
1281
+ consoleLogger.warning(() => "Test warning", "TestNS");
1282
+ consoleLogger.error(() => "Test error", "TestNS");
1283
+ });
1284
+ });