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