@willieee802/zigbee-herdsman 0.15.0 → 0.15.1

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 (345) hide show
  1. package/dist/adapter/adapter.d.ts +61 -61
  2. package/dist/adapter/adapter.d.ts.map +1 -1
  3. package/dist/adapter/adapter.js +146 -100
  4. package/dist/adapter/adapter.js.map +1 -1
  5. package/dist/adapter/deconz/adapter/deconzAdapter.d.ts +68 -68
  6. package/dist/adapter/deconz/adapter/deconzAdapter.d.ts.map +1 -1
  7. package/dist/adapter/deconz/adapter/deconzAdapter.js +1060 -1063
  8. package/dist/adapter/deconz/adapter/deconzAdapter.js.map +1 -1
  9. package/dist/adapter/deconz/adapter/index.d.ts +2 -2
  10. package/dist/adapter/deconz/adapter/index.js +10 -10
  11. package/dist/adapter/deconz/driver/constants.d.ts +104 -104
  12. package/dist/adapter/deconz/driver/constants.js +55 -55
  13. package/dist/adapter/deconz/driver/driver.d.ts +81 -81
  14. package/dist/adapter/deconz/driver/driver.js +732 -732
  15. package/dist/adapter/deconz/driver/frame.d.ts +6 -6
  16. package/dist/adapter/deconz/driver/frame.js +13 -13
  17. package/dist/adapter/deconz/driver/frameParser.d.ts +2 -2
  18. package/dist/adapter/deconz/driver/frameParser.js +443 -443
  19. package/dist/adapter/deconz/driver/parser.d.ts +12 -12
  20. package/dist/adapter/deconz/driver/parser.js +61 -61
  21. package/dist/adapter/deconz/driver/writer.d.ts +8 -8
  22. package/dist/adapter/deconz/driver/writer.js +44 -44
  23. package/dist/adapter/events.d.ts +47 -47
  24. package/dist/adapter/events.js +14 -14
  25. package/dist/adapter/ezsp/adapter/backup.d.ts +9 -9
  26. package/dist/adapter/ezsp/adapter/backup.js +53 -53
  27. package/dist/adapter/ezsp/adapter/ezspAdapter.d.ts +59 -59
  28. package/dist/adapter/ezsp/adapter/ezspAdapter.js +585 -585
  29. package/dist/adapter/ezsp/adapter/index.d.ts +2 -2
  30. package/dist/adapter/ezsp/adapter/index.js +10 -10
  31. package/dist/adapter/ezsp/driver/commands.d.ts +36 -34
  32. package/dist/adapter/ezsp/driver/commands.d.ts.map +1 -1
  33. package/dist/adapter/ezsp/driver/commands.js +2359 -2357
  34. package/dist/adapter/ezsp/driver/commands.js.map +1 -1
  35. package/dist/adapter/ezsp/driver/consts.d.ts +10 -10
  36. package/dist/adapter/ezsp/driver/consts.js +13 -13
  37. package/dist/adapter/ezsp/driver/driver.d.ts +103 -103
  38. package/dist/adapter/ezsp/driver/driver.js +639 -639
  39. package/dist/adapter/ezsp/driver/driver.js.map +1 -1
  40. package/dist/adapter/ezsp/driver/ezsp.d.ts +96 -96
  41. package/dist/adapter/ezsp/driver/ezsp.d.ts.map +1 -1
  42. package/dist/adapter/ezsp/driver/ezsp.js +586 -577
  43. package/dist/adapter/ezsp/driver/ezsp.js.map +1 -1
  44. package/dist/adapter/ezsp/driver/index.d.ts +3 -3
  45. package/dist/adapter/ezsp/driver/index.js +8 -8
  46. package/dist/adapter/ezsp/driver/multicast.d.ts +12 -12
  47. package/dist/adapter/ezsp/driver/multicast.js +74 -74
  48. package/dist/adapter/ezsp/driver/parser.d.ts +12 -12
  49. package/dist/adapter/ezsp/driver/parser.js +111 -111
  50. package/dist/adapter/ezsp/driver/types/basic.d.ts +62 -62
  51. package/dist/adapter/ezsp/driver/types/basic.js +208 -208
  52. package/dist/adapter/ezsp/driver/types/basic.js.map +1 -1
  53. package/dist/adapter/ezsp/driver/types/index.d.ts +9 -9
  54. package/dist/adapter/ezsp/driver/types/index.js +133 -133
  55. package/dist/adapter/ezsp/driver/types/named.d.ts +697 -697
  56. package/dist/adapter/ezsp/driver/types/named.js +1726 -1726
  57. package/dist/adapter/ezsp/driver/types/named.js.map +1 -1
  58. package/dist/adapter/ezsp/driver/types/struct.d.ts +251 -251
  59. package/dist/adapter/ezsp/driver/types/struct.js +708 -708
  60. package/dist/adapter/ezsp/driver/types/struct.js.map +1 -1
  61. package/dist/adapter/ezsp/driver/uart.d.ts +44 -44
  62. package/dist/adapter/ezsp/driver/uart.d.ts.map +1 -1
  63. package/dist/adapter/ezsp/driver/uart.js +368 -366
  64. package/dist/adapter/ezsp/driver/uart.js.map +1 -1
  65. package/dist/adapter/ezsp/driver/utils/crc16ccitt.d.ts +2 -2
  66. package/dist/adapter/ezsp/driver/utils/crc16ccitt.js +55 -55
  67. package/dist/adapter/ezsp/driver/utils/index.d.ts +18 -18
  68. package/dist/adapter/ezsp/driver/utils/index.js +67 -67
  69. package/dist/adapter/ezsp/driver/writer.d.ts +13 -13
  70. package/dist/adapter/ezsp/driver/writer.js +88 -88
  71. package/dist/adapter/index.d.ts +4 -4
  72. package/dist/adapter/index.js +35 -35
  73. package/dist/adapter/serialPort.d.ts +8 -8
  74. package/dist/adapter/serialPort.js +22 -22
  75. package/dist/adapter/serialPort.js.map +1 -1
  76. package/dist/adapter/serialPortUtils.d.ts +12 -12
  77. package/dist/adapter/serialPortUtils.js +18 -18
  78. package/dist/adapter/socketPortUtils.d.ts +10 -10
  79. package/dist/adapter/socketPortUtils.js +16 -16
  80. package/dist/adapter/tstype.d.ts +85 -85
  81. package/dist/adapter/tstype.js +2 -2
  82. package/dist/adapter/z-stack/adapter/adapter-backup.d.ts +62 -62
  83. package/dist/adapter/z-stack/adapter/adapter-backup.js +441 -441
  84. package/dist/adapter/z-stack/adapter/adapter-nv-memory.d.ts +150 -150
  85. package/dist/adapter/z-stack/adapter/adapter-nv-memory.js +258 -258
  86. package/dist/adapter/z-stack/adapter/endpoints.d.ts +11 -11
  87. package/dist/adapter/z-stack/adapter/endpoints.js +73 -73
  88. package/dist/adapter/z-stack/adapter/index.d.ts +2 -2
  89. package/dist/adapter/z-stack/adapter/index.js +8 -8
  90. package/dist/adapter/z-stack/adapter/manager.d.ts +86 -86
  91. package/dist/adapter/z-stack/adapter/manager.js +476 -476
  92. package/dist/adapter/z-stack/adapter/tstype.d.ts +6 -6
  93. package/dist/adapter/z-stack/adapter/tstype.js +10 -10
  94. package/dist/adapter/z-stack/adapter/zStackAdapter.d.ts +81 -81
  95. package/dist/adapter/z-stack/adapter/zStackAdapter.js +868 -868
  96. package/dist/adapter/z-stack/constants/af.d.ts +23 -23
  97. package/dist/adapter/z-stack/constants/af.js +27 -27
  98. package/dist/adapter/z-stack/constants/common.d.ts +278 -278
  99. package/dist/adapter/z-stack/constants/common.js +289 -289
  100. package/dist/adapter/z-stack/constants/dbg.d.ts +22 -22
  101. package/dist/adapter/z-stack/constants/dbg.js +24 -24
  102. package/dist/adapter/z-stack/constants/index.d.ts +10 -10
  103. package/dist/adapter/z-stack/constants/index.js +47 -47
  104. package/dist/adapter/z-stack/constants/mac.d.ts +127 -127
  105. package/dist/adapter/z-stack/constants/mac.js +129 -129
  106. package/dist/adapter/z-stack/constants/sapi.d.ts +24 -24
  107. package/dist/adapter/z-stack/constants/sapi.js +26 -26
  108. package/dist/adapter/z-stack/constants/sys.d.ts +71 -71
  109. package/dist/adapter/z-stack/constants/sys.js +73 -73
  110. package/dist/adapter/z-stack/constants/util.d.ts +81 -81
  111. package/dist/adapter/z-stack/constants/util.js +83 -83
  112. package/dist/adapter/z-stack/constants/utils.d.ts +4 -4
  113. package/dist/adapter/z-stack/constants/utils.js +14 -14
  114. package/dist/adapter/z-stack/constants/zdo.d.ts +102 -102
  115. package/dist/adapter/z-stack/constants/zdo.js +104 -104
  116. package/dist/adapter/z-stack/models/index.d.ts +1 -1
  117. package/dist/adapter/z-stack/models/index.js +17 -17
  118. package/dist/adapter/z-stack/models/startup-options.d.ts +12 -12
  119. package/dist/adapter/z-stack/models/startup-options.js +2 -2
  120. package/dist/adapter/z-stack/structs/entries/address-manager-entry.d.ts +23 -23
  121. package/dist/adapter/z-stack/structs/entries/address-manager-entry.js +45 -45
  122. package/dist/adapter/z-stack/structs/entries/address-manager-table.d.ts +10 -10
  123. package/dist/adapter/z-stack/structs/entries/address-manager-table.js +22 -22
  124. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.d.ts +10 -10
  125. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-entry.js +21 -21
  126. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.d.ts +10 -10
  127. package/dist/adapter/z-stack/structs/entries/aps-link-key-data-table.js +23 -23
  128. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.d.ts +10 -10
  129. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-entry.js +24 -24
  130. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.d.ts +10 -10
  131. package/dist/adapter/z-stack/structs/entries/aps-tc-link-key-table.js +23 -23
  132. package/dist/adapter/z-stack/structs/entries/channel-list.d.ts +8 -8
  133. package/dist/adapter/z-stack/structs/entries/channel-list.js +15 -15
  134. package/dist/adapter/z-stack/structs/entries/has-configured.d.ts +8 -8
  135. package/dist/adapter/z-stack/structs/entries/has-configured.js +16 -16
  136. package/dist/adapter/z-stack/structs/entries/index.d.ts +16 -16
  137. package/dist/adapter/z-stack/structs/entries/index.js +32 -32
  138. package/dist/adapter/z-stack/structs/entries/nib.d.ts +10 -10
  139. package/dist/adapter/z-stack/structs/entries/nib.js +68 -68
  140. package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.d.ts +10 -10
  141. package/dist/adapter/z-stack/structs/entries/nwk-key-descriptor.js +18 -18
  142. package/dist/adapter/z-stack/structs/entries/nwk-key.d.ts +8 -8
  143. package/dist/adapter/z-stack/structs/entries/nwk-key.js +15 -15
  144. package/dist/adapter/z-stack/structs/entries/nwk-pan-id.d.ts +8 -8
  145. package/dist/adapter/z-stack/structs/entries/nwk-pan-id.js +15 -15
  146. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.d.ts +13 -13
  147. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.js +23 -23
  148. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.d.ts +10 -10
  149. package/dist/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.js +22 -22
  150. package/dist/adapter/z-stack/structs/entries/security-manager-entry.d.ts +20 -20
  151. package/dist/adapter/z-stack/structs/entries/security-manager-entry.js +36 -36
  152. package/dist/adapter/z-stack/structs/entries/security-manager-table.d.ts +10 -10
  153. package/dist/adapter/z-stack/structs/entries/security-manager-table.js +24 -24
  154. package/dist/adapter/z-stack/structs/index.d.ts +4 -4
  155. package/dist/adapter/z-stack/structs/index.js +20 -20
  156. package/dist/adapter/z-stack/structs/serializable-memory-object.d.ts +13 -13
  157. package/dist/adapter/z-stack/structs/serializable-memory-object.js +2 -2
  158. package/dist/adapter/z-stack/structs/struct.d.ts +99 -99
  159. package/dist/adapter/z-stack/structs/struct.js +295 -295
  160. package/dist/adapter/z-stack/structs/table.d.ts +94 -94
  161. package/dist/adapter/z-stack/structs/table.js +161 -161
  162. package/dist/adapter/z-stack/unpi/constants.d.ts +28 -28
  163. package/dist/adapter/z-stack/unpi/constants.js +41 -41
  164. package/dist/adapter/z-stack/unpi/frame.d.ts +16 -16
  165. package/dist/adapter/z-stack/unpi/frame.js +48 -48
  166. package/dist/adapter/z-stack/unpi/index.d.ts +5 -5
  167. package/dist/adapter/z-stack/unpi/index.js +37 -37
  168. package/dist/adapter/z-stack/unpi/parser.d.ts +10 -10
  169. package/dist/adapter/z-stack/unpi/parser.js +74 -74
  170. package/dist/adapter/z-stack/unpi/writer.d.ts +10 -10
  171. package/dist/adapter/z-stack/unpi/writer.js +44 -44
  172. package/dist/adapter/z-stack/utils/channel-list.d.ts +20 -20
  173. package/dist/adapter/z-stack/utils/channel-list.js +40 -40
  174. package/dist/adapter/z-stack/utils/index.d.ts +2 -2
  175. package/dist/adapter/z-stack/utils/index.js +18 -18
  176. package/dist/adapter/z-stack/utils/network-options.d.ts +8 -8
  177. package/dist/adapter/z-stack/utils/network-options.js +22 -22
  178. package/dist/adapter/z-stack/znp/buffaloZnp.d.ts +11 -11
  179. package/dist/adapter/z-stack/znp/buffaloZnp.js +113 -113
  180. package/dist/adapter/z-stack/znp/definition.d.ts +5 -5
  181. package/dist/adapter/z-stack/znp/definition.js +3050 -3050
  182. package/dist/adapter/z-stack/znp/index.d.ts +3 -3
  183. package/dist/adapter/z-stack/znp/index.js +10 -10
  184. package/dist/adapter/z-stack/znp/parameterType.d.ts +22 -22
  185. package/dist/adapter/z-stack/znp/parameterType.js +25 -25
  186. package/dist/adapter/z-stack/znp/tstype.d.ts +21 -21
  187. package/dist/adapter/z-stack/znp/tstype.js +2 -2
  188. package/dist/adapter/z-stack/znp/znp.d.ts +43 -43
  189. package/dist/adapter/z-stack/znp/znp.js +325 -325
  190. package/dist/adapter/z-stack/znp/zpiObject.d.ts +19 -19
  191. package/dist/adapter/z-stack/znp/zpiObject.js +96 -96
  192. package/dist/adapter/zigate/adapter/index.d.ts +2 -2
  193. package/dist/adapter/zigate/adapter/index.js +10 -10
  194. package/dist/adapter/zigate/adapter/zigateAdapter.d.ts +69 -69
  195. package/dist/adapter/zigate/adapter/zigateAdapter.js +678 -678
  196. package/dist/adapter/zigate/debug.d.ts +7 -7
  197. package/dist/adapter/zigate/debug.js +22 -22
  198. package/dist/adapter/zigate/driver/buffaloZiGate.d.ts +18 -18
  199. package/dist/adapter/zigate/driver/buffaloZiGate.js +139 -139
  200. package/dist/adapter/zigate/driver/commandType.d.ts +41 -41
  201. package/dist/adapter/zigate/driver/commandType.js +385 -385
  202. package/dist/adapter/zigate/driver/constants.d.ts +276 -276
  203. package/dist/adapter/zigate/driver/constants.js +371 -371
  204. package/dist/adapter/zigate/driver/frame.d.ts +26 -26
  205. package/dist/adapter/zigate/driver/frame.js +172 -172
  206. package/dist/adapter/zigate/driver/frame.js.map +1 -1
  207. package/dist/adapter/zigate/driver/messageType.d.ts +11 -11
  208. package/dist/adapter/zigate/driver/messageType.js +278 -278
  209. package/dist/adapter/zigate/driver/parameterType.d.ts +20 -20
  210. package/dist/adapter/zigate/driver/parameterType.js +23 -23
  211. package/dist/adapter/zigate/driver/ziGateObject.d.ts +23 -23
  212. package/dist/adapter/zigate/driver/ziGateObject.js +106 -106
  213. package/dist/adapter/zigate/driver/zigate.d.ts +49 -49
  214. package/dist/adapter/zigate/driver/zigate.js +303 -303
  215. package/dist/buffalo/buffalo.d.ts +50 -48
  216. package/dist/buffalo/buffalo.d.ts.map +1 -1
  217. package/dist/buffalo/buffalo.js +322 -307
  218. package/dist/buffalo/buffalo.js.map +1 -1
  219. package/dist/buffalo/index.d.ts +3 -3
  220. package/dist/buffalo/index.js +33 -33
  221. package/dist/buffalo/tstype.d.ts +8 -8
  222. package/dist/buffalo/tstype.js +2 -2
  223. package/dist/controller/controller.d.ts +110 -110
  224. package/dist/controller/controller.js +607 -607
  225. package/dist/controller/database.d.ts +18 -18
  226. package/dist/controller/database.js +93 -93
  227. package/dist/controller/events.d.ts +55 -55
  228. package/dist/controller/events.d.ts.map +1 -1
  229. package/dist/controller/events.js +101 -99
  230. package/dist/controller/events.js.map +1 -1
  231. package/dist/controller/greenPower.d.ts +12 -12
  232. package/dist/controller/greenPower.js +220 -220
  233. package/dist/controller/helpers/index.d.ts +2 -2
  234. package/dist/controller/helpers/index.js +28 -28
  235. package/dist/controller/helpers/request.d.ts +23 -0
  236. package/dist/controller/helpers/request.d.ts.map +1 -0
  237. package/dist/controller/helpers/request.js +72 -0
  238. package/dist/controller/helpers/request.js.map +1 -0
  239. package/dist/controller/helpers/zclFrameConverter.d.ts +7 -7
  240. package/dist/controller/helpers/zclFrameConverter.js +31 -31
  241. package/dist/controller/helpers/zclTransactionSequenceNumber.d.ts +5 -5
  242. package/dist/controller/helpers/zclTransactionSequenceNumber.js +13 -13
  243. package/dist/controller/index.d.ts +5 -5
  244. package/dist/controller/index.js +8 -8
  245. package/dist/controller/logger-stub.d.ts +6 -6
  246. package/dist/controller/logger-stub.js +2 -2
  247. package/dist/controller/model/device.d.ts +132 -127
  248. package/dist/controller/model/device.d.ts.map +1 -1
  249. package/dist/controller/model/device.js +708 -681
  250. package/dist/controller/model/device.js.map +1 -1
  251. package/dist/controller/model/endpoint.d.ts +131 -128
  252. package/dist/controller/model/endpoint.d.ts.map +1 -1
  253. package/dist/controller/model/endpoint.js +817 -665
  254. package/dist/controller/model/endpoint.js.map +1 -1
  255. package/dist/controller/model/entity.d.ts +14 -14
  256. package/dist/controller/model/entity.js +26 -26
  257. package/dist/controller/model/group.d.ts +39 -39
  258. package/dist/controller/model/group.js +221 -221
  259. package/dist/controller/model/index.d.ts +5 -5
  260. package/dist/controller/model/index.js +14 -14
  261. package/dist/controller/touchlink.d.ts +19 -19
  262. package/dist/controller/touchlink.js +157 -157
  263. package/dist/controller/tstype.d.ts +21 -20
  264. package/dist/controller/tstype.d.ts.map +1 -1
  265. package/dist/controller/tstype.js +9 -9
  266. package/dist/controller/tstype.js.map +1 -1
  267. package/dist/index.d.ts +3 -3
  268. package/dist/index.js +33 -33
  269. package/dist/models/backup-storage-legacy.d.ts +26 -26
  270. package/dist/models/backup-storage-legacy.js +2 -2
  271. package/dist/models/backup-storage-unified.d.ts +49 -49
  272. package/dist/models/backup-storage-unified.js +2 -2
  273. package/dist/models/backup.d.ts +37 -37
  274. package/dist/models/backup.js +2 -2
  275. package/dist/models/index.d.ts +4 -4
  276. package/dist/models/index.js +20 -20
  277. package/dist/models/network-options.d.ts +12 -12
  278. package/dist/models/network-options.js +2 -2
  279. package/dist/utils/assertString.d.ts +2 -2
  280. package/dist/utils/assertString.js +8 -8
  281. package/dist/utils/backup.d.ts +20 -20
  282. package/dist/utils/backup.js +187 -187
  283. package/dist/utils/equalsPartial.d.ts +2 -2
  284. package/dist/utils/equalsPartial.js +11 -11
  285. package/dist/utils/index.d.ts +9 -9
  286. package/dist/utils/index.js +45 -45
  287. package/dist/utils/isNumberArray.d.ts +2 -2
  288. package/dist/utils/isNumberArray.js +6 -6
  289. package/dist/utils/queue.d.ts +11 -11
  290. package/dist/utils/queue.js +50 -50
  291. package/dist/utils/realpathSync.d.ts +2 -2
  292. package/dist/utils/realpathSync.js +12 -12
  293. package/dist/utils/wait.d.ts +2 -2
  294. package/dist/utils/wait.js +8 -8
  295. package/dist/utils/waitress.d.ts +21 -21
  296. package/dist/utils/waitress.js +61 -61
  297. package/dist/zcl/buffaloZcl.d.ts +41 -41
  298. package/dist/zcl/buffaloZcl.js +591 -591
  299. package/dist/zcl/definition/buffaloZclDataType.d.ts +17 -17
  300. package/dist/zcl/definition/buffaloZclDataType.js +20 -20
  301. package/dist/zcl/definition/cluster.d.ts +29 -29
  302. package/dist/zcl/definition/cluster.d.ts.map +1 -1
  303. package/dist/zcl/definition/cluster.js +5335 -5215
  304. package/dist/zcl/definition/cluster.js.map +1 -1
  305. package/dist/zcl/definition/dataType.d.ts +59 -59
  306. package/dist/zcl/definition/dataType.d.ts.map +1 -1
  307. package/dist/zcl/definition/dataType.js +64 -64
  308. package/dist/zcl/definition/dataType.js.map +1 -1
  309. package/dist/zcl/definition/direction.d.ts +5 -5
  310. package/dist/zcl/definition/direction.js +8 -8
  311. package/dist/zcl/definition/endpointDeviceType.d.ts +4 -4
  312. package/dist/zcl/definition/endpointDeviceType.js +15 -15
  313. package/dist/zcl/definition/foundation.d.ts +11 -11
  314. package/dist/zcl/definition/foundation.js +167 -167
  315. package/dist/zcl/definition/frameControl.d.ts +10 -10
  316. package/dist/zcl/definition/frameControl.js +2 -2
  317. package/dist/zcl/definition/frameType.d.ts +5 -5
  318. package/dist/zcl/definition/frameType.js +8 -8
  319. package/dist/zcl/definition/index.d.ts +13 -13
  320. package/dist/zcl/definition/index.js +51 -51
  321. package/dist/zcl/definition/manufacturerCode.d.ts +1074 -1074
  322. package/dist/zcl/definition/manufacturerCode.js +1079 -1079
  323. package/dist/zcl/definition/powerSource.d.ts +4 -4
  324. package/dist/zcl/definition/powerSource.js +12 -12
  325. package/dist/zcl/definition/status.d.ts +38 -38
  326. package/dist/zcl/definition/status.js +41 -41
  327. package/dist/zcl/definition/tstype.d.ts +16 -16
  328. package/dist/zcl/definition/tstype.js +2 -2
  329. package/dist/zcl/index.d.ts +15 -15
  330. package/dist/zcl/index.js +55 -55
  331. package/dist/zcl/tstype.d.ts +56 -56
  332. package/dist/zcl/tstype.js +10 -10
  333. package/dist/zcl/utils.d.ts +6 -6
  334. package/dist/zcl/utils.js +165 -165
  335. package/dist/zcl/zclFrame.d.ts +45 -45
  336. package/dist/zcl/zclFrame.js +347 -347
  337. package/dist/zcl/zclStatusError.d.ts +5 -5
  338. package/dist/zcl/zclStatusError.js +13 -13
  339. package/package.json +1 -1
  340. package/.github/ISSUE_TEMPLATE/config.yml +0 -5
  341. package/.github/dependabot.yml +0 -6
  342. package/.github/workflows/ci.yml +0 -40
  343. package/.github/workflows/release_please.yml +0 -20
  344. package/.github/workflows/stale.yml +0 -20
  345. package/.github/workflows/update_deps.yml +0 -29
@@ -1,477 +1,477 @@
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.ZnpAdapterManager = void 0;
30
- const debug_1 = __importDefault(require("debug"));
31
- const tstype_1 = require("./tstype");
32
- const common_1 = require("../constants/common");
33
- const Structs = __importStar(require("../structs"));
34
- const Utils = __importStar(require("../utils"));
35
- const ZnpConstants = __importStar(require("../constants"));
36
- const adapter_backup_1 = require("./adapter-backup");
37
- const adapter_nv_memory_1 = require("./adapter-nv-memory");
38
- const constants_1 = require("../unpi/constants");
39
- const UnpiConstants = __importStar(require("../unpi/constants"));
40
- const crypto = __importStar(require("crypto"));
41
- const utils_1 = require("../../../utils");
42
- const endpoints_1 = require("./endpoints");
43
- /**
44
- * ZNP Adapter Manager is responsible for handling adapter startup, network commissioning,
45
- * configuration backup and restore.
46
- */
47
- class ZnpAdapterManager {
48
- constructor(znp, options, logger) {
49
- this.debug = {
50
- startup: (0, debug_1.default)("zigbee-herdsman:adapter:zStack:startup"),
51
- strategy: (0, debug_1.default)("zigbee-herdsman:adapter:zStack:startup:strategy"),
52
- commissioning: (0, debug_1.default)("zigbee-herdsman:adapter:zStack:startup:commissioning")
53
- };
54
- this.znp = znp;
55
- this.options = options;
56
- this.nv = new adapter_nv_memory_1.AdapterNvMemory(this.znp);
57
- this.backup = new adapter_backup_1.AdapterBackup(this.znp, this.nv, this.options.backupPath);
58
- this.logger = logger;
59
- }
60
- /**
61
- * Performs ZNP adapter startup. After this method returns the adapter is configured, endpoints are registered
62
- * and network is ready to process frames.
63
- */
64
- async start() {
65
- this.debug.startup(`beginning znp startup`);
66
- this.nwkOptions = await this.parseConfigNetworkOptions(this.options.networkOptions);
67
- await this.nv.init();
68
- /* determine startup strategy */
69
- const strategy = await this.determineStrategy();
70
- this.debug.startup(`determined startup strategy: ${strategy}`);
71
- /* perform coordinator startup based on determined strategy */
72
- let result;
73
- switch (strategy) {
74
- case "startup": {
75
- await this.beginStartup();
76
- result = "resumed";
77
- break;
78
- }
79
- case "restoreBackup": {
80
- if (this.options.version === tstype_1.ZnpVersion.zStack12) {
81
- this.debug.startup(`performing recommissioning instead of restore for z-stack 1.2`);
82
- await this.beginCommissioning(this.nwkOptions);
83
- await this.beginStartup();
84
- }
85
- else {
86
- await this.beginRestore();
87
- }
88
- result = "restored";
89
- break;
90
- }
91
- case "startCommissioning": {
92
- if (this.options.version === tstype_1.ZnpVersion.zStack12) {
93
- const hasConfigured = await this.nv.readItem(common_1.NvItemsIds.ZNP_HAS_CONFIGURED_ZSTACK1, 0, Structs.hasConfigured);
94
- await this.beginCommissioning(this.nwkOptions);
95
- await this.beginStartup();
96
- result = hasConfigured && hasConfigured.isConfigured() ? "reset" : "restored";
97
- }
98
- else {
99
- await this.beginCommissioning(this.nwkOptions);
100
- result = "reset";
101
- }
102
- break;
103
- }
104
- }
105
- /* register endpoints */
106
- await this.registerEndpoints();
107
- /* add green power group */
108
- await this.addToGroup(242, this.options.greenPowerGroup);
109
- return result;
110
- }
111
- /**
112
- * Internal function to determine startup strategy. The strategy determination flow is described in
113
- * [this GitHub issue comment](https://github.com/Koenkk/zigbee-herdsman/issues/286#issuecomment-761029689).
114
- */
115
- async determineStrategy() {
116
- this.debug.strategy("determining znp startup strategy");
117
- /* acquire data from adapter */
118
- const hasConfiguredNvId = this.options.version === tstype_1.ZnpVersion.zStack12 ? common_1.NvItemsIds.ZNP_HAS_CONFIGURED_ZSTACK1 : common_1.NvItemsIds.ZNP_HAS_CONFIGURED_ZSTACK3;
119
- const hasConfigured = await this.nv.readItem(hasConfiguredNvId, 0, Structs.hasConfigured);
120
- const nib = await this.nv.readItem(common_1.NvItemsIds.NIB, 0, Structs.nib);
121
- const preconfiguredKey = this.options.version === tstype_1.ZnpVersion.zStack12 ?
122
- Structs.nwkKey((await this.znp.request(constants_1.Subsystem.SAPI, "readConfiguration", { configid: common_1.NvItemsIds.PRECFGKEY })).payload.value) :
123
- await this.nv.readItem(common_1.NvItemsIds.PRECFGKEY, 0, Structs.nwkKey);
124
- let activeKeyInfo = await this.nv.readItem(common_1.NvItemsIds.NWK_ACTIVE_KEY_INFO, 0, Structs.nwkKeyDescriptor);
125
- let alternateKeyInfo = await this.nv.readItem(common_1.NvItemsIds.NWK_ALTERN_KEY_INFO, 0, Structs.nwkKeyDescriptor);
126
- /* Z-Stack 1.2 does not provide key info entries */
127
- if (this.options.version === tstype_1.ZnpVersion.zStack12) {
128
- activeKeyInfo = Structs.nwkKeyDescriptor();
129
- activeKeyInfo.key = Buffer.from(preconfiguredKey.key);
130
- alternateKeyInfo = Structs.nwkKeyDescriptor();
131
- alternateKeyInfo.key = Buffer.from(preconfiguredKey.key);
132
- }
133
- /* get backup if available and supported by target */
134
- const backup = await this.backup.getStoredBackup();
135
- /* special treatment for incorrectly reversed Extended PAN IDs from previous releases */
136
- const isExtendedPanIdReversed = nib && this.nwkOptions.extendedPanId.equals(Buffer.from(nib.extendedPANID).reverse());
137
- /* istanbul ignore next */
138
- const configMatchesAdapter = (nib &&
139
- Utils.compareChannelLists(this.nwkOptions.channelList, nib.channelList) &&
140
- this.nwkOptions.panId === nib.nwkPanId &&
141
- (this.nwkOptions.extendedPanId.equals(nib.extendedPANID) ||
142
- /* exception for migration from previous code-base */
143
- isExtendedPanIdReversed ||
144
- /* exception for some adapters which may actually use 0xdddddddddddddddd as EPID (backward compatibility) */
145
- this.nwkOptions.hasDefaultExtendedPanId) &&
146
- this.nwkOptions.networkKey.equals(preconfiguredKey.key) &&
147
- this.nwkOptions.networkKey.equals(activeKeyInfo.key) &&
148
- this.nwkOptions.networkKey.equals(alternateKeyInfo.key));
149
- const backupMatchesAdapter = (backup &&
150
- nib &&
151
- backup.networkOptions.panId === nib.nwkPanId &&
152
- backup.networkOptions.extendedPanId.equals(nib.extendedPANID) &&
153
- Utils.compareChannelLists(backup.networkOptions.channelList, nib.channelList) &&
154
- backup.networkOptions.networkKey.equals(activeKeyInfo.key));
155
- const configMatchesBackup = (backup &&
156
- Utils.compareNetworkOptions(this.nwkOptions, backup.networkOptions, true));
157
- const checkRestoreVersionCompatibility = () => {
158
- var _a;
159
- if (this.options.version === tstype_1.ZnpVersion.zStack12 && backup && ((_a = backup.znp) === null || _a === void 0 ? void 0 : _a.version) !== undefined && backup.znp.version !== tstype_1.ZnpVersion.zStack12) {
160
- throw new Error(`your backup is from newer platform version (Z-Stack 3.0.x+) and cannot be restored onto Z-Stack 1.2 adapter - please remove backup before proceeding`);
161
- }
162
- };
163
- /* Determine startup strategy */
164
- if (!hasConfigured || !hasConfigured.isConfigured() || !nib) {
165
- /* Adapter is not configured or not commissioned */
166
- this.debug.strategy("(stage-1) adapter is not configured / not commissioned");
167
- if (configMatchesBackup) {
168
- /* Adapter backup is available and matches configuration */
169
- this.debug.strategy("(stage-2) configuration matches backup");
170
- checkRestoreVersionCompatibility();
171
- return "restoreBackup";
172
- }
173
- else {
174
- /* Adapter backup is either not available or does not match configuration */
175
- if (!backup) {
176
- this.debug.strategy("(stage-2) adapter backup does not exist");
177
- }
178
- else {
179
- this.debug.strategy("(stage-2) configuration does not match backup");
180
- }
181
- return "startCommissioning";
182
- }
183
- }
184
- else {
185
- /* Adapter is configured and commissioned */
186
- this.debug.strategy("(stage-1) adapter is configured");
187
- if (configMatchesAdapter) {
188
- /* Warn if EPID is reversed (backward-compat) */
189
- if (isExtendedPanIdReversed) {
190
- this.debug.strategy("(stage-2) extended pan id is reversed");
191
- this.logger.warn(`Extended PAN ID is reversed (expected=${this.nwkOptions.extendedPanId.toString("hex")}, actual=${nib.extendedPANID.toString("hex")})`);
192
- }
193
- /* Configuration matches adapter state - regular startup */
194
- this.debug.strategy("(stage-2) adapter state matches configuration");
195
- return "startup";
196
- }
197
- else {
198
- /* Configuration does not match adapter state */
199
- this.debug.strategy("(stage-2) adapter state does not match configuration");
200
- if (backup) {
201
- /* Backup is present */
202
- this.debug.strategy("(stage-3) got adapter backup");
203
- if (backupMatchesAdapter) {
204
- /* Backup matches adapter state */
205
- this.debug.strategy("(stage-4) adapter state matches backup");
206
- this.logger.error(`Configuration is not consistent with adapter state/backup!`);
207
- this.logger.error(`- PAN ID: configured=${this.nwkOptions.panId}, adapter=${nib.nwkPanId}`);
208
- this.logger.error(`- Extended PAN ID: configured=${this.nwkOptions.extendedPanId.toString("hex")}, adapter=${nib.extendedPANID.toString("hex")}`);
209
- this.logger.error(`- Network Key: configured=${this.nwkOptions.networkKey.toString("hex")}, adapter=${activeKeyInfo.key.toString("hex")}`);
210
- this.logger.error(`- Channel List: configured=${this.nwkOptions.channelList.toString()}, adapter=${Utils.unpackChannelList(nib.channelList).toString()}`);
211
- this.logger.error(`Please update configuration to prevent further issues.`);
212
- this.logger.error(`If you wish to re-commission your network, please remove coordinator backup at ${this.options.backupPath}.`);
213
- this.logger.error(`Re-commissioning your network will require re-pairing of all devices!`);
214
- if (this.options.adapterOptions.forceStartWithInconsistentAdapterConfiguration) {
215
- this.logger.error(`Running despite adapter configuration mismatch as configured. Please update the adapter to compatible firmware and recreate your network as soon as possible.`);
216
- return "startup";
217
- }
218
- else {
219
- throw new Error("startup failed - configuration-adapter mismatch - see logs above for more information");
220
- }
221
- }
222
- else {
223
- /* Backup does not match adapter state */
224
- this.debug.strategy("(stage-4) adapter state does not match backup");
225
- if (configMatchesBackup) {
226
- /* Adapter backup matches configuration */
227
- this.debug.strategy("(stage-5) adapter backup matches configuration");
228
- checkRestoreVersionCompatibility();
229
- return "restoreBackup";
230
- }
231
- else {
232
- /* Adapter backup does not match configuration */
233
- this.debug.strategy("(stage-5) adapter backup does not match configuration");
234
- return "startCommissioning";
235
- }
236
- }
237
- }
238
- else {
239
- /* Configuration mismatches adapter and no backup is available */
240
- this.debug.strategy("(stage-3) configuration-adapter mismatch (no backup)");
241
- return "startCommissioning";
242
- }
243
- }
244
- }
245
- }
246
- /**
247
- * Internal method to perform regular adapter startup in coordinator mode.
248
- */
249
- async beginStartup() {
250
- const deviceInfo = await this.znp.request(constants_1.Subsystem.UTIL, 'getDeviceInfo', {});
251
- if (deviceInfo.payload.devicestate !== common_1.DevStates.ZB_COORD) {
252
- this.debug.startup("starting adapter as coordinator");
253
- const started = this.znp.waitFor(UnpiConstants.Type.AREQ, constants_1.Subsystem.ZDO, 'stateChangeInd', { state: 9 }, 60000);
254
- await this.znp.request(constants_1.Subsystem.ZDO, 'startupFromApp', { startdelay: 100 }, null, null, [common_1.ZnpCommandStatus.SUCCESS, common_1.ZnpCommandStatus.FAILURE]);
255
- await started.start().promise;
256
- this.debug.startup("adapter successfully started in coordinator mode");
257
- }
258
- else {
259
- this.debug.startup("adapter is already running in coordinator mode");
260
- }
261
- }
262
- /**
263
- * Internal method to perform adapter restore.
264
- */
265
- async beginRestore() {
266
- const backup = await this.backup.getStoredBackup();
267
- /* istanbul ignore next */
268
- if (!backup) {
269
- throw Error("Cannot restore backup - none is available");
270
- }
271
- /* generate random provisioning network parameters */
272
- const provisioningNwkOptions = {
273
- panId: 1 + Math.round(Math.random() * 65532),
274
- extendedPanId: crypto.randomBytes(8),
275
- channelList: [11 + Math.round((Math.random() * (26 - 11)))],
276
- networkKey: crypto.randomBytes(16),
277
- networkKeyDistribute: false
278
- };
279
- /* commission provisioning network */
280
- this.debug.commissioning("commissioning random provisioning network:");
281
- this.debug.commissioning(` - panId: ${provisioningNwkOptions.panId}`);
282
- this.debug.commissioning(` - extendedPanId: ${provisioningNwkOptions.extendedPanId.toString("hex")}`);
283
- this.debug.commissioning(` - channelList: ${provisioningNwkOptions.channelList.join(", ")}`);
284
- this.debug.commissioning(` - networkKey: ${provisioningNwkOptions.networkKey.toString("hex")}`);
285
- this.debug.commissioning(` - networkKeyDistribute: ${provisioningNwkOptions.networkKeyDistribute}`);
286
- await this.beginCommissioning(provisioningNwkOptions, false, false);
287
- /* perform NV restore */
288
- await this.backup.restoreBackup(backup);
289
- /* update commissioning NV items with desired nwk configuration */
290
- await this.updateCommissioningNvItems(this.nwkOptions);
291
- /* settle & reset adapter */
292
- this.debug.commissioning("giving adapter some time to settle");
293
- await (0, utils_1.Wait)(1000);
294
- await this.resetAdapter();
295
- /* startup with restored adapter */
296
- await this.beginStartup();
297
- /* write configuration flag */
298
- await this.writeConfigurationFlag();
299
- }
300
- /**
301
- * Internal method to perform new network commissioning. Network commissioning creates a new ZigBee
302
- * network using the adapter.
303
- *
304
- * @param nwkOptions Options to configure the new network with.
305
- * @param failOnCollision Whether process should throw an error if PAN ID collision is detected.
306
- * @param writeConfiguredFlag Whether zigbee-herdsman `hasConfigured` flag should be written to NV.
307
- */
308
- async beginCommissioning(nwkOptions, failOnCollision = true, writeConfiguredFlag = true) {
309
- if (nwkOptions.panId === 65535) {
310
- throw new Error(`network commissioning failed - cannot use pan id 65535`);
311
- }
312
- /* clear and reset the adapter */
313
- await this.nv.deleteItem(common_1.NvItemsIds.NIB);
314
- await this.clearAdapter();
315
- /* commission the network as per parameters */
316
- await this.updateCommissioningNvItems(nwkOptions);
317
- this.debug.commissioning("beginning network commissioning");
318
- if ([tstype_1.ZnpVersion.zStack30x, tstype_1.ZnpVersion.zStack3x0].includes(this.options.version)) {
319
- /* configure channel */
320
- await this.znp.request(constants_1.Subsystem.APP_CNF, "bdbSetChannel", { isPrimary: 0x1, channel: Utils.packChannelList(nwkOptions.channelList) });
321
- await this.znp.request(constants_1.Subsystem.APP_CNF, "bdbSetChannel", { isPrimary: 0x0, channel: 0x0 });
322
- /* perform bdb commissioning */
323
- const started = this.znp.waitFor(UnpiConstants.Type.AREQ, constants_1.Subsystem.ZDO, "stateChangeInd", { state: 9 }, 60000);
324
- await this.znp.request(constants_1.Subsystem.APP_CNF, 'bdbStartCommissioning', { mode: 0x04 });
325
- try {
326
- await started.start().promise;
327
- }
328
- catch (error) {
329
- throw new Error(`network commissioning timed out - most likely network with the same panId or extendedPanId already exists nearby`);
330
- }
331
- }
332
- else {
333
- /* Z-Stack 1.2 requires startup to be performed instead of BDB commissioning */
334
- await this.beginStartup();
335
- }
336
- /* wait for NIB to settle (takes different amount of time of different platforms */
337
- this.debug.commissioning("waiting for NIB to settle");
338
- let reads = 0;
339
- let nib = null;
340
- do {
341
- await (0, utils_1.Wait)(3000);
342
- nib = await this.nv.readItem(common_1.NvItemsIds.NIB, 0, Structs.nib);
343
- reads++;
344
- } while ((!nib || nib.nwkPanId === 65535 || nib.nwkLogicalChannel === 0) && reads < 10);
345
- if (!nib || nib.nwkPanId === 65535 || nib.nwkLogicalChannel === 0) {
346
- throw new Error(`network commissioning failed - timed out waiting for nib to settle`);
347
- }
348
- /* validate provisioned PAN ID */
349
- const extNwkInfo = await this.znp.request(constants_1.Subsystem.ZDO, 'extNwkInfo', {});
350
- if (extNwkInfo.payload.panid !== nwkOptions.panId && failOnCollision) {
351
- throw new Error(`network commissioning failed - panId collision detected (expected=${nwkOptions.panId}, actual=${extNwkInfo.payload.panid})`);
352
- }
353
- this.debug.commissioning("network commissioned");
354
- /* write configuration flag */
355
- if (writeConfiguredFlag) {
356
- await this.writeConfigurationFlag();
357
- }
358
- }
359
- /**
360
- * Updates commissioning NV memory parameters in connected controller. This method should be invoked
361
- * to configure network commissioning parameters or update the controller after restore.
362
- *
363
- * @param options Network options to set in NV memory.
364
- */
365
- async updateCommissioningNvItems(options) {
366
- const nwkPanId = Structs.nwkPanId();
367
- nwkPanId.panId = options.panId;
368
- const channelList = Structs.channelList();
369
- channelList.channelList = Utils.packChannelList(options.channelList);
370
- const extendedPanIdReversed = Buffer.from(options.extendedPanId).reverse();
371
- this.debug.commissioning(`setting network commissioning parameters`);
372
- await this.nv.updateItem(common_1.NvItemsIds.STARTUP_OPTION, Buffer.from([0x00]));
373
- await this.nv.updateItem(common_1.NvItemsIds.LOGICAL_TYPE, Buffer.from([ZnpConstants.ZDO.deviceLogicalType.COORDINATOR]));
374
- await this.nv.updateItem(common_1.NvItemsIds.ZDO_DIRECT_CB, Buffer.from([0x01]));
375
- await this.nv.updateItem(common_1.NvItemsIds.CHANLIST, channelList.serialize());
376
- await this.nv.updateItem(common_1.NvItemsIds.PANID, nwkPanId.serialize());
377
- await this.nv.updateItem(common_1.NvItemsIds.EXTENDED_PAN_ID, extendedPanIdReversed);
378
- await this.nv.updateItem(common_1.NvItemsIds.APS_USE_EXT_PANID, extendedPanIdReversed);
379
- /* istanbul ignore next */
380
- await this.nv.updateItem(common_1.NvItemsIds.PRECFGKEYS_ENABLE, Buffer.from([options.networkKeyDistribute ? 0x01 : 0x00]));
381
- if ([tstype_1.ZnpVersion.zStack30x, tstype_1.ZnpVersion.zStack3x0].includes(this.options.version)) {
382
- await this.nv.updateItem(common_1.NvItemsIds.PRECFGKEY, options.networkKey);
383
- }
384
- else {
385
- await this.znp.request(constants_1.Subsystem.SAPI, "writeConfiguration", {
386
- configid: common_1.NvItemsIds.PRECFGKEY,
387
- len: options.networkKey.length,
388
- value: options.networkKey
389
- });
390
- await this.nv.writeItem(common_1.NvItemsIds.LEGACY_TCLK_TABLE_START_12, Buffer.from([
391
- 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x5a, 0x69, 0x67, 0x42, 0x65, 0x65, 0x41, 0x6c,
392
- 0x6c, 0x69, 0x61, 0x6e, 0x63, 0x65, 0x30, 0x39, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
393
- ]));
394
- }
395
- }
396
- /**
397
- * Registers endpoints before beginning normal operation.
398
- */
399
- async registerEndpoints() {
400
- const activeEpResponse = this.znp.waitFor(UnpiConstants.Type.AREQ, constants_1.Subsystem.ZDO, 'activeEpRsp');
401
- this.znp.request(constants_1.Subsystem.ZDO, 'activeEpReq', { dstaddr: 0, nwkaddrofinterest: 0 });
402
- const activeEp = await activeEpResponse.start().promise;
403
- for (const endpoint of endpoints_1.Endpoints) {
404
- if (activeEp.payload.activeeplist.includes(endpoint.endpoint)) {
405
- this.debug.startup(`endpoint '${endpoint.endpoint}' already registered`);
406
- }
407
- else {
408
- this.debug.startup(`registering endpoint '${endpoint.endpoint}'`);
409
- await this.znp.request(constants_1.Subsystem.AF, 'register', endpoint);
410
- }
411
- }
412
- }
413
- /**
414
- * Adds endpoint to group.
415
- *
416
- * @param endpoint Endpoint index to add.
417
- * @param group Target group index.
418
- */
419
- async addToGroup(endpoint, group) {
420
- const result = await this.znp.request(5, 'extFindGroup', { endpoint, groupid: group }, null, null, [common_1.ZnpCommandStatus.SUCCESS, common_1.ZnpCommandStatus.FAILURE]);
421
- if (result.payload.status === common_1.ZnpCommandStatus.FAILURE) {
422
- await this.znp.request(5, 'extAddGroup', { endpoint, groupid: group, namelen: 0, groupname: [] });
423
- }
424
- }
425
- /**
426
- * Internal method to reset the adapter.
427
- */
428
- async resetAdapter() {
429
- this.debug.startup("adapter reset requested");
430
- await this.znp.request(constants_1.Subsystem.SYS, 'resetReq', { type: ZnpConstants.SYS.resetType.SOFT });
431
- this.debug.startup("adapter reset successful");
432
- }
433
- /**
434
- * Internal method to reset adapter config and data.
435
- */
436
- async clearAdapter() {
437
- this.debug.startup("clearing adapter using startup option 3");
438
- await this.nv.writeItem(common_1.NvItemsIds.STARTUP_OPTION, Buffer.from([0x03]));
439
- await this.resetAdapter();
440
- await this.nv.writeItem(common_1.NvItemsIds.STARTUP_OPTION, Buffer.from([0x00]));
441
- }
442
- /**
443
- * Transforms Z2M number-based network options to local Buffer-based options.
444
- *
445
- * This function also takes care of `dd:dd:dd:dd:dd:dd:dd:dd` extended PAN ID
446
- * and replaces it with adapter IEEE address.
447
- *
448
- * @param options Source Z2M network options.
449
- */
450
- async parseConfigNetworkOptions(options) {
451
- const channelList = options.channelList;
452
- /* istanbul ignore next */
453
- channelList.sort((c1, c2) => c1 < c2 ? -1 : c1 > c2 ? 1 : 0);
454
- const parsed = {
455
- channelList: channelList,
456
- panId: options.panID,
457
- extendedPanId: Buffer.from(options.extendedPanID),
458
- networkKey: Buffer.from(options.networkKey),
459
- networkKeyDistribute: options.networkKeyDistribute
460
- };
461
- if (parsed.extendedPanId.equals(Buffer.alloc(8, 0xdd))) {
462
- const adapterIeeeAddressResponse = await this.znp.request(constants_1.Subsystem.SYS, "getExtAddr", {});
463
- parsed.extendedPanId = Buffer.from(adapterIeeeAddressResponse.payload.extaddress.split("0x")[1], "hex");
464
- parsed.hasDefaultExtendedPanId = true;
465
- }
466
- return parsed;
467
- }
468
- /**
469
- * Writes ZNP `hasConfigured` flag to NV memory. This flag indicates the adapter has been configured.
470
- */
471
- async writeConfigurationFlag() {
472
- this.debug.commissioning("writing configuration flag to adapter NV memory");
473
- await this.nv.writeItem(this.options.version === tstype_1.ZnpVersion.zStack12 ? common_1.NvItemsIds.ZNP_HAS_CONFIGURED_ZSTACK1 : common_1.NvItemsIds.ZNP_HAS_CONFIGURED_ZSTACK3, Buffer.from([0x55]));
474
- }
475
- }
476
- exports.ZnpAdapterManager = ZnpAdapterManager;
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.ZnpAdapterManager = void 0;
30
+ const debug_1 = __importDefault(require("debug"));
31
+ const tstype_1 = require("./tstype");
32
+ const common_1 = require("../constants/common");
33
+ const Structs = __importStar(require("../structs"));
34
+ const Utils = __importStar(require("../utils"));
35
+ const ZnpConstants = __importStar(require("../constants"));
36
+ const adapter_backup_1 = require("./adapter-backup");
37
+ const adapter_nv_memory_1 = require("./adapter-nv-memory");
38
+ const constants_1 = require("../unpi/constants");
39
+ const UnpiConstants = __importStar(require("../unpi/constants"));
40
+ const crypto = __importStar(require("crypto"));
41
+ const utils_1 = require("../../../utils");
42
+ const endpoints_1 = require("./endpoints");
43
+ /**
44
+ * ZNP Adapter Manager is responsible for handling adapter startup, network commissioning,
45
+ * configuration backup and restore.
46
+ */
47
+ class ZnpAdapterManager {
48
+ constructor(znp, options, logger) {
49
+ this.debug = {
50
+ startup: (0, debug_1.default)("zigbee-herdsman:adapter:zStack:startup"),
51
+ strategy: (0, debug_1.default)("zigbee-herdsman:adapter:zStack:startup:strategy"),
52
+ commissioning: (0, debug_1.default)("zigbee-herdsman:adapter:zStack:startup:commissioning")
53
+ };
54
+ this.znp = znp;
55
+ this.options = options;
56
+ this.nv = new adapter_nv_memory_1.AdapterNvMemory(this.znp);
57
+ this.backup = new adapter_backup_1.AdapterBackup(this.znp, this.nv, this.options.backupPath);
58
+ this.logger = logger;
59
+ }
60
+ /**
61
+ * Performs ZNP adapter startup. After this method returns the adapter is configured, endpoints are registered
62
+ * and network is ready to process frames.
63
+ */
64
+ async start() {
65
+ this.debug.startup(`beginning znp startup`);
66
+ this.nwkOptions = await this.parseConfigNetworkOptions(this.options.networkOptions);
67
+ await this.nv.init();
68
+ /* determine startup strategy */
69
+ const strategy = await this.determineStrategy();
70
+ this.debug.startup(`determined startup strategy: ${strategy}`);
71
+ /* perform coordinator startup based on determined strategy */
72
+ let result;
73
+ switch (strategy) {
74
+ case "startup": {
75
+ await this.beginStartup();
76
+ result = "resumed";
77
+ break;
78
+ }
79
+ case "restoreBackup": {
80
+ if (this.options.version === tstype_1.ZnpVersion.zStack12) {
81
+ this.debug.startup(`performing recommissioning instead of restore for z-stack 1.2`);
82
+ await this.beginCommissioning(this.nwkOptions);
83
+ await this.beginStartup();
84
+ }
85
+ else {
86
+ await this.beginRestore();
87
+ }
88
+ result = "restored";
89
+ break;
90
+ }
91
+ case "startCommissioning": {
92
+ if (this.options.version === tstype_1.ZnpVersion.zStack12) {
93
+ const hasConfigured = await this.nv.readItem(common_1.NvItemsIds.ZNP_HAS_CONFIGURED_ZSTACK1, 0, Structs.hasConfigured);
94
+ await this.beginCommissioning(this.nwkOptions);
95
+ await this.beginStartup();
96
+ result = hasConfigured && hasConfigured.isConfigured() ? "reset" : "restored";
97
+ }
98
+ else {
99
+ await this.beginCommissioning(this.nwkOptions);
100
+ result = "reset";
101
+ }
102
+ break;
103
+ }
104
+ }
105
+ /* register endpoints */
106
+ await this.registerEndpoints();
107
+ /* add green power group */
108
+ await this.addToGroup(242, this.options.greenPowerGroup);
109
+ return result;
110
+ }
111
+ /**
112
+ * Internal function to determine startup strategy. The strategy determination flow is described in
113
+ * [this GitHub issue comment](https://github.com/Koenkk/zigbee-herdsman/issues/286#issuecomment-761029689).
114
+ */
115
+ async determineStrategy() {
116
+ this.debug.strategy("determining znp startup strategy");
117
+ /* acquire data from adapter */
118
+ const hasConfiguredNvId = this.options.version === tstype_1.ZnpVersion.zStack12 ? common_1.NvItemsIds.ZNP_HAS_CONFIGURED_ZSTACK1 : common_1.NvItemsIds.ZNP_HAS_CONFIGURED_ZSTACK3;
119
+ const hasConfigured = await this.nv.readItem(hasConfiguredNvId, 0, Structs.hasConfigured);
120
+ const nib = await this.nv.readItem(common_1.NvItemsIds.NIB, 0, Structs.nib);
121
+ const preconfiguredKey = this.options.version === tstype_1.ZnpVersion.zStack12 ?
122
+ Structs.nwkKey((await this.znp.request(constants_1.Subsystem.SAPI, "readConfiguration", { configid: common_1.NvItemsIds.PRECFGKEY })).payload.value) :
123
+ await this.nv.readItem(common_1.NvItemsIds.PRECFGKEY, 0, Structs.nwkKey);
124
+ let activeKeyInfo = await this.nv.readItem(common_1.NvItemsIds.NWK_ACTIVE_KEY_INFO, 0, Structs.nwkKeyDescriptor);
125
+ let alternateKeyInfo = await this.nv.readItem(common_1.NvItemsIds.NWK_ALTERN_KEY_INFO, 0, Structs.nwkKeyDescriptor);
126
+ /* Z-Stack 1.2 does not provide key info entries */
127
+ if (this.options.version === tstype_1.ZnpVersion.zStack12) {
128
+ activeKeyInfo = Structs.nwkKeyDescriptor();
129
+ activeKeyInfo.key = Buffer.from(preconfiguredKey.key);
130
+ alternateKeyInfo = Structs.nwkKeyDescriptor();
131
+ alternateKeyInfo.key = Buffer.from(preconfiguredKey.key);
132
+ }
133
+ /* get backup if available and supported by target */
134
+ const backup = await this.backup.getStoredBackup();
135
+ /* special treatment for incorrectly reversed Extended PAN IDs from previous releases */
136
+ const isExtendedPanIdReversed = nib && this.nwkOptions.extendedPanId.equals(Buffer.from(nib.extendedPANID).reverse());
137
+ /* istanbul ignore next */
138
+ const configMatchesAdapter = (nib &&
139
+ Utils.compareChannelLists(this.nwkOptions.channelList, nib.channelList) &&
140
+ this.nwkOptions.panId === nib.nwkPanId &&
141
+ (this.nwkOptions.extendedPanId.equals(nib.extendedPANID) ||
142
+ /* exception for migration from previous code-base */
143
+ isExtendedPanIdReversed ||
144
+ /* exception for some adapters which may actually use 0xdddddddddddddddd as EPID (backward compatibility) */
145
+ this.nwkOptions.hasDefaultExtendedPanId) &&
146
+ this.nwkOptions.networkKey.equals(preconfiguredKey.key) &&
147
+ this.nwkOptions.networkKey.equals(activeKeyInfo.key) &&
148
+ this.nwkOptions.networkKey.equals(alternateKeyInfo.key));
149
+ const backupMatchesAdapter = (backup &&
150
+ nib &&
151
+ backup.networkOptions.panId === nib.nwkPanId &&
152
+ backup.networkOptions.extendedPanId.equals(nib.extendedPANID) &&
153
+ Utils.compareChannelLists(backup.networkOptions.channelList, nib.channelList) &&
154
+ backup.networkOptions.networkKey.equals(activeKeyInfo.key));
155
+ const configMatchesBackup = (backup &&
156
+ Utils.compareNetworkOptions(this.nwkOptions, backup.networkOptions, true));
157
+ const checkRestoreVersionCompatibility = () => {
158
+ var _a;
159
+ if (this.options.version === tstype_1.ZnpVersion.zStack12 && backup && ((_a = backup.znp) === null || _a === void 0 ? void 0 : _a.version) !== undefined && backup.znp.version !== tstype_1.ZnpVersion.zStack12) {
160
+ throw new Error(`your backup is from newer platform version (Z-Stack 3.0.x+) and cannot be restored onto Z-Stack 1.2 adapter - please remove backup before proceeding`);
161
+ }
162
+ };
163
+ /* Determine startup strategy */
164
+ if (!hasConfigured || !hasConfigured.isConfigured() || !nib) {
165
+ /* Adapter is not configured or not commissioned */
166
+ this.debug.strategy("(stage-1) adapter is not configured / not commissioned");
167
+ if (configMatchesBackup) {
168
+ /* Adapter backup is available and matches configuration */
169
+ this.debug.strategy("(stage-2) configuration matches backup");
170
+ checkRestoreVersionCompatibility();
171
+ return "restoreBackup";
172
+ }
173
+ else {
174
+ /* Adapter backup is either not available or does not match configuration */
175
+ if (!backup) {
176
+ this.debug.strategy("(stage-2) adapter backup does not exist");
177
+ }
178
+ else {
179
+ this.debug.strategy("(stage-2) configuration does not match backup");
180
+ }
181
+ return "startCommissioning";
182
+ }
183
+ }
184
+ else {
185
+ /* Adapter is configured and commissioned */
186
+ this.debug.strategy("(stage-1) adapter is configured");
187
+ if (configMatchesAdapter) {
188
+ /* Warn if EPID is reversed (backward-compat) */
189
+ if (isExtendedPanIdReversed) {
190
+ this.debug.strategy("(stage-2) extended pan id is reversed");
191
+ this.logger.warn(`Extended PAN ID is reversed (expected=${this.nwkOptions.extendedPanId.toString("hex")}, actual=${nib.extendedPANID.toString("hex")})`);
192
+ }
193
+ /* Configuration matches adapter state - regular startup */
194
+ this.debug.strategy("(stage-2) adapter state matches configuration");
195
+ return "startup";
196
+ }
197
+ else {
198
+ /* Configuration does not match adapter state */
199
+ this.debug.strategy("(stage-2) adapter state does not match configuration");
200
+ if (backup) {
201
+ /* Backup is present */
202
+ this.debug.strategy("(stage-3) got adapter backup");
203
+ if (backupMatchesAdapter) {
204
+ /* Backup matches adapter state */
205
+ this.debug.strategy("(stage-4) adapter state matches backup");
206
+ this.logger.error(`Configuration is not consistent with adapter state/backup!`);
207
+ this.logger.error(`- PAN ID: configured=${this.nwkOptions.panId}, adapter=${nib.nwkPanId}`);
208
+ this.logger.error(`- Extended PAN ID: configured=${this.nwkOptions.extendedPanId.toString("hex")}, adapter=${nib.extendedPANID.toString("hex")}`);
209
+ this.logger.error(`- Network Key: configured=${this.nwkOptions.networkKey.toString("hex")}, adapter=${activeKeyInfo.key.toString("hex")}`);
210
+ this.logger.error(`- Channel List: configured=${this.nwkOptions.channelList.toString()}, adapter=${Utils.unpackChannelList(nib.channelList).toString()}`);
211
+ this.logger.error(`Please update configuration to prevent further issues.`);
212
+ this.logger.error(`If you wish to re-commission your network, please remove coordinator backup at ${this.options.backupPath}.`);
213
+ this.logger.error(`Re-commissioning your network will require re-pairing of all devices!`);
214
+ if (this.options.adapterOptions.forceStartWithInconsistentAdapterConfiguration) {
215
+ this.logger.error(`Running despite adapter configuration mismatch as configured. Please update the adapter to compatible firmware and recreate your network as soon as possible.`);
216
+ return "startup";
217
+ }
218
+ else {
219
+ throw new Error("startup failed - configuration-adapter mismatch - see logs above for more information");
220
+ }
221
+ }
222
+ else {
223
+ /* Backup does not match adapter state */
224
+ this.debug.strategy("(stage-4) adapter state does not match backup");
225
+ if (configMatchesBackup) {
226
+ /* Adapter backup matches configuration */
227
+ this.debug.strategy("(stage-5) adapter backup matches configuration");
228
+ checkRestoreVersionCompatibility();
229
+ return "restoreBackup";
230
+ }
231
+ else {
232
+ /* Adapter backup does not match configuration */
233
+ this.debug.strategy("(stage-5) adapter backup does not match configuration");
234
+ return "startCommissioning";
235
+ }
236
+ }
237
+ }
238
+ else {
239
+ /* Configuration mismatches adapter and no backup is available */
240
+ this.debug.strategy("(stage-3) configuration-adapter mismatch (no backup)");
241
+ return "startCommissioning";
242
+ }
243
+ }
244
+ }
245
+ }
246
+ /**
247
+ * Internal method to perform regular adapter startup in coordinator mode.
248
+ */
249
+ async beginStartup() {
250
+ const deviceInfo = await this.znp.request(constants_1.Subsystem.UTIL, 'getDeviceInfo', {});
251
+ if (deviceInfo.payload.devicestate !== common_1.DevStates.ZB_COORD) {
252
+ this.debug.startup("starting adapter as coordinator");
253
+ const started = this.znp.waitFor(UnpiConstants.Type.AREQ, constants_1.Subsystem.ZDO, 'stateChangeInd', { state: 9 }, 60000);
254
+ await this.znp.request(constants_1.Subsystem.ZDO, 'startupFromApp', { startdelay: 100 }, null, null, [common_1.ZnpCommandStatus.SUCCESS, common_1.ZnpCommandStatus.FAILURE]);
255
+ await started.start().promise;
256
+ this.debug.startup("adapter successfully started in coordinator mode");
257
+ }
258
+ else {
259
+ this.debug.startup("adapter is already running in coordinator mode");
260
+ }
261
+ }
262
+ /**
263
+ * Internal method to perform adapter restore.
264
+ */
265
+ async beginRestore() {
266
+ const backup = await this.backup.getStoredBackup();
267
+ /* istanbul ignore next */
268
+ if (!backup) {
269
+ throw Error("Cannot restore backup - none is available");
270
+ }
271
+ /* generate random provisioning network parameters */
272
+ const provisioningNwkOptions = {
273
+ panId: 1 + Math.round(Math.random() * 65532),
274
+ extendedPanId: crypto.randomBytes(8),
275
+ channelList: [11 + Math.round((Math.random() * (26 - 11)))],
276
+ networkKey: crypto.randomBytes(16),
277
+ networkKeyDistribute: false
278
+ };
279
+ /* commission provisioning network */
280
+ this.debug.commissioning("commissioning random provisioning network:");
281
+ this.debug.commissioning(` - panId: ${provisioningNwkOptions.panId}`);
282
+ this.debug.commissioning(` - extendedPanId: ${provisioningNwkOptions.extendedPanId.toString("hex")}`);
283
+ this.debug.commissioning(` - channelList: ${provisioningNwkOptions.channelList.join(", ")}`);
284
+ this.debug.commissioning(` - networkKey: ${provisioningNwkOptions.networkKey.toString("hex")}`);
285
+ this.debug.commissioning(` - networkKeyDistribute: ${provisioningNwkOptions.networkKeyDistribute}`);
286
+ await this.beginCommissioning(provisioningNwkOptions, false, false);
287
+ /* perform NV restore */
288
+ await this.backup.restoreBackup(backup);
289
+ /* update commissioning NV items with desired nwk configuration */
290
+ await this.updateCommissioningNvItems(this.nwkOptions);
291
+ /* settle & reset adapter */
292
+ this.debug.commissioning("giving adapter some time to settle");
293
+ await (0, utils_1.Wait)(1000);
294
+ await this.resetAdapter();
295
+ /* startup with restored adapter */
296
+ await this.beginStartup();
297
+ /* write configuration flag */
298
+ await this.writeConfigurationFlag();
299
+ }
300
+ /**
301
+ * Internal method to perform new network commissioning. Network commissioning creates a new ZigBee
302
+ * network using the adapter.
303
+ *
304
+ * @param nwkOptions Options to configure the new network with.
305
+ * @param failOnCollision Whether process should throw an error if PAN ID collision is detected.
306
+ * @param writeConfiguredFlag Whether zigbee-herdsman `hasConfigured` flag should be written to NV.
307
+ */
308
+ async beginCommissioning(nwkOptions, failOnCollision = true, writeConfiguredFlag = true) {
309
+ if (nwkOptions.panId === 65535) {
310
+ throw new Error(`network commissioning failed - cannot use pan id 65535`);
311
+ }
312
+ /* clear and reset the adapter */
313
+ await this.nv.deleteItem(common_1.NvItemsIds.NIB);
314
+ await this.clearAdapter();
315
+ /* commission the network as per parameters */
316
+ await this.updateCommissioningNvItems(nwkOptions);
317
+ this.debug.commissioning("beginning network commissioning");
318
+ if ([tstype_1.ZnpVersion.zStack30x, tstype_1.ZnpVersion.zStack3x0].includes(this.options.version)) {
319
+ /* configure channel */
320
+ await this.znp.request(constants_1.Subsystem.APP_CNF, "bdbSetChannel", { isPrimary: 0x1, channel: Utils.packChannelList(nwkOptions.channelList) });
321
+ await this.znp.request(constants_1.Subsystem.APP_CNF, "bdbSetChannel", { isPrimary: 0x0, channel: 0x0 });
322
+ /* perform bdb commissioning */
323
+ const started = this.znp.waitFor(UnpiConstants.Type.AREQ, constants_1.Subsystem.ZDO, "stateChangeInd", { state: 9 }, 60000);
324
+ await this.znp.request(constants_1.Subsystem.APP_CNF, 'bdbStartCommissioning', { mode: 0x04 });
325
+ try {
326
+ await started.start().promise;
327
+ }
328
+ catch (error) {
329
+ throw new Error(`network commissioning timed out - most likely network with the same panId or extendedPanId already exists nearby`);
330
+ }
331
+ }
332
+ else {
333
+ /* Z-Stack 1.2 requires startup to be performed instead of BDB commissioning */
334
+ await this.beginStartup();
335
+ }
336
+ /* wait for NIB to settle (takes different amount of time of different platforms */
337
+ this.debug.commissioning("waiting for NIB to settle");
338
+ let reads = 0;
339
+ let nib = null;
340
+ do {
341
+ await (0, utils_1.Wait)(3000);
342
+ nib = await this.nv.readItem(common_1.NvItemsIds.NIB, 0, Structs.nib);
343
+ reads++;
344
+ } while ((!nib || nib.nwkPanId === 65535 || nib.nwkLogicalChannel === 0) && reads < 10);
345
+ if (!nib || nib.nwkPanId === 65535 || nib.nwkLogicalChannel === 0) {
346
+ throw new Error(`network commissioning failed - timed out waiting for nib to settle`);
347
+ }
348
+ /* validate provisioned PAN ID */
349
+ const extNwkInfo = await this.znp.request(constants_1.Subsystem.ZDO, 'extNwkInfo', {});
350
+ if (extNwkInfo.payload.panid !== nwkOptions.panId && failOnCollision) {
351
+ throw new Error(`network commissioning failed - panId collision detected (expected=${nwkOptions.panId}, actual=${extNwkInfo.payload.panid})`);
352
+ }
353
+ this.debug.commissioning("network commissioned");
354
+ /* write configuration flag */
355
+ if (writeConfiguredFlag) {
356
+ await this.writeConfigurationFlag();
357
+ }
358
+ }
359
+ /**
360
+ * Updates commissioning NV memory parameters in connected controller. This method should be invoked
361
+ * to configure network commissioning parameters or update the controller after restore.
362
+ *
363
+ * @param options Network options to set in NV memory.
364
+ */
365
+ async updateCommissioningNvItems(options) {
366
+ const nwkPanId = Structs.nwkPanId();
367
+ nwkPanId.panId = options.panId;
368
+ const channelList = Structs.channelList();
369
+ channelList.channelList = Utils.packChannelList(options.channelList);
370
+ const extendedPanIdReversed = Buffer.from(options.extendedPanId).reverse();
371
+ this.debug.commissioning(`setting network commissioning parameters`);
372
+ await this.nv.updateItem(common_1.NvItemsIds.STARTUP_OPTION, Buffer.from([0x00]));
373
+ await this.nv.updateItem(common_1.NvItemsIds.LOGICAL_TYPE, Buffer.from([ZnpConstants.ZDO.deviceLogicalType.COORDINATOR]));
374
+ await this.nv.updateItem(common_1.NvItemsIds.ZDO_DIRECT_CB, Buffer.from([0x01]));
375
+ await this.nv.updateItem(common_1.NvItemsIds.CHANLIST, channelList.serialize());
376
+ await this.nv.updateItem(common_1.NvItemsIds.PANID, nwkPanId.serialize());
377
+ await this.nv.updateItem(common_1.NvItemsIds.EXTENDED_PAN_ID, extendedPanIdReversed);
378
+ await this.nv.updateItem(common_1.NvItemsIds.APS_USE_EXT_PANID, extendedPanIdReversed);
379
+ /* istanbul ignore next */
380
+ await this.nv.updateItem(common_1.NvItemsIds.PRECFGKEYS_ENABLE, Buffer.from([options.networkKeyDistribute ? 0x01 : 0x00]));
381
+ if ([tstype_1.ZnpVersion.zStack30x, tstype_1.ZnpVersion.zStack3x0].includes(this.options.version)) {
382
+ await this.nv.updateItem(common_1.NvItemsIds.PRECFGKEY, options.networkKey);
383
+ }
384
+ else {
385
+ await this.znp.request(constants_1.Subsystem.SAPI, "writeConfiguration", {
386
+ configid: common_1.NvItemsIds.PRECFGKEY,
387
+ len: options.networkKey.length,
388
+ value: options.networkKey
389
+ });
390
+ await this.nv.writeItem(common_1.NvItemsIds.LEGACY_TCLK_TABLE_START_12, Buffer.from([
391
+ 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x5a, 0x69, 0x67, 0x42, 0x65, 0x65, 0x41, 0x6c,
392
+ 0x6c, 0x69, 0x61, 0x6e, 0x63, 0x65, 0x30, 0x39, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
393
+ ]));
394
+ }
395
+ }
396
+ /**
397
+ * Registers endpoints before beginning normal operation.
398
+ */
399
+ async registerEndpoints() {
400
+ const activeEpResponse = this.znp.waitFor(UnpiConstants.Type.AREQ, constants_1.Subsystem.ZDO, 'activeEpRsp');
401
+ this.znp.request(constants_1.Subsystem.ZDO, 'activeEpReq', { dstaddr: 0, nwkaddrofinterest: 0 });
402
+ const activeEp = await activeEpResponse.start().promise;
403
+ for (const endpoint of endpoints_1.Endpoints) {
404
+ if (activeEp.payload.activeeplist.includes(endpoint.endpoint)) {
405
+ this.debug.startup(`endpoint '${endpoint.endpoint}' already registered`);
406
+ }
407
+ else {
408
+ this.debug.startup(`registering endpoint '${endpoint.endpoint}'`);
409
+ await this.znp.request(constants_1.Subsystem.AF, 'register', endpoint);
410
+ }
411
+ }
412
+ }
413
+ /**
414
+ * Adds endpoint to group.
415
+ *
416
+ * @param endpoint Endpoint index to add.
417
+ * @param group Target group index.
418
+ */
419
+ async addToGroup(endpoint, group) {
420
+ const result = await this.znp.request(5, 'extFindGroup', { endpoint, groupid: group }, null, null, [common_1.ZnpCommandStatus.SUCCESS, common_1.ZnpCommandStatus.FAILURE]);
421
+ if (result.payload.status === common_1.ZnpCommandStatus.FAILURE) {
422
+ await this.znp.request(5, 'extAddGroup', { endpoint, groupid: group, namelen: 0, groupname: [] });
423
+ }
424
+ }
425
+ /**
426
+ * Internal method to reset the adapter.
427
+ */
428
+ async resetAdapter() {
429
+ this.debug.startup("adapter reset requested");
430
+ await this.znp.request(constants_1.Subsystem.SYS, 'resetReq', { type: ZnpConstants.SYS.resetType.SOFT });
431
+ this.debug.startup("adapter reset successful");
432
+ }
433
+ /**
434
+ * Internal method to reset adapter config and data.
435
+ */
436
+ async clearAdapter() {
437
+ this.debug.startup("clearing adapter using startup option 3");
438
+ await this.nv.writeItem(common_1.NvItemsIds.STARTUP_OPTION, Buffer.from([0x03]));
439
+ await this.resetAdapter();
440
+ await this.nv.writeItem(common_1.NvItemsIds.STARTUP_OPTION, Buffer.from([0x00]));
441
+ }
442
+ /**
443
+ * Transforms Z2M number-based network options to local Buffer-based options.
444
+ *
445
+ * This function also takes care of `dd:dd:dd:dd:dd:dd:dd:dd` extended PAN ID
446
+ * and replaces it with adapter IEEE address.
447
+ *
448
+ * @param options Source Z2M network options.
449
+ */
450
+ async parseConfigNetworkOptions(options) {
451
+ const channelList = options.channelList;
452
+ /* istanbul ignore next */
453
+ channelList.sort((c1, c2) => c1 < c2 ? -1 : c1 > c2 ? 1 : 0);
454
+ const parsed = {
455
+ channelList: channelList,
456
+ panId: options.panID,
457
+ extendedPanId: Buffer.from(options.extendedPanID),
458
+ networkKey: Buffer.from(options.networkKey),
459
+ networkKeyDistribute: options.networkKeyDistribute
460
+ };
461
+ if (parsed.extendedPanId.equals(Buffer.alloc(8, 0xdd))) {
462
+ const adapterIeeeAddressResponse = await this.znp.request(constants_1.Subsystem.SYS, "getExtAddr", {});
463
+ parsed.extendedPanId = Buffer.from(adapterIeeeAddressResponse.payload.extaddress.split("0x")[1], "hex");
464
+ parsed.hasDefaultExtendedPanId = true;
465
+ }
466
+ return parsed;
467
+ }
468
+ /**
469
+ * Writes ZNP `hasConfigured` flag to NV memory. This flag indicates the adapter has been configured.
470
+ */
471
+ async writeConfigurationFlag() {
472
+ this.debug.commissioning("writing configuration flag to adapter NV memory");
473
+ await this.nv.writeItem(this.options.version === tstype_1.ZnpVersion.zStack12 ? common_1.NvItemsIds.ZNP_HAS_CONFIGURED_ZSTACK1 : common_1.NvItemsIds.ZNP_HAS_CONFIGURED_ZSTACK3, Buffer.from([0x55]));
474
+ }
475
+ }
476
+ exports.ZnpAdapterManager = ZnpAdapterManager;
477
477
  //# sourceMappingURL=manager.js.map