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.
- package/CHANGELOG.md +16 -0
- package/dist/adapter/ezsp/driver/uart.js +1 -1
- package/dist/adapter/ezsp/driver/uart.js.map +1 -1
- package/dist/adapter/z-stack/adapter/zStackAdapter.js +4 -4
- package/dist/adapter/z-stack/adapter/zStackAdapter.js.map +1 -1
- package/dist/adapter/zigate/adapter/zigateAdapter.js +4 -4
- package/dist/adapter/zigate/adapter/zigateAdapter.js.map +1 -1
- package/dist/controller/model/device.d.ts.map +1 -1
- package/dist/controller/model/device.js +1 -0
- package/dist/controller/model/device.js.map +1 -1
- package/package.json +14 -6
- package/.github/ISSUE_TEMPLATE/config.yml +0 -5
- package/.github/dependabot.yml +0 -22
- package/.github/workflows/ci.yml +0 -64
- package/.github/workflows/release-please.yml +0 -18
- package/.github/workflows/stale.yml +0 -20
- package/.github/workflows/typedoc.yaml +0 -47
- package/.release-please-manifest.json +0 -3
- package/.vscode/extensions.json +0 -3
- package/.vscode/settings.json +0 -11
- package/biome.json +0 -98
- package/examples/join-and-log.js +0 -24
- package/release-please-config.json +0 -9
- package/src/adapter/adapter.ts +0 -189
- package/src/adapter/adapterDiscovery.ts +0 -666
- package/src/adapter/const.ts +0 -12
- package/src/adapter/deconz/adapter/deconzAdapter.ts +0 -877
- package/src/adapter/deconz/driver/constants.ts +0 -246
- package/src/adapter/deconz/driver/driver.ts +0 -1540
- package/src/adapter/deconz/driver/frame.ts +0 -11
- package/src/adapter/deconz/driver/frameParser.ts +0 -753
- package/src/adapter/deconz/driver/parser.ts +0 -45
- package/src/adapter/deconz/driver/writer.ts +0 -22
- package/src/adapter/deconz/types.d.ts +0 -13
- package/src/adapter/ember/adapter/emberAdapter.ts +0 -2265
- package/src/adapter/ember/adapter/endpoints.ts +0 -86
- package/src/adapter/ember/adapter/oneWaitress.ts +0 -324
- package/src/adapter/ember/adapter/tokensManager.ts +0 -782
- package/src/adapter/ember/consts.ts +0 -178
- package/src/adapter/ember/enums.ts +0 -1746
- package/src/adapter/ember/ezsp/buffalo.ts +0 -1392
- package/src/adapter/ember/ezsp/consts.ts +0 -148
- package/src/adapter/ember/ezsp/enums.ts +0 -1114
- package/src/adapter/ember/ezsp/ezsp.ts +0 -9061
- package/src/adapter/ember/ezspError.ts +0 -10
- package/src/adapter/ember/types.ts +0 -866
- package/src/adapter/ember/uart/ash.ts +0 -1960
- package/src/adapter/ember/uart/consts.ts +0 -109
- package/src/adapter/ember/uart/enums.ts +0 -192
- package/src/adapter/ember/uart/parser.ts +0 -48
- package/src/adapter/ember/uart/queues.ts +0 -247
- package/src/adapter/ember/uart/writer.ts +0 -53
- package/src/adapter/ember/utils/initters.ts +0 -58
- package/src/adapter/ember/utils/math.ts +0 -73
- package/src/adapter/events.ts +0 -21
- package/src/adapter/ezsp/adapter/backup.ts +0 -109
- package/src/adapter/ezsp/adapter/ezspAdapter.ts +0 -614
- package/src/adapter/ezsp/driver/commands.ts +0 -2497
- package/src/adapter/ezsp/driver/consts.ts +0 -11
- package/src/adapter/ezsp/driver/driver.ts +0 -1002
- package/src/adapter/ezsp/driver/ezsp.ts +0 -802
- package/src/adapter/ezsp/driver/frame.ts +0 -101
- package/src/adapter/ezsp/driver/index.ts +0 -4
- package/src/adapter/ezsp/driver/multicast.ts +0 -78
- package/src/adapter/ezsp/driver/parser.ts +0 -81
- package/src/adapter/ezsp/driver/types/basic.ts +0 -201
- package/src/adapter/ezsp/driver/types/index.ts +0 -239
- package/src/adapter/ezsp/driver/types/named.ts +0 -2330
- package/src/adapter/ezsp/driver/types/struct.ts +0 -844
- package/src/adapter/ezsp/driver/uart.ts +0 -460
- package/src/adapter/ezsp/driver/utils/crc16ccitt.ts +0 -44
- package/src/adapter/ezsp/driver/utils/index.ts +0 -32
- package/src/adapter/ezsp/driver/writer.ts +0 -64
- package/src/adapter/index.ts +0 -3
- package/src/adapter/serialPort.ts +0 -58
- package/src/adapter/socketPortUtils.ts +0 -16
- package/src/adapter/tstype.ts +0 -78
- package/src/adapter/z-stack/adapter/adapter-backup.ts +0 -519
- package/src/adapter/z-stack/adapter/adapter-nv-memory.ts +0 -457
- package/src/adapter/z-stack/adapter/endpoints.ts +0 -57
- package/src/adapter/z-stack/adapter/manager.ts +0 -543
- package/src/adapter/z-stack/adapter/tstype.ts +0 -6
- package/src/adapter/z-stack/adapter/zStackAdapter.ts +0 -1190
- package/src/adapter/z-stack/constants/af.ts +0 -27
- package/src/adapter/z-stack/constants/common.ts +0 -285
- package/src/adapter/z-stack/constants/dbg.ts +0 -23
- package/src/adapter/z-stack/constants/index.ts +0 -11
- package/src/adapter/z-stack/constants/mac.ts +0 -128
- package/src/adapter/z-stack/constants/sapi.ts +0 -25
- package/src/adapter/z-stack/constants/sys.ts +0 -72
- package/src/adapter/z-stack/constants/util.ts +0 -82
- package/src/adapter/z-stack/constants/utils.ts +0 -14
- package/src/adapter/z-stack/constants/zdo.ts +0 -103
- package/src/adapter/z-stack/models/startup-options.ts +0 -13
- package/src/adapter/z-stack/structs/entries/address-manager-entry.ts +0 -44
- package/src/adapter/z-stack/structs/entries/address-manager-table.ts +0 -19
- package/src/adapter/z-stack/structs/entries/aps-link-key-data-entry.ts +0 -12
- package/src/adapter/z-stack/structs/entries/aps-link-key-data-table.ts +0 -21
- package/src/adapter/z-stack/structs/entries/aps-tc-link-key-entry.ts +0 -19
- package/src/adapter/z-stack/structs/entries/aps-tc-link-key-table.ts +0 -21
- package/src/adapter/z-stack/structs/entries/channel-list.ts +0 -8
- package/src/adapter/z-stack/structs/entries/has-configured.ts +0 -16
- package/src/adapter/z-stack/structs/entries/index.ts +0 -16
- package/src/adapter/z-stack/structs/entries/nib.ts +0 -66
- package/src/adapter/z-stack/structs/entries/nwk-key-descriptor.ts +0 -15
- package/src/adapter/z-stack/structs/entries/nwk-key.ts +0 -13
- package/src/adapter/z-stack/structs/entries/nwk-pan-id.ts +0 -8
- package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.ts +0 -20
- package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.ts +0 -19
- package/src/adapter/z-stack/structs/entries/security-manager-entry.ts +0 -33
- package/src/adapter/z-stack/structs/entries/security-manager-table.ts +0 -22
- package/src/adapter/z-stack/structs/index.ts +0 -4
- package/src/adapter/z-stack/structs/serializable-memory-object.ts +0 -14
- package/src/adapter/z-stack/structs/struct.ts +0 -367
- package/src/adapter/z-stack/structs/table.ts +0 -198
- package/src/adapter/z-stack/unpi/constants.ts +0 -33
- package/src/adapter/z-stack/unpi/frame.ts +0 -62
- package/src/adapter/z-stack/unpi/index.ts +0 -4
- package/src/adapter/z-stack/unpi/parser.ts +0 -56
- package/src/adapter/z-stack/unpi/writer.ts +0 -21
- package/src/adapter/z-stack/utils/channel-list.ts +0 -40
- package/src/adapter/z-stack/utils/index.ts +0 -2
- package/src/adapter/z-stack/utils/network-options.ts +0 -26
- package/src/adapter/z-stack/znp/buffaloZnp.ts +0 -175
- package/src/adapter/z-stack/znp/definition.ts +0 -2713
- package/src/adapter/z-stack/znp/index.ts +0 -2
- package/src/adapter/z-stack/znp/parameterType.ts +0 -22
- package/src/adapter/z-stack/znp/tstype.ts +0 -44
- package/src/adapter/z-stack/znp/utils.ts +0 -10
- package/src/adapter/z-stack/znp/znp.ts +0 -342
- package/src/adapter/z-stack/znp/zpiObject.ts +0 -148
- package/src/adapter/zboss/adapter/zbossAdapter.ts +0 -526
- package/src/adapter/zboss/commands.ts +0 -1184
- package/src/adapter/zboss/consts.ts +0 -9
- package/src/adapter/zboss/driver.ts +0 -422
- package/src/adapter/zboss/enums.ts +0 -360
- package/src/adapter/zboss/frame.ts +0 -227
- package/src/adapter/zboss/reader.ts +0 -65
- package/src/adapter/zboss/types.ts +0 -0
- package/src/adapter/zboss/uart.ts +0 -428
- package/src/adapter/zboss/utils.ts +0 -58
- package/src/adapter/zboss/writer.ts +0 -49
- package/src/adapter/zigate/adapter/patchZdoBuffaloBE.ts +0 -27
- package/src/adapter/zigate/adapter/zigateAdapter.ts +0 -618
- package/src/adapter/zigate/driver/LICENSE +0 -17
- package/src/adapter/zigate/driver/buffaloZiGate.ts +0 -212
- package/src/adapter/zigate/driver/commandType.ts +0 -418
- package/src/adapter/zigate/driver/constants.ts +0 -150
- package/src/adapter/zigate/driver/frame.ts +0 -197
- package/src/adapter/zigate/driver/messageType.ts +0 -287
- package/src/adapter/zigate/driver/parameterType.ts +0 -32
- package/src/adapter/zigate/driver/ziGateObject.ts +0 -146
- package/src/adapter/zigate/driver/zigate.ts +0 -423
- package/src/adapter/zoh/adapter/utils.ts +0 -27
- package/src/adapter/zoh/adapter/zohAdapter.ts +0 -838
- package/src/buffalo/buffalo.ts +0 -342
- package/src/buffalo/index.ts +0 -1
- package/src/controller/controller.ts +0 -1022
- package/src/controller/database.ts +0 -124
- package/src/controller/events.ts +0 -52
- package/src/controller/greenPower.ts +0 -603
- package/src/controller/helpers/index.ts +0 -1
- package/src/controller/helpers/installCodes.ts +0 -107
- package/src/controller/helpers/request.ts +0 -96
- package/src/controller/helpers/requestQueue.ts +0 -125
- package/src/controller/helpers/zclFrameConverter.ts +0 -47
- package/src/controller/helpers/zclTransactionSequenceNumber.ts +0 -19
- package/src/controller/index.ts +0 -6
- package/src/controller/model/device.ts +0 -1248
- package/src/controller/model/endpoint.ts +0 -1105
- package/src/controller/model/entity.ts +0 -23
- package/src/controller/model/group.ts +0 -424
- package/src/controller/model/index.ts +0 -5
- package/src/controller/model/zigbeeEntity.ts +0 -30
- package/src/controller/touchlink.ts +0 -189
- package/src/controller/tstype.ts +0 -274
- package/src/index.ts +0 -12
- package/src/models/backup-storage-legacy.ts +0 -48
- package/src/models/backup-storage-unified.ts +0 -47
- package/src/models/backup.ts +0 -37
- package/src/models/index.ts +0 -5
- package/src/models/network-options.ts +0 -11
- package/src/utils/backup.ts +0 -152
- package/src/utils/index.ts +0 -5
- package/src/utils/logger.ts +0 -20
- package/src/utils/patchBigIntSerialization.ts +0 -8
- package/src/utils/queue.ts +0 -76
- package/src/utils/types.d.ts +0 -3
- package/src/utils/utils.ts +0 -19
- package/src/utils/wait.ts +0 -5
- package/src/utils/waitress.ts +0 -96
- package/src/zspec/consts.ts +0 -84
- package/src/zspec/enums.ts +0 -22
- package/src/zspec/index.ts +0 -3
- package/src/zspec/tstypes.ts +0 -18
- package/src/zspec/utils.ts +0 -247
- package/src/zspec/zcl/buffaloZcl.ts +0 -1220
- package/src/zspec/zcl/definition/cluster.ts +0 -5915
- package/src/zspec/zcl/definition/clusters-typegen.ts +0 -588
- package/src/zspec/zcl/definition/clusters-types.ts +0 -7331
- package/src/zspec/zcl/definition/consts.ts +0 -24
- package/src/zspec/zcl/definition/enums.ts +0 -203
- package/src/zspec/zcl/definition/foundation.ts +0 -329
- package/src/zspec/zcl/definition/manufacturerCode.ts +0 -729
- package/src/zspec/zcl/definition/status.ts +0 -69
- package/src/zspec/zcl/definition/tstype.ts +0 -377
- package/src/zspec/zcl/index.ts +0 -11
- package/src/zspec/zcl/utils.ts +0 -321
- package/src/zspec/zcl/zclFrame.ts +0 -356
- package/src/zspec/zcl/zclHeader.ts +0 -102
- package/src/zspec/zcl/zclStatusError.ts +0 -10
- package/src/zspec/zdo/buffaloZdo.ts +0 -2336
- package/src/zspec/zdo/definition/clusters.ts +0 -722
- package/src/zspec/zdo/definition/consts.ts +0 -16
- package/src/zspec/zdo/definition/enums.ts +0 -99
- package/src/zspec/zdo/definition/status.ts +0 -105
- package/src/zspec/zdo/definition/tstypes.ts +0 -1062
- package/src/zspec/zdo/index.ts +0 -7
- package/src/zspec/zdo/utils.ts +0 -76
- package/src/zspec/zdo/zdoStatusError.ts +0 -10
- package/test/adapter/adapter.test.ts +0 -1062
- package/test/adapter/ember/ash.test.ts +0 -337
- package/test/adapter/ember/consts.ts +0 -131
- package/test/adapter/ember/emberAdapter.test.ts +0 -3449
- package/test/adapter/ember/ezsp.test.ts +0 -385
- package/test/adapter/ember/ezspBuffalo.test.ts +0 -93
- package/test/adapter/ember/ezspError.test.ts +0 -12
- package/test/adapter/ember/math.test.ts +0 -206
- package/test/adapter/ezsp/frame.test.ts +0 -30
- package/test/adapter/ezsp/uart.test.ts +0 -181
- package/test/adapter/z-stack/adapter.test.ts +0 -3984
- package/test/adapter/z-stack/constants.test.ts +0 -33
- package/test/adapter/z-stack/structs.test.ts +0 -115
- package/test/adapter/z-stack/unpi.test.ts +0 -213
- package/test/adapter/z-stack/znp.test.ts +0 -1284
- package/test/adapter/zboss/fixZdoResponse.test.ts +0 -179
- package/test/adapter/zigate/patchZdoBuffaloBE.test.ts +0 -81
- package/test/adapter/zigate/zdo.test.ts +0 -187
- package/test/adapter/zoh/utils.test.ts +0 -36
- package/test/adapter/zoh/zohAdapter.test.ts +0 -1307
- package/test/buffalo.test.ts +0 -431
- package/test/controller.bench.ts +0 -193
- package/test/controller.test.ts +0 -8702
- package/test/greenpower.test.ts +0 -1408
- package/test/mockAdapters.ts +0 -65
- package/test/mockDevices.ts +0 -598
- package/test/requests.bench.ts +0 -206
- package/test/testUtils.ts +0 -20
- package/test/tsconfig.json +0 -9
- package/test/utils/math.ts +0 -19
- package/test/utils.test.ts +0 -279
- package/test/vitest.config.mts +0 -27
- package/test/zcl.test.ts +0 -2831
- package/test/zspec/utils.test.ts +0 -68
- package/test/zspec/zcl/buffalo.test.ts +0 -1374
- package/test/zspec/zcl/frame.test.ts +0 -960
- package/test/zspec/zcl/utils.test.ts +0 -273
- package/test/zspec/zdo/buffalo.test.ts +0 -1850
- package/test/zspec/zdo/utils.test.ts +0 -241
- 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-ignore
|
|
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
|
-
}
|
package/src/adapter/index.ts
DELETED
|
@@ -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};
|