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