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,146 +0,0 @@
|
|
|
1
|
-
/* v8 ignore start */
|
|
2
|
-
|
|
3
|
-
import {logger} from "../../../utils/logger";
|
|
4
|
-
import BuffaloZiGate, {type BuffaloZiGateOptions} from "./buffaloZiGate";
|
|
5
|
-
import {ZiGateCommand, type ZiGateCommandParameter, type ZiGateCommandType} from "./commandType";
|
|
6
|
-
import type {ZiGateCommandCode, ZiGateMessageCode, ZiGateObjectPayload} from "./constants";
|
|
7
|
-
import ZiGateFrame from "./frame";
|
|
8
|
-
import {ZiGateMessage, type ZiGateMessageParameter} from "./messageType";
|
|
9
|
-
import ParameterType from "./parameterType";
|
|
10
|
-
|
|
11
|
-
type ZiGateCode = ZiGateCommandCode | ZiGateMessageCode;
|
|
12
|
-
type ZiGateParameter = ZiGateCommandParameter | ZiGateMessageParameter;
|
|
13
|
-
|
|
14
|
-
const NS = "zh:zigate:object";
|
|
15
|
-
|
|
16
|
-
const BufferAndListTypes: ParameterType[] = [
|
|
17
|
-
ParameterType.BUFFER,
|
|
18
|
-
ParameterType.BUFFER8,
|
|
19
|
-
ParameterType.BUFFER16,
|
|
20
|
-
ParameterType.BUFFER18,
|
|
21
|
-
ParameterType.BUFFER32,
|
|
22
|
-
ParameterType.BUFFER42,
|
|
23
|
-
ParameterType.BUFFER100,
|
|
24
|
-
ParameterType.LIST_UINT16,
|
|
25
|
-
ParameterType.LIST_UINT8,
|
|
26
|
-
];
|
|
27
|
-
|
|
28
|
-
class ZiGateObject {
|
|
29
|
-
private readonly _code: ZiGateCode;
|
|
30
|
-
private readonly _payload: ZiGateObjectPayload;
|
|
31
|
-
private readonly _parameters: ZiGateParameter[];
|
|
32
|
-
private readonly _frame?: ZiGateFrame;
|
|
33
|
-
|
|
34
|
-
private constructor(code: ZiGateCode, payload: ZiGateObjectPayload, parameters: ZiGateParameter[], frame?: ZiGateFrame) {
|
|
35
|
-
this._code = code;
|
|
36
|
-
this._payload = payload;
|
|
37
|
-
this._parameters = parameters;
|
|
38
|
-
this._frame = frame;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
get code(): ZiGateCode {
|
|
42
|
-
return this._code;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
get frame(): ZiGateFrame | undefined {
|
|
46
|
-
return this._frame;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
get payload(): ZiGateObjectPayload {
|
|
50
|
-
return this._payload;
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
get command(): ZiGateCommandType {
|
|
54
|
-
return ZiGateCommand[this._code];
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
public static createRequest(commandCode: ZiGateCommandCode, payload: ZiGateObjectPayload): ZiGateObject {
|
|
58
|
-
const cmd = ZiGateCommand[commandCode];
|
|
59
|
-
|
|
60
|
-
if (!cmd) {
|
|
61
|
-
throw new Error(`Command '${commandCode}' not found`);
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
return new ZiGateObject(commandCode, payload, cmd.request);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
public static fromZiGateFrame(frame: ZiGateFrame): ZiGateObject {
|
|
68
|
-
const code = frame.readMsgCode();
|
|
69
|
-
return ZiGateObject.fromBuffer(code, frame.msgPayloadBytes, frame);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
public static fromBuffer(code: number, buffer: Buffer, frame: ZiGateFrame): ZiGateObject {
|
|
73
|
-
const msg = ZiGateMessage[code];
|
|
74
|
-
|
|
75
|
-
if (!msg) {
|
|
76
|
-
throw new Error(`Message '${code.toString(16)}' not found`);
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
const parameters = msg.response;
|
|
80
|
-
if (parameters === undefined) {
|
|
81
|
-
throw new Error(`Message '${code.toString(16)}' cannot be a response`);
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
const payload = ZiGateObject.readParameters(buffer, parameters);
|
|
85
|
-
|
|
86
|
-
return new ZiGateObject(code, payload, parameters, frame);
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
private static readParameters(buffer: Buffer, parameters: ZiGateParameter[]): ZiGateObjectPayload {
|
|
90
|
-
const buffalo = new BuffaloZiGate(buffer);
|
|
91
|
-
const result: ZiGateObjectPayload = {};
|
|
92
|
-
|
|
93
|
-
for (const parameter of parameters) {
|
|
94
|
-
const options: BuffaloZiGateOptions = {};
|
|
95
|
-
|
|
96
|
-
if (BufferAndListTypes.includes(parameter.parameterType)) {
|
|
97
|
-
// When reading a buffer, assume that the previous parsed parameter contains
|
|
98
|
-
// the length of the buffer
|
|
99
|
-
const lengthParameter = parameters[parameters.indexOf(parameter) - 1];
|
|
100
|
-
const length = result[lengthParameter.name];
|
|
101
|
-
|
|
102
|
-
if (typeof length === "number") {
|
|
103
|
-
options.length = length;
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
try {
|
|
108
|
-
result[parameter.name] = buffalo.read(parameter.parameterType, options);
|
|
109
|
-
} catch (error) {
|
|
110
|
-
// biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
|
|
111
|
-
logger.error((error as Error).stack!, NS);
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
if (buffalo.isMore()) {
|
|
116
|
-
const bufferString = buffalo.getBuffer().toString("hex");
|
|
117
|
-
logger.debug(
|
|
118
|
-
`Last bytes of data were not parsed \x1b[32m${bufferString.slice(0, buffalo.getPosition() * 2).replace(/../g, "$& ")}` +
|
|
119
|
-
`\x1b[31m${bufferString.slice(buffalo.getPosition() * 2).replace(/../g, "$& ")}\x1b[0m `,
|
|
120
|
-
NS,
|
|
121
|
-
);
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
return result;
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
public toZiGateFrame(): ZiGateFrame {
|
|
128
|
-
const buffer = this.createPayloadBuffer();
|
|
129
|
-
const frame = new ZiGateFrame();
|
|
130
|
-
frame.writeMsgCode(this._code as number);
|
|
131
|
-
frame.writeMsgPayload(buffer);
|
|
132
|
-
return frame;
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
private createPayloadBuffer(): Buffer {
|
|
136
|
-
const buffalo = new BuffaloZiGate(Buffer.alloc(256)); // hardcode @todo
|
|
137
|
-
|
|
138
|
-
for (const parameter of this._parameters) {
|
|
139
|
-
const value = this._payload[parameter.name];
|
|
140
|
-
buffalo.write(parameter.parameterType, value, {});
|
|
141
|
-
}
|
|
142
|
-
return buffalo.getWritten();
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
export default ZiGateObject;
|
|
@@ -1,423 +0,0 @@
|
|
|
1
|
-
/* v8 ignore start */
|
|
2
|
-
|
|
3
|
-
import assert from "node:assert";
|
|
4
|
-
import {EventEmitter} from "node:events";
|
|
5
|
-
import net from "node:net";
|
|
6
|
-
|
|
7
|
-
import {DelimiterParser} from "@serialport/parser-delimiter";
|
|
8
|
-
|
|
9
|
-
import {Queue} from "../../../utils";
|
|
10
|
-
import {logger} from "../../../utils/logger";
|
|
11
|
-
import {Waitress} from "../../../utils/waitress";
|
|
12
|
-
import * as ZSpec from "../../../zspec";
|
|
13
|
-
import * as Zdo from "../../../zspec/zdo";
|
|
14
|
-
import type {EndDeviceAnnounce, GenericZdoResponse, ResponseMap as ZdoResponseMap} from "../../../zspec/zdo/definition/tstypes";
|
|
15
|
-
import {SerialPort} from "../../serialPort";
|
|
16
|
-
import SocketPortUtils from "../../socketPortUtils";
|
|
17
|
-
import type {SerialPortOptions} from "../../tstype";
|
|
18
|
-
import {equal, type ZiGateResponseMatcher, type ZiGateResponseMatcherRule} from "./commandType";
|
|
19
|
-
import {Status, ZDO_REQ_CLUSTER_ID_TO_ZIGATE_COMMAND_ID, ZiGateCommandCode, ZiGateMessageCode, type ZiGateObjectPayload} from "./constants";
|
|
20
|
-
import ZiGateFrame from "./frame";
|
|
21
|
-
import ZiGateObject from "./ziGateObject";
|
|
22
|
-
|
|
23
|
-
const NS = "zh:zigate:driver";
|
|
24
|
-
|
|
25
|
-
const timeouts = {
|
|
26
|
-
reset: 30000,
|
|
27
|
-
default: 10000,
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
type WaitressMatcher = {
|
|
31
|
-
ziGateObject?: ZiGateObject;
|
|
32
|
-
rules: ZiGateResponseMatcher;
|
|
33
|
-
extraParameters?: object;
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
type ZdoWaitressPayload = {
|
|
37
|
-
ziGatePayload: {
|
|
38
|
-
status: number;
|
|
39
|
-
profileID: number;
|
|
40
|
-
clusterID: number;
|
|
41
|
-
sourceEndpoint: number;
|
|
42
|
-
destinationEndpoint: number;
|
|
43
|
-
sourceAddressMode: number;
|
|
44
|
-
sourceAddress: number | string;
|
|
45
|
-
destinationAddressMode: number;
|
|
46
|
-
destinationAddress: number | string;
|
|
47
|
-
payload: Buffer;
|
|
48
|
-
};
|
|
49
|
-
zdo: GenericZdoResponse;
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
type ZdoWaitressMatcher = {
|
|
53
|
-
clusterId: number;
|
|
54
|
-
target?: number | string;
|
|
55
|
-
};
|
|
56
|
-
|
|
57
|
-
function zeroPad(number: number, size?: number): string {
|
|
58
|
-
return number.toString(16).padStart(size || 4, "0");
|
|
59
|
-
}
|
|
60
|
-
// biome-ignore lint/suspicious/noExplicitAny: API
|
|
61
|
-
function resolve(path: string | [], obj: {[k: string]: any}, separator = "."): any {
|
|
62
|
-
const properties = Array.isArray(path) ? path : path.split(separator);
|
|
63
|
-
return properties.reduce((prev, curr) => prev?.[curr], obj);
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
interface ZiGateEventMap {
|
|
67
|
-
close: [];
|
|
68
|
-
zdoResponse: [Zdo.ClusterId, GenericZdoResponse];
|
|
69
|
-
received: [ZiGateObject];
|
|
70
|
-
LeaveIndication: [ZiGateObject];
|
|
71
|
-
DeviceAnnounce: [EndDeviceAnnounce];
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
export default class ZiGate extends EventEmitter<ZiGateEventMap> {
|
|
75
|
-
private path: string;
|
|
76
|
-
private baudRate: number;
|
|
77
|
-
private initialized: boolean;
|
|
78
|
-
|
|
79
|
-
private parser?: EventEmitter;
|
|
80
|
-
private serialPort?: SerialPort;
|
|
81
|
-
private socketPort?: net.Socket;
|
|
82
|
-
private queue: Queue;
|
|
83
|
-
|
|
84
|
-
public portWrite?: SerialPort | net.Socket;
|
|
85
|
-
private waitress: Waitress<ZiGateObject, WaitressMatcher>;
|
|
86
|
-
private zdoWaitress: Waitress<ZdoWaitressPayload, ZdoWaitressMatcher>;
|
|
87
|
-
|
|
88
|
-
public constructor(path: string, serialPortOptions: SerialPortOptions) {
|
|
89
|
-
super();
|
|
90
|
-
this.path = path;
|
|
91
|
-
this.baudRate = typeof serialPortOptions.baudRate === "number" ? serialPortOptions.baudRate : 115200;
|
|
92
|
-
// XXX: not used?
|
|
93
|
-
// this.rtscts = typeof serialPortOptions.rtscts === 'boolean' ? serialPortOptions.rtscts : false;
|
|
94
|
-
this.initialized = false;
|
|
95
|
-
this.queue = new Queue(1);
|
|
96
|
-
|
|
97
|
-
this.waitress = new Waitress<ZiGateObject, WaitressMatcher>(this.waitressValidator, this.waitressTimeoutFormatter);
|
|
98
|
-
this.zdoWaitress = new Waitress<ZdoWaitressPayload, ZdoWaitressMatcher>(this.zdoWaitressValidator, this.waitressTimeoutFormatter);
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
public async sendCommand(
|
|
102
|
-
code: ZiGateCommandCode,
|
|
103
|
-
payload?: ZiGateObjectPayload,
|
|
104
|
-
timeout?: number,
|
|
105
|
-
extraParameters?: object,
|
|
106
|
-
disableResponse = false,
|
|
107
|
-
): Promise<ZiGateObject> {
|
|
108
|
-
const waiters: Promise<ZiGateObject>[] = [];
|
|
109
|
-
const waitersId: number[] = [];
|
|
110
|
-
return await this.queue.execute(async () => {
|
|
111
|
-
try {
|
|
112
|
-
logger.debug(
|
|
113
|
-
() => `Send command \x1b[32m>>>> ${ZiGateCommandCode[code]} 0x${zeroPad(code)} <<<<\x1b[0m \nPayload: ${JSON.stringify(payload)}`,
|
|
114
|
-
NS,
|
|
115
|
-
);
|
|
116
|
-
const ziGateObject = ZiGateObject.createRequest(code, payload);
|
|
117
|
-
const frame = ziGateObject.toZiGateFrame();
|
|
118
|
-
logger.debug(() => `${JSON.stringify(frame)}`, NS);
|
|
119
|
-
|
|
120
|
-
const sendBuffer = frame.toBuffer();
|
|
121
|
-
logger.debug(`<-- send command ${sendBuffer.toString("hex")}`, NS);
|
|
122
|
-
logger.debug(`DisableResponse: ${disableResponse}`, NS);
|
|
123
|
-
|
|
124
|
-
if (!disableResponse && Array.isArray(ziGateObject.command.response)) {
|
|
125
|
-
for (const rules of ziGateObject.command.response) {
|
|
126
|
-
const waiter = this.waitress.waitFor({ziGateObject, rules, extraParameters}, timeout || timeouts.default);
|
|
127
|
-
waitersId.push(waiter.ID);
|
|
128
|
-
waiters.push(waiter.start().promise);
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
let resultPromise: Promise<ZiGateObject> | undefined;
|
|
133
|
-
if (ziGateObject.command.waitStatus !== false) {
|
|
134
|
-
const ruleStatus: ZiGateResponseMatcher = [
|
|
135
|
-
{receivedProperty: "code", matcher: equal, value: ZiGateMessageCode.Status},
|
|
136
|
-
{receivedProperty: "payload.packetType", matcher: equal, value: ziGateObject.code},
|
|
137
|
-
];
|
|
138
|
-
|
|
139
|
-
const statusWaiter = this.waitress.waitFor({ziGateObject, rules: ruleStatus}, timeout || timeouts.default).start();
|
|
140
|
-
resultPromise = statusWaiter.promise;
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
// biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
|
|
144
|
-
this.portWrite!.write(sendBuffer);
|
|
145
|
-
|
|
146
|
-
if (ziGateObject.command.waitStatus !== false && resultPromise) {
|
|
147
|
-
const statusResponse: ZiGateObject = await resultPromise;
|
|
148
|
-
if (statusResponse.payload.status !== Status.E_SL_MSG_STATUS_SUCCESS) {
|
|
149
|
-
waitersId.map((id) => this.waitress.remove(id));
|
|
150
|
-
return await Promise.reject(new Error(`${statusResponse}`));
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
if (waiters.length === 0) {
|
|
154
|
-
return await Promise.resolve(statusResponse);
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
return await Promise.race(waiters);
|
|
158
|
-
} catch (e) {
|
|
159
|
-
logger.error(`sendCommand error ${e}`, NS);
|
|
160
|
-
return await Promise.reject(new Error(`sendCommand error: ${e}`));
|
|
161
|
-
}
|
|
162
|
-
});
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
public async requestZdo(clusterId: Zdo.ClusterId, payload: Buffer): Promise<boolean> {
|
|
166
|
-
return await this.queue.execute(async () => {
|
|
167
|
-
const commandCode = ZDO_REQ_CLUSTER_ID_TO_ZIGATE_COMMAND_ID[clusterId];
|
|
168
|
-
assert(commandCode !== undefined, `ZDO cluster ID '${clusterId}' not supported.`);
|
|
169
|
-
const ruleStatus: ZiGateResponseMatcher = [
|
|
170
|
-
{receivedProperty: "code", matcher: equal, value: ZiGateMessageCode.Status},
|
|
171
|
-
{receivedProperty: "payload.packetType", matcher: equal, value: commandCode},
|
|
172
|
-
];
|
|
173
|
-
|
|
174
|
-
logger.debug(() => `ZDO ${Zdo.ClusterId[clusterId]}(cmd code: ${commandCode}) ${payload.toString("hex")}`, NS);
|
|
175
|
-
|
|
176
|
-
const frame = new ZiGateFrame();
|
|
177
|
-
frame.writeMsgCode(commandCode);
|
|
178
|
-
frame.writeMsgPayload(payload);
|
|
179
|
-
|
|
180
|
-
logger.debug(() => `ZDO ${JSON.stringify(frame)}`, NS);
|
|
181
|
-
|
|
182
|
-
const sendBuffer = frame.toBuffer();
|
|
183
|
-
|
|
184
|
-
logger.debug(`<-- ZDO send command ${sendBuffer.toString("hex")}`, NS);
|
|
185
|
-
|
|
186
|
-
const statusWaiter = this.waitress.waitFor({rules: ruleStatus}, timeouts.default);
|
|
187
|
-
|
|
188
|
-
// biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
|
|
189
|
-
this.portWrite!.write(sendBuffer);
|
|
190
|
-
|
|
191
|
-
const statusResponse: ZiGateObject = await statusWaiter.start().promise;
|
|
192
|
-
|
|
193
|
-
return statusResponse.payload.status === Status.E_SL_MSG_STATUS_SUCCESS;
|
|
194
|
-
});
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
public open(): Promise<void> {
|
|
198
|
-
return SocketPortUtils.isTcpPath(this.path) ? this.openSocketPort() : this.openSerialPort();
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
public async close(): Promise<void> {
|
|
202
|
-
logger.info("closing", NS);
|
|
203
|
-
this.queue.clear();
|
|
204
|
-
|
|
205
|
-
if (this.initialized) {
|
|
206
|
-
this.portWrite = undefined;
|
|
207
|
-
this.initialized = false;
|
|
208
|
-
|
|
209
|
-
if (this.serialPort) {
|
|
210
|
-
try {
|
|
211
|
-
await this.serialPort.asyncFlushAndClose();
|
|
212
|
-
} catch (error) {
|
|
213
|
-
this.emit("close");
|
|
214
|
-
|
|
215
|
-
throw error;
|
|
216
|
-
}
|
|
217
|
-
} else {
|
|
218
|
-
this.socketPort?.destroy();
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
this.emit("close");
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
private async openSerialPort(): Promise<void> {
|
|
226
|
-
this.serialPort = new SerialPort({
|
|
227
|
-
path: this.path,
|
|
228
|
-
baudRate: this.baudRate,
|
|
229
|
-
dataBits: 8,
|
|
230
|
-
parity: "none" /* one of ['none', 'even', 'mark', 'odd', 'space'] */,
|
|
231
|
-
stopBits: 1 /* one of [1,2] */,
|
|
232
|
-
autoOpen: false,
|
|
233
|
-
});
|
|
234
|
-
this.parser = this.serialPort.pipe(new DelimiterParser({delimiter: [ZiGateFrame.STOP_BYTE], includeDelimiter: true}));
|
|
235
|
-
this.parser.on("data", this.onSerialData.bind(this));
|
|
236
|
-
|
|
237
|
-
this.portWrite = this.serialPort;
|
|
238
|
-
|
|
239
|
-
try {
|
|
240
|
-
await this.serialPort.asyncOpen();
|
|
241
|
-
logger.debug("Serialport opened", NS);
|
|
242
|
-
|
|
243
|
-
this.serialPort.once("close", this.onPortClose.bind(this));
|
|
244
|
-
this.serialPort.once("error", this.onPortError.bind(this));
|
|
245
|
-
|
|
246
|
-
this.initialized = true;
|
|
247
|
-
} catch (error) {
|
|
248
|
-
this.initialized = false;
|
|
249
|
-
|
|
250
|
-
if (this.serialPort.isOpen) {
|
|
251
|
-
this.serialPort.close();
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
throw error;
|
|
255
|
-
}
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
private async openSocketPort(): Promise<void> {
|
|
259
|
-
const info = SocketPortUtils.parseTcpPath(this.path);
|
|
260
|
-
logger.debug(`Opening TCP socket with ${info.host}:${info.port}`, NS);
|
|
261
|
-
|
|
262
|
-
this.socketPort = new net.Socket();
|
|
263
|
-
this.socketPort.setNoDelay(true);
|
|
264
|
-
this.socketPort.setKeepAlive(true, 15000);
|
|
265
|
-
|
|
266
|
-
this.parser = this.socketPort.pipe(new DelimiterParser({delimiter: [ZiGateFrame.STOP_BYTE], includeDelimiter: true}));
|
|
267
|
-
this.parser.on("data", this.onSerialData.bind(this));
|
|
268
|
-
|
|
269
|
-
this.portWrite = this.socketPort;
|
|
270
|
-
return await new Promise((resolve, reject): void => {
|
|
271
|
-
// biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
|
|
272
|
-
this.socketPort!.on("connect", () => {
|
|
273
|
-
logger.debug("Socket connected", NS);
|
|
274
|
-
});
|
|
275
|
-
|
|
276
|
-
// biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
|
|
277
|
-
this.socketPort!.on("ready", () => {
|
|
278
|
-
logger.debug("Socket ready", NS);
|
|
279
|
-
this.initialized = true;
|
|
280
|
-
resolve();
|
|
281
|
-
});
|
|
282
|
-
|
|
283
|
-
// biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
|
|
284
|
-
this.socketPort!.once("close", this.onPortClose.bind(this));
|
|
285
|
-
|
|
286
|
-
// biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
|
|
287
|
-
this.socketPort!.on("error", (error) => {
|
|
288
|
-
logger.error(`Socket error ${error}`, NS);
|
|
289
|
-
reject(new Error("Error while opening socket"));
|
|
290
|
-
this.initialized = false;
|
|
291
|
-
});
|
|
292
|
-
|
|
293
|
-
// biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
|
|
294
|
-
this.socketPort!.connect(info.port, info.host);
|
|
295
|
-
});
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
private onPortError(error: Error): void {
|
|
299
|
-
logger.error(`Port error: ${error}`, NS);
|
|
300
|
-
}
|
|
301
|
-
|
|
302
|
-
private onPortClose(): void {
|
|
303
|
-
logger.debug("Port closed", NS);
|
|
304
|
-
this.initialized = false;
|
|
305
|
-
this.emit("close");
|
|
306
|
-
}
|
|
307
|
-
|
|
308
|
-
private onSerialData(buffer: Buffer): void {
|
|
309
|
-
try {
|
|
310
|
-
// logger.debug(() => `--- parseNext ${JSON.stringify(buffer)}`, NS);
|
|
311
|
-
|
|
312
|
-
const frame = new ZiGateFrame(buffer);
|
|
313
|
-
if (!(frame instanceof ZiGateFrame)) return; // @Todo fix
|
|
314
|
-
|
|
315
|
-
const code = frame.readMsgCode();
|
|
316
|
-
const msgName = `${ZiGateMessageCode[code] ? ZiGateMessageCode[code] : ""} 0x${zeroPad(code)}`;
|
|
317
|
-
|
|
318
|
-
logger.debug(`--> parsed frame \x1b[1;34m>>>> ${msgName} <<<<\x1b[0m `, NS);
|
|
319
|
-
|
|
320
|
-
try {
|
|
321
|
-
const ziGateObject = ZiGateObject.fromZiGateFrame(frame);
|
|
322
|
-
logger.debug(() => `${JSON.stringify(ziGateObject.payload)}`, NS);
|
|
323
|
-
|
|
324
|
-
if (code === ZiGateMessageCode.DataIndication && ziGateObject.payload.profileID === Zdo.ZDO_PROFILE_ID) {
|
|
325
|
-
const ziGatePayload: ZdoWaitressPayload["ziGatePayload"] = ziGateObject.payload;
|
|
326
|
-
// requests don't have tsn, but responses do
|
|
327
|
-
// https://zigate.fr/documentation/commandes-zigate/
|
|
328
|
-
const zdo = Zdo.Buffalo.readResponse(true, ziGatePayload.clusterID, ziGatePayload.payload);
|
|
329
|
-
|
|
330
|
-
this.zdoWaitress.resolve({ziGatePayload, zdo});
|
|
331
|
-
this.emit("zdoResponse", ziGatePayload.clusterID, zdo);
|
|
332
|
-
} else if (code === ZiGateMessageCode.LeaveIndication && ziGateObject.payload.rejoin === 0) {
|
|
333
|
-
// mock a ZDO response (if waiter present) as zigate does not follow spec on this (missing ZDO LEAVE_RESPONSE)
|
|
334
|
-
const ziGatePayload: ZdoWaitressPayload["ziGatePayload"] = {
|
|
335
|
-
status: 0,
|
|
336
|
-
profileID: Zdo.ZDO_PROFILE_ID,
|
|
337
|
-
clusterID: Zdo.ClusterId.LEAVE_RESPONSE, // only piece actually required for waitress validation
|
|
338
|
-
sourceEndpoint: Zdo.ZDO_ENDPOINT,
|
|
339
|
-
destinationEndpoint: Zdo.ZDO_ENDPOINT,
|
|
340
|
-
sourceAddressMode: 0x03,
|
|
341
|
-
sourceAddress: ziGateObject.payload.extendedAddress,
|
|
342
|
-
destinationAddressMode: 0x03,
|
|
343
|
-
destinationAddress: ZSpec.BLANK_EUI64,
|
|
344
|
-
// @ts-expect-error not used
|
|
345
|
-
payload: undefined,
|
|
346
|
-
};
|
|
347
|
-
|
|
348
|
-
// Workaround: `zdo` is not valid for LEAVE_RESPONSE, but required to pass altered waitress validation (in sendZdo)
|
|
349
|
-
if (this.zdoWaitress.resolve({ziGatePayload, zdo: [Zdo.Status.SUCCESS, {eui64: ziGateObject.payload.extendedAddress}]})) {
|
|
350
|
-
this.emit("zdoResponse", Zdo.ClusterId.LEAVE_RESPONSE, [
|
|
351
|
-
Zdo.Status.SUCCESS,
|
|
352
|
-
undefined,
|
|
353
|
-
] as ZdoResponseMap[Zdo.ClusterId.LEAVE_RESPONSE]);
|
|
354
|
-
}
|
|
355
|
-
|
|
356
|
-
this.emit("LeaveIndication", ziGateObject);
|
|
357
|
-
} else {
|
|
358
|
-
this.waitress.resolve(ziGateObject);
|
|
359
|
-
|
|
360
|
-
if (code === ZiGateMessageCode.DataIndication) {
|
|
361
|
-
if (ziGateObject.payload.profileID === ZSpec.HA_PROFILE_ID) {
|
|
362
|
-
this.emit("received", ziGateObject);
|
|
363
|
-
} else {
|
|
364
|
-
logger.debug(`not implemented profile: ${ziGateObject.payload.profileID}`, NS);
|
|
365
|
-
}
|
|
366
|
-
} else if (code === ZiGateMessageCode.DeviceAnnounce) {
|
|
367
|
-
this.emit("DeviceAnnounce", {
|
|
368
|
-
nwkAddress: ziGateObject.payload.shortAddress,
|
|
369
|
-
eui64: ziGateObject.payload.ieee,
|
|
370
|
-
capabilities: ziGateObject.payload.MACcapability,
|
|
371
|
-
});
|
|
372
|
-
}
|
|
373
|
-
}
|
|
374
|
-
} catch (error) {
|
|
375
|
-
logger.error(`Parsing error: ${error}`, NS);
|
|
376
|
-
}
|
|
377
|
-
} catch (error) {
|
|
378
|
-
logger.error(`Error while parsing Frame '${error}'`, NS);
|
|
379
|
-
}
|
|
380
|
-
}
|
|
381
|
-
|
|
382
|
-
private waitressTimeoutFormatter(matcher: WaitressMatcher | ZdoWaitressMatcher, timeout: number): string {
|
|
383
|
-
return `${JSON.stringify(matcher)} after ${timeout}ms`;
|
|
384
|
-
}
|
|
385
|
-
|
|
386
|
-
private waitressValidator(ziGateObject: ZiGateObject, matcher: WaitressMatcher): boolean {
|
|
387
|
-
const validator = (rule: ZiGateResponseMatcherRule): boolean => {
|
|
388
|
-
try {
|
|
389
|
-
let expectedValue: string | number;
|
|
390
|
-
if (rule.value == null && rule.expectedProperty != null) {
|
|
391
|
-
assert(matcher.ziGateObject, "Matcher ziGateObject expected valid.");
|
|
392
|
-
expectedValue = resolve(rule.expectedProperty, matcher.ziGateObject);
|
|
393
|
-
} else if (rule.value == null && rule.expectedExtraParameter != null) {
|
|
394
|
-
// biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
|
|
395
|
-
expectedValue = resolve(rule.expectedExtraParameter, matcher.extraParameters!); // XXX: assumed valid?
|
|
396
|
-
} else {
|
|
397
|
-
// biome-ignore lint/style/noNonNullAssertion: ignored using `--suppress`
|
|
398
|
-
expectedValue = rule.value!; // XXX: assumed valid?
|
|
399
|
-
}
|
|
400
|
-
const receivedValue = resolve(rule.receivedProperty, ziGateObject);
|
|
401
|
-
return rule.matcher(expectedValue, receivedValue);
|
|
402
|
-
} catch {
|
|
403
|
-
return false;
|
|
404
|
-
}
|
|
405
|
-
};
|
|
406
|
-
return matcher.rules.every(validator);
|
|
407
|
-
}
|
|
408
|
-
|
|
409
|
-
public zdoWaitFor(matcher: ZdoWaitressMatcher): ReturnType<typeof this.zdoWaitress.waitFor> {
|
|
410
|
-
return this.zdoWaitress.waitFor(matcher, timeouts.default);
|
|
411
|
-
}
|
|
412
|
-
|
|
413
|
-
private zdoWaitressValidator(payload: ZdoWaitressPayload, matcher: ZdoWaitressMatcher): boolean {
|
|
414
|
-
return (
|
|
415
|
-
(matcher.target === undefined ||
|
|
416
|
-
(typeof matcher.target === "number"
|
|
417
|
-
? matcher.target === payload.ziGatePayload.sourceAddress
|
|
418
|
-
: // @ts-expect-error checked with ?
|
|
419
|
-
matcher.target === payload.zdo?.[1]?.eui64)) &&
|
|
420
|
-
payload.ziGatePayload.clusterID === matcher.clusterId
|
|
421
|
-
);
|
|
422
|
-
}
|
|
423
|
-
}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @param value 64-bit bigint
|
|
3
|
-
* @returns 16-length hex string in big-endian
|
|
4
|
-
*/
|
|
5
|
-
export function bigUInt64ToHexBE(value: bigint): string {
|
|
6
|
-
return value.toString(16).padStart(16, "0");
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* @param value 64-bit bigint
|
|
11
|
-
* @returns 8-bytelength buffer in little-endian
|
|
12
|
-
*/
|
|
13
|
-
export function bigUInt64ToBufferLE(value: bigint): Buffer {
|
|
14
|
-
const b = Buffer.alloc(8);
|
|
15
|
-
b.writeBigUInt64LE(value, 0);
|
|
16
|
-
return b;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* @param value 64-bit bigint
|
|
21
|
-
* @returns 8-bytelength buffer in big-endian
|
|
22
|
-
*/
|
|
23
|
-
export function bigUInt64ToBufferBE(value: bigint): Buffer {
|
|
24
|
-
const b = Buffer.alloc(8);
|
|
25
|
-
b.writeBigUInt64BE(value, 0);
|
|
26
|
-
return b;
|
|
27
|
-
}
|