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