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,9 +0,0 @@
|
|
|
1
|
-
export const END = 0xc0;
|
|
2
|
-
export const ESCAPE = 0xdb;
|
|
3
|
-
export const ESCEND = 0xdc;
|
|
4
|
-
export const ESCESC = 0xdd;
|
|
5
|
-
|
|
6
|
-
export const SIGNATURE = 0xdead;
|
|
7
|
-
export const ZBOSS_NCP_API_HL = 0x06;
|
|
8
|
-
export const ZBOSS_FLAG_FIRST_FRAGMENT = 0x40;
|
|
9
|
-
export const ZBOSS_FLAG_LAST_FRAGMENT = 0x80;
|
|
@@ -1,422 +0,0 @@
|
|
|
1
|
-
/* v8 ignore start */
|
|
2
|
-
|
|
3
|
-
import assert from "node:assert";
|
|
4
|
-
import EventEmitter from "node:events";
|
|
5
|
-
|
|
6
|
-
import equals from "fast-deep-equal/es6";
|
|
7
|
-
import type {KeyValue} from "../../controller/tstype";
|
|
8
|
-
import {Queue, Waitress} from "../../utils";
|
|
9
|
-
import {logger} from "../../utils/logger";
|
|
10
|
-
import type * as ZSpec from "../../zspec";
|
|
11
|
-
import * as Zdo from "../../zspec/zdo";
|
|
12
|
-
import type {TsType} from "..";
|
|
13
|
-
import {ZDO_REQ_CLUSTER_ID_TO_ZBOSS_COMMAND_ID} from "./commands";
|
|
14
|
-
import {CommandId, DeviceType, PolicyType, ResetOptions, StatusCodeGeneric} from "./enums";
|
|
15
|
-
import {FrameType, makeFrame, type ZBOSSFrame} from "./frame";
|
|
16
|
-
import {ZBOSSUart} from "./uart";
|
|
17
|
-
|
|
18
|
-
const NS = "zh:zboss:driv";
|
|
19
|
-
|
|
20
|
-
const MAX_INIT_ATTEMPTS = 5;
|
|
21
|
-
|
|
22
|
-
type ZBOSSWaitressMatcher = {
|
|
23
|
-
tsn?: number;
|
|
24
|
-
commandId: number;
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
type ZBOSSNetworkInfo = {
|
|
28
|
-
joined: boolean;
|
|
29
|
-
nodeType: DeviceType;
|
|
30
|
-
ieeeAddr: string;
|
|
31
|
-
network: {
|
|
32
|
-
panID: number;
|
|
33
|
-
extendedPanID: number[];
|
|
34
|
-
channel: number;
|
|
35
|
-
};
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
export class ZBOSSDriver extends EventEmitter {
|
|
39
|
-
public readonly port: ZBOSSUart;
|
|
40
|
-
private waitress: Waitress<ZBOSSFrame, ZBOSSWaitressMatcher>;
|
|
41
|
-
private queue: Queue;
|
|
42
|
-
private tsn = 1; // command sequence
|
|
43
|
-
private nwkOpt: TsType.NetworkOptions;
|
|
44
|
-
public netInfo!: ZBOSSNetworkInfo; // expected valid upon startup of driver
|
|
45
|
-
|
|
46
|
-
constructor(options: TsType.SerialPortOptions, nwkOpt: TsType.NetworkOptions) {
|
|
47
|
-
super();
|
|
48
|
-
this.nwkOpt = nwkOpt;
|
|
49
|
-
this.queue = new Queue();
|
|
50
|
-
this.waitress = new Waitress<ZBOSSFrame, ZBOSSWaitressMatcher>(this.waitressValidator, this.waitressTimeoutFormatter);
|
|
51
|
-
|
|
52
|
-
this.port = new ZBOSSUart(options);
|
|
53
|
-
this.port.on("frame", this.onFrame.bind(this));
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
public async connect(): Promise<boolean> {
|
|
57
|
-
logger.info("Driver connecting", NS);
|
|
58
|
-
|
|
59
|
-
let status = false;
|
|
60
|
-
|
|
61
|
-
for (let i = 0; i < MAX_INIT_ATTEMPTS; i++) {
|
|
62
|
-
status = await this.port.resetNcp();
|
|
63
|
-
|
|
64
|
-
// fail early if we couldn't even get the port set up
|
|
65
|
-
if (!status) {
|
|
66
|
-
return status;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
status = await this.port.start();
|
|
70
|
-
|
|
71
|
-
if (status) {
|
|
72
|
-
logger.info("Driver connected", NS);
|
|
73
|
-
return status;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
return status;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
private async reset(options = ResetOptions.NoOptions): Promise<void> {
|
|
81
|
-
logger.info("Driver reset", NS);
|
|
82
|
-
this.port.inReset = true;
|
|
83
|
-
await this.execCommand(CommandId.NCP_RESET, {options}, 10000);
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
public async startup(transmitPower?: number): Promise<TsType.StartResult> {
|
|
87
|
-
logger.info("Driver startup", NS);
|
|
88
|
-
let result: TsType.StartResult = "resumed";
|
|
89
|
-
|
|
90
|
-
if (await this.needsToBeInitialised(this.nwkOpt)) {
|
|
91
|
-
// need to check the backup
|
|
92
|
-
// const restore = await this.needsToBeRestore(this.nwkOpt);
|
|
93
|
-
const restore = false;
|
|
94
|
-
|
|
95
|
-
if (this.netInfo.joined) {
|
|
96
|
-
logger.info("Leaving current network and forming new network", NS);
|
|
97
|
-
await this.reset(ResetOptions.FactoryReset);
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
if (restore) {
|
|
101
|
-
// // restore
|
|
102
|
-
// logger.info('Restore network from backup', NS);
|
|
103
|
-
// await this.formNetwork(true);
|
|
104
|
-
// result = 'restored';
|
|
105
|
-
} else {
|
|
106
|
-
// reset
|
|
107
|
-
logger.info("Form network", NS);
|
|
108
|
-
await this.formNetwork(); // false
|
|
109
|
-
result = "reset";
|
|
110
|
-
}
|
|
111
|
-
} else {
|
|
112
|
-
await this.execCommand(CommandId.NWK_START_WITHOUT_FORMATION, {});
|
|
113
|
-
}
|
|
114
|
-
await this.execCommand(CommandId.SET_TC_POLICY, {type: PolicyType.LINK_KEY_REQUIRED, value: 0});
|
|
115
|
-
await this.execCommand(CommandId.SET_TC_POLICY, {type: PolicyType.IC_REQUIRED, value: 0});
|
|
116
|
-
await this.execCommand(CommandId.SET_TC_POLICY, {type: PolicyType.TC_REJOIN_ENABLED, value: 1});
|
|
117
|
-
await this.execCommand(CommandId.SET_TC_POLICY, {type: PolicyType.IGNORE_TC_REJOIN, value: 0});
|
|
118
|
-
await this.execCommand(CommandId.SET_TC_POLICY, {type: PolicyType.APS_INSECURE_JOIN, value: 0});
|
|
119
|
-
await this.execCommand(CommandId.SET_TC_POLICY, {type: PolicyType.DISABLE_NWK_MGMT_CHANNEL_UPDATE, value: 0});
|
|
120
|
-
|
|
121
|
-
await this.addEndpoint(
|
|
122
|
-
1,
|
|
123
|
-
260,
|
|
124
|
-
0xbeef,
|
|
125
|
-
[0x0000, 0x0003, 0x0006, 0x000a, 0x0019, 0x001a, 0x0300],
|
|
126
|
-
[
|
|
127
|
-
0x0000, 0x0003, 0x0004, 0x0005, 0x0006, 0x0008, 0x0020, 0x0300, 0x0400, 0x0402, 0x0405, 0x0406, 0x0500, 0x0b01, 0x0b03, 0x0b04,
|
|
128
|
-
0x0702, 0x1000, 0xfc01, 0xfc02,
|
|
129
|
-
],
|
|
130
|
-
);
|
|
131
|
-
await this.addEndpoint(242, 0xa1e0, 0x61, [], [0x0021]);
|
|
132
|
-
|
|
133
|
-
await this.execCommand(CommandId.SET_RX_ON_WHEN_IDLE, {rxOn: 1});
|
|
134
|
-
//await this.execCommand(CommandId.SET_ED_TIMEOUT, {timeout: 8});
|
|
135
|
-
//await this.execCommand(CommandId.SET_MAX_CHILDREN, {children: 100});
|
|
136
|
-
|
|
137
|
-
if (transmitPower != null) {
|
|
138
|
-
await this.execCommand(CommandId.SET_TX_POWER, {txPower: transmitPower});
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
return result;
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
private async needsToBeInitialised(options: TsType.NetworkOptions): Promise<boolean> {
|
|
145
|
-
let valid = true;
|
|
146
|
-
this.netInfo = await this.getNetworkInfo();
|
|
147
|
-
logger.debug(() => `Current network parameters: ${JSON.stringify(this.netInfo)}`, NS);
|
|
148
|
-
if (this.netInfo) {
|
|
149
|
-
valid = valid && this.netInfo.nodeType === DeviceType.COORDINATOR;
|
|
150
|
-
valid = valid && options.panID === this.netInfo.network.panID;
|
|
151
|
-
valid = valid && options.channelList.includes(this.netInfo.network.channel);
|
|
152
|
-
valid = valid && equals(Buffer.from(options.extendedPanID || []), Buffer.from(this.netInfo.network.extendedPanID));
|
|
153
|
-
} else {
|
|
154
|
-
valid = false;
|
|
155
|
-
}
|
|
156
|
-
return !valid;
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
private async getNetworkInfo(): Promise<ZBOSSNetworkInfo> {
|
|
160
|
-
let result = await this.execCommand(CommandId.GET_JOINED, {});
|
|
161
|
-
const joined = result.payload.joined === 1;
|
|
162
|
-
if (!joined) {
|
|
163
|
-
logger.debug("Network not formed", NS);
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
result = await this.execCommand(CommandId.GET_ZIGBEE_ROLE, {});
|
|
167
|
-
const nodeType = result.payload.role;
|
|
168
|
-
|
|
169
|
-
result = await this.execCommand(CommandId.GET_LOCAL_IEEE_ADDR, {mac: 0});
|
|
170
|
-
const ieeeAddr = result.payload.ieee;
|
|
171
|
-
|
|
172
|
-
result = await this.execCommand(CommandId.GET_EXTENDED_PAN_ID, {});
|
|
173
|
-
// TODO: bug in extendedPanID - got reversed value
|
|
174
|
-
const extendedPanID = result.payload.extendedPanID.reverse();
|
|
175
|
-
|
|
176
|
-
result = await this.execCommand(CommandId.GET_PAN_ID, {});
|
|
177
|
-
const panID = result.payload.panID;
|
|
178
|
-
|
|
179
|
-
result = await this.execCommand(CommandId.GET_ZIGBEE_CHANNEL, {});
|
|
180
|
-
const channel = result.payload.channel;
|
|
181
|
-
|
|
182
|
-
return {
|
|
183
|
-
joined,
|
|
184
|
-
nodeType,
|
|
185
|
-
ieeeAddr,
|
|
186
|
-
network: {
|
|
187
|
-
panID,
|
|
188
|
-
extendedPanID,
|
|
189
|
-
channel,
|
|
190
|
-
},
|
|
191
|
-
};
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
private async addEndpoint(
|
|
195
|
-
endpoint: number,
|
|
196
|
-
profileId: number,
|
|
197
|
-
deviceId: number,
|
|
198
|
-
inputClusters: number[],
|
|
199
|
-
outputClusters: number[],
|
|
200
|
-
): Promise<void> {
|
|
201
|
-
const res = await this.execCommand(CommandId.AF_SET_SIMPLE_DESC, {
|
|
202
|
-
endpoint: endpoint,
|
|
203
|
-
profileID: profileId,
|
|
204
|
-
deviceID: deviceId,
|
|
205
|
-
version: 0,
|
|
206
|
-
inputClusterCount: inputClusters.length,
|
|
207
|
-
outputClusterCount: outputClusters.length,
|
|
208
|
-
inputClusters: inputClusters,
|
|
209
|
-
outputClusters: outputClusters,
|
|
210
|
-
});
|
|
211
|
-
|
|
212
|
-
logger.debug(() => `Adding endpoint: ${JSON.stringify(res)}`, NS);
|
|
213
|
-
}
|
|
214
|
-
|
|
215
|
-
private getChannelMask(channels: number[]): number {
|
|
216
|
-
return channels.reduce((mask, channel) => mask | (1 << channel), 0);
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
private async formNetwork(): Promise<void> {
|
|
220
|
-
const channelMask = this.getChannelMask(this.nwkOpt.channelList);
|
|
221
|
-
await this.execCommand(CommandId.SET_ZIGBEE_ROLE, {role: DeviceType.COORDINATOR});
|
|
222
|
-
await this.execCommand(CommandId.SET_ZIGBEE_CHANNEL_MASK, {page: 0, mask: channelMask});
|
|
223
|
-
await this.execCommand(CommandId.SET_PAN_ID, {panID: this.nwkOpt.panID});
|
|
224
|
-
// await this.execCommand(CommandId.SET_EXTENDED_PAN_ID, {extendedPanID: this.nwkOpt.extendedPanID});
|
|
225
|
-
await this.execCommand(CommandId.SET_NWK_KEY, {nwkKey: this.nwkOpt.networkKey, index: 0});
|
|
226
|
-
|
|
227
|
-
const res = await this.execCommand(
|
|
228
|
-
CommandId.NWK_FORMATION,
|
|
229
|
-
{
|
|
230
|
-
len: 1,
|
|
231
|
-
channels: [{page: 0, mask: channelMask}],
|
|
232
|
-
duration: 0x05,
|
|
233
|
-
distribFlag: 0x00,
|
|
234
|
-
distribNwk: 0x0000,
|
|
235
|
-
extendedPanID: this.nwkOpt.extendedPanID,
|
|
236
|
-
},
|
|
237
|
-
20000,
|
|
238
|
-
);
|
|
239
|
-
logger.debug(() => `Forming network: ${JSON.stringify(res)}`, NS);
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
public async stop(): Promise<void> {
|
|
243
|
-
await this.port.stop();
|
|
244
|
-
|
|
245
|
-
logger.info("Driver stopped", NS);
|
|
246
|
-
}
|
|
247
|
-
|
|
248
|
-
private onFrame(frame: ZBOSSFrame): void {
|
|
249
|
-
logger.debug(() => `<== Frame: ${JSON.stringify(frame)}`, NS);
|
|
250
|
-
|
|
251
|
-
const handled = this.waitress.resolve(frame);
|
|
252
|
-
|
|
253
|
-
if (!handled) {
|
|
254
|
-
this.emit("frame", frame);
|
|
255
|
-
}
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
public isInitialized(): boolean | undefined {
|
|
259
|
-
return this.port.portOpen && !this.port.inReset;
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
public async execCommand(commandId: number, params: KeyValue = {}, timeout = 10000): Promise<ZBOSSFrame> {
|
|
263
|
-
logger.debug(() => `==> ${CommandId[commandId]}(${commandId}): ${JSON.stringify(params)}`, NS);
|
|
264
|
-
|
|
265
|
-
if (!this.port.portOpen) {
|
|
266
|
-
throw new Error("Connection not initialized");
|
|
267
|
-
}
|
|
268
|
-
|
|
269
|
-
return await this.queue.execute<ZBOSSFrame>(async (): Promise<ZBOSSFrame> => {
|
|
270
|
-
const frame = makeFrame(FrameType.REQUEST, commandId, params);
|
|
271
|
-
frame.tsn = this.tsn;
|
|
272
|
-
const waiter = this.waitFor(commandId, commandId === CommandId.NCP_RESET ? undefined : this.tsn, timeout);
|
|
273
|
-
this.tsn = (this.tsn + 1) & 255;
|
|
274
|
-
|
|
275
|
-
try {
|
|
276
|
-
logger.debug(() => `==> FRAME: ${JSON.stringify(frame)}`, NS);
|
|
277
|
-
await this.port.sendFrame(frame);
|
|
278
|
-
|
|
279
|
-
const response = await waiter.start().promise;
|
|
280
|
-
if (response?.payload?.status !== StatusCodeGeneric.OK) {
|
|
281
|
-
throw new Error(`Error on command ${CommandId[commandId]}(${commandId}): ${JSON.stringify(response)}`);
|
|
282
|
-
}
|
|
283
|
-
|
|
284
|
-
return response;
|
|
285
|
-
} catch (error) {
|
|
286
|
-
this.waitress.remove(waiter.ID);
|
|
287
|
-
logger.error(`==> Error: ${error}`, NS);
|
|
288
|
-
throw new Error(`Failure send ${commandId}:${JSON.stringify(frame)}`);
|
|
289
|
-
}
|
|
290
|
-
});
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
public waitFor(
|
|
294
|
-
commandId: number,
|
|
295
|
-
tsn: number | undefined,
|
|
296
|
-
timeout = 10000,
|
|
297
|
-
): {start: () => {promise: Promise<ZBOSSFrame>; ID: number}; ID: number} {
|
|
298
|
-
return this.waitress.waitFor({commandId, tsn}, timeout);
|
|
299
|
-
}
|
|
300
|
-
|
|
301
|
-
private waitressTimeoutFormatter(matcher: ZBOSSWaitressMatcher, timeout: number): string {
|
|
302
|
-
return `${JSON.stringify(matcher)} after ${timeout}ms`;
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
private waitressValidator(payload: ZBOSSFrame, matcher: ZBOSSWaitressMatcher): boolean {
|
|
306
|
-
return (matcher.tsn === undefined || matcher.tsn === payload.tsn) && matcher.commandId === payload.commandId;
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
public async request(ieee: string, profileID: number, clusterID: number, dstEp: number, srcEp: number, data: Buffer): Promise<ZBOSSFrame> {
|
|
310
|
-
const payload = {
|
|
311
|
-
paramLength: 21,
|
|
312
|
-
dataLength: data.length,
|
|
313
|
-
addr: ieee,
|
|
314
|
-
profileID: profileID,
|
|
315
|
-
clusterID: clusterID,
|
|
316
|
-
dstEndpoint: dstEp,
|
|
317
|
-
srcEndpoint: srcEp,
|
|
318
|
-
radius: 3,
|
|
319
|
-
dstAddrMode: 3, // ADDRESS MODE ieee
|
|
320
|
-
txOptions: 2, // ROUTE DISCOVERY
|
|
321
|
-
useAlias: 0,
|
|
322
|
-
aliasAddr: 0,
|
|
323
|
-
aliasSequence: 0,
|
|
324
|
-
data: data,
|
|
325
|
-
};
|
|
326
|
-
return await this.execCommand(CommandId.APSDE_DATA_REQ, payload);
|
|
327
|
-
}
|
|
328
|
-
|
|
329
|
-
public async brequest(
|
|
330
|
-
addr: ZSpec.BroadcastAddress,
|
|
331
|
-
profileID: number,
|
|
332
|
-
clusterID: number,
|
|
333
|
-
dstEp: number,
|
|
334
|
-
srcEp: number,
|
|
335
|
-
data: Buffer,
|
|
336
|
-
): Promise<ZBOSSFrame> {
|
|
337
|
-
const payload = {
|
|
338
|
-
paramLength: 21,
|
|
339
|
-
dataLength: data.length,
|
|
340
|
-
addr: `0x${addr.toString(16).padStart(16, "0")}`,
|
|
341
|
-
profileID: profileID,
|
|
342
|
-
clusterID: clusterID,
|
|
343
|
-
dstEndpoint: dstEp,
|
|
344
|
-
srcEndpoint: srcEp,
|
|
345
|
-
radius: 3,
|
|
346
|
-
dstAddrMode: 2, // ADDRESS MODE broadcast
|
|
347
|
-
txOptions: 2, // ROUTE DISCOVERY
|
|
348
|
-
useAlias: 0,
|
|
349
|
-
aliasAddr: 0,
|
|
350
|
-
aliasSequence: 0,
|
|
351
|
-
data: data,
|
|
352
|
-
};
|
|
353
|
-
return await this.execCommand(CommandId.APSDE_DATA_REQ, payload);
|
|
354
|
-
}
|
|
355
|
-
|
|
356
|
-
public async grequest(group: number, profileID: number, clusterID: number, srcEp: number, data: Buffer): Promise<ZBOSSFrame> {
|
|
357
|
-
const payload = {
|
|
358
|
-
paramLength: 20,
|
|
359
|
-
dataLength: data.length,
|
|
360
|
-
addr: `0x${group.toString(16).padStart(16, "0")}`,
|
|
361
|
-
profileID: profileID,
|
|
362
|
-
clusterID: clusterID,
|
|
363
|
-
srcEndpoint: srcEp,
|
|
364
|
-
radius: 3,
|
|
365
|
-
dstAddrMode: 1, // ADDRESS MODE group
|
|
366
|
-
txOptions: 2, // ROUTE DISCOVERY
|
|
367
|
-
useAlias: 0,
|
|
368
|
-
aliasAddr: 0,
|
|
369
|
-
aliasSequence: 0,
|
|
370
|
-
data: data,
|
|
371
|
-
};
|
|
372
|
-
return await this.execCommand(CommandId.APSDE_DATA_REQ, payload);
|
|
373
|
-
}
|
|
374
|
-
|
|
375
|
-
public async requestZdo(clusterId: Zdo.ClusterId, payload: Buffer, disableResponse: boolean): Promise<ZBOSSFrame | undefined> {
|
|
376
|
-
if (!this.port.portOpen) {
|
|
377
|
-
throw new Error("Connection not initialized");
|
|
378
|
-
}
|
|
379
|
-
|
|
380
|
-
const commandId = ZDO_REQ_CLUSTER_ID_TO_ZBOSS_COMMAND_ID[clusterId];
|
|
381
|
-
assert(commandId !== undefined, `ZDO cluster ID '${clusterId}' not supported.`);
|
|
382
|
-
|
|
383
|
-
const cmdLog = `${Zdo.ClusterId[clusterId]}(cmd: ${commandId})`;
|
|
384
|
-
logger.debug(() => `===> ZDO ${cmdLog}: ${payload.toString("hex")}`, NS);
|
|
385
|
-
|
|
386
|
-
return await this.queue.execute<ZBOSSFrame | undefined>(async () => {
|
|
387
|
-
const buf = Buffer.alloc(5 + payload.length);
|
|
388
|
-
buf.writeInt8(0, 0);
|
|
389
|
-
buf.writeInt8(FrameType.REQUEST, 1);
|
|
390
|
-
buf.writeUInt16LE(commandId, 2);
|
|
391
|
-
buf.writeUInt8(this.tsn, 4);
|
|
392
|
-
buf.set(payload, 5);
|
|
393
|
-
|
|
394
|
-
let waiter: ReturnType<typeof this.waitFor> | undefined;
|
|
395
|
-
|
|
396
|
-
if (!disableResponse) {
|
|
397
|
-
waiter = this.waitFor(commandId, this.tsn, 10000);
|
|
398
|
-
}
|
|
399
|
-
|
|
400
|
-
this.tsn = (this.tsn + 1) & 255;
|
|
401
|
-
|
|
402
|
-
try {
|
|
403
|
-
await this.port.sendBuffer(buf);
|
|
404
|
-
|
|
405
|
-
if (waiter) {
|
|
406
|
-
return await waiter.start().promise;
|
|
407
|
-
}
|
|
408
|
-
} catch (error) {
|
|
409
|
-
if (waiter) {
|
|
410
|
-
this.waitress.remove(waiter.ID);
|
|
411
|
-
}
|
|
412
|
-
|
|
413
|
-
logger.debug(`=x=> Failed to send ${cmdLog}: ${(error as Error).stack}`, NS);
|
|
414
|
-
throw new Error(`Failed to send ${cmdLog}.`);
|
|
415
|
-
}
|
|
416
|
-
});
|
|
417
|
-
}
|
|
418
|
-
|
|
419
|
-
public async ieeeByNwk(nwk: number): Promise<string> {
|
|
420
|
-
return (await this.execCommand(CommandId.NWK_GET_IEEE_BY_SHORT, {nwk: nwk})).payload.ieee;
|
|
421
|
-
}
|
|
422
|
-
}
|