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,460 +0,0 @@
1
- /* v8 ignore start */
2
-
3
- import {EventEmitter} from "node:events";
4
- import net from "node:net";
5
-
6
- import {Queue, Waitress, wait} from "../../../utils";
7
- import {logger} from "../../../utils/logger";
8
- import {SerialPort} from "../../serialPort";
9
- import SocketPortUtils from "../../socketPortUtils";
10
- import type {SerialPortOptions} from "../../tstype";
11
- import {FrameType, Frame as NpiFrame} from "./frame";
12
- import {Parser} from "./parser";
13
- import {Writer} from "./writer";
14
-
15
- const NS = "zh:ezsp:uart";
16
-
17
- enum NcpResetCode {
18
- RESET_UNKNOWN_REASON = 0x00,
19
- RESET_EXTERNAL = 0x01,
20
- RESET_POWER_ON = 0x02,
21
- RESET_WATCHDOG = 0x03,
22
- RESET_ASSERT = 0x06,
23
- RESET_BOOTLOADER = 0x09,
24
- RESET_SOFTWARE = 0x0b,
25
- ERROR_EXCEEDED_MAXIMUM_ACK_TIMEOUT_COUNT = 0x51,
26
- ERROR_UNKNOWN_EM3XX_ERROR = 0x80,
27
- }
28
-
29
- type EZSPPacket = {
30
- sequence: number;
31
- };
32
-
33
- type EZSPPacketMatcher = {
34
- sequence: number;
35
- };
36
-
37
- export class SerialDriver extends EventEmitter {
38
- private serialPort?: SerialPort;
39
- private socketPort?: net.Socket;
40
- private writer: Writer;
41
- private parser: Parser;
42
- private initialized: boolean;
43
- private sendSeq = 0; // next frame number to send
44
- private recvSeq = 0; // next frame number to receive
45
- private ackSeq = 0; // next number after the last accepted frame
46
- private rejectCondition = false;
47
- private waitress: Waitress<EZSPPacket, EZSPPacketMatcher>;
48
- private queue: Queue;
49
-
50
- constructor() {
51
- super();
52
- this.initialized = false;
53
- this.queue = new Queue(1);
54
- this.waitress = new Waitress<EZSPPacket, EZSPPacketMatcher>(this.waitressValidator, this.waitressTimeoutFormatter);
55
- this.writer = new Writer();
56
- this.parser = new Parser();
57
- }
58
-
59
- async connect(options: SerialPortOptions): Promise<void> {
60
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
61
- if (SocketPortUtils.isTcpPath(options.path!)) {
62
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
63
- await this.openSocketPort(options.path!);
64
- } else {
65
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
66
- await this.openSerialPort(options.path!, options.baudRate!, options.rtscts!);
67
- }
68
- }
69
-
70
- private async openSerialPort(path: string, baudRate: number, rtscts: boolean): Promise<void> {
71
- const options = {
72
- path,
73
- baudRate: typeof baudRate === "number" ? baudRate : 115200,
74
- rtscts: typeof rtscts === "boolean" ? rtscts : false,
75
- autoOpen: false,
76
- parity: "none",
77
- stopBits: 1,
78
- xon: false,
79
- xoff: false,
80
- };
81
-
82
- // enable software flow control if RTS/CTS not enabled in config
83
- if (!options.rtscts) {
84
- logger.debug("RTS/CTS config is off, enabling software flow control.", NS);
85
- options.xon = true;
86
- options.xoff = true;
87
- }
88
-
89
- logger.debug(`Opening SerialPort with ${JSON.stringify(options)}`, NS);
90
- // @ts-expect-error
91
- this.serialPort = new SerialPort(options);
92
-
93
- this.writer.pipe(this.serialPort);
94
-
95
- this.serialPort.pipe(this.parser);
96
- this.parser.on("parsed", this.onParsed.bind(this));
97
-
98
- try {
99
- await this.serialPort.asyncOpen();
100
- logger.debug("Serialport opened", NS);
101
-
102
- this.serialPort.once("close", this.onPortClose.bind(this));
103
- this.serialPort.on("error", this.onPortError.bind(this));
104
-
105
- // reset
106
- await this.reset();
107
-
108
- this.initialized = true;
109
- } catch (error) {
110
- this.initialized = false;
111
-
112
- if (this.serialPort.isOpen) {
113
- this.serialPort.close();
114
- }
115
-
116
- throw error;
117
- }
118
- }
119
-
120
- private async openSocketPort(path: string): Promise<void> {
121
- const info = SocketPortUtils.parseTcpPath(path);
122
- logger.debug(`Opening TCP socket with ${info.host}:${info.port}`, NS);
123
-
124
- this.socketPort = new net.Socket();
125
- this.socketPort.setNoDelay(true);
126
- this.socketPort.setKeepAlive(true, 15000);
127
-
128
- this.writer.pipe(this.socketPort);
129
-
130
- this.socketPort.pipe(this.parser);
131
- this.parser.on("parsed", this.onParsed.bind(this));
132
-
133
- return await new Promise((resolve, reject): void => {
134
- const openError = (err: Error): void => {
135
- this.initialized = false;
136
-
137
- reject(err);
138
- };
139
-
140
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
141
- this.socketPort!.on("connect", () => {
142
- logger.debug("Socket connected", NS);
143
- });
144
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
145
- this.socketPort!.on("ready", async (): Promise<void> => {
146
- logger.debug("Socket ready", NS);
147
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
148
- this.socketPort!.removeListener("error", openError);
149
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
150
- this.socketPort!.once("close", this.onPortClose.bind(this));
151
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
152
- this.socketPort!.on("error", this.onPortError.bind(this));
153
-
154
- // reset
155
- await this.reset();
156
-
157
- this.initialized = true;
158
-
159
- resolve();
160
- });
161
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
162
- this.socketPort!.once("error", openError);
163
-
164
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
165
- this.socketPort!.connect(info.port, info.host);
166
- });
167
- }
168
-
169
- private async onParsed(frame: NpiFrame): Promise<void> {
170
- const rejectCondition = this.rejectCondition;
171
- try {
172
- frame.checkCRC();
173
-
174
- /* Frame receive handler */
175
- switch (frame.type) {
176
- case FrameType.DATA:
177
- this.handleDATA(frame);
178
- break;
179
- case FrameType.ACK:
180
- this.handleACK(frame);
181
- break;
182
- case FrameType.NAK:
183
- this.handleNAK(frame);
184
- break;
185
- case FrameType.RST:
186
- this.handleRST(frame);
187
- break;
188
- case FrameType.RSTACK:
189
- this.handleRSTACK(frame);
190
- break;
191
- case FrameType.ERROR:
192
- await this.handleError(frame);
193
- break;
194
- default:
195
- this.rejectCondition = true;
196
- logger.debug(`UNKNOWN FRAME RECEIVED: ${frame}`, NS);
197
- }
198
- } catch (error) {
199
- this.rejectCondition = true;
200
- logger.error(`Error while parsing to NpiFrame '${error}'`, NS);
201
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
202
- logger.debug((error as Error).stack!, NS);
203
- }
204
-
205
- // We send NAK only if the rejectCondition was set in the current processing
206
- if (!rejectCondition && this.rejectCondition) {
207
- // send NAK
208
- this.writer.sendNAK(this.recvSeq);
209
- }
210
- }
211
-
212
- private handleDATA(frame: NpiFrame): void {
213
- /* Data frame receive handler */
214
- const frmNum = (frame.control & 0x70) >> 4;
215
- const reTx = (frame.control & 0x08) >> 3;
216
-
217
- logger.debug(`<-- DATA (${frmNum},${frame.control & 0x07},${reTx}): ${frame}`, NS);
218
-
219
- // Expected package {recvSeq}, but received {frmNum}
220
- // This happens when the chip sends us a reTx packet, but we are waiting for the next one
221
- if (this.recvSeq !== frmNum) {
222
- if (reTx) {
223
- // if the reTx flag is set, then this is a packet replay
224
- logger.debug(`Unexpected DATA packet sequence ${frmNum} | ${this.recvSeq}: packet replay`, NS);
225
- } else {
226
- // otherwise, the sequence of packets is out of order - skip or send NAK is needed
227
- logger.debug(`Unexpected DATA packet sequence ${frmNum} | ${this.recvSeq}: reject condition`, NS);
228
- this.rejectCondition = true;
229
- return;
230
- }
231
- }
232
-
233
- this.rejectCondition = false;
234
-
235
- this.recvSeq = (frmNum + 1) & 7; // next
236
-
237
- logger.debug(`--> ACK (${this.recvSeq})`, NS);
238
-
239
- this.writer.sendACK(this.recvSeq);
240
-
241
- const handled = this.handleACK(frame);
242
-
243
- if (reTx && !handled) {
244
- // if the package is resent and did not expect it,
245
- // then will skip it - already processed it earlier
246
- logger.debug(`Skipping the packet as repeated (${this.recvSeq})`, NS);
247
-
248
- return;
249
- }
250
-
251
- const data = frame.buffer.subarray(1, -3);
252
-
253
- this.emit("received", NpiFrame.makeRandomizedBuffer(data));
254
- }
255
-
256
- private handleACK(frame: NpiFrame): boolean {
257
- /* Handle an acknowledgement frame */
258
- // next number after the last accepted frame
259
- this.ackSeq = frame.control & 0x07;
260
-
261
- logger.debug(`<-- ACK (${this.ackSeq}): ${frame}`, NS);
262
-
263
- const handled = this.waitress.resolve({sequence: this.ackSeq});
264
-
265
- if (!handled && this.sendSeq !== this.ackSeq) {
266
- // Packet confirmation received for {ackSeq}, but was expected {sendSeq}
267
- // This happens when the chip has not yet received of the packet {sendSeq} from us,
268
- // but has already sent us the next one.
269
- logger.debug(`Unexpected packet sequence ${this.ackSeq} | ${this.sendSeq}`, NS);
270
- }
271
-
272
- return handled;
273
- }
274
-
275
- private handleNAK(frame: NpiFrame): void {
276
- /* Handle negative acknowledgment frame */
277
- const nakNum = frame.control & 0x07;
278
-
279
- logger.debug(`<-- NAK (${nakNum}): ${frame}`, NS);
280
-
281
- const handled = this.waitress.reject({sequence: nakNum}, "Recv NAK frame");
282
-
283
- if (!handled) {
284
- // send NAK
285
- logger.debug(`NAK Unexpected packet sequence ${nakNum}`, NS);
286
- } else {
287
- logger.debug(`NAK Expected packet sequence ${nakNum}`, NS);
288
- }
289
- }
290
-
291
- private handleRST(frame: NpiFrame): void {
292
- logger.debug(`<-- RST: ${frame}`, NS);
293
- }
294
-
295
- private handleRSTACK(frame: NpiFrame): void {
296
- /* Reset acknowledgement frame receive handler */
297
- let code: string | number;
298
- this.rejectCondition = false;
299
-
300
- logger.debug(`<-- RSTACK ${frame}`, NS);
301
-
302
- try {
303
- code = NcpResetCode[frame.buffer[2]];
304
- } catch {
305
- code = NcpResetCode.ERROR_UNKNOWN_EM3XX_ERROR;
306
- }
307
-
308
- logger.debug(`RSTACK Version: ${frame.buffer[1]} Reason: ${code.toString()} frame: ${frame}`, NS);
309
-
310
- if (NcpResetCode[<number>code].toString() !== NcpResetCode.RESET_SOFTWARE.toString()) {
311
- return;
312
- }
313
-
314
- this.waitress.resolve({sequence: -1});
315
- }
316
-
317
- private async handleError(frame: NpiFrame): Promise<void> {
318
- logger.debug(`<-- Error ${frame}`, NS);
319
-
320
- try {
321
- // send reset
322
- await this.reset();
323
- } catch (error) {
324
- logger.error(`Failed to reset on Error Frame: ${error}`, NS);
325
- }
326
- }
327
-
328
- async reset(): Promise<void> {
329
- logger.debug("Uart reseting", NS);
330
- this.parser.reset();
331
- this.queue.clear();
332
- this.sendSeq = 0;
333
- this.recvSeq = 0;
334
-
335
- return await this.queue.execute<void>(async (): Promise<void> => {
336
- try {
337
- logger.debug("--> Write reset", NS);
338
- const waiter = this.waitFor(-1, 10000);
339
- this.rejectCondition = false;
340
-
341
- this.writer.sendReset();
342
- logger.debug("-?- waiting reset", NS);
343
- await waiter.start().promise;
344
- logger.debug("-+- waiting reset success", NS);
345
-
346
- await wait(2000);
347
- } catch (e) {
348
- logger.error(`--> Error: ${e}`, NS);
349
-
350
- this.emit("reset");
351
-
352
- throw new Error(`Reset error: ${e}`);
353
- }
354
- });
355
- }
356
-
357
- public async close(emitClose: boolean): Promise<void> {
358
- logger.debug("Closing UART", NS);
359
- this.queue.clear();
360
-
361
- if (this.initialized) {
362
- this.initialized = false;
363
-
364
- if (this.serialPort) {
365
- try {
366
- await this.serialPort.asyncFlushAndClose();
367
- } catch (error) {
368
- if (emitClose) {
369
- this.emit("close");
370
- }
371
-
372
- throw error;
373
- }
374
- } else {
375
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
376
- this.socketPort!.destroy();
377
- }
378
- }
379
-
380
- if (emitClose) {
381
- this.emit("close");
382
- }
383
- }
384
-
385
- private onPortError(error: Error): void {
386
- logger.error(`Port error: ${error}`, NS);
387
- }
388
-
389
- private onPortClose(err: boolean | Error): void {
390
- logger.debug(`Port closed. Error? ${err}`, NS);
391
-
392
- // on error: serialport passes an Error object (in case of disconnect)
393
- // net.Socket passes a boolean (in case of a transmission error)
394
- // try to reset instead of failing immediately
395
- if (err != null && err !== false) {
396
- this.emit("reset");
397
- } else {
398
- this.initialized = false;
399
- this.emit("close");
400
- }
401
- }
402
-
403
- public isInitialized(): boolean {
404
- return this.initialized;
405
- }
406
-
407
- public async sendDATA(data: Buffer): Promise<void> {
408
- const seq = this.sendSeq;
409
- this.sendSeq = (seq + 1) % 8; // next
410
- const nextSeq = this.sendSeq;
411
- const ackSeq = this.recvSeq;
412
-
413
- return await this.queue.execute<void>(async (): Promise<void> => {
414
- const randData = NpiFrame.makeRandomizedBuffer(data);
415
-
416
- try {
417
- const waiter = this.waitFor(nextSeq);
418
- logger.debug(`--> DATA (${seq},${ackSeq},0): ${data.toString("hex")}`, NS);
419
- this.writer.sendData(randData, seq, 0, ackSeq);
420
- logger.debug(`-?- waiting (${nextSeq})`, NS);
421
- await waiter.start().promise;
422
- logger.debug(`-+- waiting (${nextSeq}) success`, NS);
423
- } catch (e1) {
424
- logger.error(`--> Error: ${e1}`, NS);
425
- logger.error(`-!- break waiting (${nextSeq})`, NS);
426
- logger.error(`Can't send DATA frame (${seq},${ackSeq},0): ${data.toString("hex")}`, NS);
427
-
428
- try {
429
- await wait(500);
430
- const waiter = this.waitFor(nextSeq);
431
- logger.debug(`->> DATA (${seq},${ackSeq},1): ${data.toString("hex")}`, NS);
432
- this.writer.sendData(randData, seq, 1, ackSeq);
433
- logger.debug(`-?- rewaiting (${nextSeq})`, NS);
434
- await waiter.start().promise;
435
- logger.debug(`-+- rewaiting (${nextSeq}) success`, NS);
436
- } catch (e2) {
437
- logger.error(`--> Error: ${e2}`, NS);
438
- logger.error(`-!- break rewaiting (${nextSeq})`, NS);
439
- logger.error(`Can't resend DATA frame (${seq},${ackSeq},1): ${data.toString("hex")}`, NS);
440
- if (this.initialized) {
441
- this.emit("reset");
442
- }
443
- throw new Error(`sendDATA error: try 1: ${e1}, try 2: ${e2}`);
444
- }
445
- }
446
- });
447
- }
448
-
449
- public waitFor(sequence: number, timeout = 4000): {start: () => {promise: Promise<EZSPPacket>; ID: number}; ID: number} {
450
- return this.waitress.waitFor({sequence}, timeout);
451
- }
452
-
453
- private waitressTimeoutFormatter(matcher: EZSPPacketMatcher, timeout: number): string {
454
- return `${JSON.stringify(matcher)} after ${timeout}ms`;
455
- }
456
-
457
- private waitressValidator(payload: EZSPPacket, matcher: EZSPPacketMatcher): boolean {
458
- return payload.sequence === matcher.sequence;
459
- }
460
- }
@@ -1,44 +0,0 @@
1
- /* v8 ignore start */
2
-
3
- import type {Buffer} from "node:buffer";
4
-
5
- type CalcFn = (buf: Buffer | number[], previous: number) => number;
6
-
7
- function defineCrc(model: string, calc: CalcFn): CalcFn {
8
- const fn = (buf: Buffer | number[], previous: number): number => calc(buf, previous) >>> 0;
9
- fn.signed = calc;
10
- fn.unsigned = fn;
11
- fn.model = model;
12
-
13
- return fn;
14
- }
15
-
16
- // Generated by `./pycrc.py --algorithm=table-driven --model=ccitt --generate=c`
17
- const TABLE: number[] = [
18
- 0x0000, 0x1021, 0x2042, 0x3063, 0x4084, 0x50a5, 0x60c6, 0x70e7, 0x8108, 0x9129, 0xa14a, 0xb16b, 0xc18c, 0xd1ad, 0xe1ce, 0xf1ef, 0x1231, 0x0210,
19
- 0x3273, 0x2252, 0x52b5, 0x4294, 0x72f7, 0x62d6, 0x9339, 0x8318, 0xb37b, 0xa35a, 0xd3bd, 0xc39c, 0xf3ff, 0xe3de, 0x2462, 0x3443, 0x0420, 0x1401,
20
- 0x64e6, 0x74c7, 0x44a4, 0x5485, 0xa56a, 0xb54b, 0x8528, 0x9509, 0xe5ee, 0xf5cf, 0xc5ac, 0xd58d, 0x3653, 0x2672, 0x1611, 0x0630, 0x76d7, 0x66f6,
21
- 0x5695, 0x46b4, 0xb75b, 0xa77a, 0x9719, 0x8738, 0xf7df, 0xe7fe, 0xd79d, 0xc7bc, 0x48c4, 0x58e5, 0x6886, 0x78a7, 0x0840, 0x1861, 0x2802, 0x3823,
22
- 0xc9cc, 0xd9ed, 0xe98e, 0xf9af, 0x8948, 0x9969, 0xa90a, 0xb92b, 0x5af5, 0x4ad4, 0x7ab7, 0x6a96, 0x1a71, 0x0a50, 0x3a33, 0x2a12, 0xdbfd, 0xcbdc,
23
- 0xfbbf, 0xeb9e, 0x9b79, 0x8b58, 0xbb3b, 0xab1a, 0x6ca6, 0x7c87, 0x4ce4, 0x5cc5, 0x2c22, 0x3c03, 0x0c60, 0x1c41, 0xedae, 0xfd8f, 0xcdec, 0xddcd,
24
- 0xad2a, 0xbd0b, 0x8d68, 0x9d49, 0x7e97, 0x6eb6, 0x5ed5, 0x4ef4, 0x3e13, 0x2e32, 0x1e51, 0x0e70, 0xff9f, 0xefbe, 0xdfdd, 0xcffc, 0xbf1b, 0xaf3a,
25
- 0x9f59, 0x8f78, 0x9188, 0x81a9, 0xb1ca, 0xa1eb, 0xd10c, 0xc12d, 0xf14e, 0xe16f, 0x1080, 0x00a1, 0x30c2, 0x20e3, 0x5004, 0x4025, 0x7046, 0x6067,
26
- 0x83b9, 0x9398, 0xa3fb, 0xb3da, 0xc33d, 0xd31c, 0xe37f, 0xf35e, 0x02b1, 0x1290, 0x22f3, 0x32d2, 0x4235, 0x5214, 0x6277, 0x7256, 0xb5ea, 0xa5cb,
27
- 0x95a8, 0x8589, 0xf56e, 0xe54f, 0xd52c, 0xc50d, 0x34e2, 0x24c3, 0x14a0, 0x0481, 0x7466, 0x6447, 0x5424, 0x4405, 0xa7db, 0xb7fa, 0x8799, 0x97b8,
28
- 0xe75f, 0xf77e, 0xc71d, 0xd73c, 0x26d3, 0x36f2, 0x0691, 0x16b0, 0x6657, 0x7676, 0x4615, 0x5634, 0xd94c, 0xc96d, 0xf90e, 0xe92f, 0x99c8, 0x89e9,
29
- 0xb98a, 0xa9ab, 0x5844, 0x4865, 0x7806, 0x6827, 0x18c0, 0x08e1, 0x3882, 0x28a3, 0xcb7d, 0xdb5c, 0xeb3f, 0xfb1e, 0x8bf9, 0x9bd8, 0xabbb, 0xbb9a,
30
- 0x4a75, 0x5a54, 0x6a37, 0x7a16, 0x0af1, 0x1ad0, 0x2ab3, 0x3a92, 0xfd2e, 0xed0f, 0xdd6c, 0xcd4d, 0xbdaa, 0xad8b, 0x9de8, 0x8dc9, 0x7c26, 0x6c07,
31
- 0x5c64, 0x4c45, 0x3ca2, 0x2c83, 0x1ce0, 0x0cc1, 0xef1f, 0xff3e, 0xcf5d, 0xdf7c, 0xaf9b, 0xbfba, 0x8fd9, 0x9ff8, 0x6e17, 0x7e36, 0x4e55, 0x5e74,
32
- 0x2e93, 0x3eb2, 0x0ed1, 0x1ef0,
33
- ];
34
-
35
- const crc16ccitt = defineCrc("ccitt", (buf: Buffer | number[], previous: number): number => {
36
- let crc = ~~previous;
37
- for (const byte of buf) {
38
- crc = (TABLE[((crc >> 8) ^ byte) & 0xff] ^ (crc << 8)) & 0xffff;
39
- }
40
-
41
- return crc;
42
- });
43
-
44
- export default crc16ccitt;
@@ -1,32 +0,0 @@
1
- /* v8 ignore start */
2
-
3
- import {randomBytes} from "node:crypto";
4
-
5
- import {EmberEUI64, EmberInitialSecurityBitmask} from "../types/named";
6
- import {EmberInitialSecurityState, EmberKeyData} from "../types/struct";
7
- import crc16ccitt from "./crc16ccitt";
8
-
9
- if (!Symbol.asyncIterator) {
10
- // biome-ignore lint/suspicious/noExplicitAny: API
11
- (<any>Symbol).asyncIterator = Symbol.for("Symbol.asyncIterator");
12
- }
13
-
14
- function emberSecurity(networkKey: Buffer): EmberInitialSecurityState {
15
- const isc: EmberInitialSecurityState = new EmberInitialSecurityState();
16
- isc.bitmask =
17
- EmberInitialSecurityBitmask.HAVE_PRECONFIGURED_KEY |
18
- EmberInitialSecurityBitmask.TRUST_CENTER_GLOBAL_LINK_KEY |
19
- EmberInitialSecurityBitmask.HAVE_NETWORK_KEY |
20
- //EmberInitialSecurityBitmask.PRECONFIGURED_NETWORK_KEY_MODE |
21
- EmberInitialSecurityBitmask.REQUIRE_ENCRYPTED_KEY |
22
- EmberInitialSecurityBitmask.TRUST_CENTER_USES_HASHED_LINK_KEY;
23
- isc.preconfiguredKey = new EmberKeyData();
24
- isc.preconfiguredKey.contents = randomBytes(16);
25
- isc.networkKey = new EmberKeyData();
26
- isc.networkKey.contents = networkKey;
27
- isc.networkKeySequenceNumber = 0;
28
- isc.preconfiguredTrustCenterEui64 = new EmberEUI64([0, 0, 0, 0, 0, 0, 0, 0]);
29
- return isc;
30
- }
31
-
32
- export {crc16ccitt, emberSecurity};
@@ -1,64 +0,0 @@
1
- /* v8 ignore start */
2
-
3
- import * as stream from "node:stream";
4
-
5
- import {logger} from "../../../utils/logger";
6
- import * as consts from "./consts";
7
- import {crc16ccitt} from "./utils";
8
-
9
- const NS = "zh:ezsp:uart";
10
-
11
- export class Writer extends stream.Readable {
12
- public writeBuffer(buffer: Buffer): void {
13
- logger.debug(`--> [${buffer.toString("hex")}]`, NS);
14
- this.push(buffer);
15
- }
16
-
17
- public override _read(): void {}
18
-
19
- public sendACK(ackNum: number): void {
20
- /* Construct a acknowledgement frame */
21
- const ackFrame = this.makeFrame(0b10000000 | ackNum);
22
- this.writeBuffer(ackFrame);
23
- }
24
-
25
- public sendNAK(ackNum: number): void {
26
- /* Construct a negative acknowledgement frame */
27
- const nakFrame = this.makeFrame(0b10100000 | ackNum);
28
- this.writeBuffer(nakFrame);
29
- }
30
-
31
- public sendReset(): void {
32
- /* Construct a reset frame */
33
- const rstFrame = Buffer.concat([Buffer.from([consts.CANCEL]), this.makeFrame(0xc0)]);
34
- this.writeBuffer(rstFrame);
35
- }
36
-
37
- public sendData(data: Buffer, seq: number, rxmit: number, ackSeq: number): void {
38
- /* Construct a data frame */
39
- const control = (seq << 4) | (rxmit << 3) | ackSeq;
40
- const dataFrame = this.makeFrame(control, data);
41
- this.writeBuffer(dataFrame);
42
- }
43
-
44
- private *stuff(buffer: number[]): Generator<number> {
45
- /* Byte stuff (escape) a string for transmission */
46
- for (const byte of buffer) {
47
- if (consts.RESERVED.includes(byte)) {
48
- yield consts.ESCAPE;
49
- yield byte ^ consts.STUFF;
50
- } else {
51
- yield byte;
52
- }
53
- }
54
- }
55
-
56
- private makeFrame(control: number, data?: Buffer): Buffer {
57
- /* Construct a frame */
58
- const frm = [control, ...(data || [])];
59
- const crc = crc16ccitt(frm, 65535);
60
- frm.push(crc >> 8);
61
- frm.push(crc % 256);
62
- return Buffer.from([...this.stuff(frm), consts.FLAG]);
63
- }
64
- }
@@ -1,3 +0,0 @@
1
- export {Adapter} from "./adapter";
2
- export * as Events from "./events";
3
- export * as TsType from "./tstype";
@@ -1,58 +0,0 @@
1
- /* v8 ignore start */
2
-
3
- import {type AutoDetectTypes, autoDetect, type OpenOptionsFromBinding, type SetOptions} from "@serialport/bindings-cpp";
4
- // This file was copied from https://github.com/serialport/node-serialport/blob/master/packages/serialport/lib/serialport.ts.
5
- import {type ErrorCallback, type OpenOptions, SerialPortStream, type StreamOptions} from "@serialport/stream";
6
-
7
- const DetectedBinding = autoDetect();
8
-
9
- export type SerialPortOpenOptions<T extends AutoDetectTypes> = Omit<StreamOptions<T>, "binding"> & OpenOptionsFromBinding<T>;
10
-
11
- export class SerialPort<T extends AutoDetectTypes = AutoDetectTypes> extends SerialPortStream<T> {
12
- static list = DetectedBinding.list;
13
- static readonly binding = DetectedBinding;
14
-
15
- constructor(options: SerialPortOpenOptions<T>, openCallback?: ErrorCallback) {
16
- const opts: OpenOptions<T> = {
17
- binding: DetectedBinding as T,
18
- ...options,
19
- };
20
- super(opts, openCallback);
21
- }
22
-
23
- public async asyncOpen(): Promise<void> {
24
- return await new Promise((resolve, reject): void => {
25
- this.open((err) => (err ? reject(err) : resolve()));
26
- });
27
- }
28
-
29
- public async asyncClose(): Promise<void> {
30
- return await new Promise((resolve, reject): void => {
31
- this.close((err) => (err ? reject(err) : resolve()));
32
- });
33
- }
34
-
35
- public async asyncFlush(): Promise<void> {
36
- return await new Promise((resolve, reject): void => {
37
- this.flush((err) => (err ? reject(err) : resolve()));
38
- });
39
- }
40
-
41
- public async asyncFlushAndClose(): Promise<void> {
42
- await this.asyncFlush();
43
- await this.asyncClose();
44
- }
45
-
46
- public async asyncGet(): Promise<{cts: boolean; dsr: boolean; dcd: boolean}> {
47
- return await new Promise((resolve, reject): void => {
48
- // biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
49
- this.get((err, options?) => (err ? reject(err) : resolve(options!)));
50
- });
51
- }
52
-
53
- public async asyncSet(options: SetOptions): Promise<void> {
54
- return await new Promise((resolve, reject): void => {
55
- this.set(options, (err) => (err ? reject(err) : resolve()));
56
- });
57
- }
58
- }
@@ -1,16 +0,0 @@
1
- export function isTcpPath(path: string): boolean {
2
- // tcp path must be:
3
- // tcp://<host>:<port>
4
- const regex = /^(?:tcp:\/\/)[\w.-]+[:][\d]+$/gm;
5
- return regex.test(path);
6
- }
7
-
8
- export function parseTcpPath(path: string): {host: string; port: number} {
9
- const str = path.replace("tcp://", "");
10
- return {
11
- host: str.substring(0, str.indexOf(":")),
12
- port: Number(str.substring(str.indexOf(":") + 1)),
13
- };
14
- }
15
-
16
- export default {isTcpPath, parseTcpPath};