@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,587 +1,653 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- var __importDefault = (this && this.__importDefault) || function (mod) {
26
- return (mod && mod.__esModule) ? mod : { "default": mod };
27
- };
28
- Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.Ezsp = exports.EZSPZDOResponseFrameData = exports.EZSPZDORequestFrameData = exports.EZSPFrameData = void 0;
30
- /* istanbul ignore file */
31
- /* eslint-disable @typescript-eslint/explicit-module-boundary-types */
32
- const t = __importStar(require("./types"));
33
- const uart_1 = require("./uart");
34
- const commands_1 = require("./commands");
35
- const named_1 = require("./types/named");
36
- const events_1 = require("events");
37
- const utils_1 = require("../../../utils");
38
- const debug_1 = __importDefault(require("debug"));
39
- const debug = {
40
- error: (0, debug_1.default)('zigbee-herdsman:adapter:ezsp:erro'),
41
- log: (0, debug_1.default)('zigbee-herdsman:adapter:ezsp:ezsp'),
42
- };
43
- const MTOR_MIN_INTERVAL = 10;
44
- const MTOR_MAX_INTERVAL = 90;
45
- const MTOR_ROUTE_ERROR_THRESHOLD = 4;
46
- const MTOR_DELIVERY_FAIL_THRESHOLD = 3;
47
- const MAX_WATCHDOG_FAILURES = 4;
48
- //const RESET_ATTEMPT_BACKOFF_TIME = 5;
49
- const WATCHDOG_WAKE_PERIOD = 10; // in sec
50
- //const EZSP_COUNTER_CLEAR_INTERVAL = 180; // Clear counters every n * WATCHDOG_WAKE_PERIOD
51
- const EZSP_DEFAULT_RADIUS = 0;
52
- const EZSP_MULTICAST_NON_MEMBER_RADIUS = 3;
53
- class EZSPFrameData {
54
- static createFrame(ezspv, frame_id, isRequest, params) {
55
- const names = commands_1.FRAME_NAMES_BY_ID[frame_id];
56
- if (!names) {
57
- throw new Error(`Unrecognized frame FrameID ${frame_id}`);
58
- }
59
- let frm;
60
- names.every((frameName) => {
61
- const frameDesc = EZSPFrameData.getFrame(frameName);
62
- if ((frameDesc.maxV && frameDesc.maxV < ezspv) || (frameDesc.minV && frameDesc.minV > ezspv)) {
63
- return true;
64
- }
65
- try {
66
- frm = new EZSPFrameData(frameName, isRequest, params);
67
- }
68
- catch (error) {
69
- debug.error(`Frame ${frameName} parsing error: ${error.stack}`);
70
- return true;
71
- }
72
- return false;
73
- });
74
- return frm;
75
- }
76
- static getFrame(name) {
77
- const frameDesc = commands_1.FRAMES[name];
78
- if (!frameDesc)
79
- throw new Error(`Unrecognized frame from FrameID ${name}`);
80
- return frameDesc;
81
- }
82
- constructor(key, isRequest, params) {
83
- this._cls_ = key;
84
- this._id_ = commands_1.FRAMES[this._cls_].ID;
85
- this._isRequest_ = isRequest;
86
- const frame = EZSPFrameData.getFrame(key);
87
- const frameDesc = (this._isRequest_) ? frame.request || {} : frame.response || {};
88
- if (Buffer.isBuffer(params)) {
89
- let data = params;
90
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
91
- [this[prop], data] = frameDesc[prop].deserialize(frameDesc[prop], data);
92
- }
93
- }
94
- else {
95
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
96
- this[prop] = params[prop];
97
- }
98
- }
99
- }
100
- serialize() {
101
- const frame = EZSPFrameData.getFrame(this._cls_);
102
- const frameDesc = (this._isRequest_) ? frame.request || {} : frame.response || {};
103
- const result = [];
104
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
105
- result.push(frameDesc[prop].serialize(frameDesc[prop], this[prop]));
106
- }
107
- return Buffer.concat(result);
108
- }
109
- get name() {
110
- return this._cls_;
111
- }
112
- get id() {
113
- return this._id_;
114
- }
115
- }
116
- exports.EZSPFrameData = EZSPFrameData;
117
- class EZSPZDORequestFrameData {
118
- static getFrame(key) {
119
- const name = (typeof key == 'string') ? key : commands_1.ZDOREQUEST_NAME_BY_ID[key];
120
- const frameDesc = commands_1.ZDOREQUESTS[name];
121
- if (!frameDesc)
122
- throw new Error(`Unrecognized ZDOFrame from FrameID ${key}`);
123
- return frameDesc;
124
- }
125
- constructor(key, isRequest, params) {
126
- if (typeof key == 'string') {
127
- this._cls_ = key;
128
- this._id_ = commands_1.ZDOREQUESTS[this._cls_].ID;
129
- }
130
- else {
131
- this._id_ = key;
132
- this._cls_ = commands_1.ZDOREQUEST_NAME_BY_ID[key];
133
- }
134
- this._isRequest_ = isRequest;
135
- const frame = EZSPZDORequestFrameData.getFrame(key);
136
- const frameDesc = (this._isRequest_) ? frame.request || {} : frame.response || {};
137
- if (Buffer.isBuffer(params)) {
138
- let data = params;
139
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
140
- [this[prop], data] = frameDesc[prop].deserialize(frameDesc[prop], data);
141
- }
142
- }
143
- else {
144
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
145
- this[prop] = params[prop];
146
- }
147
- }
148
- }
149
- serialize() {
150
- const frame = EZSPZDORequestFrameData.getFrame(this._cls_);
151
- const frameDesc = (this._isRequest_) ? frame.request || {} : frame.response || {};
152
- const result = [];
153
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
154
- result.push(frameDesc[prop].serialize(frameDesc[prop], this[prop]));
155
- }
156
- return Buffer.concat(result);
157
- }
158
- get name() {
159
- return this._cls_;
160
- }
161
- get id() {
162
- return this._id_;
163
- }
164
- }
165
- exports.EZSPZDORequestFrameData = EZSPZDORequestFrameData;
166
- class EZSPZDOResponseFrameData {
167
- static getFrame(key) {
168
- const name = (typeof key == 'string') ? key : commands_1.ZDORESPONSE_NAME_BY_ID[key];
169
- const frameDesc = commands_1.ZDORESPONSES[name];
170
- if (!frameDesc)
171
- throw new Error(`Unrecognized ZDOFrame from FrameID ${key}`);
172
- return frameDesc.params;
173
- }
174
- constructor(key, params) {
175
- if (typeof key == 'string') {
176
- this._cls_ = key;
177
- this._id_ = commands_1.ZDORESPONSES[this._cls_].ID;
178
- }
179
- else {
180
- this._id_ = key;
181
- this._cls_ = commands_1.ZDORESPONSE_NAME_BY_ID[key];
182
- }
183
- const frameDesc = EZSPZDOResponseFrameData.getFrame(key);
184
- if (Buffer.isBuffer(params)) {
185
- let data = params;
186
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
187
- [this[prop], data] = frameDesc[prop].deserialize(frameDesc[prop], data);
188
- }
189
- }
190
- else {
191
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
192
- this[prop] = params[prop];
193
- }
194
- }
195
- }
196
- serialize() {
197
- const frameDesc = EZSPZDOResponseFrameData.getFrame(this._cls_);
198
- const result = [];
199
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
200
- result.push(frameDesc[prop].serialize(frameDesc[prop], this[prop]));
201
- }
202
- return Buffer.concat(result);
203
- }
204
- get name() {
205
- return this._cls_;
206
- }
207
- get id() {
208
- return this._id_;
209
- }
210
- }
211
- exports.EZSPZDOResponseFrameData = EZSPZDOResponseFrameData;
212
- class Ezsp extends events_1.EventEmitter {
213
- constructor() {
214
- super();
215
- this.ezspV = 4;
216
- this.cmdSeq = 0; // command sequence
217
- this.failures = 0;
218
- this.queue = new utils_1.Queue();
219
- this.waitress = new utils_1.Waitress(this.waitressValidator, this.waitressTimeoutFormatter);
220
- this.serialDriver = new uart_1.SerialDriver();
221
- this.serialDriver.on('received', this.onFrameReceived.bind(this));
222
- this.serialDriver.on('close', this.onClose.bind(this));
223
- this.serialDriver.on('reset', this.resetHandler.bind(this));
224
- }
225
- async connect(path, options) {
226
- for (let i = 1; i < 5; i += 1) {
227
- try {
228
- await this.serialDriver.connect(path, options);
229
- break;
230
- }
231
- catch (error) {
232
- debug.error(`Connection attempt ${i} error: ${error.stack}`);
233
- await (0, utils_1.Wait)(5000);
234
- debug.log(`Next attempt ${i + 1}`);
235
- }
236
- }
237
- if (!this.serialDriver.isInitialized) {
238
- throw new Error("Failure to connect");
239
- }
240
- if (WATCHDOG_WAKE_PERIOD) {
241
- this.watchdogTimer = setInterval(this.watchdogHandler.bind(this), WATCHDOG_WAKE_PERIOD * 1000);
242
- }
243
- }
244
- onClose() {
245
- debug.log('Close ezsp');
246
- this.emit('close');
247
- }
248
- async close(force) {
249
- debug.log('Stop ezsp');
250
- if (force) {
251
- clearTimeout(this.watchdogTimer);
252
- }
253
- this.queue.clear();
254
- await this.serialDriver.close();
255
- }
256
- getFrameDesc(name) {
257
- return (name in commands_1.FRAMES) ? commands_1.FRAMES[name] : null;
258
- }
259
- onFrameReceived(data) {
260
- /*Handle a received EZSP frame
261
-
262
- The protocol has taken care of UART specific framing etc, so we should
263
- just have EZSP application stuff here, with all escaping/stuffing and
264
- data randomization removed.
265
- */
266
- debug.log(`<== Frame: ${data.toString('hex')}`);
267
- let frame_id, sequence;
268
- if ((this.ezspV < 8)) {
269
- [sequence, frame_id, data] = [data[0], data[2], data.subarray(3)];
270
- }
271
- else {
272
- sequence = data[0];
273
- [[frame_id], data] = t.deserialize(data.subarray(3), [t.uint16_t]);
274
- }
275
- if ((frame_id === 255)) {
276
- frame_id = 0;
277
- if ((data.length > 1)) {
278
- frame_id = data[1];
279
- data = data.subarray(2);
280
- }
281
- }
282
- const frm = EZSPFrameData.createFrame(this.ezspV, frame_id, false, data);
283
- if (!frm) {
284
- debug.error(`Unparsed frame 0x${frame_id.toString(16)}. Skipped`);
285
- return;
286
- }
287
- debug.log(`<== 0x${frame_id.toString(16)}: ${JSON.stringify(frm)}`);
288
- const handled = this.waitress.resolve({
289
- frameId: frame_id,
290
- frameName: frm.name,
291
- sequence: sequence,
292
- payload: frm
293
- });
294
- if (!handled)
295
- this.emit('frame', frm.name, frm);
296
- if ((frame_id === 0)) {
297
- this.ezspV = frm.protocolVersion;
298
- }
299
- }
300
- async version() {
301
- const version = this.ezspV;
302
- const result = await this.execCommand("version", { desiredProtocolVersion: version });
303
- if ((result.protocolVersion !== version)) {
304
- debug.log("Switching to eszp version %d", result.protocolVersion);
305
- await this.execCommand("version", { desiredProtocolVersion: result.protocolVersion });
306
- }
307
- return result.protocolVersion;
308
- }
309
- async networkInit() {
310
- const waiter = this.waitFor("stackStatusHandler", null).start();
311
- const result = await this.execCommand("networkInit");
312
- debug.log('network init result: ', JSON.stringify(result));
313
- if ((result.status !== named_1.EmberStatus.SUCCESS)) {
314
- this.waitress.remove(waiter.ID);
315
- debug.log("Failure to init network");
316
- return false;
317
- }
318
- const response = await waiter.promise;
319
- return response.payload.status == named_1.EmberStatus.NETWORK_UP;
320
- }
321
- async leaveNetwork() {
322
- const waiter = this.waitFor("stackStatusHandler", null).start();
323
- const result = await this.execCommand("leaveNetwork");
324
- debug.log('network init result', JSON.stringify(result));
325
- if ((result.status !== named_1.EmberStatus.SUCCESS)) {
326
- this.waitress.remove(waiter.ID);
327
- debug.log("Failure to leave network");
328
- throw new Error(("Failure to leave network: " + JSON.stringify(result)));
329
- }
330
- const response = await waiter.promise;
331
- if ((response.payload.status !== named_1.EmberStatus.NETWORK_DOWN)) {
332
- debug.log("Wrong network status: " + JSON.stringify(response.payload));
333
- throw new Error(("Wrong network status: " + JSON.stringify(response.payload)));
334
- }
335
- return response.payload.status;
336
- }
337
- async setConfigurationValue(configId, value) {
338
- debug.log('Set %s = %s', named_1.EzspConfigId.valueToName(named_1.EzspConfigId, configId), value);
339
- const ret = await this.execCommand('setConfigurationValue', { configId: configId, value: value });
340
- console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (setConfigurationValue) returned unexpected state: ${ret}`);
341
- }
342
- async getConfigurationValue(configId) {
343
- debug.log('Get %s', named_1.EzspConfigId.valueToName(named_1.EzspConfigId, configId));
344
- const ret = await this.execCommand('getConfigurationValue', { configId: configId });
345
- console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (getConfigurationValue) returned unexpected state: ${ret}`);
346
- debug.log('Got %s = %s', named_1.EzspConfigId.valueToName(named_1.EzspConfigId, configId), ret.value.toString());
347
- return ret.value;
348
- }
349
- async getMulticastTableEntry(index) {
350
- const ret = await this.execCommand('getMulticastTableEntry', { index: index });
351
- return ret.value;
352
- }
353
- async setMulticastTableEntry(index, entry) {
354
- const ret = await this.execCommand('setMulticastTableEntry', { index: index, value: entry });
355
- console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (setMulticastTableEntry) returned unexpected state: ${ret}`);
356
- return ret.status;
357
- }
358
- async setInitialSecurityState(entry) {
359
- const ret = await this.execCommand('setInitialSecurityState', { state: entry });
360
- console.assert(ret.success === named_1.EmberStatus.SUCCESS, `Command (setInitialSecurityState) returned unexpected state: ${ret}`);
361
- return ret.success;
362
- }
363
- async getCurrentSecurityState() {
364
- const ret = await this.execCommand('getCurrentSecurityState');
365
- console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (getCurrentSecurityState) returned unexpected state: ${ret}`);
366
- return ret;
367
- }
368
- async setValue(valueId, value) {
369
- debug.log('Set %s = %s', t.EzspValueId.valueToName(t.EzspValueId, valueId), value);
370
- const ret = await this.execCommand('setValue', { valueId, value });
371
- console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (setValue) returned unexpected state: ${ret.status}`);
372
- return ret;
373
- }
374
- async getValue(valueId) {
375
- debug.log('Get %s', t.EzspValueId.valueToName(t.EzspValueId, valueId));
376
- const ret = await this.execCommand('getValue', { valueId });
377
- console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (getValue) returned unexpected state: ${ret}`);
378
- debug.log('Got %s = %s', t.EzspValueId.valueToName(t.EzspValueId, valueId), ret.value);
379
- return ret.value;
380
- }
381
- async setPolicy(policyId, value) {
382
- debug.log('Set %s = %s', named_1.EzspPolicyId.valueToName(named_1.EzspPolicyId, policyId), value);
383
- const ret = await this.execCommand('setPolicy', { policyId: policyId, decisionId: value });
384
- console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (setPolicy) returned unexpected state: ${ret}`);
385
- return ret;
386
- }
387
- async updateConfig() {
388
- const config = [
389
- [named_1.EzspConfigId.CONFIG_TC_REJOINS_USING_WELL_KNOWN_KEY_TIMEOUT_S, 90],
390
- [named_1.EzspConfigId.CONFIG_TRUST_CENTER_ADDRESS_CACHE_SIZE, 2],
391
- //[EzspConfigId.CONFIG_SUPPORTED_NETWORKS, 1],
392
- [named_1.EzspConfigId.CONFIG_FRAGMENT_DELAY_MS, 50],
393
- [named_1.EzspConfigId.CONFIG_PAN_ID_CONFLICT_REPORT_THRESHOLD, 2],
394
- //[EzspConfigId.CONFIG_SOURCE_ROUTE_TABLE_SIZE, 16],
395
- //[EzspConfigId.CONFIG_ADDRESS_TABLE_SIZE, 16],
396
- [named_1.EzspConfigId.CONFIG_APPLICATION_ZDO_FLAGS,
397
- named_1.EmberZdoConfigurationFlags.APP_HANDLES_UNSUPPORTED_ZDO_REQUESTS |
398
- named_1.EmberZdoConfigurationFlags.APP_RECEIVES_SUPPORTED_ZDO_REQUESTS],
399
- [named_1.EzspConfigId.CONFIG_INDIRECT_TRANSMISSION_TIMEOUT, 7680],
400
- [named_1.EzspConfigId.CONFIG_END_DEVICE_POLL_TIMEOUT, 14],
401
- [named_1.EzspConfigId.CONFIG_SECURITY_LEVEL, 5],
402
- [named_1.EzspConfigId.CONFIG_STACK_PROFILE, 2],
403
- //[EzspConfigId.CONFIG_TX_POWER_MODE, 3],
404
- [named_1.EzspConfigId.CONFIG_FRAGMENT_WINDOW_SIZE, 1],
405
- //[EzspConfigId.CONFIG_NEIGHBOR_TABLE_SIZE, 16],
406
- //[EzspConfigId.CONFIG_ROUTE_TABLE_SIZE, 16],
407
- //[EzspConfigId.CONFIG_BINDING_TABLE_SIZE, 32],
408
- //[EzspConfigId.CONFIG_KEY_TABLE_SIZE, 12],
409
- //[EzspConfigId.CONFIG_ZLL_GROUP_ADDRESSES, 0],
410
- //[EzspConfigId.CONFIG_ZLL_RSSI_THRESHOLD, 0],
411
- //[EzspConfigId.CONFIG_APS_UNICAST_MESSAGE_COUNT, 255],
412
- //[EzspConfigId.CONFIG_BROADCAST_TABLE_SIZE, 43],
413
- //[EzspConfigId.CONFIG_MAX_HOPS, 30],
414
- //[EzspConfigId.CONFIG_MAX_END_DEVICE_CHILDREN, 32],
415
- [named_1.EzspConfigId.CONFIG_PACKET_BUFFER_COUNT, 255],
416
- ];
417
- for (const [confName, value] of config) {
418
- try {
419
- await this.setConfigurationValue(confName, value);
420
- }
421
- catch (error) {
422
- debug.error(`setConfigurationValue(${confName}, ${value}) error: ${error} ${error.stack}`);
423
- }
424
- }
425
- }
426
- async updatePolicies() {
427
- // Set up the policies for what the NCP should do.
428
- let policies = [
429
- // [EzspPolicyId.BINDING_MODIFICATION_POLICY,
430
- // EzspDecisionId.DISALLOW_BINDING_MODIFICATION],
431
- // [EzspPolicyId.UNICAST_REPLIES_POLICY, EzspDecisionId.HOST_WILL_NOT_SUPPLY_REPLY],
432
- // [EzspPolicyId.POLL_HANDLER_POLICY, EzspDecisionId.POLL_HANDLER_IGNORE],
433
- // [EzspPolicyId.MESSAGE_CONTENTS_IN_CALLBACK_POLICY,
434
- // EzspDecisionId.MESSAGE_TAG_ONLY_IN_CALLBACK],
435
- // [EzspPolicyId.PACKET_VALIDATE_LIBRARY_POLICY,
436
- // EzspDecisionId.PACKET_VALIDATE_LIBRARY_CHECKS_DISABLED],
437
- // [EzspPolicyId.ZLL_POLICY, EzspDecisionId.ALLOW_JOINS],
438
- // [EzspPolicyId.TC_REJOINS_USING_WELL_KNOWN_KEY_POLICY, EzspDecisionId.ALLOW_JOINS],
439
- [named_1.EzspPolicyId.APP_KEY_REQUEST_POLICY, named_1.EzspDecisionId.DENY_APP_KEY_REQUESTS],
440
- [named_1.EzspPolicyId.TC_KEY_REQUEST_POLICY, named_1.EzspDecisionId.ALLOW_TC_KEY_REQUESTS],
441
- ];
442
- if (this.ezspV >= 8) {
443
- policies = policies.concat([
444
- [named_1.EzspPolicyId.TRUST_CENTER_POLICY, named_1.EzspDecisionBitmask.ALLOW_UNSECURED_REJOINS
445
- | named_1.EzspDecisionBitmask.ALLOW_JOINS],
446
- ]);
447
- }
448
- for (const [policy, value] of policies) {
449
- await this.setPolicy(policy, value);
450
- }
451
- }
452
- makeZDOframe(name, params) {
453
- const frmData = new EZSPZDORequestFrameData(name, true, params);
454
- return frmData.serialize();
455
- }
456
- makeFrame(name, params, seq) {
457
- const frmData = new EZSPFrameData(name, true, params);
458
- debug.log(`==> ${JSON.stringify(frmData)}`);
459
- const frame = [(seq & 255)];
460
- if ((this.ezspV < 8)) {
461
- if ((this.ezspV >= 5)) {
462
- frame.push(0x00, 0xFF, 0x00, frmData.id);
463
- }
464
- else {
465
- frame.push(0x00, frmData.id);
466
- }
467
- }
468
- else {
469
- const cmd_id = t.serialize([frmData.id], [t.uint16_t]);
470
- frame.push(0x00, 0x01, ...cmd_id);
471
- }
472
- return Buffer.concat([Buffer.from(frame), frmData.serialize()]);
473
- }
474
- async execCommand(name, params = null) {
475
- debug.log(`==> ${name}: ${JSON.stringify(params)}`);
476
- if (!this.serialDriver.isInitialized()) {
477
- throw new Error('Connection not initialized');
478
- }
479
- return this.queue.execute(async () => {
480
- const data = this.makeFrame(name, params, this.cmdSeq);
481
- const waiter = this.waitFor(name, this.cmdSeq);
482
- this.cmdSeq = (this.cmdSeq + 1) & 255;
483
- return this.serialDriver.sendDATA(data).then(async () => {
484
- const response = await waiter.start().promise;
485
- return response.payload;
486
- }).catch(() => {
487
- this.waitress.remove(waiter.ID);
488
- throw new Error(`Failure send ${name}:` + JSON.stringify(data));
489
- });
490
- });
491
- }
492
- async formNetwork(params) {
493
- const waiter = this.waitFor("stackStatusHandler", null).start();
494
- const v = await this.execCommand("formNetwork", { parameters: params });
495
- if ((v.status !== named_1.EmberStatus.SUCCESS)) {
496
- this.waitress.remove(waiter.ID);
497
- debug.error("Failure forming network: " + JSON.stringify(v));
498
- throw new Error(("Failure forming network: " + JSON.stringify(v)));
499
- }
500
- const response = await waiter.promise;
501
- if ((response.payload.status !== named_1.EmberStatus.NETWORK_UP)) {
502
- debug.error("Wrong network status: " + JSON.stringify(response.payload));
503
- throw new Error(("Wrong network status: " + JSON.stringify(response.payload)));
504
- }
505
- return response.payload.status;
506
- }
507
- parse_frame_payload(name, data) {
508
- const frame = new EZSPZDOResponseFrameData(name, data);
509
- return frame;
510
- }
511
- sendUnicast(direct, nwk, apsFrame, seq, data) {
512
- return this.execCommand('sendUnicast', {
513
- type: direct,
514
- indexOrDestination: nwk,
515
- apsFrame: apsFrame,
516
- messageTag: seq,
517
- message: data
518
- });
519
- }
520
- sendMulticast(apsFrame, seq, data) {
521
- return this.execCommand('sendMulticast', {
522
- apsFrame: apsFrame,
523
- hops: EZSP_DEFAULT_RADIUS,
524
- nonmemberRadius: EZSP_MULTICAST_NON_MEMBER_RADIUS,
525
- messageTag: seq,
526
- message: data
527
- });
528
- }
529
- async setSourceRouting() {
530
- const res = await this.execCommand('setConcentrator', {
531
- on: true,
532
- concentratorType: named_1.EmberConcentratorType.HIGH_RAM_CONCENTRATOR,
533
- minTime: MTOR_MIN_INTERVAL,
534
- maxTime: MTOR_MAX_INTERVAL,
535
- routeErrorThreshold: MTOR_ROUTE_ERROR_THRESHOLD,
536
- deliveryFailureThreshold: MTOR_DELIVERY_FAIL_THRESHOLD,
537
- maxHops: 0,
538
- });
539
- debug.log("Set concentrator type: %s", JSON.stringify(res));
540
- if (res.status != named_1.EmberStatus.SUCCESS) {
541
- debug.log("Couldn't set concentrator type %s: %s", true, JSON.stringify(res));
542
- }
543
- if (this.ezspV >= 8) {
544
- await this.execCommand('setSourceRouteDiscoveryMode', { mode: 1 });
545
- }
546
- }
547
- sendBroadcast(destination, apsFrame, seq, data) {
548
- return this.execCommand('sendBroadcast', {
549
- destination: destination,
550
- apsFrame: apsFrame,
551
- radius: EZSP_DEFAULT_RADIUS,
552
- messageTag: seq,
553
- message: data
554
- });
555
- }
556
- waitFor(frameId, sequence, timeout = 10000) {
557
- return this.waitress.waitFor({ frameId, sequence }, timeout);
558
- }
559
- waitressTimeoutFormatter(matcher, timeout) {
560
- return `${JSON.stringify(matcher)} after ${timeout}ms`;
561
- }
562
- waitressValidator(payload, matcher) {
563
- const frameNames = (typeof matcher.frameId == 'string') ?
564
- [matcher.frameId] : commands_1.FRAME_NAMES_BY_ID[matcher.frameId];
565
- return ((matcher.sequence == null || payload.sequence === matcher.sequence) &&
566
- frameNames.includes(payload.frameName));
567
- }
568
- async watchdogHandler() {
569
- debug.log(`Time to watchdog ... ${this.failures}`);
570
- try {
571
- await this.execCommand('nop');
572
- }
573
- catch (error) {
574
- debug.error(`Watchdog heartbeat timeout ${error.stack}`);
575
- this.failures += 1;
576
- if (this.failures > MAX_WATCHDOG_FAILURES) {
577
- this.failures = 0;
578
- this.resetHandler();
579
- }
580
- }
581
- }
582
- async resetHandler() {
583
- this.emit('reset');
584
- }
585
- }
586
- exports.Ezsp = Ezsp;
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.Ezsp = exports.EZSPZDOResponseFrameData = exports.EZSPZDORequestFrameData = exports.EZSPFrameData = void 0;
30
+ /* istanbul ignore file */
31
+ /* eslint-disable @typescript-eslint/explicit-module-boundary-types */
32
+ const t = __importStar(require("./types"));
33
+ const uart_1 = require("./uart");
34
+ const commands_1 = require("./commands");
35
+ const named_1 = require("./types/named");
36
+ const events_1 = require("events");
37
+ const utils_1 = require("../../../utils");
38
+ const debug_1 = __importDefault(require("debug"));
39
+ const debug = {
40
+ error: (0, debug_1.default)('zigbee-herdsman:adapter:ezsp:erro'),
41
+ log: (0, debug_1.default)('zigbee-herdsman:adapter:ezsp:ezsp'),
42
+ };
43
+ const MAX_SERIAL_CONNECT_ATTEMPTS = 4;
44
+ /** In ms. This is multiplied by tries count (above), e.g. 4 tries = 5000, 10000, 15000 */
45
+ const SERIAL_CONNECT_NEW_ATTEMPT_MIN_DELAY = 5000;
46
+ const MTOR_MIN_INTERVAL = 10;
47
+ const MTOR_MAX_INTERVAL = 90;
48
+ const MTOR_ROUTE_ERROR_THRESHOLD = 4;
49
+ const MTOR_DELIVERY_FAIL_THRESHOLD = 3;
50
+ const MAX_WATCHDOG_FAILURES = 4;
51
+ //const RESET_ATTEMPT_BACKOFF_TIME = 5;
52
+ const WATCHDOG_WAKE_PERIOD = 10; // in sec
53
+ //const EZSP_COUNTER_CLEAR_INTERVAL = 180; // Clear counters every n * WATCHDOG_WAKE_PERIOD
54
+ const EZSP_DEFAULT_RADIUS = 0;
55
+ const EZSP_MULTICAST_NON_MEMBER_RADIUS = 3;
56
+ const CONFIG_IDS_PRE_V9 = [
57
+ [named_1.EzspConfigId.CONFIG_TC_REJOINS_USING_WELL_KNOWN_KEY_TIMEOUT_S, 90],
58
+ [named_1.EzspConfigId.CONFIG_TRUST_CENTER_ADDRESS_CACHE_SIZE, 2],
59
+ //[EzspConfigId.CONFIG_SUPPORTED_NETWORKS, 1],
60
+ [named_1.EzspConfigId.CONFIG_FRAGMENT_DELAY_MS, 50],
61
+ [named_1.EzspConfigId.CONFIG_PAN_ID_CONFLICT_REPORT_THRESHOLD, 2],
62
+ //[EzspConfigId.CONFIG_SOURCE_ROUTE_TABLE_SIZE, 16],
63
+ //[EzspConfigId.CONFIG_ADDRESS_TABLE_SIZE, 16],
64
+ [named_1.EzspConfigId.CONFIG_APPLICATION_ZDO_FLAGS,
65
+ named_1.EmberZdoConfigurationFlags.APP_HANDLES_UNSUPPORTED_ZDO_REQUESTS |
66
+ named_1.EmberZdoConfigurationFlags.APP_RECEIVES_SUPPORTED_ZDO_REQUESTS],
67
+ [named_1.EzspConfigId.CONFIG_INDIRECT_TRANSMISSION_TIMEOUT, 7680],
68
+ [named_1.EzspConfigId.CONFIG_END_DEVICE_POLL_TIMEOUT, 14],
69
+ [named_1.EzspConfigId.CONFIG_SECURITY_LEVEL, 5],
70
+ [named_1.EzspConfigId.CONFIG_STACK_PROFILE, 2],
71
+ //[EzspConfigId.CONFIG_TX_POWER_MODE, 3],
72
+ [named_1.EzspConfigId.CONFIG_FRAGMENT_WINDOW_SIZE, 1],
73
+ //[EzspConfigId.CONFIG_NEIGHBOR_TABLE_SIZE, 16],
74
+ //[EzspConfigId.CONFIG_ROUTE_TABLE_SIZE, 16],
75
+ //[EzspConfigId.CONFIG_BINDING_TABLE_SIZE, 32],
76
+ //[EzspConfigId.CONFIG_KEY_TABLE_SIZE, 12],
77
+ //[EzspConfigId.CONFIG_ZLL_GROUP_ADDRESSES, 0],
78
+ //[EzspConfigId.CONFIG_ZLL_RSSI_THRESHOLD, 0],
79
+ //[EzspConfigId.CONFIG_APS_UNICAST_MESSAGE_COUNT, 255],
80
+ //[EzspConfigId.CONFIG_BROADCAST_TABLE_SIZE, 43],
81
+ //[EzspConfigId.CONFIG_MAX_HOPS, 30],
82
+ //[EzspConfigId.CONFIG_MAX_END_DEVICE_CHILDREN, 32],
83
+ [named_1.EzspConfigId.CONFIG_PACKET_BUFFER_COUNT, 255],
84
+ ];
85
+ /**
86
+ * Can only decrease "NCP Memory Allocation" configs at runtime from V9 on.
87
+ * @see https://www.silabs.com/documents/public/release-notes/emberznet-release-notes-7.0.1.0.pdf
88
+ */
89
+ const CONFIG_IDS_CURRENT = [
90
+ [named_1.EzspConfigId.CONFIG_TC_REJOINS_USING_WELL_KNOWN_KEY_TIMEOUT_S, 90],
91
+ [named_1.EzspConfigId.CONFIG_TRUST_CENTER_ADDRESS_CACHE_SIZE, 2],
92
+ [named_1.EzspConfigId.CONFIG_FRAGMENT_DELAY_MS, 50],
93
+ [named_1.EzspConfigId.CONFIG_PAN_ID_CONFLICT_REPORT_THRESHOLD, 2],
94
+ [named_1.EzspConfigId.CONFIG_APPLICATION_ZDO_FLAGS,
95
+ named_1.EmberZdoConfigurationFlags.APP_HANDLES_UNSUPPORTED_ZDO_REQUESTS |
96
+ named_1.EmberZdoConfigurationFlags.APP_RECEIVES_SUPPORTED_ZDO_REQUESTS],
97
+ [named_1.EzspConfigId.CONFIG_INDIRECT_TRANSMISSION_TIMEOUT, 7680],
98
+ [named_1.EzspConfigId.CONFIG_END_DEVICE_POLL_TIMEOUT, 14],
99
+ [named_1.EzspConfigId.CONFIG_SECURITY_LEVEL, 5],
100
+ [named_1.EzspConfigId.CONFIG_STACK_PROFILE, 2],
101
+ [named_1.EzspConfigId.CONFIG_FRAGMENT_WINDOW_SIZE, 1],
102
+ ];
103
+ const POLICY_IDS_PRE_V8 = [
104
+ // [EzspPolicyId.BINDING_MODIFICATION_POLICY,
105
+ // EzspDecisionId.DISALLOW_BINDING_MODIFICATION],
106
+ // [EzspPolicyId.UNICAST_REPLIES_POLICY, EzspDecisionId.HOST_WILL_NOT_SUPPLY_REPLY],
107
+ // [EzspPolicyId.POLL_HANDLER_POLICY, EzspDecisionId.POLL_HANDLER_IGNORE],
108
+ // [EzspPolicyId.MESSAGE_CONTENTS_IN_CALLBACK_POLICY,
109
+ // EzspDecisionId.MESSAGE_TAG_ONLY_IN_CALLBACK],
110
+ // [EzspPolicyId.PACKET_VALIDATE_LIBRARY_POLICY,
111
+ // EzspDecisionId.PACKET_VALIDATE_LIBRARY_CHECKS_DISABLED],
112
+ // [EzspPolicyId.ZLL_POLICY, EzspDecisionId.ALLOW_JOINS],
113
+ // [EzspPolicyId.TC_REJOINS_USING_WELL_KNOWN_KEY_POLICY, EzspDecisionId.ALLOW_JOINS],
114
+ [named_1.EzspPolicyId.APP_KEY_REQUEST_POLICY, named_1.EzspDecisionId.DENY_APP_KEY_REQUESTS],
115
+ [named_1.EzspPolicyId.TC_KEY_REQUEST_POLICY, named_1.EzspDecisionId.ALLOW_TC_KEY_REQUESTS],
116
+ ];
117
+ const POLICY_IDS_CURRENT = [
118
+ [named_1.EzspPolicyId.APP_KEY_REQUEST_POLICY, named_1.EzspDecisionId.DENY_APP_KEY_REQUESTS],
119
+ [named_1.EzspPolicyId.TC_KEY_REQUEST_POLICY, named_1.EzspDecisionId.ALLOW_TC_KEY_REQUESTS],
120
+ [named_1.EzspPolicyId.TRUST_CENTER_POLICY, named_1.EzspDecisionBitmask.ALLOW_UNSECURED_REJOINS | named_1.EzspDecisionBitmask.ALLOW_JOINS],
121
+ ];
122
+ class EZSPFrameData {
123
+ _cls_;
124
+ _id_;
125
+ _isRequest_;
126
+ static createFrame(ezspv, frame_id, isRequest, params) {
127
+ const names = commands_1.FRAME_NAMES_BY_ID[frame_id];
128
+ if (!names) {
129
+ throw new Error(`Unrecognized frame FrameID ${frame_id}`);
130
+ }
131
+ let frm;
132
+ names.every((frameName) => {
133
+ const frameDesc = EZSPFrameData.getFrame(frameName);
134
+ if ((frameDesc.maxV && frameDesc.maxV < ezspv) || (frameDesc.minV && frameDesc.minV > ezspv)) {
135
+ return true;
136
+ }
137
+ try {
138
+ frm = new EZSPFrameData(frameName, isRequest, params);
139
+ }
140
+ catch (error) {
141
+ debug.error(`Frame ${frameName} parsing error: ${error.stack}`);
142
+ return true;
143
+ }
144
+ return false;
145
+ });
146
+ return frm;
147
+ }
148
+ static getFrame(name) {
149
+ const frameDesc = commands_1.FRAMES[name];
150
+ if (!frameDesc)
151
+ throw new Error(`Unrecognized frame from FrameID ${name}`);
152
+ return frameDesc;
153
+ }
154
+ constructor(key, isRequest, params) {
155
+ this._cls_ = key;
156
+ this._id_ = commands_1.FRAMES[this._cls_].ID;
157
+ this._isRequest_ = isRequest;
158
+ const frame = EZSPFrameData.getFrame(key);
159
+ const frameDesc = (this._isRequest_) ? frame.request || {} : frame.response || {};
160
+ if (Buffer.isBuffer(params)) {
161
+ let data = params;
162
+ for (const prop of Object.getOwnPropertyNames(frameDesc)) {
163
+ [this[prop], data] = frameDesc[prop].deserialize(frameDesc[prop], data);
164
+ }
165
+ }
166
+ else {
167
+ for (const prop of Object.getOwnPropertyNames(frameDesc)) {
168
+ this[prop] = params[prop];
169
+ }
170
+ }
171
+ }
172
+ serialize() {
173
+ const frame = EZSPFrameData.getFrame(this._cls_);
174
+ const frameDesc = (this._isRequest_) ? frame.request || {} : frame.response || {};
175
+ const result = [];
176
+ for (const prop of Object.getOwnPropertyNames(frameDesc)) {
177
+ result.push(frameDesc[prop].serialize(frameDesc[prop], this[prop]));
178
+ }
179
+ return Buffer.concat(result);
180
+ }
181
+ get name() {
182
+ return this._cls_;
183
+ }
184
+ get id() {
185
+ return this._id_;
186
+ }
187
+ }
188
+ exports.EZSPFrameData = EZSPFrameData;
189
+ class EZSPZDORequestFrameData {
190
+ _cls_;
191
+ _id_;
192
+ _isRequest_;
193
+ static getFrame(key) {
194
+ const name = (typeof key == 'string') ? key : commands_1.ZDOREQUEST_NAME_BY_ID[key];
195
+ const frameDesc = commands_1.ZDOREQUESTS[name];
196
+ if (!frameDesc)
197
+ throw new Error(`Unrecognized ZDOFrame from FrameID ${key}`);
198
+ return frameDesc;
199
+ }
200
+ constructor(key, isRequest, params) {
201
+ if (typeof key == 'string') {
202
+ this._cls_ = key;
203
+ this._id_ = commands_1.ZDOREQUESTS[this._cls_].ID;
204
+ }
205
+ else {
206
+ this._id_ = key;
207
+ this._cls_ = commands_1.ZDOREQUEST_NAME_BY_ID[key];
208
+ }
209
+ this._isRequest_ = isRequest;
210
+ const frame = EZSPZDORequestFrameData.getFrame(key);
211
+ const frameDesc = (this._isRequest_) ? frame.request || {} : frame.response || {};
212
+ if (Buffer.isBuffer(params)) {
213
+ let data = params;
214
+ for (const prop of Object.getOwnPropertyNames(frameDesc)) {
215
+ [this[prop], data] = frameDesc[prop].deserialize(frameDesc[prop], data);
216
+ }
217
+ }
218
+ else {
219
+ for (const prop of Object.getOwnPropertyNames(frameDesc)) {
220
+ this[prop] = params[prop];
221
+ }
222
+ }
223
+ }
224
+ serialize() {
225
+ const frame = EZSPZDORequestFrameData.getFrame(this._cls_);
226
+ const frameDesc = (this._isRequest_) ? frame.request || {} : frame.response || {};
227
+ const result = [];
228
+ for (const prop of Object.getOwnPropertyNames(frameDesc)) {
229
+ result.push(frameDesc[prop].serialize(frameDesc[prop], this[prop]));
230
+ }
231
+ return Buffer.concat(result);
232
+ }
233
+ get name() {
234
+ return this._cls_;
235
+ }
236
+ get id() {
237
+ return this._id_;
238
+ }
239
+ }
240
+ exports.EZSPZDORequestFrameData = EZSPZDORequestFrameData;
241
+ class EZSPZDOResponseFrameData {
242
+ _cls_;
243
+ _id_;
244
+ static getFrame(key) {
245
+ const name = (typeof key == 'string') ? key : commands_1.ZDORESPONSE_NAME_BY_ID[key];
246
+ const frameDesc = commands_1.ZDORESPONSES[name];
247
+ if (!frameDesc)
248
+ throw new Error(`Unrecognized ZDOFrame from FrameID ${key}`);
249
+ return frameDesc.params;
250
+ }
251
+ constructor(key, params) {
252
+ if (typeof key == 'string') {
253
+ this._cls_ = key;
254
+ this._id_ = commands_1.ZDORESPONSES[this._cls_].ID;
255
+ }
256
+ else {
257
+ this._id_ = key;
258
+ this._cls_ = commands_1.ZDORESPONSE_NAME_BY_ID[key];
259
+ }
260
+ const frameDesc = EZSPZDOResponseFrameData.getFrame(key);
261
+ if (Buffer.isBuffer(params)) {
262
+ let data = params;
263
+ for (const prop of Object.getOwnPropertyNames(frameDesc)) {
264
+ [this[prop], data] = frameDesc[prop].deserialize(frameDesc[prop], data);
265
+ }
266
+ }
267
+ else {
268
+ for (const prop of Object.getOwnPropertyNames(frameDesc)) {
269
+ this[prop] = params[prop];
270
+ }
271
+ }
272
+ }
273
+ serialize() {
274
+ const frameDesc = EZSPZDOResponseFrameData.getFrame(this._cls_);
275
+ const result = [];
276
+ for (const prop of Object.getOwnPropertyNames(frameDesc)) {
277
+ result.push(frameDesc[prop].serialize(frameDesc[prop], this[prop]));
278
+ }
279
+ return Buffer.concat(result);
280
+ }
281
+ get name() {
282
+ return this._cls_;
283
+ }
284
+ get id() {
285
+ return this._id_;
286
+ }
287
+ }
288
+ exports.EZSPZDOResponseFrameData = EZSPZDOResponseFrameData;
289
+ class Ezsp extends events_1.EventEmitter {
290
+ ezspV = 4;
291
+ cmdSeq = 0; // command sequence
292
+ /* eslint-disable-next-line @typescript-eslint/no-explicit-any*/
293
+ // COMMANDS_BY_ID = new Map<number, { name: string, inArgs: any[], outArgs: any[] }>();
294
+ serialDriver;
295
+ waitress;
296
+ queue;
297
+ watchdogTimer;
298
+ failures = 0;
299
+ inResetingProcess = false;
300
+ constructor() {
301
+ super();
302
+ this.queue = new utils_1.Queue();
303
+ this.waitress = new utils_1.Waitress(this.waitressValidator, this.waitressTimeoutFormatter);
304
+ this.serialDriver = new uart_1.SerialDriver();
305
+ this.serialDriver.on('received', this.onFrameReceived.bind(this));
306
+ this.serialDriver.on('close', this.onSerialClose.bind(this));
307
+ }
308
+ async connect(options) {
309
+ let lastError = null;
310
+ const resetForReconnect = () => {
311
+ throw new Error("Failure to connect");
312
+ };
313
+ this.serialDriver.on('reset', resetForReconnect);
314
+ for (let i = 1; i <= MAX_SERIAL_CONNECT_ATTEMPTS; i++) {
315
+ try {
316
+ await this.serialDriver.connect(options);
317
+ break;
318
+ }
319
+ catch (error) {
320
+ debug.error(`Connection attempt ${i} error: ${error.stack}`);
321
+ if (i < MAX_SERIAL_CONNECT_ATTEMPTS) {
322
+ await (0, utils_1.Wait)(SERIAL_CONNECT_NEW_ATTEMPT_MIN_DELAY * i);
323
+ debug.log(`Next attempt ${i + 1}`);
324
+ }
325
+ lastError = error;
326
+ }
327
+ }
328
+ this.serialDriver.off('reset', resetForReconnect);
329
+ if (!this.serialDriver.isInitialized()) {
330
+ throw new Error("Failure to connect", { cause: lastError });
331
+ }
332
+ this.inResetingProcess = false;
333
+ this.serialDriver.on('reset', this.onSerialReset.bind(this));
334
+ if (WATCHDOG_WAKE_PERIOD) {
335
+ this.watchdogTimer = setInterval(this.watchdogHandler.bind(this), WATCHDOG_WAKE_PERIOD * 1000);
336
+ }
337
+ }
338
+ isInitialized() {
339
+ return this.serialDriver?.isInitialized();
340
+ }
341
+ onSerialReset() {
342
+ debug.log('onSerialReset()');
343
+ this.inResetingProcess = true;
344
+ this.emit('reset');
345
+ }
346
+ onSerialClose() {
347
+ debug.log('onSerialClose()');
348
+ if (!this.inResetingProcess) {
349
+ this.emit('close');
350
+ }
351
+ }
352
+ async close(emitClose) {
353
+ debug.log('Closing Ezsp');
354
+ clearTimeout(this.watchdogTimer);
355
+ this.queue.clear();
356
+ await this.serialDriver.close(emitClose);
357
+ }
358
+ /**
359
+ * Handle a received EZSP frame
360
+ *
361
+ * The protocol has taken care of UART specific framing etc, so we should
362
+ * just have EZSP application stuff here, with all escaping/stuffing and
363
+ * data randomization removed.
364
+ * @param data
365
+ */
366
+ onFrameReceived(data) {
367
+ debug.log(`<== Frame: ${data.toString('hex')}`);
368
+ let frameId;
369
+ const sequence = data[0];
370
+ if ((this.ezspV < 8)) {
371
+ [frameId, data] = [data[2], data.subarray(3)];
372
+ }
373
+ else {
374
+ [[frameId], data] = t.deserialize(data.subarray(3), [t.uint16_t]);
375
+ }
376
+ if ((frameId === 255)) {
377
+ frameId = 0;
378
+ if ((data.length > 1)) {
379
+ frameId = data[1];
380
+ data = data.subarray(2);
381
+ }
382
+ }
383
+ const frm = EZSPFrameData.createFrame(this.ezspV, frameId, false, data);
384
+ if (!frm) {
385
+ debug.error(`Unparsed frame 0x${frameId.toString(16)}. Skipped`);
386
+ return;
387
+ }
388
+ debug.log(`<== 0x${frameId.toString(16)}: ${JSON.stringify(frm)}`);
389
+ const handled = this.waitress.resolve({
390
+ frameId,
391
+ frameName: frm.name,
392
+ sequence,
393
+ payload: frm
394
+ });
395
+ if (!handled) {
396
+ this.emit('frame', frm.name, frm);
397
+ }
398
+ if ((frameId === 0)) {
399
+ this.ezspV = frm.protocolVersion;
400
+ }
401
+ }
402
+ async version() {
403
+ const version = this.ezspV;
404
+ const result = await this.execCommand("version", { desiredProtocolVersion: version });
405
+ if ((result.protocolVersion !== version)) {
406
+ debug.log("Switching to eszp version %d", result.protocolVersion);
407
+ await this.execCommand("version", { desiredProtocolVersion: result.protocolVersion });
408
+ }
409
+ return result.protocolVersion;
410
+ }
411
+ async networkInit() {
412
+ const waiter = this.waitFor("stackStatusHandler", null);
413
+ const result = await this.execCommand("networkInit");
414
+ debug.log('network init result: ', JSON.stringify(result));
415
+ if ((result.status !== named_1.EmberStatus.SUCCESS)) {
416
+ this.waitress.remove(waiter.ID);
417
+ debug.log("Failure to init network");
418
+ return false;
419
+ }
420
+ const response = await waiter.start().promise;
421
+ return response.payload.status == named_1.EmberStatus.NETWORK_UP;
422
+ }
423
+ async leaveNetwork() {
424
+ const waiter = this.waitFor("stackStatusHandler", null);
425
+ const result = await this.execCommand("leaveNetwork");
426
+ debug.log('network init result', JSON.stringify(result));
427
+ if ((result.status !== named_1.EmberStatus.SUCCESS)) {
428
+ this.waitress.remove(waiter.ID);
429
+ debug.log("Failure to leave network");
430
+ throw new Error(("Failure to leave network: " + JSON.stringify(result)));
431
+ }
432
+ const response = await waiter.start().promise;
433
+ if ((response.payload.status !== named_1.EmberStatus.NETWORK_DOWN)) {
434
+ debug.log("Wrong network status: " + JSON.stringify(response.payload));
435
+ throw new Error(("Wrong network status: " + JSON.stringify(response.payload)));
436
+ }
437
+ return response.payload.status;
438
+ }
439
+ async setConfigurationValue(configId, value) {
440
+ const configName = named_1.EzspConfigId.valueToName(named_1.EzspConfigId, configId);
441
+ debug.log(`Set ${configName} = ${value}`);
442
+ const ret = await this.execCommand('setConfigurationValue', { configId: configId, value: value });
443
+ console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (setConfigurationValue(${configName}, ${value})) returned unexpected state: ${JSON.stringify(ret)}`);
444
+ }
445
+ async getConfigurationValue(configId) {
446
+ const configName = named_1.EzspConfigId.valueToName(named_1.EzspConfigId, configId);
447
+ debug.log(`Get ${configName}`);
448
+ const ret = await this.execCommand('getConfigurationValue', { configId: configId });
449
+ console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (getConfigurationValue(${configName})) returned unexpected state: ${JSON.stringify(ret)}`);
450
+ debug.log(`Got ${configName} = ${ret.value}`);
451
+ return ret.value;
452
+ }
453
+ async getMulticastTableEntry(index) {
454
+ const ret = await this.execCommand('getMulticastTableEntry', { index: index });
455
+ return ret.value;
456
+ }
457
+ async setMulticastTableEntry(index, entry) {
458
+ const ret = await this.execCommand('setMulticastTableEntry', { index: index, value: entry });
459
+ console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (setMulticastTableEntry) returned unexpected state: ${JSON.stringify(ret)}`);
460
+ return ret.status;
461
+ }
462
+ async setInitialSecurityState(entry) {
463
+ const ret = await this.execCommand('setInitialSecurityState', { state: entry });
464
+ console.assert(ret.success === named_1.EmberStatus.SUCCESS, `Command (setInitialSecurityState) returned unexpected state: ${JSON.stringify(ret)}`);
465
+ return ret.success;
466
+ }
467
+ async getCurrentSecurityState() {
468
+ const ret = await this.execCommand('getCurrentSecurityState');
469
+ console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (getCurrentSecurityState) returned unexpected state: ${JSON.stringify(ret)}`);
470
+ return ret;
471
+ }
472
+ async setValue(valueId, value) {
473
+ const valueName = t.EzspValueId.valueToName(t.EzspValueId, valueId);
474
+ debug.log(`Set ${valueName} = ${value}`);
475
+ const ret = await this.execCommand('setValue', { valueId, value });
476
+ console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (setValue(${valueName}, ${value})) returned unexpected state: ${JSON.stringify(ret)}`);
477
+ return ret;
478
+ }
479
+ async getValue(valueId) {
480
+ const valueName = t.EzspValueId.valueToName(t.EzspValueId, valueId);
481
+ debug.log(`Get ${valueName}`);
482
+ const ret = await this.execCommand('getValue', { valueId });
483
+ console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (getValue(${valueName})) returned unexpected state: ${JSON.stringify(ret)}`);
484
+ debug.log(`Got ${valueName} = ${ret.value}`);
485
+ return ret.value;
486
+ }
487
+ async setPolicy(policyId, value) {
488
+ const policyName = named_1.EzspPolicyId.valueToName(named_1.EzspPolicyId, policyId);
489
+ debug.log(`Set ${policyName} = ${value}`);
490
+ const ret = await this.execCommand('setPolicy', { policyId: policyId, decisionId: value });
491
+ console.assert(ret.status === named_1.EmberStatus.SUCCESS, `Command (setPolicy(${policyName}, ${value})) returned unexpected state: ${JSON.stringify(ret)}`);
492
+ return ret;
493
+ }
494
+ async updateConfig() {
495
+ const config = (this.ezspV < 9 ? CONFIG_IDS_PRE_V9 : CONFIG_IDS_CURRENT);
496
+ for (const [confName, value] of config) {
497
+ try {
498
+ await this.setConfigurationValue(confName, value);
499
+ }
500
+ catch (error) {
501
+ debug.error(`setConfigurationValue(${confName}, ${value}) error: ${error} ${error.stack}`);
502
+ }
503
+ }
504
+ }
505
+ async updatePolicies() {
506
+ // Set up the policies for what the NCP should do.
507
+ const policies = (this.ezspV < 8 ? POLICY_IDS_PRE_V8 : POLICY_IDS_CURRENT);
508
+ for (const [policy, value] of policies) {
509
+ try {
510
+ await this.setPolicy(policy, value);
511
+ }
512
+ catch (error) {
513
+ debug.error(`setPolicy(${policy}, ${value}) error: ${error} ${error.stack}`);
514
+ }
515
+ }
516
+ }
517
+ makeZDOframe(name, params) {
518
+ const frmData = new EZSPZDORequestFrameData(name, true, params);
519
+ return frmData.serialize();
520
+ }
521
+ makeFrame(name, params, seq) {
522
+ const frmData = new EZSPFrameData(name, true, params);
523
+ debug.log(`==> ${JSON.stringify(frmData)}`);
524
+ const frame = [(seq & 255)];
525
+ if ((this.ezspV < 8)) {
526
+ if ((this.ezspV >= 5)) {
527
+ frame.push(0x00, 0xFF, 0x00, frmData.id);
528
+ }
529
+ else {
530
+ frame.push(0x00, frmData.id);
531
+ }
532
+ }
533
+ else {
534
+ const cmd_id = t.serialize([frmData.id], [t.uint16_t]);
535
+ frame.push(0x00, 0x01, ...cmd_id);
536
+ }
537
+ return Buffer.concat([Buffer.from(frame), frmData.serialize()]);
538
+ }
539
+ async execCommand(name, params = null) {
540
+ debug.log(`==> ${name}: ${JSON.stringify(params)}`);
541
+ if (!this.serialDriver.isInitialized()) {
542
+ throw new Error('Connection not initialized');
543
+ }
544
+ return this.queue.execute(async () => {
545
+ const data = this.makeFrame(name, params, this.cmdSeq);
546
+ const waiter = this.waitFor(name, this.cmdSeq);
547
+ this.cmdSeq = (this.cmdSeq + 1) & 255;
548
+ try {
549
+ await this.serialDriver.sendDATA(data);
550
+ const response = await waiter.start().promise;
551
+ return response.payload;
552
+ }
553
+ catch (error) {
554
+ this.waitress.remove(waiter.ID);
555
+ throw new Error(`Failure send ${name}:` + JSON.stringify(data));
556
+ }
557
+ });
558
+ }
559
+ async formNetwork(params) {
560
+ const waiter = this.waitFor("stackStatusHandler", null);
561
+ const v = await this.execCommand("formNetwork", { parameters: params });
562
+ if ((v.status !== named_1.EmberStatus.SUCCESS)) {
563
+ this.waitress.remove(waiter.ID);
564
+ debug.error("Failure forming network: " + JSON.stringify(v));
565
+ throw new Error(("Failure forming network: " + JSON.stringify(v)));
566
+ }
567
+ const response = await waiter.start().promise;
568
+ if ((response.payload.status !== named_1.EmberStatus.NETWORK_UP)) {
569
+ debug.error("Wrong network status: " + JSON.stringify(response.payload));
570
+ throw new Error(("Wrong network status: " + JSON.stringify(response.payload)));
571
+ }
572
+ return response.payload.status;
573
+ }
574
+ sendUnicast(direct, nwk, apsFrame, seq, data) {
575
+ return this.execCommand('sendUnicast', {
576
+ type: direct,
577
+ indexOrDestination: nwk,
578
+ apsFrame: apsFrame,
579
+ messageTag: seq,
580
+ message: data
581
+ });
582
+ }
583
+ sendMulticast(apsFrame, seq, data) {
584
+ return this.execCommand('sendMulticast', {
585
+ apsFrame: apsFrame,
586
+ hops: EZSP_DEFAULT_RADIUS,
587
+ nonmemberRadius: EZSP_MULTICAST_NON_MEMBER_RADIUS,
588
+ messageTag: seq,
589
+ message: data
590
+ });
591
+ }
592
+ async setSourceRouting() {
593
+ const res = await this.execCommand('setConcentrator', {
594
+ on: true,
595
+ concentratorType: named_1.EmberConcentratorType.HIGH_RAM_CONCENTRATOR,
596
+ minTime: MTOR_MIN_INTERVAL,
597
+ maxTime: MTOR_MAX_INTERVAL,
598
+ routeErrorThreshold: MTOR_ROUTE_ERROR_THRESHOLD,
599
+ deliveryFailureThreshold: MTOR_DELIVERY_FAIL_THRESHOLD,
600
+ maxHops: 0,
601
+ });
602
+ debug.log("Set concentrator type: %s", JSON.stringify(res));
603
+ if (res.status != named_1.EmberStatus.SUCCESS) {
604
+ debug.log("Couldn't set concentrator type %s: %s", true, JSON.stringify(res));
605
+ }
606
+ if (this.ezspV >= 8) {
607
+ await this.execCommand('setSourceRouteDiscoveryMode', { mode: 1 });
608
+ }
609
+ }
610
+ sendBroadcast(destination, apsFrame, seq, data) {
611
+ return this.execCommand('sendBroadcast', {
612
+ destination: destination,
613
+ apsFrame: apsFrame,
614
+ radius: EZSP_DEFAULT_RADIUS,
615
+ messageTag: seq,
616
+ message: data
617
+ });
618
+ }
619
+ waitFor(frameId, sequence, timeout = 10000) {
620
+ return this.waitress.waitFor({ frameId, sequence }, timeout);
621
+ }
622
+ waitressTimeoutFormatter(matcher, timeout) {
623
+ return `${JSON.stringify(matcher)} after ${timeout}ms`;
624
+ }
625
+ waitressValidator(payload, matcher) {
626
+ const frameNames = (typeof matcher.frameId == 'string') ?
627
+ [matcher.frameId] : commands_1.FRAME_NAMES_BY_ID[matcher.frameId];
628
+ return ((matcher.sequence == null || payload.sequence === matcher.sequence) &&
629
+ frameNames.includes(payload.frameName));
630
+ }
631
+ async watchdogHandler() {
632
+ debug.log(`Time to watchdog ... ${this.failures}`);
633
+ if (this.inResetingProcess) {
634
+ debug.log('The reset process is in progress...');
635
+ return;
636
+ }
637
+ try {
638
+ await this.execCommand('nop');
639
+ }
640
+ catch (error) {
641
+ debug.error(`Watchdog heartbeat timeout ${error.stack}`);
642
+ if (!this.inResetingProcess) {
643
+ this.failures += 1;
644
+ if (this.failures > MAX_WATCHDOG_FAILURES) {
645
+ this.failures = 0;
646
+ this.emit('reset');
647
+ }
648
+ }
649
+ }
650
+ }
651
+ }
652
+ exports.Ezsp = Ezsp;
587
653
  //# sourceMappingURL=ezsp.js.map