@willieee802/zigbee-herdsman 0.48.3 → 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 +1 -1
  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,1520 @@
1
+ /**
2
+ * Script: Update cluster.ts with data from ZCL XML files.
3
+ *
4
+ * Goals:
5
+ * - Parse XML cluster definition files (Basic.xml, Time.xml, ElectricalMeasurement.xml, etc.)
6
+ * - Respect XSD-described structure (cluster.xsd, type.xsd)
7
+ * - Map <type:type> definitions (with inheritsFrom chains) to base ZCL primitive types
8
+ * - Merge new attributes/commands into existing cluster definitions in src/zspec/zcl/definition/cluster.ts
9
+ * - Do NOT overwrite existing attributes (comparison by numeric ID)
10
+ * - Do NOT overwrite existing command parameters at existing indices (only append missing tail params)
11
+ * - Add missing commands (decide placement: commands vs commandsResponse)
12
+ * - Preserve existing formatting of cluster.ts as much as possible
13
+ *
14
+ * Requirements:
15
+ * pnpm i xml2js @types/xml2js
16
+ *
17
+ * Usage:
18
+ * tsx scripts/zap-update-clusters.ts ../zap/zcl-builtin/dotdot
19
+ */
20
+
21
+ import {promises as fs} from "node:fs";
22
+ import path from "node:path";
23
+ import process from "node:process";
24
+ import ts from "typescript";
25
+ import {parseStringPromise} from "xml2js";
26
+ // biome-ignore lint/correctness/noUnusedImports: reference names (not executed in script context, but helps validation if compiled in-project)
27
+ import {BuffaloZclDataType, DataType} from "../src/zspec/zcl/definition/enums.js";
28
+ import {fuzzyMatch} from "./utils.js";
29
+ import {applyXmlOverrides, parseOverrides} from "./zap-xml-clusters-overrides.js";
30
+ import type {
31
+ XMLAttributeDefinition,
32
+ XMLCluster,
33
+ XMLClusterSide,
34
+ XMLCommandDefinition,
35
+ XMLFieldDefinition,
36
+ XMLRoot,
37
+ XMLTypeType,
38
+ } from "./zap-xml-types.js";
39
+
40
+ // #region Type Definitions
41
+
42
+ interface ParsedXMLClusterData {
43
+ id: number;
44
+ name: string;
45
+ attributes: ParsedXMLAttribute[];
46
+ serverCommands: ParsedXMLCommand[];
47
+ clientCommands: ParsedXMLCommand[];
48
+ }
49
+
50
+ interface ParsedXMLAttribute {
51
+ id: number;
52
+ name: string;
53
+ dataTypeExpr: string;
54
+ meta?: XMLAttributeDefinition;
55
+ client?: boolean;
56
+ }
57
+
58
+ interface ParsedXMLCommand {
59
+ id: number;
60
+ name: string;
61
+ isResponse: boolean;
62
+ parameters: ParsedXMLCommandParameter[];
63
+ meta?: XMLCommandDefinition;
64
+ client?: boolean;
65
+ }
66
+
67
+ interface ParsedXMLCommandParameter {
68
+ name: string;
69
+ dataTypeExpr: string;
70
+ meta?: XMLFieldDefinition;
71
+ isLength?: boolean;
72
+ }
73
+
74
+ interface ValidationRecord {
75
+ warnings: string[];
76
+ errors: string[];
77
+ unknownTypes: Set<string>;
78
+ addedAttributes: string[];
79
+ addedCommands: string[];
80
+ addedParameters: string[];
81
+ scannedClusters: string[];
82
+ changedClusters: string[];
83
+ xmlClustersMissingFromTs: Map<string, string>;
84
+ tsClustersMissingFromXml: string[];
85
+ }
86
+
87
+ // #endregion
88
+
89
+ // #region Helpers
90
+
91
+ function parseAttributeOrCommandId(hexId: string): number {
92
+ const clean = hexId.trim().toLowerCase();
93
+
94
+ return Number.parseInt(clean, 16);
95
+ }
96
+
97
+ function normalizeAttributeOrCommandName(name: string): string {
98
+ if (!name) {
99
+ return name;
100
+ }
101
+
102
+ const first = name[0].toLowerCase();
103
+
104
+ return `${first}${name.slice(1)}`.replace(/[^A-Za-z0-9]/g, "");
105
+ }
106
+
107
+ function findBestFuzzyAttrMatch(
108
+ refName: string,
109
+ candidates: ParsedXMLAttribute[],
110
+ existingTsNames: Map<number, string>,
111
+ factory: ts.NodeFactory,
112
+ ): ts.StringLiteral | undefined {
113
+ if (candidates.length === 0) {
114
+ return undefined;
115
+ }
116
+
117
+ let bestMatch: {score: number; attribute: ParsedXMLAttribute | undefined} = {score: -1, attribute: undefined};
118
+ const normalizedRefName = normalizeAttributeOrCommandName(refName);
119
+
120
+ for (const candidate of candidates) {
121
+ const score = fuzzyMatch(normalizedRefName, candidate.name);
122
+
123
+ if (score > bestMatch.score) {
124
+ bestMatch = {score, attribute: candidate};
125
+ }
126
+ }
127
+
128
+ if (bestMatch.attribute && bestMatch.score > 0.7) {
129
+ // If a match is found, check if it has a corresponding name in the existing TS file.
130
+ // If so, use that name. Otherwise, fall back to the normalized XML name.
131
+ const tsName = existingTsNames.get(bestMatch.attribute.id);
132
+ const finalName = tsName || bestMatch.attribute.name;
133
+
134
+ return factory.createStringLiteral(finalName);
135
+ }
136
+
137
+ return undefined;
138
+ }
139
+
140
+ function findBestFuzzyParamMatch(
141
+ refName: string,
142
+ candidates: ParsedXMLCommandParameter[],
143
+ existingTsParamNames: Map<string, string>,
144
+ factory: ts.NodeFactory,
145
+ ): ts.StringLiteral | undefined {
146
+ if (candidates.length === 0) {
147
+ return undefined;
148
+ }
149
+
150
+ let bestMatch: {score: number; parameter: ParsedXMLCommandParameter | undefined} = {score: -1, parameter: undefined};
151
+ const normalizedRefName = normalizeAttributeOrCommandName(refName);
152
+
153
+ for (const candidate of candidates) {
154
+ const score = fuzzyMatch(normalizedRefName, candidate.name);
155
+
156
+ if (score > bestMatch.score) {
157
+ bestMatch = {score, parameter: candidate};
158
+ }
159
+ }
160
+
161
+ if (bestMatch.parameter && bestMatch.score > 0.7) {
162
+ // If a match is found, check if it has a corresponding name in the existing TS file.
163
+ // If so, use that name. Otherwise, fall back to the normalized XML name.
164
+ const tsName = existingTsParamNames.get(bestMatch.parameter.name);
165
+ const finalName = tsName || bestMatch.parameter.name;
166
+
167
+ return factory.createStringLiteral(finalName);
168
+ }
169
+
170
+ return undefined;
171
+ }
172
+
173
+ // #endregion
174
+
175
+ // #region XML processing
176
+
177
+ async function collectFromLibrary(libraryFile: string): Promise<{includeFiles: string[]; libraryTypes: XMLTypeType[]}> {
178
+ const txt = await fs.readFile(libraryFile, "utf8");
179
+
180
+ const parsed = (await parseStringPromise(txt, {
181
+ explicitArray: true,
182
+ preserveChildrenOrder: true,
183
+ mergeAttrs: false,
184
+ explicitRoot: true,
185
+ })) as XMLRoot;
186
+
187
+ const includeFiles: string[] = [];
188
+ const libraryTypes: XMLTypeType[] = [];
189
+ const libs = parsed["zcl:library"];
190
+
191
+ if (libs) {
192
+ const libsArray = Array.isArray(libs) ? libs : [libs];
193
+
194
+ for (const lib of libsArray) {
195
+ if (lib["type:type"]) {
196
+ for (const t of lib["type:type"]) {
197
+ libraryTypes.push(t);
198
+ }
199
+ }
200
+
201
+ if (lib["xi:include"]) {
202
+ const baseDir = path.dirname(libraryFile);
203
+
204
+ for (const inc of lib["xi:include"]) {
205
+ const parse = inc.$.parse;
206
+ const href = inc.$.href;
207
+
208
+ if (parse === "xml" && href.toLowerCase().endsWith(".xml")) {
209
+ const full = path.resolve(baseDir, href);
210
+ includeFiles.push(full);
211
+ }
212
+ }
213
+ }
214
+ }
215
+ }
216
+
217
+ return {includeFiles, libraryTypes};
218
+ }
219
+
220
+ async function parseXMLClusters(file: string): Promise<XMLCluster[]> {
221
+ const text = await fs.readFile(file, "utf8");
222
+
223
+ const parsed = (await parseStringPromise(text, {
224
+ explicitArray: true,
225
+ preserveChildrenOrder: true,
226
+ mergeAttrs: false,
227
+ explicitRoot: true,
228
+ })) as XMLRoot;
229
+
230
+ const clusters: XMLCluster[] = [];
231
+ const baseClusters = parsed["zcl:cluster"];
232
+ // const derivedClusters = parsed["zcl:derivedCluster"];
233
+
234
+ if (baseClusters) {
235
+ if (Array.isArray(baseClusters)) {
236
+ clusters.push(...baseClusters);
237
+ } else {
238
+ clusters.push(baseClusters);
239
+ }
240
+ }
241
+
242
+ // if (derivedClusters) {
243
+ // if (Array.isArray(derivedClusters)) {
244
+ // clusters.push(...derivedClusters);
245
+ // } else {
246
+ // clusters.push(derivedClusters);
247
+ // }
248
+ // }
249
+
250
+ return clusters;
251
+ }
252
+
253
+ function processClusterSide(
254
+ side: XMLClusterSide | undefined,
255
+ isClient: boolean,
256
+ resolver: TypeResolver,
257
+ validation: ValidationRecord,
258
+ ): {attributes: ParsedXMLAttribute[]; commands: ParsedXMLCommand[]} {
259
+ const attributes: ParsedXMLAttribute[] = [];
260
+ const commands: ParsedXMLCommand[] = [];
261
+
262
+ if (!side) {
263
+ return {attributes, commands};
264
+ }
265
+
266
+ if (side.attributes && side.attributes.length > 0) {
267
+ const attrs = side.attributes[0].attribute;
268
+
269
+ if (attrs) {
270
+ for (const a of attrs) {
271
+ if (!a?.$?.id) {
272
+ continue;
273
+ }
274
+
275
+ const attrId = parseAttributeOrCommandId(a.$.id);
276
+ const attrTypeShortRaw = a.$.type.trim().toLowerCase();
277
+ const baseShort = resolver.resolve(attrTypeShortRaw);
278
+ const mappedDataType = mapZclTypeToDataType(baseShort);
279
+
280
+ if (mappedDataType === "DataType.UNKNOWN" && attrTypeShortRaw !== "unk") {
281
+ validation.unknownTypes.add(attrTypeShortRaw);
282
+ }
283
+
284
+ const attrName = normalizeAttributeOrCommandName(a.$.name);
285
+ const attribute: ParsedXMLAttribute = {id: attrId, name: attrName, dataTypeExpr: mappedDataType, meta: a};
286
+
287
+ if (isClient) {
288
+ attribute.client = true;
289
+ }
290
+
291
+ attributes.push(attribute);
292
+ }
293
+ }
294
+ }
295
+
296
+ if (side.commands && side.commands.length > 0) {
297
+ const cmds = side.commands[0].command;
298
+
299
+ if (cmds) {
300
+ for (const cmd of cmds) {
301
+ if (!cmd?.$?.id) {
302
+ continue;
303
+ }
304
+
305
+ const cmdId = parseAttributeOrCommandId(cmd.$.id);
306
+ const cmdNameRaw = cmd.$.name;
307
+ const cmdName = normalizeAttributeOrCommandName(cmdNameRaw);
308
+ const parameters: ParsedXMLCommandParameter[] = [];
309
+
310
+ if (cmd.fields && cmd.fields.length > 0) {
311
+ const fields = cmd.fields[0].field;
312
+
313
+ if (fields) {
314
+ for (const [paramIndex, fld] of fields.entries()) {
315
+ const paramName = normalizeAttributeOrCommandName(fld.$.name);
316
+ const typeShortRaw = fld.$.type.trim().toLowerCase();
317
+ const baseShort = resolver.resolve(typeShortRaw);
318
+ let mapped = mapZclTypeToDataType(baseShort);
319
+ const arrayFlag = fld.$.array === "true";
320
+
321
+ if (mapped === "DataType.UNKNOWN" && typeShortRaw !== "unk") {
322
+ validation.unknownTypes.add(typeShortRaw);
323
+ }
324
+
325
+ if (arrayFlag && !fld.$.arrayLengthSize && !fld.$.arrayLengthField) {
326
+ // This field represents an array with an implicit count.
327
+ // Create the count parameter.
328
+ parameters.push({
329
+ name: `${paramName}Count`,
330
+ dataTypeExpr: "DataType.UINT8", // The implicit count is usually UINT8
331
+ meta: fld, // Carry over meta for context, but it's for the count
332
+ isLength: true,
333
+ });
334
+
335
+ // Now, create the actual array parameter.
336
+ mapped = mapToBuffaloZclDataType(mapped);
337
+
338
+ parameters.push({
339
+ name: paramName,
340
+ dataTypeExpr: mapped,
341
+ meta: fld,
342
+ });
343
+ } else {
344
+ // Original logic for non-arrays or arrays with explicit length fields.
345
+ if (arrayFlag) {
346
+ mapped = mapToBuffaloZclDataType(mapped);
347
+ }
348
+
349
+ parameters.push({
350
+ name: paramName || `param${paramIndex}`,
351
+ dataTypeExpr: mapped,
352
+ meta: fld,
353
+ });
354
+ }
355
+ }
356
+ }
357
+ }
358
+
359
+ const command: ParsedXMLCommand = {id: cmdId, name: cmdName, isResponse: isClient, parameters, meta: cmd};
360
+
361
+ if (isClient) {
362
+ command.client = true;
363
+ }
364
+
365
+ commands.push(command);
366
+ }
367
+ }
368
+ }
369
+
370
+ return {attributes, commands};
371
+ }
372
+
373
+ function parseClustersFromXML(list: XMLCluster[], globalResolver: TypeResolver, validation: ValidationRecord): ParsedXMLClusterData[] {
374
+ const out: ParsedXMLClusterData[] = [];
375
+
376
+ for (const cluster of list) {
377
+ const idHex = cluster.$.id;
378
+
379
+ if (!idHex) {
380
+ continue;
381
+ }
382
+
383
+ // Create a new resolver for this specific cluster, with the global resolver as its parent.
384
+ const clusterResolver = new TypeResolver(globalResolver);
385
+
386
+ // Add only this cluster's local types to it.
387
+ clusterResolver.add(cluster["type:type"]);
388
+
389
+ const idNum = parseAttributeOrCommandId(idHex);
390
+ const idHexStr = `0x${idNum.toString(16).padStart(4, "0")}`;
391
+ const name = cluster.$.name;
392
+
393
+ validation.scannedClusters.push(`${idHexStr} ${name}`);
394
+ validation.xmlClustersMissingFromTs.set(idHexStr, `${idHexStr} ${name}`);
395
+
396
+ // Process the cluster using its own scoped resolver.
397
+ const serverData = processClusterSide(cluster.server?.[0], false, clusterResolver, validation);
398
+ const clientData = processClusterSide(cluster.client?.[0], true, clusterResolver, validation);
399
+
400
+ out.push({
401
+ id: idNum,
402
+ name,
403
+ attributes: [...serverData.attributes, ...clientData.attributes],
404
+ serverCommands: serverData.commands,
405
+ clientCommands: clientData.commands,
406
+ });
407
+ }
408
+
409
+ return out;
410
+ }
411
+
412
+ // #endregion
413
+
414
+ // #region Mapping types
415
+
416
+ class TypeResolver {
417
+ #map: Map<string, string | undefined /* inheritsFrom */>;
418
+ #parent?: TypeResolver;
419
+
420
+ constructor(parent?: TypeResolver) {
421
+ this.#map = new Map();
422
+ this.#parent = parent;
423
+ }
424
+
425
+ add(types: XMLTypeType[] | undefined): void {
426
+ if (!types) {
427
+ return;
428
+ }
429
+
430
+ for (const t of types) {
431
+ const short = t.$.short.trim().toLowerCase();
432
+ const inheritsFrom = t.$.inheritsFrom ? t.$.inheritsFrom.trim().toLowerCase() : undefined;
433
+
434
+ if (!this.#map.has(short)) {
435
+ this.#map.set(short, inheritsFrom);
436
+ }
437
+ }
438
+ }
439
+
440
+ resolve(short: string): string {
441
+ if (this.#map.has(short)) {
442
+ return this.#map.get(short) ?? short;
443
+ }
444
+
445
+ return this.#parent?.resolve(short) ?? "unk";
446
+ }
447
+ }
448
+
449
+ function mapZclTypeToDataType(base: string): string {
450
+ const t = base.toLowerCase();
451
+
452
+ if (t === "data8") return "DataType.DATA8";
453
+ if (t === "data16") return "DataType.DATA16";
454
+ if (t === "data24") return "DataType.DATA24";
455
+ if (t === "data32") return "DataType.DATA32";
456
+ if (t === "data40") return "DataType.DATA40";
457
+ if (t === "data48") return "DataType.DATA48";
458
+ if (t === "data56") return "DataType.DATA56";
459
+ if (t === "data64") return "DataType.DATA64";
460
+
461
+ if (t === "bool") return "DataType.BOOLEAN";
462
+
463
+ if (t === "map8") return "DataType.BITMAP8";
464
+ if (t === "map16") return "DataType.BITMAP16";
465
+ if (t === "map24") return "DataType.BITMAP24";
466
+ if (t === "map32") return "DataType.BITMAP32";
467
+ if (t === "map40") return "DataType.BITMAP40";
468
+ if (t === "map48") return "DataType.BITMAP48";
469
+ if (t === "map56") return "DataType.BITMAP56";
470
+ if (t === "map64") return "DataType.BITMAP64";
471
+
472
+ if (t === "uint8") return "DataType.UINT8";
473
+ if (t === "uint16") return "DataType.UINT16";
474
+ if (t === "uint24") return "DataType.UINT24";
475
+ if (t === "uint32") return "DataType.UINT32";
476
+ if (t === "uint40") return "DataType.UINT40";
477
+ if (t === "uint48") return "DataType.UINT48";
478
+ if (t === "uint56") return "DataType.UINT56";
479
+ if (t === "uint64") return "DataType.UINT64";
480
+
481
+ if (t === "int8") return "DataType.INT8";
482
+ if (t === "int16") return "DataType.INT16";
483
+ if (t === "int24") return "DataType.INT24";
484
+ if (t === "int32") return "DataType.INT32";
485
+ if (t === "int40") return "DataType.INT40";
486
+ if (t === "int48") return "DataType.INT48";
487
+ if (t === "int56") return "DataType.INT56";
488
+ if (t === "int64") return "DataType.INT64";
489
+
490
+ if (t === "enum8") return "DataType.ENUM8";
491
+ if (t === "enum16") return "DataType.ENUM16";
492
+
493
+ if (t === "semi") return "DataType.SEMI_PREC";
494
+ if (t === "single") return "DataType.SINGLE_PREC";
495
+ if (t === "double") return "DataType.DOUBLE_PREC";
496
+
497
+ if (t === "octstr") return "DataType.OCTET_STR";
498
+ if (t === "string") return "DataType.CHAR_STR";
499
+ if (t === "octstr16") return "DataType.LONG_OCTET_STR";
500
+ if (t === "string16") return "DataType.LONG_CHAR_STR";
501
+
502
+ if (t === "array") return "DataType.ARRAY";
503
+ if (t === "struct") return "DataType.STRUCT";
504
+
505
+ if (t === "set") return "DataType.SET";
506
+ if (t === "bag") return "DataType.BAG";
507
+
508
+ if (t === "tod") return "DataType.TOD";
509
+ if (t === "date") return "DataType.DATE";
510
+ if (t === "utc") return "DataType.UTC";
511
+
512
+ if (t === "clusterid") return "DataType.CLUSTER_ID";
513
+ if (t === "attribid") return "DataType.ATTR_ID";
514
+ if (t === "bacoid") return "DataType.BAC_OID";
515
+
516
+ if (t === "eui64") return "DataType.IEEE_ADDR";
517
+ if (t === "key128") return "DataType.SEC_KEY";
518
+
519
+ if (t === "unk") return "DataType.UNKNOWN";
520
+ if (t === "zcltype") return "DataType.ZCLTYPE";
521
+ if (t === "attributereportingstatus") return "DataType.ENUM8";
522
+ if (t === "zclstatus") return "DataType.ENUM8";
523
+ if (t === "profileintervalperiod") return "DataType.ENUM8";
524
+ if (t === "iaszonetype") return "DataType.ENUM16";
525
+ if (t === "iaszonestatus") return "DataType.BITMAP16";
526
+
527
+ if (t === "sextensionfieldsetlist") return "BuffaloZclDataType.EXTENSION_FIELD_SETS";
528
+ if (t === "transitiontype") return "BuffaloZclDataType.LIST_THERMO_TRANSITIONS";
529
+ if (t === "iasacezonestatusrecord") return "BuffaloZclDataType.LIST_ZONEINFO";
530
+
531
+ return "DataType.UNKNOWN";
532
+ }
533
+
534
+ function isNumericDataType(dataTypeExpr: string): boolean {
535
+ switch (dataTypeExpr) {
536
+ case "DataType.DATA8":
537
+ case "DataType.DATA16":
538
+ case "DataType.DATA24":
539
+ case "DataType.DATA32":
540
+ case "DataType.DATA40":
541
+ case "DataType.DATA48":
542
+ case "DataType.DATA56":
543
+ case "DataType.DATA64":
544
+ case "DataType.BOOLEAN":
545
+ case "DataType.BITMAP8":
546
+ case "DataType.BITMAP16":
547
+ case "DataType.BITMAP24":
548
+ case "DataType.BITMAP32":
549
+ case "DataType.BITMAP40":
550
+ case "DataType.BITMAP48":
551
+ case "DataType.BITMAP56":
552
+ case "DataType.BITMAP64":
553
+ case "DataType.UINT8":
554
+ case "DataType.UINT16":
555
+ case "DataType.UINT24":
556
+ case "DataType.UINT32":
557
+ case "DataType.UINT40":
558
+ case "DataType.UINT48":
559
+ case "DataType.UINT56":
560
+ case "DataType.UINT64":
561
+ case "DataType.INT8":
562
+ case "DataType.INT16":
563
+ case "DataType.INT24":
564
+ case "DataType.INT32":
565
+ case "DataType.INT40":
566
+ case "DataType.INT48":
567
+ case "DataType.INT56":
568
+ case "DataType.INT64":
569
+ case "DataType.ENUM8":
570
+ case "DataType.ENUM16":
571
+ case "DataType.SEMI_PREC":
572
+ case "DataType.SINGLE_PREC":
573
+ case "DataType.DOUBLE_PREC":
574
+ case "DataType.CLUSTER_ID":
575
+ case "DataType.ATTR_ID":
576
+ case "DataType.BAC_OID":
577
+ case "DataType.UTC":
578
+ return true;
579
+ default:
580
+ return false;
581
+ }
582
+ }
583
+
584
+ function mapToBuffaloZclDataType(base: string): string {
585
+ if (base === "DataType.UINT8") return "BuffaloZclDataType.LIST_UINT8";
586
+ if (base === "DataType.UINT16") return "BuffaloZclDataType.LIST_UINT16";
587
+ if (base === "DataType.UINT24") return "BuffaloZclDataType.LIST_UINT24";
588
+ if (base === "DataType.UINT32") return "BuffaloZclDataType.LIST_UINT32";
589
+ if (base.startsWith("DataType")) return "BuffaloZclDataType.BUFFER";
590
+
591
+ return base;
592
+ }
593
+
594
+ // #endregion
595
+
596
+ // #region AST Transformer
597
+
598
+ const findProperty = (obj: ts.ObjectLiteralExpression, name: string): ts.PropertyAssignment | undefined => {
599
+ for (const p of obj.properties) {
600
+ if (ts.isPropertyAssignment(p) && ts.isIdentifier(p.name) && p.name.text === name) {
601
+ return p;
602
+ }
603
+ }
604
+
605
+ return undefined;
606
+ };
607
+
608
+ const extractNumericId = (node: ts.Node): number | undefined => {
609
+ if (!ts.isPropertyAssignment(node)) {
610
+ return undefined;
611
+ }
612
+
613
+ if (!ts.isObjectLiteralExpression(node.initializer)) {
614
+ return undefined;
615
+ }
616
+
617
+ const idProp = findProperty(node.initializer, "ID");
618
+
619
+ if (!idProp) {
620
+ return undefined;
621
+ }
622
+
623
+ const initializer = idProp.initializer;
624
+
625
+ if (ts.isNumericLiteral(initializer)) {
626
+ const text = initializer.text;
627
+
628
+ return text.startsWith("0x") ? Number.parseInt(text, 16) : Number(text);
629
+ }
630
+
631
+ if (ts.isPrefixUnaryExpression(initializer) && ts.isNumericLiteral(initializer.operand)) {
632
+ const text = initializer.operand.text;
633
+ const num = text.startsWith("0x") ? Number.parseInt(text, 16) : Number(text);
634
+
635
+ return -num;
636
+ }
637
+
638
+ return undefined;
639
+ };
640
+
641
+ function createSafeNumericLiteral(value: string | number, factory: ts.NodeFactory): ts.Expression {
642
+ const num = Number(value);
643
+
644
+ if (Number.isNaN(num)) {
645
+ // Fallback for invalid numbers, though this case should be rare.
646
+ return factory.createNumericLiteral(0);
647
+ }
648
+
649
+ if (num < 0) {
650
+ return factory.createPrefixUnaryExpression(ts.SyntaxKind.MinusToken, factory.createNumericLiteral(Math.abs(num)));
651
+ }
652
+
653
+ return factory.createNumericLiteral(num);
654
+ }
655
+
656
+ function getExistingTsAttributeNames(attributesProp: ts.PropertyAssignment | undefined): Map<number, string> {
657
+ const existingTsNames = new Map<number, string>();
658
+
659
+ if (!attributesProp || !ts.isObjectLiteralExpression(attributesProp.initializer)) {
660
+ return existingTsNames;
661
+ }
662
+
663
+ for (const attr of attributesProp.initializer.properties) {
664
+ if (ts.isPropertyAssignment(attr)) {
665
+ const id = extractNumericId(attr);
666
+
667
+ if (id !== undefined && ts.isIdentifier(attr.name) && !existingTsNames.has(id)) {
668
+ existingTsNames.set(id, attr.name.text);
669
+ }
670
+ }
671
+ }
672
+
673
+ return existingTsNames;
674
+ }
675
+
676
+ function createUpdateTransformer(
677
+ xmlClusterData: Map<number, ParsedXMLClusterData>,
678
+ validation: ValidationRecord,
679
+ ): ts.TransformerFactory<ts.SourceFile> {
680
+ return (context) => {
681
+ const factory = context.factory;
682
+
683
+ const visitor: ts.Visitor = (node) => {
684
+ if (
685
+ ts.isVariableDeclaration(node) &&
686
+ ts.isIdentifier(node.name) &&
687
+ node.name.text === "Clusters" &&
688
+ node.initializer &&
689
+ ts.isObjectLiteralExpression(node.initializer)
690
+ ) {
691
+ const tsClusterIds = new Set<number>();
692
+ const newClusterProps: ts.ObjectLiteralElementLike[] = [];
693
+
694
+ for (const prop of node.initializer.properties) {
695
+ if (!ts.isPropertyAssignment(prop) || !ts.isObjectLiteralExpression(prop.initializer)) {
696
+ newClusterProps.push(prop);
697
+
698
+ continue;
699
+ }
700
+
701
+ const clusterId = extractNumericId(prop);
702
+
703
+ if (clusterId !== undefined) {
704
+ tsClusterIds.add(clusterId);
705
+ } else {
706
+ newClusterProps.push(prop);
707
+
708
+ continue;
709
+ }
710
+
711
+ const xmlCluster = xmlClusterData.get(clusterId);
712
+
713
+ if (!xmlCluster) {
714
+ newClusterProps.push(prop);
715
+
716
+ continue;
717
+ }
718
+
719
+ const clusterIdHexStr = `0x${clusterId.toString(16).padStart(4, "0")}`;
720
+
721
+ validation.xmlClustersMissingFromTs.delete(clusterIdHexStr); // Found it
722
+
723
+ let changed = false;
724
+ const newSubProps: ts.ObjectLiteralElementLike[] = [];
725
+ const subPropsMap = new Map<string, ts.PropertyAssignment>();
726
+
727
+ for (const subProp of prop.initializer.properties) {
728
+ if (ts.isPropertyAssignment(subProp) && ts.isIdentifier(subProp.name)) {
729
+ subPropsMap.set(subProp.name.text, subProp);
730
+ }
731
+ }
732
+
733
+ const attributesProp = subPropsMap.get("attributes");
734
+ const existingTsAttributeNames = getExistingTsAttributeNames(attributesProp);
735
+
736
+ for (const subProp of prop.initializer.properties) {
737
+ if (!ts.isPropertyAssignment(subProp) || !ts.isIdentifier(subProp.name)) {
738
+ newSubProps.push(subProp);
739
+
740
+ continue;
741
+ }
742
+
743
+ if (!ts.isObjectLiteralExpression(subProp.initializer)) {
744
+ newSubProps.push(subProp);
745
+
746
+ continue;
747
+ }
748
+
749
+ const subPropName = subProp.name.text;
750
+ let updatedProp: ts.PropertyAssignment | undefined;
751
+
752
+ if (subPropName === "attributes") {
753
+ updatedProp = updateAttributes(subProp, xmlCluster.attributes, factory, validation);
754
+ } else if (subPropName === "commands") {
755
+ updatedProp = updateCommands(
756
+ subProp,
757
+ xmlCluster.serverCommands,
758
+ xmlCluster.attributes,
759
+ existingTsAttributeNames,
760
+ false,
761
+ factory,
762
+ validation,
763
+ );
764
+ } else if (subPropName === "commandsResponse") {
765
+ updatedProp = updateCommands(
766
+ subProp,
767
+ xmlCluster.clientCommands,
768
+ xmlCluster.attributes,
769
+ existingTsAttributeNames,
770
+ true,
771
+ factory,
772
+ validation,
773
+ );
774
+ }
775
+
776
+ if (updatedProp && updatedProp !== subProp) {
777
+ changed = true;
778
+
779
+ newSubProps.push(updatedProp);
780
+ } else {
781
+ newSubProps.push(subProp);
782
+ }
783
+ }
784
+
785
+ if (changed) {
786
+ validation.changedClusters.push(`${clusterIdHexStr} ${xmlCluster.name}`);
787
+ const updatedInitializer = factory.updateObjectLiteralExpression(prop.initializer, newSubProps);
788
+ const updatedProperty = factory.updatePropertyAssignment(prop, prop.name, updatedInitializer);
789
+
790
+ newClusterProps.push(updatedProperty);
791
+ } else {
792
+ newClusterProps.push(prop);
793
+ }
794
+ }
795
+
796
+ // Populate clusters present in TS but not in XML
797
+ for (const id of tsClusterIds) {
798
+ if (!xmlClusterData.has(id) && id <= 0x7fff /* std cluster */) {
799
+ validation.tsClustersMissingFromXml.push(`0x${id.toString(16).padStart(4, "0")}`);
800
+ }
801
+ }
802
+
803
+ const updatedInitializer = factory.updateObjectLiteralExpression(node.initializer, newClusterProps);
804
+
805
+ return factory.updateVariableDeclaration(node, node.name, node.exclamationToken, node.type, updatedInitializer);
806
+ }
807
+
808
+ return ts.visitEachChild(node, visitor, context);
809
+ };
810
+
811
+ return (sourceFile) => ts.visitNode(sourceFile, visitor) as ts.SourceFile;
812
+ };
813
+ }
814
+
815
+ function createHexIdTransformer(): ts.TransformerFactory<ts.SourceFile> {
816
+ return (context) => {
817
+ const factory = context.factory;
818
+ const visitor: ts.Visitor = (node) => {
819
+ if (ts.isPropertyAssignment(node) && ts.isIdentifier(node.name) && node.name.text === "ID" && ts.isNumericLiteral(node.initializer)) {
820
+ const num = Number(node.initializer.text);
821
+
822
+ if (!Number.isNaN(num) && !node.initializer.text.startsWith("0x")) {
823
+ let pad = 4; // Default to 4 for clusters and attributes
824
+ let current: ts.Node = node.parent;
825
+
826
+ // Traverse up to find if the ID is inside a `commands` or `commandsResponse` block.
827
+ while (current?.parent) {
828
+ if (ts.isPropertyAssignment(current.parent) && ts.isIdentifier(current.parent.name)) {
829
+ const parentName = current.parent.name.text;
830
+
831
+ if (parentName === "commands" || parentName === "commandsResponse") {
832
+ pad = 2;
833
+ break;
834
+ }
835
+ }
836
+
837
+ current = current.parent;
838
+ }
839
+
840
+ const hex = `0x${num.toString(16).padStart(pad, "0")}`;
841
+
842
+ return factory.updatePropertyAssignment(node, node.name, factory.createNumericLiteral(hex));
843
+ }
844
+ }
845
+
846
+ return ts.visitEachChild(node, visitor, context);
847
+ };
848
+
849
+ return (sourceFile) => ts.visitNode(sourceFile, visitor) as ts.SourceFile;
850
+ };
851
+ }
852
+
853
+ function updateAttributes(
854
+ attributesProp: ts.PropertyAssignment,
855
+ xmlAttributes: ParsedXMLAttribute[],
856
+ factory: ts.NodeFactory,
857
+ validation: ValidationRecord,
858
+ ): ts.PropertyAssignment {
859
+ const initializer = attributesProp.initializer as ts.ObjectLiteralExpression;
860
+ const existingTsAttributes = new Map<number, ts.PropertyAssignment[]>();
861
+ const existingTsNames = new Map<number, string>();
862
+
863
+ for (const attr of initializer.properties) {
864
+ if (ts.isPropertyAssignment(attr)) {
865
+ const id = extractNumericId(attr);
866
+
867
+ if (id !== undefined) {
868
+ if (!existingTsAttributes.has(id)) {
869
+ existingTsAttributes.set(id, []);
870
+ }
871
+
872
+ // biome-ignore lint/style/noNonNullAssertion: set above if not exist
873
+ existingTsAttributes.get(id)!.push(attr);
874
+
875
+ if (ts.isIdentifier(attr.name) && !existingTsNames.has(id)) {
876
+ existingTsNames.set(id, attr.name.text);
877
+ }
878
+ }
879
+ }
880
+ }
881
+
882
+ const finalAttributes: ts.PropertyAssignment[] = [];
883
+ const processedTsNodes = new Set<ts.PropertyAssignment>();
884
+
885
+ for (const xmlAttr of xmlAttributes) {
886
+ const existingNodesWithId = existingTsAttributes.get(xmlAttr.id) || [];
887
+ let existingAttrNode: ts.PropertyAssignment | undefined;
888
+
889
+ for (const node of existingNodesWithId) {
890
+ const initializer = node.initializer as ts.ObjectLiteralExpression;
891
+ const manuCodeProp = findProperty(initializer, "manufacturerCode");
892
+
893
+ if (!manuCodeProp) {
894
+ existingAttrNode = node;
895
+
896
+ break;
897
+ }
898
+ }
899
+
900
+ const attributeName = existingAttrNode ? (existingAttrNode.name as ts.Identifier) : factory.createIdentifier(xmlAttr.name);
901
+ const existingProps =
902
+ existingAttrNode && ts.isObjectLiteralExpression(existingAttrNode.initializer) ? [...existingAttrNode.initializer.properties] : [];
903
+ const existingPropNames = new Set<string>();
904
+
905
+ for (const p of existingProps) {
906
+ if (p.name && ts.isIdentifier(p.name)) {
907
+ existingPropNames.add(p.name.text);
908
+ }
909
+ }
910
+
911
+ const propsToAdd: ts.PropertyAssignment[] = [];
912
+
913
+ // Unified logic to build required properties
914
+ if (xmlAttr.meta) {
915
+ const meta = xmlAttr.meta.$;
916
+
917
+ if (xmlAttr.client && !existingPropNames.has("client")) {
918
+ propsToAdd.push(factory.createPropertyAssignment("client", factory.createTrue()));
919
+ }
920
+
921
+ if (meta.readable === "false" && !existingPropNames.has("read")) {
922
+ propsToAdd.push(factory.createPropertyAssignment("read", factory.createFalse()));
923
+ }
924
+
925
+ if (meta.writable === "true" && !existingPropNames.has("write")) {
926
+ propsToAdd.push(factory.createPropertyAssignment("write", factory.createTrue()));
927
+ }
928
+
929
+ if (meta.writeOptional === "true" && !existingPropNames.has("writeOptional")) {
930
+ propsToAdd.push(factory.createPropertyAssignment("writeOptional", factory.createTrue()));
931
+ }
932
+
933
+ if (meta.reportRequired === "true" && !existingPropNames.has("report")) {
934
+ propsToAdd.push(factory.createPropertyAssignment("report", factory.createTrue()));
935
+ }
936
+
937
+ if (meta.sceneRequired === "true" && !existingPropNames.has("scene")) {
938
+ propsToAdd.push(factory.createPropertyAssignment("scene", factory.createTrue()));
939
+ }
940
+
941
+ if (meta.required === "true" && !existingPropNames.has("required")) {
942
+ propsToAdd.push(factory.createPropertyAssignment("required", factory.createTrue()));
943
+ }
944
+
945
+ if (meta.min && !existingPropNames.has("min")) {
946
+ // skip when too long for number format (not especially useful anyway for these types)
947
+ if (xmlAttr.dataTypeExpr !== "DataType.IEEE_ADDR" && xmlAttr.dataTypeExpr !== "DataType.SEC_KEY") {
948
+ propsToAdd.push(factory.createPropertyAssignment("min", createSafeNumericLiteral(meta.min, factory)));
949
+ }
950
+ }
951
+
952
+ if (meta.max && !existingPropNames.has("max")) {
953
+ // skip when too long for number format (not especially useful anyway for these types)
954
+ if (xmlAttr.dataTypeExpr !== "DataType.IEEE_ADDR" && xmlAttr.dataTypeExpr !== "DataType.SEC_KEY") {
955
+ propsToAdd.push(factory.createPropertyAssignment("max", createSafeNumericLiteral(meta.max, factory)));
956
+ }
957
+ }
958
+
959
+ if (meta.default != null && !existingPropNames.has("default")) {
960
+ if (isNumericDataType(xmlAttr.dataTypeExpr)) {
961
+ propsToAdd.push(factory.createPropertyAssignment("default", createSafeNumericLiteral(meta.default, factory)));
962
+ } else {
963
+ propsToAdd.push(factory.createPropertyAssignment("default", factory.createStringLiteral(meta.default)));
964
+ }
965
+ }
966
+
967
+ if (meta.defaultRef && !existingPropNames.has("defaultRef")) {
968
+ const otherAttributes = xmlAttributes.filter((a) => a.id !== xmlAttr.id);
969
+ const matched = findBestFuzzyAttrMatch(meta.defaultRef, otherAttributes, existingTsNames, factory);
970
+
971
+ if (!matched) {
972
+ console.log(`\x1b[31mCould not find match for attribute ${meta.defaultRef}.\x1b[0m`);
973
+ }
974
+
975
+ propsToAdd.push(
976
+ factory.createPropertyAssignment(
977
+ "defaultRef",
978
+ matched ?? factory.createStringLiteral(normalizeAttributeOrCommandName(meta.defaultRef)),
979
+ ),
980
+ );
981
+ }
982
+ }
983
+
984
+ if (xmlAttr.meta?.restriction?.[0]) {
985
+ const restriction = xmlAttr.meta.restriction[0];
986
+ const otherAttributes = xmlAttributes.filter((a) => a.id !== xmlAttr.id);
987
+ const restrictionFacets: {name: string; value: string | {name: string; value: string}[] | undefined; isRef?: boolean}[] = [
988
+ {name: "length", value: restriction["type:length"]?.[0]?.$?.value},
989
+ {name: "minLen", value: restriction["type:minLength"]?.[0]?.$?.value},
990
+ {name: "maxLen", value: restriction["type:maxLength"]?.[0]?.$?.value},
991
+ {name: "minExcl", value: restriction["type:minExclusive"]?.[0]?.$?.value},
992
+ {name: "min", value: restriction["type:minInclusive"]?.[0]?.$?.value},
993
+ {name: "maxExcl", value: restriction["type:maxExclusive"]?.[0]?.$?.value},
994
+ {name: "max", value: restriction["type:maxInclusive"]?.[0]?.$?.value},
995
+ {name: "minRef", value: restriction["type:minInclusiveRef"]?.[0]?.$?.ref, isRef: true},
996
+ {name: "minExclRef", value: restriction["type:minExclusiveRef"]?.[0]?.$?.ref, isRef: true},
997
+ {name: "maxRef", value: restriction["type:maxInclusiveRef"]?.[0]?.$?.ref, isRef: true},
998
+ {name: "maxExclRef", value: restriction["type:maxExclusiveRef"]?.[0]?.$?.ref, isRef: true},
999
+ {name: "special", value: restriction["type:special"]?.map((s) => s.$)},
1000
+ ];
1001
+
1002
+ for (const facet of restrictionFacets) {
1003
+ if (facet.value && !existingPropNames.has(facet.name)) {
1004
+ if (facet.name === "special" && Array.isArray(facet.value)) {
1005
+ const specialArray = factory.createArrayLiteralExpression(
1006
+ facet.value.map((s) =>
1007
+ factory.createArrayLiteralExpression([factory.createStringLiteral(s.name), factory.createStringLiteral(s.value)]),
1008
+ ),
1009
+ true,
1010
+ );
1011
+
1012
+ propsToAdd.push(factory.createPropertyAssignment(facet.name, specialArray));
1013
+ } else if (typeof facet.value === "string") {
1014
+ if (facet.isRef) {
1015
+ const matched = findBestFuzzyAttrMatch(facet.value, otherAttributes, existingTsNames, factory);
1016
+
1017
+ if (!matched) {
1018
+ console.log(`\x1b[31mCould not find match for attribute ${facet.value}.\x1b[0m`);
1019
+ }
1020
+
1021
+ propsToAdd.push(
1022
+ factory.createPropertyAssignment(
1023
+ facet.name,
1024
+ matched ?? factory.createStringLiteral(normalizeAttributeOrCommandName(facet.value)),
1025
+ ),
1026
+ );
1027
+ } else {
1028
+ if (facet.name === "minLength" && facet.value === "0") {
1029
+ continue;
1030
+ }
1031
+
1032
+ propsToAdd.push(factory.createPropertyAssignment(facet.name, createSafeNumericLiteral(facet.value, factory)));
1033
+ }
1034
+ }
1035
+ }
1036
+ }
1037
+ }
1038
+
1039
+ let finalNode: ts.PropertyAssignment;
1040
+
1041
+ if (existingAttrNode) {
1042
+ processedTsNodes.add(existingAttrNode);
1043
+ const finalProps = [...existingProps, ...propsToAdd];
1044
+ const finalInitializer = factory.updateObjectLiteralExpression(existingAttrNode.initializer as ts.ObjectLiteralExpression, finalProps);
1045
+ finalNode = factory.updatePropertyAssignment(existingAttrNode, attributeName, finalInitializer);
1046
+ } else {
1047
+ validation.addedAttributes.push(`0x${xmlAttr.id.toString(16).padStart(4, "0")} ${xmlAttr.name}`);
1048
+ const typeIdentifierParts = xmlAttr.dataTypeExpr.split(".");
1049
+ const typeIdentifier =
1050
+ typeIdentifierParts.length > 1
1051
+ ? factory.createPropertyAccessExpression(factory.createIdentifier(typeIdentifierParts[0]), typeIdentifierParts[1])
1052
+ : factory.createIdentifier(xmlAttr.dataTypeExpr);
1053
+ const finalProps = [
1054
+ factory.createPropertyAssignment("ID", factory.createNumericLiteral(String(xmlAttr.id))),
1055
+ factory.createPropertyAssignment("type", typeIdentifier),
1056
+ ...propsToAdd,
1057
+ ];
1058
+ const finalInitializer = factory.createObjectLiteralExpression(finalProps, true);
1059
+ finalNode = factory.createPropertyAssignment(attributeName, finalInitializer);
1060
+ }
1061
+
1062
+ finalAttributes.push(finalNode);
1063
+ }
1064
+
1065
+ // Add back any TS-only attributes that were not processed
1066
+ for (const nodes of existingTsAttributes.values()) {
1067
+ for (const node of nodes) {
1068
+ if (!processedTsNodes.has(node)) {
1069
+ finalAttributes.push(node);
1070
+ }
1071
+ }
1072
+ }
1073
+
1074
+ finalAttributes.sort((a, b) => {
1075
+ const idA = extractNumericId(a) ?? -1;
1076
+ const idB = extractNumericId(b) ?? -1;
1077
+
1078
+ if (idA !== idB) {
1079
+ return idA - idB;
1080
+ }
1081
+
1082
+ // If IDs are the same, check for manufacturerCode to sort standard attributes first
1083
+ const initA = a.initializer as ts.ObjectLiteralExpression;
1084
+ const initB = b.initializer as ts.ObjectLiteralExpression;
1085
+ const hasManuA = findProperty(initA, "manufacturerCode") !== undefined;
1086
+ const hasManuB = findProperty(initB, "manufacturerCode") !== undefined;
1087
+
1088
+ if (hasManuA && !hasManuB) {
1089
+ return 1;
1090
+ }
1091
+
1092
+ if (!hasManuA && hasManuB) {
1093
+ return -1;
1094
+ }
1095
+
1096
+ return 0;
1097
+ });
1098
+
1099
+ const updatedInitializer = factory.updateObjectLiteralExpression(initializer, finalAttributes);
1100
+
1101
+ return factory.updatePropertyAssignment(attributesProp, attributesProp.name, updatedInitializer);
1102
+ }
1103
+
1104
+ function updateCommands(
1105
+ commandsProp: ts.PropertyAssignment,
1106
+ xmlCommands: ParsedXMLCommand[],
1107
+ xmlAttributes: ParsedXMLAttribute[],
1108
+ existingTsAttributeNames: Map<number, string>,
1109
+ isResponse: boolean,
1110
+ factory: ts.NodeFactory,
1111
+ validation: ValidationRecord,
1112
+ ): ts.PropertyAssignment {
1113
+ const initializer = commandsProp.initializer as ts.ObjectLiteralExpression;
1114
+ const existingCommandIds = new Map<number, ts.PropertyAssignment[]>();
1115
+
1116
+ for (const cmd of initializer.properties) {
1117
+ if (ts.isPropertyAssignment(cmd)) {
1118
+ const id = extractNumericId(cmd);
1119
+
1120
+ if (id !== undefined) {
1121
+ if (!existingCommandIds.has(id)) {
1122
+ existingCommandIds.set(id, []);
1123
+ }
1124
+
1125
+ // biome-ignore lint/style/noNonNullAssertion: set above if not exist
1126
+ existingCommandIds.get(id)!.push(cmd);
1127
+ }
1128
+ }
1129
+ }
1130
+
1131
+ const finalCommands: ts.PropertyAssignment[] = [];
1132
+ const xmlCommandsForScope: ParsedXMLCommand[] = [];
1133
+
1134
+ for (const cmd of xmlCommands) {
1135
+ if (cmd.isResponse === isResponse) {
1136
+ xmlCommandsForScope.push(cmd);
1137
+ }
1138
+ }
1139
+
1140
+ const processedTsNodes = new Set<ts.PropertyAssignment>();
1141
+
1142
+ for (const xmlCmd of xmlCommandsForScope) {
1143
+ const existingCmdNodes = existingCommandIds.get(xmlCmd.id);
1144
+ let existingCmdNode: ts.PropertyAssignment | undefined;
1145
+
1146
+ if (existingCmdNodes) {
1147
+ if (existingCmdNodes.length === 1) {
1148
+ existingCmdNode = existingCmdNodes[0];
1149
+ } else if (existingCmdNodes.length > 1) {
1150
+ let bestMatch: {score: number; node: ts.PropertyAssignment | undefined} = {score: -1, node: undefined};
1151
+
1152
+ for (const node of existingCmdNodes) {
1153
+ const nodeName = ts.isIdentifier(node.name) ? node.name.text : "";
1154
+ const score = fuzzyMatch(xmlCmd.name, nodeName);
1155
+
1156
+ if (score > bestMatch.score) {
1157
+ bestMatch = {score, node};
1158
+ }
1159
+ }
1160
+
1161
+ existingCmdNode = bestMatch.node;
1162
+ }
1163
+ }
1164
+
1165
+ const commandName = existingCmdNode ? existingCmdNode.name : factory.createIdentifier(xmlCmd.name);
1166
+ const existingCmdProps =
1167
+ existingCmdNode && ts.isObjectLiteralExpression(existingCmdNode.initializer) ? [...existingCmdNode.initializer.properties] : [];
1168
+ const existingCmdPropNames = new Set<string>();
1169
+
1170
+ for (const p of existingCmdProps) {
1171
+ if (p.name && ts.isIdentifier(p.name)) {
1172
+ existingCmdPropNames.add(p.name.text);
1173
+ }
1174
+ }
1175
+
1176
+ // --- Unified Parameter Logic ---
1177
+ const paramsProp = existingCmdNode ? findProperty(existingCmdNode.initializer as ts.ObjectLiteralExpression, "parameters") : undefined;
1178
+ const existingParamsArray: ts.ObjectLiteralExpression[] = [];
1179
+ const existingTsParamNames = new Map<string, string>(); // Map from normalized XML name to TS name
1180
+
1181
+ if (paramsProp && ts.isArrayLiteralExpression(paramsProp.initializer)) {
1182
+ for (const [i, el] of paramsProp.initializer.elements.entries()) {
1183
+ if (ts.isObjectLiteralExpression(el)) {
1184
+ existingParamsArray.push(el);
1185
+ const nameProp = findProperty(el, "name");
1186
+
1187
+ if (nameProp && ts.isStringLiteral(nameProp.initializer) && xmlCmd.parameters[i]) {
1188
+ existingTsParamNames.set(xmlCmd.parameters[i].name, nameProp.initializer.text);
1189
+ }
1190
+ }
1191
+ }
1192
+ }
1193
+
1194
+ const newParams: ts.ObjectLiteralExpression[] = [];
1195
+ const maxParams = Math.max(xmlCmd.parameters.length, existingParamsArray.length);
1196
+
1197
+ for (let i = 0; i < maxParams; i++) {
1198
+ const xmlParam = xmlCmd.parameters[i];
1199
+ const existingParamExpr = existingParamsArray[i];
1200
+
1201
+ if (!xmlParam && existingParamExpr) {
1202
+ newParams.push(existingParamExpr);
1203
+
1204
+ continue;
1205
+ }
1206
+
1207
+ if (!xmlParam) {
1208
+ continue;
1209
+ }
1210
+
1211
+ const existingParamProps = existingParamExpr ? [...existingParamExpr.properties] : [];
1212
+ const existingParamPropNames = new Set(existingParamProps.flatMap((p) => (p.name && ts.isIdentifier(p.name) ? [p.name.text] : [])));
1213
+ const paramPropsToAdd: ts.PropertyAssignment[] = [];
1214
+ const otherParams = xmlCmd.parameters.filter((_p, index) => index !== i);
1215
+
1216
+ // Add name/type if missing
1217
+ if (!existingParamPropNames.has("name")) {
1218
+ paramPropsToAdd.push(factory.createPropertyAssignment("name", factory.createStringLiteral(xmlParam.name)));
1219
+ }
1220
+
1221
+ if (!existingParamPropNames.has("type")) {
1222
+ const typeIdentifierParts = xmlParam.dataTypeExpr.split(".");
1223
+ const typeIdentifier =
1224
+ typeIdentifierParts.length > 1
1225
+ ? factory.createPropertyAccessExpression(factory.createIdentifier(typeIdentifierParts[0]), typeIdentifierParts[1])
1226
+ : factory.createIdentifier(xmlParam.dataTypeExpr);
1227
+
1228
+ paramPropsToAdd.push(factory.createPropertyAssignment("type", typeIdentifier));
1229
+ }
1230
+
1231
+ // Add metadata
1232
+ if (xmlParam.meta?.$.arrayLengthSize && !existingParamPropNames.has("arrayLengthSize")) {
1233
+ paramPropsToAdd.push(
1234
+ factory.createPropertyAssignment("arrayLengthSize", factory.createNumericLiteral(xmlParam.meta.$.arrayLengthSize)),
1235
+ );
1236
+ }
1237
+
1238
+ if (xmlParam.meta?.$.arrayLengthField && !existingParamPropNames.has("arrayLengthField")) {
1239
+ const matched = findBestFuzzyParamMatch(xmlParam.meta.$.arrayLengthField, otherParams, existingTsParamNames, factory);
1240
+
1241
+ if (!matched) {
1242
+ console.log(`\x1b[31mCould not find match for parameter ${xmlParam.meta.$.arrayLengthField}.\x1b[0m`);
1243
+ }
1244
+
1245
+ paramPropsToAdd.push(
1246
+ factory.createPropertyAssignment(
1247
+ "arrayLengthField",
1248
+ matched ?? factory.createStringLiteral(normalizeAttributeOrCommandName(xmlParam.meta.$.arrayLengthField)),
1249
+ ),
1250
+ );
1251
+ }
1252
+
1253
+ // Add all restrictions ("..Count" params don't have metas)
1254
+ if (xmlParam.meta?.restriction?.[0] && !xmlParam.isLength) {
1255
+ const restriction = xmlParam.meta.restriction[0];
1256
+ const restrictionFacets: {name: string; value: string | {name: string; value: string}[] | undefined; isRef?: boolean}[] = [
1257
+ {name: "length", value: restriction["type:length"]?.[0]?.$?.value},
1258
+ {name: "minLen", value: restriction["type:minLength"]?.[0]?.$?.value},
1259
+ {name: "maxLen", value: restriction["type:maxLength"]?.[0]?.$?.value},
1260
+ {name: "minExcl", value: restriction["type:minExclusive"]?.[0]?.$?.value},
1261
+ {name: "min", value: restriction["type:minInclusive"]?.[0]?.$?.value},
1262
+ {name: "maxExcl", value: restriction["type:maxExclusive"]?.[0]?.$?.value},
1263
+ {name: "max", value: restriction["type:maxInclusive"]?.[0]?.$?.value},
1264
+ {name: "minRef", value: restriction["type:minInclusiveRef"]?.[0]?.$?.ref, isRef: true},
1265
+ {name: "minExclRef", value: restriction["type:minExclusiveRef"]?.[0]?.$?.ref, isRef: true},
1266
+ {name: "maxRef", value: restriction["type:maxInclusiveRef"]?.[0]?.$?.ref, isRef: true},
1267
+ {name: "maxExclRef", value: restriction["type:maxExclusiveRef"]?.[0]?.$?.ref, isRef: true},
1268
+ {name: "special", value: restriction["type:special"]?.map((s) => s.$)},
1269
+ ];
1270
+
1271
+ for (const facet of restrictionFacets) {
1272
+ if (facet.value && !existingParamPropNames.has(facet.name)) {
1273
+ if (facet.name === "special" && Array.isArray(facet.value)) {
1274
+ const specialArray = factory.createArrayLiteralExpression(
1275
+ facet.value.map((s) =>
1276
+ factory.createArrayLiteralExpression([factory.createStringLiteral(s.name), factory.createStringLiteral(s.value)]),
1277
+ ),
1278
+ true,
1279
+ );
1280
+ paramPropsToAdd.push(factory.createPropertyAssignment(facet.name, specialArray));
1281
+ } else if (typeof facet.value === "string") {
1282
+ if (facet.isRef) {
1283
+ let matched = findBestFuzzyAttrMatch(facet.value, xmlAttributes, existingTsAttributeNames, factory);
1284
+
1285
+ if (!matched) {
1286
+ matched = findBestFuzzyParamMatch(facet.value, otherParams, existingTsParamNames, factory);
1287
+ }
1288
+
1289
+ if (!matched) {
1290
+ console.log(`\x1b[31mCould not find match for ref ${facet.value}.\x1b[0m`);
1291
+ }
1292
+
1293
+ paramPropsToAdd.push(
1294
+ factory.createPropertyAssignment(
1295
+ facet.name,
1296
+ matched ?? factory.createStringLiteral(normalizeAttributeOrCommandName(facet.value)),
1297
+ ),
1298
+ );
1299
+ } else {
1300
+ // a few entries are in hex form like "fd", this is obviously flawed, entries that are too complex should be overriden instead
1301
+ if (facet.value.match(/^[0-9]+$/)) {
1302
+ paramPropsToAdd.push(
1303
+ factory.createPropertyAssignment(facet.name, createSafeNumericLiteral(facet.value, factory)),
1304
+ );
1305
+ } else if (facet.value.match(/^[0-9a-fA-F]+$/)) {
1306
+ console.log(`\x1b[33mWriting ${JSON.stringify(facet)} as hex number\x1b[0m`);
1307
+ paramPropsToAdd.push(
1308
+ factory.createPropertyAssignment(facet.name, createSafeNumericLiteral(`0x${facet.value}`, factory)),
1309
+ );
1310
+ }
1311
+ }
1312
+ }
1313
+ }
1314
+ }
1315
+ }
1316
+
1317
+ if (existingParamExpr) {
1318
+ newParams.push(factory.updateObjectLiteralExpression(existingParamExpr, [...existingParamProps, ...paramPropsToAdd]));
1319
+ } else {
1320
+ validation.addedParameters.push(`0x${xmlCmd.id.toString(16).padStart(2, "0")} ${xmlCmd.name} > ${xmlParam.name}`);
1321
+ newParams.push(factory.createObjectLiteralExpression(paramPropsToAdd, true));
1322
+ }
1323
+ }
1324
+ // --- End Unified Parameter Logic ---
1325
+
1326
+ const cmdPropsToAdd: ts.PropertyAssignment[] = [];
1327
+
1328
+ cmdPropsToAdd.push(factory.createPropertyAssignment("parameters", factory.createArrayLiteralExpression(newParams, true)));
1329
+
1330
+ if (xmlCmd.meta?.$.required === "true" && !existingCmdPropNames.has("required")) {
1331
+ cmdPropsToAdd.push(factory.createPropertyAssignment("required", factory.createTrue()));
1332
+ }
1333
+
1334
+ let finalNode: ts.PropertyAssignment;
1335
+
1336
+ if (existingCmdNode) {
1337
+ processedTsNodes.add(existingCmdNode);
1338
+
1339
+ const finalProps = [...existingCmdProps];
1340
+
1341
+ for (const propToAdd of cmdPropsToAdd) {
1342
+ const propName = (propToAdd.name as ts.Identifier).text;
1343
+ const existingIndex = finalProps.findIndex((p) => ts.isPropertyAssignment(p) && ts.isIdentifier(p.name) && p.name.text === propName);
1344
+
1345
+ if (existingIndex !== -1) {
1346
+ finalProps[existingIndex] = propToAdd;
1347
+ } else {
1348
+ finalProps.push(propToAdd);
1349
+ }
1350
+ }
1351
+
1352
+ const finalInitializer = factory.updateObjectLiteralExpression(existingCmdNode.initializer as ts.ObjectLiteralExpression, finalProps);
1353
+ finalNode = factory.updatePropertyAssignment(existingCmdNode, commandName, finalInitializer);
1354
+ } else {
1355
+ const hexId = `0x${xmlCmd.id.toString(16).padStart(2, "0")}`;
1356
+
1357
+ validation.addedCommands.push(`${hexId} ${xmlCmd.name}`);
1358
+
1359
+ const finalProps = [factory.createPropertyAssignment("ID", factory.createNumericLiteral(hexId)), ...cmdPropsToAdd];
1360
+ const finalInitializer = factory.createObjectLiteralExpression(finalProps, true);
1361
+ finalNode = factory.createPropertyAssignment(commandName, finalInitializer);
1362
+ }
1363
+
1364
+ finalCommands.push(finalNode);
1365
+ }
1366
+
1367
+ // Add back any TS-only commands
1368
+ for (const tsOnlyCmds of existingCommandIds.values()) {
1369
+ for (const tsOnlyCmd of tsOnlyCmds) {
1370
+ if (!processedTsNodes.has(tsOnlyCmd)) {
1371
+ finalCommands.push(tsOnlyCmd);
1372
+ }
1373
+ }
1374
+ }
1375
+
1376
+ finalCommands.sort((a, b) => {
1377
+ const idA = extractNumericId(a) ?? -1;
1378
+ const idB = extractNumericId(b) ?? -1;
1379
+
1380
+ return idA - idB;
1381
+ });
1382
+
1383
+ const updatedInitializer = factory.updateObjectLiteralExpression(initializer, finalCommands);
1384
+
1385
+ return factory.updatePropertyAssignment(commandsProp, commandsProp.name, updatedInitializer);
1386
+ }
1387
+
1388
+ // #endregion
1389
+
1390
+ // #region Main
1391
+
1392
+ async function main(): Promise<void> {
1393
+ const args = process.argv.slice(2);
1394
+
1395
+ if (args.length !== 1) {
1396
+ throw new Error("Usage: tsx scripts/zap-update-clusters.ts <path-to-xml-files>");
1397
+ }
1398
+
1399
+ const xmlPath = args[0];
1400
+ const clusterFile = "src/zspec/zcl/definition/cluster.ts";
1401
+ const overridesFile = "scripts/zap-xml-clusters-overrides-data.ts";
1402
+ const validation: ValidationRecord = {
1403
+ warnings: [],
1404
+ errors: [],
1405
+ unknownTypes: new Set(),
1406
+ addedAttributes: [],
1407
+ addedCommands: [],
1408
+ addedParameters: [],
1409
+ scannedClusters: [],
1410
+ changedClusters: [],
1411
+ xmlClustersMissingFromTs: new Map(),
1412
+ tsClustersMissingFromXml: [],
1413
+ };
1414
+ const allXmlClusters: XMLCluster[] = [];
1415
+
1416
+ const globalResolver = new TypeResolver();
1417
+ const libraryPath = path.join(xmlPath, "library.xml");
1418
+
1419
+ try {
1420
+ // Collect all data and types first.
1421
+ const {includeFiles, libraryTypes} = await collectFromLibrary(libraryPath);
1422
+
1423
+ globalResolver.add(libraryTypes); // Populate the global resolver.
1424
+
1425
+ for (const f of includeFiles) {
1426
+ if (!f.toLowerCase().endsWith(".xml")) {
1427
+ continue;
1428
+ }
1429
+ try {
1430
+ const clusters = await parseXMLClusters(f);
1431
+ allXmlClusters.push(...clusters);
1432
+ } catch (e) {
1433
+ validation.errors.push(`Failed parsing XML ${f}: ${(e as Error).message}`);
1434
+ }
1435
+ }
1436
+ } catch (e) {
1437
+ throw new Error(`Unable to process library file at ${libraryPath}: ${(e as Error).message}`);
1438
+ }
1439
+
1440
+ const overridesFileContent = await fs.readFile(overridesFile, "utf8");
1441
+ const overridesSourceFile = ts.createSourceFile(overridesFile, overridesFileContent, ts.ScriptTarget.Latest, true);
1442
+ const overrides = parseOverrides(overridesSourceFile);
1443
+
1444
+ applyXmlOverrides(allXmlClusters, overrides);
1445
+
1446
+ // Pass the prepared globalResolver to the parsing function.
1447
+ const parsedData = parseClustersFromXML(allXmlClusters, globalResolver, validation);
1448
+ const xmlClusterDataMap = new Map<number, ParsedXMLClusterData>();
1449
+
1450
+ for (const d of parsedData) {
1451
+ const existing = xmlClusterDataMap.get(d.id);
1452
+
1453
+ if (existing) {
1454
+ // This is a derived cluster, merge its data with the base cluster.
1455
+ existing.attributes.push(...d.attributes);
1456
+ existing.serverCommands.push(...d.serverCommands);
1457
+ existing.clientCommands.push(...d.clientCommands);
1458
+ } else {
1459
+ xmlClusterDataMap.set(d.id, d);
1460
+ }
1461
+ }
1462
+
1463
+ const clusterFileContent = await fs.readFile(clusterFile, "utf8");
1464
+ const sourceFile = ts.createSourceFile(clusterFile, clusterFileContent, ts.ScriptTarget.Latest, true, ts.ScriptKind.TS);
1465
+ const updateTransformer = createUpdateTransformer(xmlClusterDataMap, validation);
1466
+ const hexTransformer = createHexIdTransformer();
1467
+ const result1 = ts.transform(sourceFile, [updateTransformer]);
1468
+ const updatedSourceFile = result1.transformed[0];
1469
+ const result3 = ts.transform(updatedSourceFile, [hexTransformer]);
1470
+ const finalSourceFile = result3.transformed[0];
1471
+ const printer = ts.createPrinter({newLine: ts.NewLineKind.LineFeed, removeComments: false});
1472
+ let newContent = printer.printFile(finalSourceFile);
1473
+ // help biome re-format
1474
+ newContent = newContent.replaceAll("{\n ID:", "{ID:");
1475
+ newContent = newContent.replaceAll("{\n name:", "{name:");
1476
+
1477
+ await fs.writeFile(clusterFile, newContent, "utf8");
1478
+
1479
+ console.log(
1480
+ `Successfully updated ${clusterFile}. Changes: ${validation.changedClusters} clusters, ${validation.addedAttributes} attributes, ${validation.addedCommands} commands, ${validation.addedParameters} parameters.`,
1481
+ );
1482
+
1483
+ if (validation.warnings.length > 0) {
1484
+ console.log("Warnings:");
1485
+
1486
+ for (const w of validation.warnings) {
1487
+ console.log(` - ${w}`);
1488
+ }
1489
+ }
1490
+
1491
+ if (validation.errors.length > 0) {
1492
+ console.log("Errors:");
1493
+
1494
+ for (const e of validation.errors) {
1495
+ console.log(` - ${e}`);
1496
+ }
1497
+ }
1498
+
1499
+ const report = {
1500
+ scannedClusters: validation.scannedClusters,
1501
+ changedClusters: validation.changedClusters,
1502
+ addedAttributes: validation.addedAttributes,
1503
+ addedCommands: validation.addedCommands,
1504
+ addedParameters: validation.addedParameters,
1505
+ unknownTypes: Array.from(validation.unknownTypes.values()),
1506
+ xmlClustersMissingFromTs: Array.from(validation.xmlClustersMissingFromTs.values()),
1507
+ tsClustersMissingFromXml: validation.tsClustersMissingFromXml,
1508
+ warnings: validation.warnings,
1509
+ errors: validation.errors,
1510
+ };
1511
+
1512
+ await fs.writeFile("scripts/zap-update-clusters-report.json", JSON.stringify(report, null, 2), "utf8");
1513
+ }
1514
+
1515
+ main().catch((err) => {
1516
+ console.error(err);
1517
+ process.exit(1);
1518
+ });
1519
+
1520
+ // #endregion