zigbee-herdsman 6.0.2 → 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 (252) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/package.json +12 -3
  3. package/.github/ISSUE_TEMPLATE/config.yml +0 -5
  4. package/.github/dependabot.yml +0 -22
  5. package/.github/workflows/ci.yml +0 -69
  6. package/.github/workflows/release-please.yml +0 -18
  7. package/.github/workflows/stale.yml +0 -20
  8. package/.github/workflows/typedoc.yaml +0 -47
  9. package/.release-please-manifest.json +0 -3
  10. package/.vscode/extensions.json +0 -3
  11. package/.vscode/settings.json +0 -11
  12. package/biome.json +0 -98
  13. package/examples/join-and-log.js +0 -24
  14. package/release-please-config.json +0 -9
  15. package/src/adapter/adapter.ts +0 -189
  16. package/src/adapter/adapterDiscovery.ts +0 -666
  17. package/src/adapter/const.ts +0 -12
  18. package/src/adapter/deconz/adapter/deconzAdapter.ts +0 -877
  19. package/src/adapter/deconz/driver/constants.ts +0 -246
  20. package/src/adapter/deconz/driver/driver.ts +0 -1540
  21. package/src/adapter/deconz/driver/frame.ts +0 -11
  22. package/src/adapter/deconz/driver/frameParser.ts +0 -753
  23. package/src/adapter/deconz/driver/parser.ts +0 -45
  24. package/src/adapter/deconz/driver/writer.ts +0 -22
  25. package/src/adapter/deconz/types.d.ts +0 -13
  26. package/src/adapter/ember/adapter/emberAdapter.ts +0 -2265
  27. package/src/adapter/ember/adapter/endpoints.ts +0 -86
  28. package/src/adapter/ember/adapter/oneWaitress.ts +0 -324
  29. package/src/adapter/ember/adapter/tokensManager.ts +0 -782
  30. package/src/adapter/ember/consts.ts +0 -178
  31. package/src/adapter/ember/enums.ts +0 -1746
  32. package/src/adapter/ember/ezsp/buffalo.ts +0 -1392
  33. package/src/adapter/ember/ezsp/consts.ts +0 -148
  34. package/src/adapter/ember/ezsp/enums.ts +0 -1114
  35. package/src/adapter/ember/ezsp/ezsp.ts +0 -9061
  36. package/src/adapter/ember/ezspError.ts +0 -10
  37. package/src/adapter/ember/types.ts +0 -866
  38. package/src/adapter/ember/uart/ash.ts +0 -1960
  39. package/src/adapter/ember/uart/consts.ts +0 -109
  40. package/src/adapter/ember/uart/enums.ts +0 -192
  41. package/src/adapter/ember/uart/parser.ts +0 -48
  42. package/src/adapter/ember/uart/queues.ts +0 -247
  43. package/src/adapter/ember/uart/writer.ts +0 -53
  44. package/src/adapter/ember/utils/initters.ts +0 -58
  45. package/src/adapter/ember/utils/math.ts +0 -73
  46. package/src/adapter/events.ts +0 -21
  47. package/src/adapter/ezsp/adapter/backup.ts +0 -109
  48. package/src/adapter/ezsp/adapter/ezspAdapter.ts +0 -614
  49. package/src/adapter/ezsp/driver/commands.ts +0 -2497
  50. package/src/adapter/ezsp/driver/consts.ts +0 -11
  51. package/src/adapter/ezsp/driver/driver.ts +0 -1002
  52. package/src/adapter/ezsp/driver/ezsp.ts +0 -802
  53. package/src/adapter/ezsp/driver/frame.ts +0 -101
  54. package/src/adapter/ezsp/driver/index.ts +0 -4
  55. package/src/adapter/ezsp/driver/multicast.ts +0 -78
  56. package/src/adapter/ezsp/driver/parser.ts +0 -81
  57. package/src/adapter/ezsp/driver/types/basic.ts +0 -201
  58. package/src/adapter/ezsp/driver/types/index.ts +0 -239
  59. package/src/adapter/ezsp/driver/types/named.ts +0 -2330
  60. package/src/adapter/ezsp/driver/types/struct.ts +0 -844
  61. package/src/adapter/ezsp/driver/uart.ts +0 -460
  62. package/src/adapter/ezsp/driver/utils/crc16ccitt.ts +0 -44
  63. package/src/adapter/ezsp/driver/utils/index.ts +0 -32
  64. package/src/adapter/ezsp/driver/writer.ts +0 -64
  65. package/src/adapter/index.ts +0 -3
  66. package/src/adapter/serialPort.ts +0 -58
  67. package/src/adapter/socketPortUtils.ts +0 -16
  68. package/src/adapter/tstype.ts +0 -78
  69. package/src/adapter/z-stack/adapter/adapter-backup.ts +0 -519
  70. package/src/adapter/z-stack/adapter/adapter-nv-memory.ts +0 -457
  71. package/src/adapter/z-stack/adapter/endpoints.ts +0 -57
  72. package/src/adapter/z-stack/adapter/manager.ts +0 -543
  73. package/src/adapter/z-stack/adapter/tstype.ts +0 -6
  74. package/src/adapter/z-stack/adapter/zStackAdapter.ts +0 -1190
  75. package/src/adapter/z-stack/constants/af.ts +0 -27
  76. package/src/adapter/z-stack/constants/common.ts +0 -285
  77. package/src/adapter/z-stack/constants/dbg.ts +0 -23
  78. package/src/adapter/z-stack/constants/index.ts +0 -11
  79. package/src/adapter/z-stack/constants/mac.ts +0 -128
  80. package/src/adapter/z-stack/constants/sapi.ts +0 -25
  81. package/src/adapter/z-stack/constants/sys.ts +0 -72
  82. package/src/adapter/z-stack/constants/util.ts +0 -82
  83. package/src/adapter/z-stack/constants/utils.ts +0 -14
  84. package/src/adapter/z-stack/constants/zdo.ts +0 -103
  85. package/src/adapter/z-stack/models/startup-options.ts +0 -13
  86. package/src/adapter/z-stack/structs/entries/address-manager-entry.ts +0 -44
  87. package/src/adapter/z-stack/structs/entries/address-manager-table.ts +0 -19
  88. package/src/adapter/z-stack/structs/entries/aps-link-key-data-entry.ts +0 -12
  89. package/src/adapter/z-stack/structs/entries/aps-link-key-data-table.ts +0 -21
  90. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-entry.ts +0 -19
  91. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-table.ts +0 -21
  92. package/src/adapter/z-stack/structs/entries/channel-list.ts +0 -8
  93. package/src/adapter/z-stack/structs/entries/has-configured.ts +0 -16
  94. package/src/adapter/z-stack/structs/entries/index.ts +0 -16
  95. package/src/adapter/z-stack/structs/entries/nib.ts +0 -66
  96. package/src/adapter/z-stack/structs/entries/nwk-key-descriptor.ts +0 -15
  97. package/src/adapter/z-stack/structs/entries/nwk-key.ts +0 -13
  98. package/src/adapter/z-stack/structs/entries/nwk-pan-id.ts +0 -8
  99. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.ts +0 -20
  100. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.ts +0 -19
  101. package/src/adapter/z-stack/structs/entries/security-manager-entry.ts +0 -33
  102. package/src/adapter/z-stack/structs/entries/security-manager-table.ts +0 -22
  103. package/src/adapter/z-stack/structs/index.ts +0 -4
  104. package/src/adapter/z-stack/structs/serializable-memory-object.ts +0 -14
  105. package/src/adapter/z-stack/structs/struct.ts +0 -367
  106. package/src/adapter/z-stack/structs/table.ts +0 -198
  107. package/src/adapter/z-stack/unpi/constants.ts +0 -33
  108. package/src/adapter/z-stack/unpi/frame.ts +0 -62
  109. package/src/adapter/z-stack/unpi/index.ts +0 -4
  110. package/src/adapter/z-stack/unpi/parser.ts +0 -56
  111. package/src/adapter/z-stack/unpi/writer.ts +0 -21
  112. package/src/adapter/z-stack/utils/channel-list.ts +0 -40
  113. package/src/adapter/z-stack/utils/index.ts +0 -2
  114. package/src/adapter/z-stack/utils/network-options.ts +0 -26
  115. package/src/adapter/z-stack/znp/buffaloZnp.ts +0 -175
  116. package/src/adapter/z-stack/znp/definition.ts +0 -2713
  117. package/src/adapter/z-stack/znp/index.ts +0 -2
  118. package/src/adapter/z-stack/znp/parameterType.ts +0 -22
  119. package/src/adapter/z-stack/znp/tstype.ts +0 -44
  120. package/src/adapter/z-stack/znp/utils.ts +0 -10
  121. package/src/adapter/z-stack/znp/znp.ts +0 -342
  122. package/src/adapter/z-stack/znp/zpiObject.ts +0 -148
  123. package/src/adapter/zboss/adapter/zbossAdapter.ts +0 -526
  124. package/src/adapter/zboss/commands.ts +0 -1184
  125. package/src/adapter/zboss/consts.ts +0 -9
  126. package/src/adapter/zboss/driver.ts +0 -422
  127. package/src/adapter/zboss/enums.ts +0 -360
  128. package/src/adapter/zboss/frame.ts +0 -227
  129. package/src/adapter/zboss/reader.ts +0 -65
  130. package/src/adapter/zboss/types.ts +0 -0
  131. package/src/adapter/zboss/uart.ts +0 -428
  132. package/src/adapter/zboss/utils.ts +0 -58
  133. package/src/adapter/zboss/writer.ts +0 -49
  134. package/src/adapter/zigate/adapter/patchZdoBuffaloBE.ts +0 -27
  135. package/src/adapter/zigate/adapter/zigateAdapter.ts +0 -618
  136. package/src/adapter/zigate/driver/LICENSE +0 -17
  137. package/src/adapter/zigate/driver/buffaloZiGate.ts +0 -212
  138. package/src/adapter/zigate/driver/commandType.ts +0 -418
  139. package/src/adapter/zigate/driver/constants.ts +0 -150
  140. package/src/adapter/zigate/driver/frame.ts +0 -197
  141. package/src/adapter/zigate/driver/messageType.ts +0 -287
  142. package/src/adapter/zigate/driver/parameterType.ts +0 -32
  143. package/src/adapter/zigate/driver/ziGateObject.ts +0 -146
  144. package/src/adapter/zigate/driver/zigate.ts +0 -423
  145. package/src/adapter/zoh/adapter/utils.ts +0 -27
  146. package/src/adapter/zoh/adapter/zohAdapter.ts +0 -838
  147. package/src/buffalo/buffalo.ts +0 -342
  148. package/src/buffalo/index.ts +0 -1
  149. package/src/controller/controller.ts +0 -1022
  150. package/src/controller/database.ts +0 -124
  151. package/src/controller/events.ts +0 -52
  152. package/src/controller/greenPower.ts +0 -603
  153. package/src/controller/helpers/index.ts +0 -1
  154. package/src/controller/helpers/installCodes.ts +0 -107
  155. package/src/controller/helpers/request.ts +0 -96
  156. package/src/controller/helpers/requestQueue.ts +0 -125
  157. package/src/controller/helpers/zclFrameConverter.ts +0 -47
  158. package/src/controller/helpers/zclTransactionSequenceNumber.ts +0 -19
  159. package/src/controller/index.ts +0 -6
  160. package/src/controller/model/device.ts +0 -1249
  161. package/src/controller/model/endpoint.ts +0 -1105
  162. package/src/controller/model/entity.ts +0 -23
  163. package/src/controller/model/group.ts +0 -424
  164. package/src/controller/model/index.ts +0 -5
  165. package/src/controller/model/zigbeeEntity.ts +0 -30
  166. package/src/controller/touchlink.ts +0 -189
  167. package/src/controller/tstype.ts +0 -274
  168. package/src/index.ts +0 -12
  169. package/src/models/backup-storage-legacy.ts +0 -48
  170. package/src/models/backup-storage-unified.ts +0 -47
  171. package/src/models/backup.ts +0 -37
  172. package/src/models/index.ts +0 -5
  173. package/src/models/network-options.ts +0 -11
  174. package/src/utils/backup.ts +0 -152
  175. package/src/utils/index.ts +0 -5
  176. package/src/utils/logger.ts +0 -20
  177. package/src/utils/patchBigIntSerialization.ts +0 -8
  178. package/src/utils/queue.ts +0 -76
  179. package/src/utils/types.d.ts +0 -3
  180. package/src/utils/utils.ts +0 -19
  181. package/src/utils/wait.ts +0 -5
  182. package/src/utils/waitress.ts +0 -96
  183. package/src/zspec/consts.ts +0 -84
  184. package/src/zspec/enums.ts +0 -22
  185. package/src/zspec/index.ts +0 -3
  186. package/src/zspec/tstypes.ts +0 -18
  187. package/src/zspec/utils.ts +0 -247
  188. package/src/zspec/zcl/buffaloZcl.ts +0 -1220
  189. package/src/zspec/zcl/definition/cluster.ts +0 -5915
  190. package/src/zspec/zcl/definition/clusters-typegen.ts +0 -588
  191. package/src/zspec/zcl/definition/clusters-types.ts +0 -7331
  192. package/src/zspec/zcl/definition/consts.ts +0 -24
  193. package/src/zspec/zcl/definition/enums.ts +0 -203
  194. package/src/zspec/zcl/definition/foundation.ts +0 -329
  195. package/src/zspec/zcl/definition/manufacturerCode.ts +0 -729
  196. package/src/zspec/zcl/definition/status.ts +0 -69
  197. package/src/zspec/zcl/definition/tstype.ts +0 -377
  198. package/src/zspec/zcl/index.ts +0 -11
  199. package/src/zspec/zcl/utils.ts +0 -321
  200. package/src/zspec/zcl/zclFrame.ts +0 -356
  201. package/src/zspec/zcl/zclHeader.ts +0 -102
  202. package/src/zspec/zcl/zclStatusError.ts +0 -10
  203. package/src/zspec/zdo/buffaloZdo.ts +0 -2336
  204. package/src/zspec/zdo/definition/clusters.ts +0 -722
  205. package/src/zspec/zdo/definition/consts.ts +0 -16
  206. package/src/zspec/zdo/definition/enums.ts +0 -99
  207. package/src/zspec/zdo/definition/status.ts +0 -105
  208. package/src/zspec/zdo/definition/tstypes.ts +0 -1062
  209. package/src/zspec/zdo/index.ts +0 -7
  210. package/src/zspec/zdo/utils.ts +0 -76
  211. package/src/zspec/zdo/zdoStatusError.ts +0 -10
  212. package/test/adapter/adapter.test.ts +0 -1062
  213. package/test/adapter/ember/ash.test.ts +0 -337
  214. package/test/adapter/ember/consts.ts +0 -131
  215. package/test/adapter/ember/emberAdapter.test.ts +0 -3449
  216. package/test/adapter/ember/ezsp.test.ts +0 -385
  217. package/test/adapter/ember/ezspBuffalo.test.ts +0 -93
  218. package/test/adapter/ember/ezspError.test.ts +0 -12
  219. package/test/adapter/ember/math.test.ts +0 -206
  220. package/test/adapter/ezsp/frame.test.ts +0 -30
  221. package/test/adapter/ezsp/uart.test.ts +0 -181
  222. package/test/adapter/z-stack/adapter.test.ts +0 -3984
  223. package/test/adapter/z-stack/constants.test.ts +0 -33
  224. package/test/adapter/z-stack/structs.test.ts +0 -115
  225. package/test/adapter/z-stack/unpi.test.ts +0 -213
  226. package/test/adapter/z-stack/znp.test.ts +0 -1284
  227. package/test/adapter/zboss/fixZdoResponse.test.ts +0 -179
  228. package/test/adapter/zigate/patchZdoBuffaloBE.test.ts +0 -81
  229. package/test/adapter/zigate/zdo.test.ts +0 -187
  230. package/test/adapter/zoh/utils.test.ts +0 -36
  231. package/test/adapter/zoh/zohAdapter.test.ts +0 -1307
  232. package/test/benchOptions.ts +0 -14
  233. package/test/buffalo.test.ts +0 -431
  234. package/test/controller.bench.ts +0 -214
  235. package/test/controller.test.ts +0 -8702
  236. package/test/greenpower.test.ts +0 -1408
  237. package/test/mockAdapters.ts +0 -65
  238. package/test/mockDevices.ts +0 -598
  239. package/test/requests.bench.ts +0 -229
  240. package/test/testUtils.ts +0 -20
  241. package/test/tsconfig.json +0 -9
  242. package/test/utils/math.ts +0 -19
  243. package/test/utils.test.ts +0 -279
  244. package/test/vitest.config.mts +0 -26
  245. package/test/zcl.test.ts +0 -2831
  246. package/test/zspec/utils.test.ts +0 -68
  247. package/test/zspec/zcl/buffalo.test.ts +0 -1374
  248. package/test/zspec/zcl/frame.test.ts +0 -960
  249. package/test/zspec/zcl/utils.test.ts +0 -273
  250. package/test/zspec/zdo/buffalo.test.ts +0 -1850
  251. package/test/zspec/zdo/utils.test.ts +0 -241
  252. 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
- }