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.
Files changed (260) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/adapter/ezsp/driver/uart.js +1 -1
  3. package/dist/adapter/ezsp/driver/uart.js.map +1 -1
  4. package/dist/adapter/z-stack/adapter/zStackAdapter.js +4 -4
  5. package/dist/adapter/z-stack/adapter/zStackAdapter.js.map +1 -1
  6. package/dist/adapter/zigate/adapter/zigateAdapter.js +4 -4
  7. package/dist/adapter/zigate/adapter/zigateAdapter.js.map +1 -1
  8. package/dist/controller/model/device.d.ts.map +1 -1
  9. package/dist/controller/model/device.js +1 -0
  10. package/dist/controller/model/device.js.map +1 -1
  11. package/package.json +14 -6
  12. package/.github/ISSUE_TEMPLATE/config.yml +0 -5
  13. package/.github/dependabot.yml +0 -22
  14. package/.github/workflows/ci.yml +0 -64
  15. package/.github/workflows/release-please.yml +0 -18
  16. package/.github/workflows/stale.yml +0 -20
  17. package/.github/workflows/typedoc.yaml +0 -47
  18. package/.release-please-manifest.json +0 -3
  19. package/.vscode/extensions.json +0 -3
  20. package/.vscode/settings.json +0 -11
  21. package/biome.json +0 -98
  22. package/examples/join-and-log.js +0 -24
  23. package/release-please-config.json +0 -9
  24. package/src/adapter/adapter.ts +0 -189
  25. package/src/adapter/adapterDiscovery.ts +0 -666
  26. package/src/adapter/const.ts +0 -12
  27. package/src/adapter/deconz/adapter/deconzAdapter.ts +0 -877
  28. package/src/adapter/deconz/driver/constants.ts +0 -246
  29. package/src/adapter/deconz/driver/driver.ts +0 -1540
  30. package/src/adapter/deconz/driver/frame.ts +0 -11
  31. package/src/adapter/deconz/driver/frameParser.ts +0 -753
  32. package/src/adapter/deconz/driver/parser.ts +0 -45
  33. package/src/adapter/deconz/driver/writer.ts +0 -22
  34. package/src/adapter/deconz/types.d.ts +0 -13
  35. package/src/adapter/ember/adapter/emberAdapter.ts +0 -2265
  36. package/src/adapter/ember/adapter/endpoints.ts +0 -86
  37. package/src/adapter/ember/adapter/oneWaitress.ts +0 -324
  38. package/src/adapter/ember/adapter/tokensManager.ts +0 -782
  39. package/src/adapter/ember/consts.ts +0 -178
  40. package/src/adapter/ember/enums.ts +0 -1746
  41. package/src/adapter/ember/ezsp/buffalo.ts +0 -1392
  42. package/src/adapter/ember/ezsp/consts.ts +0 -148
  43. package/src/adapter/ember/ezsp/enums.ts +0 -1114
  44. package/src/adapter/ember/ezsp/ezsp.ts +0 -9061
  45. package/src/adapter/ember/ezspError.ts +0 -10
  46. package/src/adapter/ember/types.ts +0 -866
  47. package/src/adapter/ember/uart/ash.ts +0 -1960
  48. package/src/adapter/ember/uart/consts.ts +0 -109
  49. package/src/adapter/ember/uart/enums.ts +0 -192
  50. package/src/adapter/ember/uart/parser.ts +0 -48
  51. package/src/adapter/ember/uart/queues.ts +0 -247
  52. package/src/adapter/ember/uart/writer.ts +0 -53
  53. package/src/adapter/ember/utils/initters.ts +0 -58
  54. package/src/adapter/ember/utils/math.ts +0 -73
  55. package/src/adapter/events.ts +0 -21
  56. package/src/adapter/ezsp/adapter/backup.ts +0 -109
  57. package/src/adapter/ezsp/adapter/ezspAdapter.ts +0 -614
  58. package/src/adapter/ezsp/driver/commands.ts +0 -2497
  59. package/src/adapter/ezsp/driver/consts.ts +0 -11
  60. package/src/adapter/ezsp/driver/driver.ts +0 -1002
  61. package/src/adapter/ezsp/driver/ezsp.ts +0 -802
  62. package/src/adapter/ezsp/driver/frame.ts +0 -101
  63. package/src/adapter/ezsp/driver/index.ts +0 -4
  64. package/src/adapter/ezsp/driver/multicast.ts +0 -78
  65. package/src/adapter/ezsp/driver/parser.ts +0 -81
  66. package/src/adapter/ezsp/driver/types/basic.ts +0 -201
  67. package/src/adapter/ezsp/driver/types/index.ts +0 -239
  68. package/src/adapter/ezsp/driver/types/named.ts +0 -2330
  69. package/src/adapter/ezsp/driver/types/struct.ts +0 -844
  70. package/src/adapter/ezsp/driver/uart.ts +0 -460
  71. package/src/adapter/ezsp/driver/utils/crc16ccitt.ts +0 -44
  72. package/src/adapter/ezsp/driver/utils/index.ts +0 -32
  73. package/src/adapter/ezsp/driver/writer.ts +0 -64
  74. package/src/adapter/index.ts +0 -3
  75. package/src/adapter/serialPort.ts +0 -58
  76. package/src/adapter/socketPortUtils.ts +0 -16
  77. package/src/adapter/tstype.ts +0 -78
  78. package/src/adapter/z-stack/adapter/adapter-backup.ts +0 -519
  79. package/src/adapter/z-stack/adapter/adapter-nv-memory.ts +0 -457
  80. package/src/adapter/z-stack/adapter/endpoints.ts +0 -57
  81. package/src/adapter/z-stack/adapter/manager.ts +0 -543
  82. package/src/adapter/z-stack/adapter/tstype.ts +0 -6
  83. package/src/adapter/z-stack/adapter/zStackAdapter.ts +0 -1190
  84. package/src/adapter/z-stack/constants/af.ts +0 -27
  85. package/src/adapter/z-stack/constants/common.ts +0 -285
  86. package/src/adapter/z-stack/constants/dbg.ts +0 -23
  87. package/src/adapter/z-stack/constants/index.ts +0 -11
  88. package/src/adapter/z-stack/constants/mac.ts +0 -128
  89. package/src/adapter/z-stack/constants/sapi.ts +0 -25
  90. package/src/adapter/z-stack/constants/sys.ts +0 -72
  91. package/src/adapter/z-stack/constants/util.ts +0 -82
  92. package/src/adapter/z-stack/constants/utils.ts +0 -14
  93. package/src/adapter/z-stack/constants/zdo.ts +0 -103
  94. package/src/adapter/z-stack/models/startup-options.ts +0 -13
  95. package/src/adapter/z-stack/structs/entries/address-manager-entry.ts +0 -44
  96. package/src/adapter/z-stack/structs/entries/address-manager-table.ts +0 -19
  97. package/src/adapter/z-stack/structs/entries/aps-link-key-data-entry.ts +0 -12
  98. package/src/adapter/z-stack/structs/entries/aps-link-key-data-table.ts +0 -21
  99. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-entry.ts +0 -19
  100. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-table.ts +0 -21
  101. package/src/adapter/z-stack/structs/entries/channel-list.ts +0 -8
  102. package/src/adapter/z-stack/structs/entries/has-configured.ts +0 -16
  103. package/src/adapter/z-stack/structs/entries/index.ts +0 -16
  104. package/src/adapter/z-stack/structs/entries/nib.ts +0 -66
  105. package/src/adapter/z-stack/structs/entries/nwk-key-descriptor.ts +0 -15
  106. package/src/adapter/z-stack/structs/entries/nwk-key.ts +0 -13
  107. package/src/adapter/z-stack/structs/entries/nwk-pan-id.ts +0 -8
  108. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.ts +0 -20
  109. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.ts +0 -19
  110. package/src/adapter/z-stack/structs/entries/security-manager-entry.ts +0 -33
  111. package/src/adapter/z-stack/structs/entries/security-manager-table.ts +0 -22
  112. package/src/adapter/z-stack/structs/index.ts +0 -4
  113. package/src/adapter/z-stack/structs/serializable-memory-object.ts +0 -14
  114. package/src/adapter/z-stack/structs/struct.ts +0 -367
  115. package/src/adapter/z-stack/structs/table.ts +0 -198
  116. package/src/adapter/z-stack/unpi/constants.ts +0 -33
  117. package/src/adapter/z-stack/unpi/frame.ts +0 -62
  118. package/src/adapter/z-stack/unpi/index.ts +0 -4
  119. package/src/adapter/z-stack/unpi/parser.ts +0 -56
  120. package/src/adapter/z-stack/unpi/writer.ts +0 -21
  121. package/src/adapter/z-stack/utils/channel-list.ts +0 -40
  122. package/src/adapter/z-stack/utils/index.ts +0 -2
  123. package/src/adapter/z-stack/utils/network-options.ts +0 -26
  124. package/src/adapter/z-stack/znp/buffaloZnp.ts +0 -175
  125. package/src/adapter/z-stack/znp/definition.ts +0 -2713
  126. package/src/adapter/z-stack/znp/index.ts +0 -2
  127. package/src/adapter/z-stack/znp/parameterType.ts +0 -22
  128. package/src/adapter/z-stack/znp/tstype.ts +0 -44
  129. package/src/adapter/z-stack/znp/utils.ts +0 -10
  130. package/src/adapter/z-stack/znp/znp.ts +0 -342
  131. package/src/adapter/z-stack/znp/zpiObject.ts +0 -148
  132. package/src/adapter/zboss/adapter/zbossAdapter.ts +0 -526
  133. package/src/adapter/zboss/commands.ts +0 -1184
  134. package/src/adapter/zboss/consts.ts +0 -9
  135. package/src/adapter/zboss/driver.ts +0 -422
  136. package/src/adapter/zboss/enums.ts +0 -360
  137. package/src/adapter/zboss/frame.ts +0 -227
  138. package/src/adapter/zboss/reader.ts +0 -65
  139. package/src/adapter/zboss/types.ts +0 -0
  140. package/src/adapter/zboss/uart.ts +0 -428
  141. package/src/adapter/zboss/utils.ts +0 -58
  142. package/src/adapter/zboss/writer.ts +0 -49
  143. package/src/adapter/zigate/adapter/patchZdoBuffaloBE.ts +0 -27
  144. package/src/adapter/zigate/adapter/zigateAdapter.ts +0 -618
  145. package/src/adapter/zigate/driver/LICENSE +0 -17
  146. package/src/adapter/zigate/driver/buffaloZiGate.ts +0 -212
  147. package/src/adapter/zigate/driver/commandType.ts +0 -418
  148. package/src/adapter/zigate/driver/constants.ts +0 -150
  149. package/src/adapter/zigate/driver/frame.ts +0 -197
  150. package/src/adapter/zigate/driver/messageType.ts +0 -287
  151. package/src/adapter/zigate/driver/parameterType.ts +0 -32
  152. package/src/adapter/zigate/driver/ziGateObject.ts +0 -146
  153. package/src/adapter/zigate/driver/zigate.ts +0 -423
  154. package/src/adapter/zoh/adapter/utils.ts +0 -27
  155. package/src/adapter/zoh/adapter/zohAdapter.ts +0 -838
  156. package/src/buffalo/buffalo.ts +0 -342
  157. package/src/buffalo/index.ts +0 -1
  158. package/src/controller/controller.ts +0 -1022
  159. package/src/controller/database.ts +0 -124
  160. package/src/controller/events.ts +0 -52
  161. package/src/controller/greenPower.ts +0 -603
  162. package/src/controller/helpers/index.ts +0 -1
  163. package/src/controller/helpers/installCodes.ts +0 -107
  164. package/src/controller/helpers/request.ts +0 -96
  165. package/src/controller/helpers/requestQueue.ts +0 -125
  166. package/src/controller/helpers/zclFrameConverter.ts +0 -47
  167. package/src/controller/helpers/zclTransactionSequenceNumber.ts +0 -19
  168. package/src/controller/index.ts +0 -6
  169. package/src/controller/model/device.ts +0 -1248
  170. package/src/controller/model/endpoint.ts +0 -1105
  171. package/src/controller/model/entity.ts +0 -23
  172. package/src/controller/model/group.ts +0 -424
  173. package/src/controller/model/index.ts +0 -5
  174. package/src/controller/model/zigbeeEntity.ts +0 -30
  175. package/src/controller/touchlink.ts +0 -189
  176. package/src/controller/tstype.ts +0 -274
  177. package/src/index.ts +0 -12
  178. package/src/models/backup-storage-legacy.ts +0 -48
  179. package/src/models/backup-storage-unified.ts +0 -47
  180. package/src/models/backup.ts +0 -37
  181. package/src/models/index.ts +0 -5
  182. package/src/models/network-options.ts +0 -11
  183. package/src/utils/backup.ts +0 -152
  184. package/src/utils/index.ts +0 -5
  185. package/src/utils/logger.ts +0 -20
  186. package/src/utils/patchBigIntSerialization.ts +0 -8
  187. package/src/utils/queue.ts +0 -76
  188. package/src/utils/types.d.ts +0 -3
  189. package/src/utils/utils.ts +0 -19
  190. package/src/utils/wait.ts +0 -5
  191. package/src/utils/waitress.ts +0 -96
  192. package/src/zspec/consts.ts +0 -84
  193. package/src/zspec/enums.ts +0 -22
  194. package/src/zspec/index.ts +0 -3
  195. package/src/zspec/tstypes.ts +0 -18
  196. package/src/zspec/utils.ts +0 -247
  197. package/src/zspec/zcl/buffaloZcl.ts +0 -1220
  198. package/src/zspec/zcl/definition/cluster.ts +0 -5915
  199. package/src/zspec/zcl/definition/clusters-typegen.ts +0 -588
  200. package/src/zspec/zcl/definition/clusters-types.ts +0 -7331
  201. package/src/zspec/zcl/definition/consts.ts +0 -24
  202. package/src/zspec/zcl/definition/enums.ts +0 -203
  203. package/src/zspec/zcl/definition/foundation.ts +0 -329
  204. package/src/zspec/zcl/definition/manufacturerCode.ts +0 -729
  205. package/src/zspec/zcl/definition/status.ts +0 -69
  206. package/src/zspec/zcl/definition/tstype.ts +0 -377
  207. package/src/zspec/zcl/index.ts +0 -11
  208. package/src/zspec/zcl/utils.ts +0 -321
  209. package/src/zspec/zcl/zclFrame.ts +0 -356
  210. package/src/zspec/zcl/zclHeader.ts +0 -102
  211. package/src/zspec/zcl/zclStatusError.ts +0 -10
  212. package/src/zspec/zdo/buffaloZdo.ts +0 -2336
  213. package/src/zspec/zdo/definition/clusters.ts +0 -722
  214. package/src/zspec/zdo/definition/consts.ts +0 -16
  215. package/src/zspec/zdo/definition/enums.ts +0 -99
  216. package/src/zspec/zdo/definition/status.ts +0 -105
  217. package/src/zspec/zdo/definition/tstypes.ts +0 -1062
  218. package/src/zspec/zdo/index.ts +0 -7
  219. package/src/zspec/zdo/utils.ts +0 -76
  220. package/src/zspec/zdo/zdoStatusError.ts +0 -10
  221. package/test/adapter/adapter.test.ts +0 -1062
  222. package/test/adapter/ember/ash.test.ts +0 -337
  223. package/test/adapter/ember/consts.ts +0 -131
  224. package/test/adapter/ember/emberAdapter.test.ts +0 -3449
  225. package/test/adapter/ember/ezsp.test.ts +0 -385
  226. package/test/adapter/ember/ezspBuffalo.test.ts +0 -93
  227. package/test/adapter/ember/ezspError.test.ts +0 -12
  228. package/test/adapter/ember/math.test.ts +0 -206
  229. package/test/adapter/ezsp/frame.test.ts +0 -30
  230. package/test/adapter/ezsp/uart.test.ts +0 -181
  231. package/test/adapter/z-stack/adapter.test.ts +0 -3984
  232. package/test/adapter/z-stack/constants.test.ts +0 -33
  233. package/test/adapter/z-stack/structs.test.ts +0 -115
  234. package/test/adapter/z-stack/unpi.test.ts +0 -213
  235. package/test/adapter/z-stack/znp.test.ts +0 -1284
  236. package/test/adapter/zboss/fixZdoResponse.test.ts +0 -179
  237. package/test/adapter/zigate/patchZdoBuffaloBE.test.ts +0 -81
  238. package/test/adapter/zigate/zdo.test.ts +0 -187
  239. package/test/adapter/zoh/utils.test.ts +0 -36
  240. package/test/adapter/zoh/zohAdapter.test.ts +0 -1307
  241. package/test/buffalo.test.ts +0 -431
  242. package/test/controller.bench.ts +0 -193
  243. package/test/controller.test.ts +0 -8702
  244. package/test/greenpower.test.ts +0 -1408
  245. package/test/mockAdapters.ts +0 -65
  246. package/test/mockDevices.ts +0 -598
  247. package/test/requests.bench.ts +0 -206
  248. package/test/testUtils.ts +0 -20
  249. package/test/tsconfig.json +0 -9
  250. package/test/utils/math.ts +0 -19
  251. package/test/utils.test.ts +0 -279
  252. package/test/vitest.config.mts +0 -27
  253. package/test/zcl.test.ts +0 -2831
  254. package/test/zspec/utils.test.ts +0 -68
  255. package/test/zspec/zcl/buffalo.test.ts +0 -1374
  256. package/test/zspec/zcl/frame.test.ts +0 -960
  257. package/test/zspec/zcl/utils.test.ts +0 -273
  258. package/test/zspec/zdo/buffalo.test.ts +0 -1850
  259. package/test/zspec/zdo/utils.test.ts +0 -241
  260. package/tsconfig.json +0 -24
@@ -1,367 +0,0 @@
1
- import assert from "node:assert";
2
-
3
- import type {SerializableMemoryObject} from "./serializable-memory-object";
4
-
5
- /* Helper Types */
6
- type StructMemberType = "uint8" | "uint16" | "uint32" | "uint8array" | "uint8array-reversed" | "struct";
7
- type StructBuildOmitKeys = "member" | "method" | "padding" | "build" | "default";
8
- type StructChild = {offset: number; struct: Struct};
9
- export type BuiltStruct<T = Struct> = Omit<T, StructBuildOmitKeys>;
10
- export type StructFactorySignature<T = Struct> = (data?: Buffer) => T;
11
-
12
- export type StructMemoryAlignment = "unaligned" | "aligned";
13
-
14
- /**
15
- * Struct provides a builder-like interface to create Buffer-based memory
16
- * structures for read/write interfacing with data structures from adapters.
17
- */
18
- export class Struct implements SerializableMemoryObject {
19
- /**
20
- * Creates an empty struct. Further calls to `member()` and `method()` functions will form the structure.
21
- * Finally call to `build()` will type the resulting structure appropriately without internal functions.
22
- */
23
- public static new(): Struct {
24
- return new Struct();
25
- }
26
-
27
- // @ts-expect-error initialized in `build()`
28
- private buffer: Buffer;
29
- private defaultData: Buffer | undefined;
30
- private members: {key: string; offset: number; type: StructMemberType; length?: number}[] = [];
31
- private childStructs: {[key: string]: StructChild} = {};
32
- private length = 0;
33
- private paddingByte = 0x00;
34
-
35
- private constructor() {}
36
-
37
- /**
38
- * Returns raw contents of the structure as a sliced Buffer.
39
- * Mutations to the returned buffer will not be reflected within struct.
40
- */
41
- public serialize(alignment: StructMemoryAlignment = "unaligned", padLength = true, parentOffset = 0): Buffer {
42
- switch (alignment) {
43
- case "unaligned": {
44
- /* update child struct values and return as-is (unaligned) */
45
- for (const key of Object.keys(this.childStructs)) {
46
- const child = this.childStructs[key];
47
- this.buffer.set(child.struct.serialize(alignment), child.offset);
48
- }
49
- return Buffer.from(this.buffer);
50
- }
51
- case "aligned": {
52
- /* create 16-bit aligned buffer */
53
- const aligned = Buffer.alloc(this.getLength(alignment, padLength, parentOffset), this.paddingByte);
54
- let offset = 0;
55
- for (const member of this.members) {
56
- switch (member.type) {
57
- case "uint8":
58
- aligned.set(this.buffer.slice(member.offset, member.offset + 1), offset);
59
- offset += 1;
60
- break;
61
- case "uint16":
62
- offset += offset % 2;
63
- aligned.set(this.buffer.slice(member.offset, member.offset + 2), offset);
64
- offset += 2;
65
- break;
66
- case "uint32":
67
- offset += offset % 2;
68
- aligned.set(this.buffer.slice(member.offset, member.offset + 4), offset);
69
- offset += 4;
70
- break;
71
- case "uint8array":
72
- case "uint8array-reversed":
73
- assert(member.length !== undefined);
74
- aligned.set(this.buffer.slice(member.offset, member.offset + member.length), offset);
75
- offset += member.length;
76
- break;
77
- case "struct": {
78
- const structData = this.childStructs[member.key].struct.serialize(alignment, false, offset);
79
- aligned.set(structData, offset);
80
- offset += structData.length;
81
- break;
82
- }
83
- }
84
- }
85
- return aligned;
86
- }
87
- }
88
- }
89
-
90
- /**
91
- * Returns total length of the struct. Struct length is always fixed and configured
92
- * by calls to `member()` methods.
93
- */
94
- public getLength(alignment: StructMemoryAlignment = "unaligned", padLength = true, parentOffset = 0): number {
95
- switch (alignment) {
96
- case "unaligned": {
97
- /* return actual length */
98
- return this.length;
99
- }
100
- case "aligned": {
101
- /* compute aligned length and return */
102
- let length = this.members.reduce((offset, member) => {
103
- switch (member.type) {
104
- case "uint8":
105
- offset += 1;
106
- break;
107
- case "uint16":
108
- offset += ((parentOffset + offset) % 2) + 2;
109
- break;
110
- case "uint32":
111
- offset += ((parentOffset + offset) % 2) + 4;
112
- break;
113
- case "uint8array":
114
- case "uint8array-reversed":
115
- assert(member.length !== undefined);
116
- offset += member.length;
117
- break;
118
- case "struct":
119
- offset += this.childStructs[member.key].struct.getLength(alignment, false);
120
- break;
121
- }
122
- return offset;
123
- }, 0);
124
- if (padLength) {
125
- length += length % 2;
126
- }
127
- return length;
128
- }
129
- }
130
- }
131
-
132
- /**
133
- * Returns structure contents in JS object format.
134
- */
135
- public toJSON() {
136
- return this.members.reduce((a, c) => {
137
- // biome-ignore lint/suspicious/noExplicitAny: API
138
- a[c.key] = (this as any)[c.key];
139
- return a;
140
- // biome-ignore lint/suspicious/noExplicitAny: API
141
- }, {} as any);
142
- }
143
-
144
- /**
145
- * Adds a numeric member of `uint8`, `uint16` or `uint32` type.
146
- * Internal representation is always little endian.
147
- *
148
- * *This method is stripped from type on struct `build()`.*
149
- *
150
- * @param type Underlying data type (uint8, uint16 or uint32).
151
- * @param name Name of the struct member.
152
- */
153
- public member<T extends number, N extends string, R extends this & Record<N, T>>(type: "uint8" | "uint16" | "uint32", name: N): R;
154
-
155
- /**
156
- * Adds an uint8 array (byte array) as a struct member.
157
- *
158
- * *This method is stripped from type on struct `build()`.*
159
- *
160
- * @param type Underlying data type. Must be `uint8array`.
161
- * @param name Name of the struct member.
162
- * @param length Length of the byte array.
163
- */
164
- public member<T extends Buffer, N extends string, R extends this & Record<N, T>>(
165
- type: "uint8array" | "uint8array-reversed",
166
- name: N,
167
- length: number,
168
- ): R;
169
-
170
- /**
171
- * Adds another struct type as a struct member. Struct factory is provided
172
- * as a child struct definition source.
173
- *
174
- * *This method is stripped from type on struct `build()`.*
175
- *
176
- * @param type Underlying data type. Must be `struct`.
177
- * @param name Name of the struct member.
178
- * @param structFactory Factory providing the wanted child struct.
179
- */
180
- public member<T extends BuiltStruct, N extends string, R extends this & Record<N, T>>(
181
- type: "struct",
182
- name: N,
183
- structFactory: StructFactorySignature<T>,
184
- ): R;
185
-
186
- public member<T extends number | BuiltStruct, N extends string, R extends this & Record<N, T>>(
187
- type: StructMemberType,
188
- name: N,
189
- lengthOrStructFactory?: number | StructFactorySignature<T>,
190
- ): R {
191
- const offset = this.length;
192
- const structFactory = type === "struct" ? (lengthOrStructFactory as StructFactorySignature<T>) : undefined;
193
- const length = structFactory ? (structFactory() as unknown as Struct).length : (lengthOrStructFactory as number);
194
-
195
- switch (type) {
196
- case "uint8": {
197
- Object.defineProperty(this, name, {
198
- enumerable: true,
199
- get: () => this.buffer.readUInt8(offset),
200
- set: (value: number) => this.buffer.writeUInt8(value, offset),
201
- });
202
- this.length += 1;
203
- break;
204
- }
205
- case "uint16": {
206
- Object.defineProperty(this, name, {
207
- enumerable: true,
208
- get: () => this.buffer.readUInt16LE(offset),
209
- set: (value: number) => this.buffer.writeUInt16LE(value, offset),
210
- });
211
- this.length += 2;
212
- break;
213
- }
214
- case "uint32": {
215
- Object.defineProperty(this, name, {
216
- enumerable: true,
217
- get: () => this.buffer.readUInt32LE(offset),
218
- set: (value: number) => this.buffer.writeUInt32LE(value, offset),
219
- });
220
- this.length += 4;
221
- break;
222
- }
223
- case "uint8array":
224
- case "uint8array-reversed": {
225
- /* v8 ignore start */
226
- if (!length) {
227
- throw new Error("Struct builder requires length for `uint8array` and `uint8array-reversed` type");
228
- }
229
- /* v8 ignore stop */
230
- Object.defineProperty(this, name, {
231
- enumerable: true,
232
- get: () =>
233
- type === "uint8array-reversed"
234
- ? Buffer.from(this.buffer.slice(offset, offset + length)).reverse()
235
- : Buffer.from(this.buffer.slice(offset, offset + length)),
236
- set: (value: Buffer) => {
237
- if (value.length !== length) {
238
- throw new Error(`Invalid length for member ${name} (expected=${length}, got=${value.length})`);
239
- }
240
- if (type === "uint8array-reversed") {
241
- value = Buffer.from(value).reverse();
242
- }
243
- for (let i = 0; i < length; i++) {
244
- this.buffer[offset + i] = value[i];
245
- }
246
- },
247
- });
248
- this.length += length;
249
- break;
250
- }
251
- case "struct": {
252
- assert(structFactory);
253
- this.childStructs[name] = {offset, struct: structFactory() as unknown as Struct};
254
- Object.defineProperty(this, name, {
255
- enumerable: true,
256
- get: () => this.childStructs[name].struct,
257
- });
258
- this.length += length;
259
- }
260
- }
261
- this.members.push({key: name, offset, type, length});
262
- return this as unknown as R;
263
- }
264
-
265
- /**
266
- * Adds a custom method to the struct.
267
- *
268
- * *This method is stripped from type on struct `build()`.*
269
- *
270
- * @param name Name of the method to be appended.
271
- * @param _returnType Return type (eg. `Buffer.prototype`).
272
- * @param body Function implementation. Takes struct as a first and single input parameter.
273
- */
274
- public method<T, N extends string, R extends this & Record<N, () => T>>(name: N, _returnType: T, body: (struct: R) => T): R {
275
- Object.defineProperty(this, name, {
276
- enumerable: true,
277
- configurable: false,
278
- writable: false,
279
- // @ts-expect-error ignore because we are using `this`
280
- value: () => body.bind(this)(this),
281
- });
282
- return this as unknown as R;
283
- }
284
-
285
- /**
286
- * Sets default data to initialize empty struct with.
287
- *
288
- * @param data Data to initialize empty struct with.
289
- */
290
- public default(data: Buffer): this {
291
- /* v8 ignore start */
292
- if (data.length !== this.length) {
293
- throw new Error("Default value needs to have the length of unaligned structure.");
294
- }
295
- /* v8 ignore stop */
296
- this.defaultData = Buffer.from(data);
297
- return this;
298
- }
299
-
300
- /**
301
- * Sets byte to use for padding.
302
- *
303
- * @param padding Byte to use for padding
304
- */
305
- public padding(padding = 0x00): this {
306
- this.paddingByte = padding;
307
- return this;
308
- }
309
-
310
- /**
311
- * Creates the struct and optionally fills it with data. If data is provided, the length
312
- * of the provided buffer needs to match the structure length.
313
- *
314
- * *This method is stripped from type on struct `build()`.*
315
- */
316
- public build(data?: Buffer): BuiltStruct<this> {
317
- if (data) {
318
- if (data.length === this.getLength("unaligned")) {
319
- this.buffer = Buffer.from(data);
320
- for (const key of Object.keys(this.childStructs)) {
321
- const child = this.childStructs[key];
322
- child.struct.build(this.buffer.slice(child.offset, child.offset + child.struct.length));
323
- }
324
- } else if (data.length === this.getLength("aligned")) {
325
- this.buffer = Buffer.alloc(this.length, this.paddingByte);
326
- let offset = 0;
327
- for (const member of this.members) {
328
- switch (member.type) {
329
- case "uint8":
330
- this.buffer.set(data.slice(offset, offset + 1), member.offset);
331
- offset += 1;
332
- break;
333
- case "uint16":
334
- offset += offset % 2;
335
- this.buffer.set(data.slice(offset, offset + 2), member.offset);
336
- offset += 2;
337
- break;
338
- case "uint32":
339
- offset += offset % 2;
340
- this.buffer.set(data.slice(offset, offset + 4), member.offset);
341
- offset += 4;
342
- break;
343
- case "uint8array":
344
- case "uint8array-reversed":
345
- assert(member.length !== undefined);
346
- this.buffer.set(data.slice(offset, offset + member.length), member.offset);
347
- offset += member.length;
348
- break;
349
- case "struct": {
350
- const child = this.childStructs[member.key];
351
- child.struct.build(data.slice(offset, offset + child.struct.length));
352
- this.buffer.set(child.struct.serialize(), member.offset);
353
- offset += child.struct.length;
354
- break;
355
- }
356
- }
357
- }
358
- } else {
359
- const expectedLengths = `${this.getLength("unaligned")}/${this.getLength("aligned")}`;
360
- throw new Error(`Struct length mismatch (expected=${expectedLengths}, got=${data.length})`);
361
- }
362
- } else {
363
- this.buffer = this.defaultData ? Buffer.from(this.defaultData) : Buffer.alloc(this.length);
364
- }
365
- return this;
366
- }
367
- }
@@ -1,198 +0,0 @@
1
- import assert from "node:assert";
2
-
3
- import type {SerializableMemoryObject} from "./serializable-memory-object";
4
- import type {BuiltStruct, StructFactorySignature, StructMemoryAlignment} from "./struct";
5
-
6
- type TableBuildOmitKeys = "struct" | "header" | "occupancy" | "load" | "build" | "inlineHeader";
7
- export type BuiltTable<R extends BuiltStruct, T = Table<R>> = Omit<T, TableBuildOmitKeys>;
8
- export type TableFactorySignature<R extends BuiltStruct, T = Table<R>> = (data?: Buffer) => T;
9
-
10
- /**
11
- * Table structure wraps `Struct`-based entries for tables present within ZNP NV memory.
12
- */
13
- export class Table<R extends BuiltStruct> implements SerializableMemoryObject {
14
- /**
15
- * Create a new table builder.
16
- */
17
- public static new<R extends BuiltStruct>(): Table<R> {
18
- return new Table();
19
- }
20
-
21
- // @ts-expect-error initialized in `build()`
22
- private data: R[];
23
- // @ts-expect-error initialized in `struct()`
24
- private emptyEntry: R;
25
- private hasInlineLengthHeader = false;
26
- // @ts-expect-error initialized in `struct()`
27
- private entryStructFactory: StructFactorySignature<R>;
28
- private entryOccupancyFunction: ((entry: R) => boolean) | undefined;
29
-
30
- private constructor() {}
31
-
32
- /**
33
- * Return total capacity of the table.
34
- */
35
- public get capacity(): number {
36
- return this.data.length;
37
- }
38
-
39
- /**
40
- * Returns all entries within table.
41
- */
42
- public get entries(): R[] {
43
- return this.data;
44
- }
45
-
46
- /**
47
- * Returns all used entries.
48
- */
49
- public get used(): R[] {
50
- assert(this.entryOccupancyFunction, "Table usage cannot be determined without occupancy function when header is not present.");
51
- const fun = this.entryOccupancyFunction;
52
- return this.entries.filter((e) => fun(e));
53
- }
54
-
55
- /**
56
- * Returns all unused entries.
57
- */
58
- public get free(): R[] {
59
- assert(this.entryOccupancyFunction, "Table usage cannot be determined without occupancy function when header is not present.");
60
- const fun = this.entryOccupancyFunction;
61
- return this.entries.filter((e) => !fun(e));
62
- }
63
-
64
- /**
65
- * Return number of records marked as free.
66
- */
67
- public get freeCount(): number {
68
- return this.free.length;
69
- }
70
-
71
- /**
72
- * Return number of records marked as used.
73
- */
74
- public get usedCount(): number {
75
- return this.used.length;
76
- }
77
-
78
- /**
79
- * Return next free entry or `null` if no entries are free within the table.
80
- */
81
- public getNextFree(): R {
82
- return this.free[0] ?? null;
83
- }
84
-
85
- /**
86
- * Returns index of element in table.
87
- *
88
- * @param entry Entry to resolve index for.
89
- */
90
- public indexOf(entry: R): number | null {
91
- return this.entries.findIndex((e) => e.serialize().equals(entry.serialize())) ?? /* v8 ignore next */ null;
92
- }
93
-
94
- /**
95
- * Export the table in target platform format.
96
- *
97
- * @param alignment Memory alignment to use for export.
98
- */
99
- public serialize(alignment: StructMemoryAlignment = "unaligned"): Buffer {
100
- const entryLength = this.emptyEntry.getLength(alignment);
101
- const output = Buffer.alloc((this.hasInlineLengthHeader ? 2 : 0) + this.capacity * entryLength, 0x00);
102
- let offset = 0;
103
- if (this.hasInlineLengthHeader) {
104
- output.writeUInt16LE(this.usedCount);
105
- offset += 2;
106
- }
107
- for (const e of this.data) {
108
- output.set(e.serialize(alignment), offset);
109
- offset += e.getLength(alignment);
110
- }
111
- return output;
112
- }
113
-
114
- /**
115
- * Applies function to determine table entry occupancy. This function is invoked with an entry instance
116
- * and returns `boolean` indicating if the entry is occupied or not.
117
- *
118
- * @param fn Function to determine entry occupancy.
119
- */
120
- public occupancy(fn: (entry: R) => boolean): this {
121
- this.entryOccupancyFunction = fn;
122
- return this;
123
- }
124
-
125
- /**
126
- * Defines a struct factory for entries contained within table.
127
- *
128
- * @param entryStructFactory Struct factory.
129
- */
130
- public struct(entryStructFactory: StructFactorySignature<R>): this {
131
- this.entryStructFactory = entryStructFactory;
132
- this.emptyEntry = this.entryStructFactory();
133
- return this;
134
- }
135
-
136
- /**
137
- * Sets whether the table has a table header containing a 16-bit unsigned used table length.
138
- *
139
- * @param hasInlineHeader Sets whether table has record count header.
140
- */
141
- public inlineHeader(hasInlineHeader = true): this {
142
- this.hasInlineLengthHeader = hasInlineHeader;
143
- return this;
144
- }
145
-
146
- /**
147
- * Builds the table from existing buffer or buffers representing entries.
148
- *
149
- * @param data Buffer to populate table from.
150
- * @param alignment Memory alignment of the source platform.
151
- */
152
- public build(data: Buffer | Buffer[], alignment?: StructMemoryAlignment): BuiltTable<R>;
153
-
154
- /**
155
- * Creates an empty table with set capacity.
156
- *
157
- * @param capacity Capacity to create the table with.
158
- */
159
- public build(capacity: number): BuiltTable<R>;
160
-
161
- public build(dataOrCapacity: Buffer | Buffer[] | number, alignment: StructMemoryAlignment = "unaligned"): BuiltTable<R> {
162
- /* v8 ignore start */
163
- if (!this.entryStructFactory) {
164
- throw new Error("Table requires an entry struct factory.");
165
- }
166
- /* v8 ignore stop */
167
- if (Array.isArray(dataOrCapacity) && dataOrCapacity.every((e) => Buffer.isBuffer(e))) {
168
- /* create table from given entries */
169
- const data = dataOrCapacity;
170
- if (!data.every((e) => e.length === data[0].length)) {
171
- throw new Error("All table entries need to be the same length");
172
- }
173
- this.data = data.map((buffer) => this.entryStructFactory(buffer));
174
- } else if (Buffer.isBuffer(dataOrCapacity)) {
175
- /* create table from inline structure */
176
- const data = dataOrCapacity;
177
- const entryLength = this.emptyEntry.getLength(alignment);
178
- const dataLength = this.hasInlineLengthHeader ? data.length - 2 : data.length;
179
- if (dataLength % entryLength !== 0) {
180
- throw new Error(
181
- `Table length not divisible by entry length (alignment=${alignment}, data_length=${data.length}, entry_length=${entryLength})`,
182
- );
183
- }
184
- const capacity = dataLength / entryLength;
185
- const entriesStart = this.hasInlineLengthHeader ? data.slice(2, data.length) : data.slice();
186
- this.data = [...Array(capacity)].map((_, i) =>
187
- this.entryStructFactory(entriesStart.slice(i * entryLength, i * entryLength + entryLength)),
188
- );
189
- } else if (typeof dataOrCapacity === "number") {
190
- /* create empty table of given capacity */
191
- const capacity = dataOrCapacity;
192
- this.data = [...Array(capacity)].map(() => this.entryStructFactory());
193
- } else {
194
- throw new Error("Unsupported table data source");
195
- }
196
- return this;
197
- }
198
- }
@@ -1,33 +0,0 @@
1
- enum Type {
2
- POLL = 0,
3
- SREQ = 1,
4
- AREQ = 2,
5
- SRSP = 3,
6
- }
7
-
8
- enum Subsystem {
9
- RESERVED = 0,
10
- SYS = 1,
11
- MAC = 2,
12
- NWK = 3,
13
- AF = 4,
14
- ZDO = 5,
15
- SAPI = 6,
16
- UTIL = 7,
17
- DEBUG = 8,
18
- APP = 9,
19
- APP_CNF = 15,
20
- GREENPOWER = 21,
21
- }
22
-
23
- const DataStart = 4;
24
- const SOF = 0xfe;
25
-
26
- const PositionDataLength = 1;
27
- const PositionCmd0 = 2;
28
- const PositionCmd1 = 3;
29
-
30
- const MinMessageLength = 5;
31
- const MaxDataSize = 250;
32
-
33
- export {Type, Subsystem, DataStart, SOF, PositionDataLength, MinMessageLength, PositionCmd0, PositionCmd1, MaxDataSize};
@@ -1,62 +0,0 @@
1
- import {DataStart, PositionCmd0, PositionCmd1, SOF, type Subsystem, type Type} from "./constants";
2
-
3
- export class Frame {
4
- public readonly type: Type;
5
- public readonly subsystem: Subsystem;
6
- public readonly commandID: number;
7
- public readonly data: Buffer;
8
-
9
- public readonly length?: number;
10
- public readonly fcs?: number;
11
-
12
- public constructor(type: Type, subsystem: Subsystem, commandID: number, data: Buffer, length?: number, fcs?: number) {
13
- this.type = type;
14
- this.subsystem = subsystem;
15
- this.commandID = commandID;
16
- this.data = data;
17
- this.length = length;
18
- this.fcs = fcs;
19
- }
20
-
21
- public toBuffer(): Buffer {
22
- const length = this.data.length;
23
- const cmd0 = ((this.type << 5) & 0xe0) | (this.subsystem & 0x1f);
24
-
25
- let payload = Buffer.from([SOF, length, cmd0, this.commandID]);
26
- payload = Buffer.concat([payload, this.data]);
27
- const fcs = Frame.calculateChecksum(payload.slice(1, payload.length));
28
-
29
- return Buffer.concat([payload, Buffer.from([fcs])]);
30
- }
31
-
32
- public static fromBuffer(length: number, fcsPosition: number, buffer: Buffer): Frame {
33
- const subsystem: Subsystem = buffer.readUInt8(PositionCmd0) & 0x1f;
34
- const type: Type = (buffer.readUInt8(PositionCmd0) & 0xe0) >> 5;
35
- const commandID = buffer.readUInt8(PositionCmd1);
36
- const data = buffer.subarray(DataStart, fcsPosition);
37
- const fcs = buffer.readUInt8(fcsPosition);
38
-
39
- // Validate the checksum to see if we fully received the message
40
- const checksum = Frame.calculateChecksum(buffer.subarray(1, fcsPosition));
41
-
42
- if (checksum === fcs) {
43
- return new Frame(type, subsystem, commandID, data, length, fcs);
44
- }
45
-
46
- throw new Error("Invalid checksum");
47
- }
48
-
49
- private static calculateChecksum(values: Buffer): number {
50
- let checksum = 0;
51
-
52
- for (const value of values) {
53
- checksum ^= value;
54
- }
55
-
56
- return checksum;
57
- }
58
-
59
- public toString(): string {
60
- return `${this.length} - ${this.type} - ${this.subsystem} - ${this.commandID} - [${[...this.data]}] - ${this.fcs}`;
61
- }
62
- }
@@ -1,4 +0,0 @@
1
- export * as Constants from "./constants";
2
- export {Frame} from "./frame";
3
- export {Parser} from "./parser";
4
- export {Writer} from "./writer";