zigbee-herdsman 6.0.1 → 6.0.3

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 (260) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/adapter/ezsp/driver/uart.js +1 -1
  3. package/dist/adapter/ezsp/driver/uart.js.map +1 -1
  4. package/dist/adapter/z-stack/adapter/zStackAdapter.js +4 -4
  5. package/dist/adapter/z-stack/adapter/zStackAdapter.js.map +1 -1
  6. package/dist/adapter/zigate/adapter/zigateAdapter.js +4 -4
  7. package/dist/adapter/zigate/adapter/zigateAdapter.js.map +1 -1
  8. package/dist/controller/model/device.d.ts.map +1 -1
  9. package/dist/controller/model/device.js +1 -0
  10. package/dist/controller/model/device.js.map +1 -1
  11. package/package.json +14 -6
  12. package/.github/ISSUE_TEMPLATE/config.yml +0 -5
  13. package/.github/dependabot.yml +0 -22
  14. package/.github/workflows/ci.yml +0 -64
  15. package/.github/workflows/release-please.yml +0 -18
  16. package/.github/workflows/stale.yml +0 -20
  17. package/.github/workflows/typedoc.yaml +0 -47
  18. package/.release-please-manifest.json +0 -3
  19. package/.vscode/extensions.json +0 -3
  20. package/.vscode/settings.json +0 -11
  21. package/biome.json +0 -98
  22. package/examples/join-and-log.js +0 -24
  23. package/release-please-config.json +0 -9
  24. package/src/adapter/adapter.ts +0 -189
  25. package/src/adapter/adapterDiscovery.ts +0 -666
  26. package/src/adapter/const.ts +0 -12
  27. package/src/adapter/deconz/adapter/deconzAdapter.ts +0 -877
  28. package/src/adapter/deconz/driver/constants.ts +0 -246
  29. package/src/adapter/deconz/driver/driver.ts +0 -1540
  30. package/src/adapter/deconz/driver/frame.ts +0 -11
  31. package/src/adapter/deconz/driver/frameParser.ts +0 -753
  32. package/src/adapter/deconz/driver/parser.ts +0 -45
  33. package/src/adapter/deconz/driver/writer.ts +0 -22
  34. package/src/adapter/deconz/types.d.ts +0 -13
  35. package/src/adapter/ember/adapter/emberAdapter.ts +0 -2265
  36. package/src/adapter/ember/adapter/endpoints.ts +0 -86
  37. package/src/adapter/ember/adapter/oneWaitress.ts +0 -324
  38. package/src/adapter/ember/adapter/tokensManager.ts +0 -782
  39. package/src/adapter/ember/consts.ts +0 -178
  40. package/src/adapter/ember/enums.ts +0 -1746
  41. package/src/adapter/ember/ezsp/buffalo.ts +0 -1392
  42. package/src/adapter/ember/ezsp/consts.ts +0 -148
  43. package/src/adapter/ember/ezsp/enums.ts +0 -1114
  44. package/src/adapter/ember/ezsp/ezsp.ts +0 -9061
  45. package/src/adapter/ember/ezspError.ts +0 -10
  46. package/src/adapter/ember/types.ts +0 -866
  47. package/src/adapter/ember/uart/ash.ts +0 -1960
  48. package/src/adapter/ember/uart/consts.ts +0 -109
  49. package/src/adapter/ember/uart/enums.ts +0 -192
  50. package/src/adapter/ember/uart/parser.ts +0 -48
  51. package/src/adapter/ember/uart/queues.ts +0 -247
  52. package/src/adapter/ember/uart/writer.ts +0 -53
  53. package/src/adapter/ember/utils/initters.ts +0 -58
  54. package/src/adapter/ember/utils/math.ts +0 -73
  55. package/src/adapter/events.ts +0 -21
  56. package/src/adapter/ezsp/adapter/backup.ts +0 -109
  57. package/src/adapter/ezsp/adapter/ezspAdapter.ts +0 -614
  58. package/src/adapter/ezsp/driver/commands.ts +0 -2497
  59. package/src/adapter/ezsp/driver/consts.ts +0 -11
  60. package/src/adapter/ezsp/driver/driver.ts +0 -1002
  61. package/src/adapter/ezsp/driver/ezsp.ts +0 -802
  62. package/src/adapter/ezsp/driver/frame.ts +0 -101
  63. package/src/adapter/ezsp/driver/index.ts +0 -4
  64. package/src/adapter/ezsp/driver/multicast.ts +0 -78
  65. package/src/adapter/ezsp/driver/parser.ts +0 -81
  66. package/src/adapter/ezsp/driver/types/basic.ts +0 -201
  67. package/src/adapter/ezsp/driver/types/index.ts +0 -239
  68. package/src/adapter/ezsp/driver/types/named.ts +0 -2330
  69. package/src/adapter/ezsp/driver/types/struct.ts +0 -844
  70. package/src/adapter/ezsp/driver/uart.ts +0 -460
  71. package/src/adapter/ezsp/driver/utils/crc16ccitt.ts +0 -44
  72. package/src/adapter/ezsp/driver/utils/index.ts +0 -32
  73. package/src/adapter/ezsp/driver/writer.ts +0 -64
  74. package/src/adapter/index.ts +0 -3
  75. package/src/adapter/serialPort.ts +0 -58
  76. package/src/adapter/socketPortUtils.ts +0 -16
  77. package/src/adapter/tstype.ts +0 -78
  78. package/src/adapter/z-stack/adapter/adapter-backup.ts +0 -519
  79. package/src/adapter/z-stack/adapter/adapter-nv-memory.ts +0 -457
  80. package/src/adapter/z-stack/adapter/endpoints.ts +0 -57
  81. package/src/adapter/z-stack/adapter/manager.ts +0 -543
  82. package/src/adapter/z-stack/adapter/tstype.ts +0 -6
  83. package/src/adapter/z-stack/adapter/zStackAdapter.ts +0 -1190
  84. package/src/adapter/z-stack/constants/af.ts +0 -27
  85. package/src/adapter/z-stack/constants/common.ts +0 -285
  86. package/src/adapter/z-stack/constants/dbg.ts +0 -23
  87. package/src/adapter/z-stack/constants/index.ts +0 -11
  88. package/src/adapter/z-stack/constants/mac.ts +0 -128
  89. package/src/adapter/z-stack/constants/sapi.ts +0 -25
  90. package/src/adapter/z-stack/constants/sys.ts +0 -72
  91. package/src/adapter/z-stack/constants/util.ts +0 -82
  92. package/src/adapter/z-stack/constants/utils.ts +0 -14
  93. package/src/adapter/z-stack/constants/zdo.ts +0 -103
  94. package/src/adapter/z-stack/models/startup-options.ts +0 -13
  95. package/src/adapter/z-stack/structs/entries/address-manager-entry.ts +0 -44
  96. package/src/adapter/z-stack/structs/entries/address-manager-table.ts +0 -19
  97. package/src/adapter/z-stack/structs/entries/aps-link-key-data-entry.ts +0 -12
  98. package/src/adapter/z-stack/structs/entries/aps-link-key-data-table.ts +0 -21
  99. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-entry.ts +0 -19
  100. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-table.ts +0 -21
  101. package/src/adapter/z-stack/structs/entries/channel-list.ts +0 -8
  102. package/src/adapter/z-stack/structs/entries/has-configured.ts +0 -16
  103. package/src/adapter/z-stack/structs/entries/index.ts +0 -16
  104. package/src/adapter/z-stack/structs/entries/nib.ts +0 -66
  105. package/src/adapter/z-stack/structs/entries/nwk-key-descriptor.ts +0 -15
  106. package/src/adapter/z-stack/structs/entries/nwk-key.ts +0 -13
  107. package/src/adapter/z-stack/structs/entries/nwk-pan-id.ts +0 -8
  108. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.ts +0 -20
  109. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.ts +0 -19
  110. package/src/adapter/z-stack/structs/entries/security-manager-entry.ts +0 -33
  111. package/src/adapter/z-stack/structs/entries/security-manager-table.ts +0 -22
  112. package/src/adapter/z-stack/structs/index.ts +0 -4
  113. package/src/adapter/z-stack/structs/serializable-memory-object.ts +0 -14
  114. package/src/adapter/z-stack/structs/struct.ts +0 -367
  115. package/src/adapter/z-stack/structs/table.ts +0 -198
  116. package/src/adapter/z-stack/unpi/constants.ts +0 -33
  117. package/src/adapter/z-stack/unpi/frame.ts +0 -62
  118. package/src/adapter/z-stack/unpi/index.ts +0 -4
  119. package/src/adapter/z-stack/unpi/parser.ts +0 -56
  120. package/src/adapter/z-stack/unpi/writer.ts +0 -21
  121. package/src/adapter/z-stack/utils/channel-list.ts +0 -40
  122. package/src/adapter/z-stack/utils/index.ts +0 -2
  123. package/src/adapter/z-stack/utils/network-options.ts +0 -26
  124. package/src/adapter/z-stack/znp/buffaloZnp.ts +0 -175
  125. package/src/adapter/z-stack/znp/definition.ts +0 -2713
  126. package/src/adapter/z-stack/znp/index.ts +0 -2
  127. package/src/adapter/z-stack/znp/parameterType.ts +0 -22
  128. package/src/adapter/z-stack/znp/tstype.ts +0 -44
  129. package/src/adapter/z-stack/znp/utils.ts +0 -10
  130. package/src/adapter/z-stack/znp/znp.ts +0 -342
  131. package/src/adapter/z-stack/znp/zpiObject.ts +0 -148
  132. package/src/adapter/zboss/adapter/zbossAdapter.ts +0 -526
  133. package/src/adapter/zboss/commands.ts +0 -1184
  134. package/src/adapter/zboss/consts.ts +0 -9
  135. package/src/adapter/zboss/driver.ts +0 -422
  136. package/src/adapter/zboss/enums.ts +0 -360
  137. package/src/adapter/zboss/frame.ts +0 -227
  138. package/src/adapter/zboss/reader.ts +0 -65
  139. package/src/adapter/zboss/types.ts +0 -0
  140. package/src/adapter/zboss/uart.ts +0 -428
  141. package/src/adapter/zboss/utils.ts +0 -58
  142. package/src/adapter/zboss/writer.ts +0 -49
  143. package/src/adapter/zigate/adapter/patchZdoBuffaloBE.ts +0 -27
  144. package/src/adapter/zigate/adapter/zigateAdapter.ts +0 -618
  145. package/src/adapter/zigate/driver/LICENSE +0 -17
  146. package/src/adapter/zigate/driver/buffaloZiGate.ts +0 -212
  147. package/src/adapter/zigate/driver/commandType.ts +0 -418
  148. package/src/adapter/zigate/driver/constants.ts +0 -150
  149. package/src/adapter/zigate/driver/frame.ts +0 -197
  150. package/src/adapter/zigate/driver/messageType.ts +0 -287
  151. package/src/adapter/zigate/driver/parameterType.ts +0 -32
  152. package/src/adapter/zigate/driver/ziGateObject.ts +0 -146
  153. package/src/adapter/zigate/driver/zigate.ts +0 -423
  154. package/src/adapter/zoh/adapter/utils.ts +0 -27
  155. package/src/adapter/zoh/adapter/zohAdapter.ts +0 -838
  156. package/src/buffalo/buffalo.ts +0 -342
  157. package/src/buffalo/index.ts +0 -1
  158. package/src/controller/controller.ts +0 -1022
  159. package/src/controller/database.ts +0 -124
  160. package/src/controller/events.ts +0 -52
  161. package/src/controller/greenPower.ts +0 -603
  162. package/src/controller/helpers/index.ts +0 -1
  163. package/src/controller/helpers/installCodes.ts +0 -107
  164. package/src/controller/helpers/request.ts +0 -96
  165. package/src/controller/helpers/requestQueue.ts +0 -125
  166. package/src/controller/helpers/zclFrameConverter.ts +0 -47
  167. package/src/controller/helpers/zclTransactionSequenceNumber.ts +0 -19
  168. package/src/controller/index.ts +0 -6
  169. package/src/controller/model/device.ts +0 -1248
  170. package/src/controller/model/endpoint.ts +0 -1105
  171. package/src/controller/model/entity.ts +0 -23
  172. package/src/controller/model/group.ts +0 -424
  173. package/src/controller/model/index.ts +0 -5
  174. package/src/controller/model/zigbeeEntity.ts +0 -30
  175. package/src/controller/touchlink.ts +0 -189
  176. package/src/controller/tstype.ts +0 -274
  177. package/src/index.ts +0 -12
  178. package/src/models/backup-storage-legacy.ts +0 -48
  179. package/src/models/backup-storage-unified.ts +0 -47
  180. package/src/models/backup.ts +0 -37
  181. package/src/models/index.ts +0 -5
  182. package/src/models/network-options.ts +0 -11
  183. package/src/utils/backup.ts +0 -152
  184. package/src/utils/index.ts +0 -5
  185. package/src/utils/logger.ts +0 -20
  186. package/src/utils/patchBigIntSerialization.ts +0 -8
  187. package/src/utils/queue.ts +0 -76
  188. package/src/utils/types.d.ts +0 -3
  189. package/src/utils/utils.ts +0 -19
  190. package/src/utils/wait.ts +0 -5
  191. package/src/utils/waitress.ts +0 -96
  192. package/src/zspec/consts.ts +0 -84
  193. package/src/zspec/enums.ts +0 -22
  194. package/src/zspec/index.ts +0 -3
  195. package/src/zspec/tstypes.ts +0 -18
  196. package/src/zspec/utils.ts +0 -247
  197. package/src/zspec/zcl/buffaloZcl.ts +0 -1220
  198. package/src/zspec/zcl/definition/cluster.ts +0 -5915
  199. package/src/zspec/zcl/definition/clusters-typegen.ts +0 -588
  200. package/src/zspec/zcl/definition/clusters-types.ts +0 -7331
  201. package/src/zspec/zcl/definition/consts.ts +0 -24
  202. package/src/zspec/zcl/definition/enums.ts +0 -203
  203. package/src/zspec/zcl/definition/foundation.ts +0 -329
  204. package/src/zspec/zcl/definition/manufacturerCode.ts +0 -729
  205. package/src/zspec/zcl/definition/status.ts +0 -69
  206. package/src/zspec/zcl/definition/tstype.ts +0 -377
  207. package/src/zspec/zcl/index.ts +0 -11
  208. package/src/zspec/zcl/utils.ts +0 -321
  209. package/src/zspec/zcl/zclFrame.ts +0 -356
  210. package/src/zspec/zcl/zclHeader.ts +0 -102
  211. package/src/zspec/zcl/zclStatusError.ts +0 -10
  212. package/src/zspec/zdo/buffaloZdo.ts +0 -2336
  213. package/src/zspec/zdo/definition/clusters.ts +0 -722
  214. package/src/zspec/zdo/definition/consts.ts +0 -16
  215. package/src/zspec/zdo/definition/enums.ts +0 -99
  216. package/src/zspec/zdo/definition/status.ts +0 -105
  217. package/src/zspec/zdo/definition/tstypes.ts +0 -1062
  218. package/src/zspec/zdo/index.ts +0 -7
  219. package/src/zspec/zdo/utils.ts +0 -76
  220. package/src/zspec/zdo/zdoStatusError.ts +0 -10
  221. package/test/adapter/adapter.test.ts +0 -1062
  222. package/test/adapter/ember/ash.test.ts +0 -337
  223. package/test/adapter/ember/consts.ts +0 -131
  224. package/test/adapter/ember/emberAdapter.test.ts +0 -3449
  225. package/test/adapter/ember/ezsp.test.ts +0 -385
  226. package/test/adapter/ember/ezspBuffalo.test.ts +0 -93
  227. package/test/adapter/ember/ezspError.test.ts +0 -12
  228. package/test/adapter/ember/math.test.ts +0 -206
  229. package/test/adapter/ezsp/frame.test.ts +0 -30
  230. package/test/adapter/ezsp/uart.test.ts +0 -181
  231. package/test/adapter/z-stack/adapter.test.ts +0 -3984
  232. package/test/adapter/z-stack/constants.test.ts +0 -33
  233. package/test/adapter/z-stack/structs.test.ts +0 -115
  234. package/test/adapter/z-stack/unpi.test.ts +0 -213
  235. package/test/adapter/z-stack/znp.test.ts +0 -1284
  236. package/test/adapter/zboss/fixZdoResponse.test.ts +0 -179
  237. package/test/adapter/zigate/patchZdoBuffaloBE.test.ts +0 -81
  238. package/test/adapter/zigate/zdo.test.ts +0 -187
  239. package/test/adapter/zoh/utils.test.ts +0 -36
  240. package/test/adapter/zoh/zohAdapter.test.ts +0 -1307
  241. package/test/buffalo.test.ts +0 -431
  242. package/test/controller.bench.ts +0 -193
  243. package/test/controller.test.ts +0 -8702
  244. package/test/greenpower.test.ts +0 -1408
  245. package/test/mockAdapters.ts +0 -65
  246. package/test/mockDevices.ts +0 -598
  247. package/test/requests.bench.ts +0 -206
  248. package/test/testUtils.ts +0 -20
  249. package/test/tsconfig.json +0 -9
  250. package/test/utils/math.ts +0 -19
  251. package/test/utils.test.ts +0 -279
  252. package/test/vitest.config.mts +0 -27
  253. package/test/zcl.test.ts +0 -2831
  254. package/test/zspec/utils.test.ts +0 -68
  255. package/test/zspec/zcl/buffalo.test.ts +0 -1374
  256. package/test/zspec/zcl/frame.test.ts +0 -960
  257. package/test/zspec/zcl/utils.test.ts +0 -273
  258. package/test/zspec/zdo/buffalo.test.ts +0 -1850
  259. package/test/zspec/zdo/utils.test.ts +0 -241
  260. package/tsconfig.json +0 -24
@@ -1,802 +0,0 @@
1
- /* v8 ignore start */
2
-
3
- import {EventEmitter} from "node:events";
4
-
5
- import {Queue, Waitress, wait} from "../../../utils";
6
- import {logger} from "../../../utils/logger";
7
- import type {SerialPortOptions} from "../../tstype";
8
- import {
9
- type EZSPFrameDesc,
10
- FRAME_NAMES_BY_ID,
11
- FRAMES,
12
- type ParamsDesc,
13
- ZDOREQUEST_NAME_BY_ID,
14
- ZDOREQUESTS,
15
- ZDORESPONSE_NAME_BY_ID,
16
- ZDORESPONSES,
17
- } from "./commands";
18
- import * as t from "./types";
19
- import {
20
- EmberConcentratorType,
21
- type EmberOutgoingMessageType,
22
- EmberStatus,
23
- EmberZdoConfigurationFlags,
24
- EzspConfigId,
25
- EzspDecisionBitmask,
26
- EzspDecisionId,
27
- EzspPolicyId,
28
- } from "./types/named";
29
- import type {EmberApsFrame, EmberNetworkParameters} from "./types/struct";
30
- import {SerialDriver} from "./uart";
31
-
32
- const NS = "zh:ezsp:ezsp";
33
-
34
- const MAX_SERIAL_CONNECT_ATTEMPTS = 4;
35
- /** In ms. This is multiplied by tries count (above), e.g. 4 tries = 5000, 10000, 15000 */
36
- const SERIAL_CONNECT_NEW_ATTEMPT_MIN_DELAY = 5000;
37
- const MTOR_MIN_INTERVAL = 10;
38
- const MTOR_MAX_INTERVAL = 90;
39
- const MTOR_ROUTE_ERROR_THRESHOLD = 4;
40
- const MTOR_DELIVERY_FAIL_THRESHOLD = 3;
41
- const MAX_WATCHDOG_FAILURES = 4;
42
- //const RESET_ATTEMPT_BACKOFF_TIME = 5;
43
- const WATCHDOG_WAKE_PERIOD = 10; // in sec
44
- //const EZSP_COUNTER_CLEAR_INTERVAL = 180; // Clear counters every n * WATCHDOG_WAKE_PERIOD
45
- const EZSP_DEFAULT_RADIUS = 0;
46
- const EZSP_MULTICAST_NON_MEMBER_RADIUS = 3;
47
-
48
- const CONFIG_IDS_PRE_V9: number[][] = [
49
- [EzspConfigId.CONFIG_TC_REJOINS_USING_WELL_KNOWN_KEY_TIMEOUT_S, 90],
50
- [EzspConfigId.CONFIG_TRUST_CENTER_ADDRESS_CACHE_SIZE, 2],
51
- //[EzspConfigId.CONFIG_SUPPORTED_NETWORKS, 1],
52
- [EzspConfigId.CONFIG_FRAGMENT_DELAY_MS, 50],
53
- [EzspConfigId.CONFIG_PAN_ID_CONFLICT_REPORT_THRESHOLD, 2],
54
- //[EzspConfigId.CONFIG_SOURCE_ROUTE_TABLE_SIZE, 16],
55
- //[EzspConfigId.CONFIG_ADDRESS_TABLE_SIZE, 16],
56
- [
57
- EzspConfigId.CONFIG_APPLICATION_ZDO_FLAGS,
58
- EmberZdoConfigurationFlags.APP_HANDLES_UNSUPPORTED_ZDO_REQUESTS | EmberZdoConfigurationFlags.APP_RECEIVES_SUPPORTED_ZDO_REQUESTS,
59
- ],
60
- [EzspConfigId.CONFIG_INDIRECT_TRANSMISSION_TIMEOUT, 7680],
61
- [EzspConfigId.CONFIG_END_DEVICE_POLL_TIMEOUT, 14],
62
- [EzspConfigId.CONFIG_SECURITY_LEVEL, 5],
63
- [EzspConfigId.CONFIG_STACK_PROFILE, 2],
64
- //[EzspConfigId.CONFIG_TX_POWER_MODE, 3],
65
- [EzspConfigId.CONFIG_FRAGMENT_WINDOW_SIZE, 1],
66
- //[EzspConfigId.CONFIG_NEIGHBOR_TABLE_SIZE, 16],
67
- //[EzspConfigId.CONFIG_ROUTE_TABLE_SIZE, 16],
68
- //[EzspConfigId.CONFIG_BINDING_TABLE_SIZE, 32],
69
- //[EzspConfigId.CONFIG_KEY_TABLE_SIZE, 12],
70
- //[EzspConfigId.CONFIG_ZLL_GROUP_ADDRESSES, 0],
71
- //[EzspConfigId.CONFIG_ZLL_RSSI_THRESHOLD, 0],
72
- //[EzspConfigId.CONFIG_APS_UNICAST_MESSAGE_COUNT, 255],
73
- //[EzspConfigId.CONFIG_BROADCAST_TABLE_SIZE, 43],
74
- //[EzspConfigId.CONFIG_MAX_HOPS, 30],
75
- //[EzspConfigId.CONFIG_MAX_END_DEVICE_CHILDREN, 32],
76
- [EzspConfigId.CONFIG_PACKET_BUFFER_COUNT, 255],
77
- ];
78
-
79
- /**
80
- * Can only decrease "NCP Memory Allocation" configs at runtime from V9 on.
81
- * @see https://www.silabs.com/documents/public/release-notes/emberznet-release-notes-7.0.1.0.pdf
82
- */
83
- const CONFIG_IDS_CURRENT: number[][] = [
84
- [EzspConfigId.CONFIG_TC_REJOINS_USING_WELL_KNOWN_KEY_TIMEOUT_S, 90],
85
- [EzspConfigId.CONFIG_TRUST_CENTER_ADDRESS_CACHE_SIZE, 2],
86
- [EzspConfigId.CONFIG_FRAGMENT_DELAY_MS, 50],
87
- [EzspConfigId.CONFIG_PAN_ID_CONFLICT_REPORT_THRESHOLD, 2],
88
- [
89
- EzspConfigId.CONFIG_APPLICATION_ZDO_FLAGS,
90
- EmberZdoConfigurationFlags.APP_HANDLES_UNSUPPORTED_ZDO_REQUESTS | EmberZdoConfigurationFlags.APP_RECEIVES_SUPPORTED_ZDO_REQUESTS,
91
- ],
92
- [EzspConfigId.CONFIG_INDIRECT_TRANSMISSION_TIMEOUT, 7680],
93
- [EzspConfigId.CONFIG_END_DEVICE_POLL_TIMEOUT, 14],
94
- [EzspConfigId.CONFIG_SECURITY_LEVEL, 5],
95
- [EzspConfigId.CONFIG_STACK_PROFILE, 2],
96
- [EzspConfigId.CONFIG_FRAGMENT_WINDOW_SIZE, 1],
97
- ];
98
-
99
- const POLICY_IDS_PRE_V8: number[][] = [
100
- // [EzspPolicyId.BINDING_MODIFICATION_POLICY,
101
- // EzspDecisionId.DISALLOW_BINDING_MODIFICATION],
102
- // [EzspPolicyId.UNICAST_REPLIES_POLICY, EzspDecisionId.HOST_WILL_NOT_SUPPLY_REPLY],
103
- // [EzspPolicyId.POLL_HANDLER_POLICY, EzspDecisionId.POLL_HANDLER_IGNORE],
104
- // [EzspPolicyId.MESSAGE_CONTENTS_IN_CALLBACK_POLICY,
105
- // EzspDecisionId.MESSAGE_TAG_ONLY_IN_CALLBACK],
106
- // [EzspPolicyId.PACKET_VALIDATE_LIBRARY_POLICY,
107
- // EzspDecisionId.PACKET_VALIDATE_LIBRARY_CHECKS_DISABLED],
108
- // [EzspPolicyId.ZLL_POLICY, EzspDecisionId.ALLOW_JOINS],
109
- // [EzspPolicyId.TC_REJOINS_USING_WELL_KNOWN_KEY_POLICY, EzspDecisionId.ALLOW_JOINS],
110
- [EzspPolicyId.APP_KEY_REQUEST_POLICY, EzspDecisionId.DENY_APP_KEY_REQUESTS],
111
- [EzspPolicyId.TC_KEY_REQUEST_POLICY, EzspDecisionId.ALLOW_TC_KEY_REQUESTS],
112
- ];
113
-
114
- const POLICY_IDS_CURRENT: number[][] = [
115
- [EzspPolicyId.APP_KEY_REQUEST_POLICY, EzspDecisionId.DENY_APP_KEY_REQUESTS],
116
- [EzspPolicyId.TC_KEY_REQUEST_POLICY, EzspDecisionId.ALLOW_TC_KEY_REQUESTS],
117
- [EzspPolicyId.TRUST_CENTER_POLICY, EzspDecisionBitmask.ALLOW_UNSECURED_REJOINS | EzspDecisionBitmask.ALLOW_JOINS],
118
- ];
119
-
120
- type EZSPFrame = {
121
- sequence: number;
122
- frameId: number;
123
- frameName: string;
124
- payload: EZSPFrameData;
125
- };
126
-
127
- type EZSPWaitressMatcher = {
128
- sequence: number | null;
129
- frameId: number | string;
130
- };
131
-
132
- export class EZSPFrameData {
133
- _cls_: string;
134
- _id_: number;
135
- _isRequest_: boolean;
136
- // biome-ignore lint/suspicious/noExplicitAny: API
137
- [name: string]: any;
138
-
139
- static createFrame(ezspv: number, frameId: number, isRequest: boolean, params: ParamsDesc | Buffer): EZSPFrameData {
140
- const names = FRAME_NAMES_BY_ID[frameId];
141
- if (!names) {
142
- throw new Error(`Unrecognized frame FrameID ${frameId}`);
143
- }
144
- let frm: EZSPFrameData;
145
- names.every((frameName) => {
146
- const frameDesc = EZSPFrameData.getFrame(frameName);
147
- if ((frameDesc.maxV && frameDesc.maxV < ezspv) || (frameDesc.minV && frameDesc.minV > ezspv)) {
148
- return true;
149
- }
150
- try {
151
- frm = new EZSPFrameData(frameName, isRequest, params);
152
- } catch (error) {
153
- logger.error(`Frame ${frameName} parsing error: ${error}`, NS);
154
- return true;
155
- }
156
- return false;
157
- });
158
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
159
- return frm!;
160
- }
161
-
162
- static getFrame(name: string): EZSPFrameDesc {
163
- const frameDesc = FRAMES[name];
164
- if (!frameDesc) throw new Error(`Unrecognized frame from FrameID ${name}`);
165
- return frameDesc;
166
- }
167
-
168
- constructor(key: string, isRequest: boolean, params: ParamsDesc | Buffer | undefined) {
169
- this._cls_ = key;
170
- this._id_ = FRAMES[this._cls_].ID;
171
-
172
- this._isRequest_ = isRequest;
173
- const frame = EZSPFrameData.getFrame(key);
174
- const frameDesc = this._isRequest_ ? frame.request || {} : frame.response || {};
175
- if (Buffer.isBuffer(params)) {
176
- let data = params;
177
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
178
- [this[prop], data] = frameDesc[prop].deserialize(frameDesc[prop], data);
179
- }
180
- } else {
181
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
182
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
183
- this[prop] = params![prop]; // XXX: assumed defined with logic
184
- }
185
- }
186
- }
187
-
188
- serialize(): Buffer {
189
- const frame = EZSPFrameData.getFrame(this._cls_);
190
- const frameDesc = this._isRequest_ ? frame.request || {} : frame.response || {};
191
- const result = [];
192
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
193
- result.push(frameDesc[prop].serialize(frameDesc[prop], this[prop]));
194
- }
195
- return Buffer.concat(result);
196
- }
197
-
198
- get name(): string {
199
- return this._cls_;
200
- }
201
-
202
- get id(): number {
203
- return this._id_;
204
- }
205
- }
206
-
207
- export class EZSPZDORequestFrameData {
208
- _cls_: string;
209
- _id_: number;
210
- _isRequest_: boolean;
211
- // biome-ignore lint/suspicious/noExplicitAny: API
212
- [name: string]: any;
213
-
214
- static getFrame(key: string | number): EZSPFrameDesc {
215
- const name = typeof key === "string" ? key : ZDOREQUEST_NAME_BY_ID[key];
216
- const frameDesc = ZDOREQUESTS[name];
217
- if (!frameDesc) throw new Error(`Unrecognized ZDOFrame from FrameID ${key}`);
218
- return frameDesc;
219
- }
220
-
221
- constructor(key: string | number, isRequest: boolean, params: ParamsDesc | Buffer) {
222
- if (typeof key === "string") {
223
- this._cls_ = key;
224
- this._id_ = ZDOREQUESTS[this._cls_].ID;
225
- } else {
226
- this._id_ = key;
227
- this._cls_ = ZDOREQUEST_NAME_BY_ID[key];
228
- }
229
-
230
- this._isRequest_ = isRequest;
231
- const frame = EZSPZDORequestFrameData.getFrame(key);
232
- const frameDesc = this._isRequest_ ? frame.request || {} : frame.response || {};
233
- if (Buffer.isBuffer(params)) {
234
- let data = params;
235
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
236
- [this[prop], data] = frameDesc[prop].deserialize(frameDesc[prop], data);
237
- }
238
- } else {
239
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
240
- this[prop] = params[prop];
241
- }
242
- }
243
- }
244
-
245
- serialize(): Buffer {
246
- const frame = EZSPZDORequestFrameData.getFrame(this._cls_);
247
- const frameDesc = this._isRequest_ ? frame.request || {} : frame.response || {};
248
- const result = [];
249
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
250
- result.push(frameDesc[prop].serialize(frameDesc[prop], this[prop]));
251
- }
252
- return Buffer.concat(result);
253
- }
254
-
255
- get name(): string {
256
- return this._cls_;
257
- }
258
-
259
- get id(): number {
260
- return this._id_;
261
- }
262
- }
263
-
264
- export class EZSPZDOResponseFrameData {
265
- _cls_: string;
266
- _id_: number;
267
- // biome-ignore lint/suspicious/noExplicitAny: API
268
- [name: string]: any;
269
-
270
- static getFrame(key: string | number): ParamsDesc {
271
- const name = typeof key === "string" ? key : ZDORESPONSE_NAME_BY_ID[key];
272
- const frameDesc = ZDORESPONSES[name];
273
- if (!frameDesc) throw new Error(`Unrecognized ZDOFrame from FrameID ${key}`);
274
- return frameDesc.params;
275
- }
276
-
277
- constructor(key: string | number, params: ParamsDesc | Buffer) {
278
- if (typeof key === "string") {
279
- this._cls_ = key;
280
- this._id_ = ZDORESPONSES[this._cls_].ID;
281
- } else {
282
- this._id_ = key;
283
- this._cls_ = ZDORESPONSE_NAME_BY_ID[key];
284
- }
285
-
286
- const frameDesc = EZSPZDOResponseFrameData.getFrame(key);
287
- if (Buffer.isBuffer(params)) {
288
- let data = params;
289
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
290
- [this[prop], data] = frameDesc[prop].deserialize(frameDesc[prop], data);
291
- }
292
- } else {
293
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
294
- this[prop] = params[prop];
295
- }
296
- }
297
- }
298
-
299
- serialize(): Buffer {
300
- const frameDesc = EZSPZDOResponseFrameData.getFrame(this._cls_);
301
- const result = [];
302
- for (const prop of Object.getOwnPropertyNames(frameDesc)) {
303
- result.push(frameDesc[prop].serialize(frameDesc[prop], this[prop]));
304
- }
305
- return Buffer.concat(result);
306
- }
307
-
308
- get name(): string {
309
- return this._cls_;
310
- }
311
-
312
- get id(): number {
313
- return this._id_;
314
- }
315
- }
316
-
317
- export class Ezsp extends EventEmitter {
318
- ezspV = 4;
319
- cmdSeq = 0; // command sequence
320
-
321
- // COMMANDS_BY_ID = new Map<number, { name: string, inArgs: any[], outArgs: any[] }>();
322
- private serialDriver: SerialDriver;
323
- private waitress: Waitress<EZSPFrame, EZSPWaitressMatcher>;
324
- private queue: Queue;
325
- private watchdogTimer?: NodeJS.Timeout;
326
- private failures = 0;
327
- private inResetingProcess = false;
328
-
329
- constructor() {
330
- super();
331
- this.queue = new Queue();
332
- this.waitress = new Waitress<EZSPFrame, EZSPWaitressMatcher>(this.waitressValidator, this.waitressTimeoutFormatter);
333
-
334
- this.serialDriver = new SerialDriver();
335
- this.serialDriver.on("received", this.onFrameReceived.bind(this));
336
- this.serialDriver.on("close", this.onSerialClose.bind(this));
337
- }
338
-
339
- public async connect(options: SerialPortOptions): Promise<void> {
340
- let lastError = null;
341
-
342
- const resetForReconnect = (): void => {
343
- throw new Error("Failure to connect");
344
- };
345
- this.serialDriver.on("reset", resetForReconnect);
346
-
347
- for (let i = 1; i <= MAX_SERIAL_CONNECT_ATTEMPTS; i++) {
348
- try {
349
- await this.serialDriver.connect(options);
350
- break;
351
- } catch (error) {
352
- logger.error(`Connection attempt ${i} error: ${error}`, NS);
353
-
354
- if (i < MAX_SERIAL_CONNECT_ATTEMPTS) {
355
- await wait(SERIAL_CONNECT_NEW_ATTEMPT_MIN_DELAY * i);
356
- logger.debug(`Next attempt ${i + 1}`, NS);
357
- }
358
-
359
- lastError = error;
360
- }
361
- }
362
-
363
- this.serialDriver.off("reset", resetForReconnect);
364
-
365
- if (!this.serialDriver.isInitialized()) {
366
- throw new Error("Failure to connect", {cause: lastError});
367
- }
368
-
369
- this.inResetingProcess = false;
370
-
371
- this.serialDriver.on("reset", this.onSerialReset.bind(this));
372
-
373
- if (WATCHDOG_WAKE_PERIOD) {
374
- this.watchdogTimer = setInterval(this.watchdogHandler.bind(this), WATCHDOG_WAKE_PERIOD * 1000);
375
- }
376
- }
377
-
378
- public isInitialized(): boolean {
379
- return this.serialDriver?.isInitialized();
380
- }
381
-
382
- private onSerialReset(): void {
383
- logger.debug("onSerialReset()", NS);
384
- this.inResetingProcess = true;
385
- this.emit("reset");
386
- }
387
-
388
- private onSerialClose(): void {
389
- logger.debug("onSerialClose()", NS);
390
- if (!this.inResetingProcess) {
391
- this.emit("close");
392
- }
393
- }
394
-
395
- public async close(emitClose: boolean): Promise<void> {
396
- logger.debug("Closing Ezsp", NS);
397
-
398
- clearTimeout(this.watchdogTimer);
399
- this.queue.clear();
400
- await this.serialDriver.close(emitClose);
401
- }
402
-
403
- /**
404
- * Handle a received EZSP frame
405
- *
406
- * The protocol has taken care of UART specific framing etc, so we should
407
- * just have EZSP application stuff here, with all escaping/stuffing and
408
- * data randomization removed.
409
- * @param data
410
- */
411
- private onFrameReceived(data: Buffer): void {
412
- logger.debug(`<== Frame: ${data.toString("hex")}`, NS);
413
-
414
- let frameId: number;
415
- const sequence = data[0];
416
-
417
- if (this.ezspV < 8) {
418
- [frameId, data] = [data[2], data.subarray(3)];
419
- } else {
420
- [[frameId], data] = t.deserialize(data.subarray(3), [t.uint16_t]);
421
- }
422
-
423
- if (frameId === 255) {
424
- frameId = 0;
425
-
426
- if (data.length > 1) {
427
- frameId = data[1];
428
- data = data.subarray(2);
429
- }
430
- }
431
-
432
- const frm = EZSPFrameData.createFrame(this.ezspV, frameId, false, data);
433
-
434
- if (!frm) {
435
- logger.error(`Unparsed frame 0x${frameId.toString(16)}. Skipped`, NS);
436
- return;
437
- }
438
-
439
- logger.debug(() => `<== 0x${frameId.toString(16)}: ${JSON.stringify(frm)}`, NS);
440
-
441
- const handled = this.waitress.resolve({
442
- frameId,
443
- frameName: frm.name,
444
- sequence,
445
- payload: frm,
446
- });
447
-
448
- if (!handled) {
449
- this.emit("frame", frm.name, frm);
450
- }
451
-
452
- if (frameId === 0) {
453
- this.ezspV = frm.protocolVersion;
454
- }
455
- }
456
-
457
- async version(): Promise<number> {
458
- const version = this.ezspV;
459
- const result = await this.execCommand("version", {desiredProtocolVersion: version});
460
-
461
- if (result.protocolVersion >= 14) {
462
- throw new Error(`'ezsp' driver is not compatible with firmware 8.x.x or above (EZSP v14+). Use 'ember' driver instead.`);
463
- }
464
-
465
- if (result.protocolVersion !== version) {
466
- logger.debug(`Switching to eszp version ${result.protocolVersion}`, NS);
467
-
468
- await this.execCommand("version", {desiredProtocolVersion: result.protocolVersion});
469
- }
470
-
471
- return result.protocolVersion;
472
- }
473
-
474
- async networkInit(): Promise<boolean> {
475
- const waiter = this.waitFor("stackStatusHandler", null);
476
- const result = await this.execCommand("networkInit");
477
-
478
- logger.debug(`Network init result: ${JSON.stringify(result)}`, NS);
479
-
480
- if (result.status !== EmberStatus.SUCCESS) {
481
- this.waitress.remove(waiter.ID);
482
- logger.error("Failure to init network", NS);
483
- return false;
484
- }
485
-
486
- const response = await waiter.start().promise;
487
-
488
- return response.payload.status === EmberStatus.NETWORK_UP;
489
- }
490
-
491
- async leaveNetwork(): Promise<number> {
492
- const waiter = this.waitFor("stackStatusHandler", null);
493
- const result = await this.execCommand("leaveNetwork");
494
-
495
- logger.debug(`Network init result: ${JSON.stringify(result)}`, NS);
496
-
497
- if (result.status !== EmberStatus.SUCCESS) {
498
- this.waitress.remove(waiter.ID);
499
- logger.debug("Failure to leave network", NS);
500
- throw new Error(`Failure to leave network: ${JSON.stringify(result)}`);
501
- }
502
-
503
- const response = await waiter.start().promise;
504
-
505
- if (response.payload.status !== EmberStatus.NETWORK_DOWN) {
506
- const msg = `Wrong network status: ${JSON.stringify(response.payload)}`;
507
- logger.debug(msg, NS);
508
- throw new Error(msg);
509
- }
510
-
511
- return response.payload.status;
512
- }
513
-
514
- async setConfigurationValue(configId: number, value: number): Promise<void> {
515
- const configName = EzspConfigId.valueToName(EzspConfigId, configId);
516
- logger.debug(`Set ${configName} = ${value}`, NS);
517
- const ret = await this.execCommand("setConfigurationValue", {configId: configId, value: value});
518
-
519
- if (ret.status !== EmberStatus.SUCCESS) {
520
- logger.error(`Command (setConfigurationValue(${configName}, ${value})) returned unexpected state: ${JSON.stringify(ret)}`, NS);
521
- }
522
- }
523
-
524
- async getConfigurationValue(configId: number): Promise<number> {
525
- const configName = EzspConfigId.valueToName(EzspConfigId, configId);
526
- logger.debug(`Get ${configName}`, NS);
527
- const ret = await this.execCommand("getConfigurationValue", {configId: configId});
528
-
529
- if (ret.status !== EmberStatus.SUCCESS) {
530
- logger.error(`Command (getConfigurationValue(${configName})) returned unexpected state: ${JSON.stringify(ret)}`, NS);
531
- }
532
-
533
- logger.debug(`Got ${configName} = ${ret.value}`, NS);
534
- return ret.value;
535
- }
536
-
537
- async getMulticastTableEntry(index: number): Promise<t.EmberMulticastTableEntry> {
538
- const ret = await this.execCommand("getMulticastTableEntry", {index: index});
539
- return ret.value;
540
- }
541
-
542
- async setMulticastTableEntry(index: number, entry: t.EmberMulticastTableEntry): Promise<EmberStatus> {
543
- const ret = await this.execCommand("setMulticastTableEntry", {index: index, value: entry});
544
-
545
- if (ret.status !== EmberStatus.SUCCESS) {
546
- logger.error(`Command (setMulticastTableEntry) returned unexpected state: ${JSON.stringify(ret)}`, NS);
547
- }
548
-
549
- return ret.status;
550
- }
551
-
552
- async setInitialSecurityState(entry: t.EmberInitialSecurityState): Promise<EmberStatus> {
553
- const ret = await this.execCommand("setInitialSecurityState", {state: entry});
554
-
555
- if (ret.success !== EmberStatus.SUCCESS) {
556
- logger.error(`Command (setInitialSecurityState) returned unexpected state: ${JSON.stringify(ret)}`, NS);
557
- }
558
-
559
- return ret.success;
560
- }
561
-
562
- async getCurrentSecurityState(): Promise<EZSPFrameData> {
563
- const ret = await this.execCommand("getCurrentSecurityState");
564
-
565
- if (ret.status !== EmberStatus.SUCCESS) {
566
- logger.error(`Command (getCurrentSecurityState) returned unexpected state: ${JSON.stringify(ret)}`, NS);
567
- }
568
-
569
- return ret;
570
- }
571
-
572
- async setValue(valueId: t.EzspValueId, value: number): Promise<EZSPFrameData> {
573
- const valueName = t.EzspValueId.valueToName(t.EzspValueId, valueId);
574
- logger.debug(`Set ${valueName} = ${value}`, NS);
575
- const ret = await this.execCommand("setValue", {valueId, value});
576
-
577
- if (ret.status !== EmberStatus.SUCCESS) {
578
- logger.error(`Command (setValue(${valueName}, ${value})) returned unexpected state: ${JSON.stringify(ret)}`, NS);
579
- }
580
-
581
- return ret;
582
- }
583
-
584
- async getValue(valueId: t.EzspValueId): Promise<Buffer> {
585
- const valueName = t.EzspValueId.valueToName(t.EzspValueId, valueId);
586
- logger.debug(`Get ${valueName}`, NS);
587
- const ret = await this.execCommand("getValue", {valueId});
588
-
589
- if (ret.status !== EmberStatus.SUCCESS) {
590
- logger.error(`Command (getValue(${valueName})) returned unexpected state: ${JSON.stringify(ret)}`, NS);
591
- }
592
-
593
- logger.debug(`Got ${valueName} = ${ret.value}`, NS);
594
- return ret.value;
595
- }
596
-
597
- async setPolicy(policyId: EzspPolicyId, value: number): Promise<EZSPFrameData> {
598
- const policyName = EzspPolicyId.valueToName(EzspPolicyId, policyId);
599
- logger.debug(`Set ${policyName} = ${value}`, NS);
600
- const ret = await this.execCommand("setPolicy", {policyId: policyId, decisionId: value});
601
-
602
- if (ret.status !== EmberStatus.SUCCESS) {
603
- logger.error(`Command (setPolicy(${policyName}, ${value})) returned unexpected state: ${JSON.stringify(ret)}`, NS);
604
- }
605
-
606
- return ret;
607
- }
608
-
609
- async updateConfig(): Promise<void> {
610
- const config = this.ezspV < 9 ? CONFIG_IDS_PRE_V9 : CONFIG_IDS_CURRENT;
611
-
612
- for (const [confName, value] of config) {
613
- try {
614
- await this.setConfigurationValue(confName, value);
615
- } catch (error) {
616
- logger.error(`setConfigurationValue(${confName}, ${value}) error: ${error}`, NS);
617
- }
618
- }
619
- }
620
-
621
- async updatePolicies(): Promise<void> {
622
- // Set up the policies for what the NCP should do.
623
- const policies = this.ezspV < 8 ? POLICY_IDS_PRE_V8 : POLICY_IDS_CURRENT;
624
-
625
- for (const [policy, value] of policies) {
626
- try {
627
- await this.setPolicy(policy, value);
628
- } catch (error) {
629
- logger.error(`setPolicy(${policy}, ${value}) error: ${error}`, NS);
630
- }
631
- }
632
- }
633
-
634
- public makeZDOframe(name: string | number, params: ParamsDesc): Buffer {
635
- const frmData = new EZSPZDORequestFrameData(name, true, params);
636
- return frmData.serialize();
637
- }
638
-
639
- private makeFrame(name: string, params: ParamsDesc | undefined, seq: number): Buffer {
640
- const frmData = new EZSPFrameData(name, true, params);
641
-
642
- logger.debug(() => `==> ${JSON.stringify(frmData)}`, NS);
643
-
644
- const frame = [seq & 255];
645
-
646
- if (this.ezspV < 8) {
647
- if (this.ezspV >= 5) {
648
- frame.push(0x00, 0xff, 0x00, frmData.id);
649
- } else {
650
- frame.push(0x00, frmData.id);
651
- }
652
- } else {
653
- const cmd_id = t.serialize([frmData.id], [t.uint16_t]);
654
-
655
- frame.push(0x00, 0x01, ...cmd_id);
656
- }
657
-
658
- return Buffer.concat([Buffer.from(frame), frmData.serialize()]);
659
- }
660
-
661
- public async execCommand(name: string, params?: ParamsDesc): Promise<EZSPFrameData> {
662
- logger.debug(() => `==> ${name}: ${JSON.stringify(params)}`, NS);
663
-
664
- if (!this.serialDriver.isInitialized()) {
665
- throw new Error("Connection not initialized");
666
- }
667
-
668
- return await this.queue.execute<EZSPFrameData>(async (): Promise<EZSPFrameData> => {
669
- const data = this.makeFrame(name, params, this.cmdSeq);
670
- const waiter = this.waitFor(name, this.cmdSeq);
671
- this.cmdSeq = (this.cmdSeq + 1) & 255;
672
-
673
- try {
674
- await this.serialDriver.sendDATA(data);
675
-
676
- const response = await waiter.start().promise;
677
-
678
- return response.payload;
679
- } catch {
680
- this.waitress.remove(waiter.ID);
681
- throw new Error(`Failure send ${name}:${JSON.stringify(data)}`);
682
- }
683
- });
684
- }
685
-
686
- async formNetwork(params: EmberNetworkParameters): Promise<number> {
687
- const waiter = this.waitFor("stackStatusHandler", null);
688
- const v = await this.execCommand("formNetwork", {parameters: params});
689
-
690
- if (v.status !== EmberStatus.SUCCESS) {
691
- this.waitress.remove(waiter.ID);
692
-
693
- logger.error(`Failure forming network: ${JSON.stringify(v)}`, NS);
694
-
695
- throw new Error(`Failure forming network: ${JSON.stringify(v)}`);
696
- }
697
-
698
- const response = await waiter.start().promise;
699
-
700
- if (response.payload.status !== EmberStatus.NETWORK_UP) {
701
- logger.error(`Wrong network status: ${JSON.stringify(response.payload)}`, NS);
702
-
703
- throw new Error(`Wrong network status: ${JSON.stringify(response.payload)}`);
704
- }
705
-
706
- return response.payload.status;
707
- }
708
-
709
- public sendUnicast(direct: EmberOutgoingMessageType, nwk: number, apsFrame: EmberApsFrame, seq: number, data: Buffer): Promise<EZSPFrameData> {
710
- return this.execCommand("sendUnicast", {
711
- type: direct,
712
- indexOrDestination: nwk,
713
- apsFrame: apsFrame,
714
- messageTag: seq,
715
- message: data,
716
- });
717
- }
718
-
719
- public sendMulticast(apsFrame: EmberApsFrame, seq: number, data: Buffer): Promise<EZSPFrameData> {
720
- return this.execCommand("sendMulticast", {
721
- apsFrame: apsFrame,
722
- hops: EZSP_DEFAULT_RADIUS,
723
- nonmemberRadius: EZSP_MULTICAST_NON_MEMBER_RADIUS,
724
- messageTag: seq,
725
- message: data,
726
- });
727
- }
728
-
729
- public async setSourceRouting(): Promise<void> {
730
- const res = await this.execCommand("setConcentrator", {
731
- on: true,
732
- concentratorType: EmberConcentratorType.HIGH_RAM_CONCENTRATOR,
733
- minTime: MTOR_MIN_INTERVAL,
734
- maxTime: MTOR_MAX_INTERVAL,
735
- routeErrorThreshold: MTOR_ROUTE_ERROR_THRESHOLD,
736
- deliveryFailureThreshold: MTOR_DELIVERY_FAIL_THRESHOLD,
737
- maxHops: 0,
738
- });
739
-
740
- logger.debug(`Set concentrator type: ${JSON.stringify(res)}`, NS);
741
-
742
- if (res.status !== EmberStatus.SUCCESS) {
743
- logger.error(`Couldn't set concentrator ${JSON.stringify(res)}`, NS);
744
- }
745
-
746
- if (this.ezspV >= 8) {
747
- await this.execCommand("setSourceRouteDiscoveryMode", {mode: 1});
748
- }
749
- }
750
-
751
- public sendBroadcast(destination: number, apsFrame: EmberApsFrame, seq: number, data: Buffer): Promise<EZSPFrameData> {
752
- return this.execCommand("sendBroadcast", {
753
- destination: destination,
754
- apsFrame: apsFrame,
755
- radius: EZSP_DEFAULT_RADIUS,
756
- messageTag: seq,
757
- message: data,
758
- });
759
- }
760
-
761
- public waitFor(
762
- frameId: string | number,
763
- sequence: number | null,
764
- timeout = 10000,
765
- ): {start: () => {promise: Promise<EZSPFrame>; ID: number}; ID: number} {
766
- return this.waitress.waitFor({frameId, sequence}, timeout);
767
- }
768
-
769
- private waitressTimeoutFormatter(matcher: EZSPWaitressMatcher, timeout: number): string {
770
- return `${JSON.stringify(matcher)} after ${timeout}ms`;
771
- }
772
-
773
- private waitressValidator(payload: EZSPFrame, matcher: EZSPWaitressMatcher): boolean {
774
- const frameNames = typeof matcher.frameId === "string" ? [matcher.frameId] : FRAME_NAMES_BY_ID[matcher.frameId];
775
- return (matcher.sequence == null || payload.sequence === matcher.sequence) && frameNames.includes(payload.frameName);
776
- }
777
-
778
- private async watchdogHandler(): Promise<void> {
779
- logger.debug(`Time to watchdog ... ${this.failures}`, NS);
780
-
781
- if (this.inResetingProcess) {
782
- logger.debug("The reset process is in progress...", NS);
783
- return;
784
- }
785
-
786
- try {
787
- await this.execCommand("nop");
788
- } catch (error) {
789
- logger.error(`Watchdog heartbeat timeout ${error}`, NS);
790
-
791
- if (!this.inResetingProcess) {
792
- this.failures += 1;
793
-
794
- if (this.failures > MAX_WATCHDOG_FAILURES) {
795
- this.failures = 0;
796
-
797
- this.emit("reset");
798
- }
799
- }
800
- }
801
- }
802
- }