matterbridge 3.3.3 → 3.3.4-dev-20251020-4d2dd49

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 (296) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/dist/broadcastServer.js +1 -86
  3. package/dist/broadcastServerTypes.js +0 -24
  4. package/dist/cli.js +110 -444
  5. package/dist/cliEmitter.js +0 -37
  6. package/dist/cliHistory.js +15 -95
  7. package/dist/clusters/export.js +0 -2
  8. package/dist/defaultConfigSchema.js +0 -24
  9. package/dist/deviceManager.js +1 -124
  10. package/dist/devices/airConditioner.js +0 -57
  11. package/dist/devices/batteryStorage.js +1 -48
  12. package/dist/devices/cooktop.js +0 -55
  13. package/dist/devices/dishwasher.js +0 -57
  14. package/dist/devices/evse.js +10 -74
  15. package/dist/devices/export.js +0 -5
  16. package/dist/devices/extractorHood.js +0 -42
  17. package/dist/devices/heatPump.js +2 -50
  18. package/dist/devices/laundryDryer.js +3 -62
  19. package/dist/devices/laundryWasher.js +4 -70
  20. package/dist/devices/microwaveOven.js +5 -88
  21. package/dist/devices/oven.js +0 -85
  22. package/dist/devices/refrigerator.js +0 -102
  23. package/dist/devices/roboticVacuumCleaner.js +9 -100
  24. package/dist/devices/solarPower.js +0 -38
  25. package/dist/devices/speaker.js +0 -84
  26. package/dist/devices/temperatureControl.js +3 -25
  27. package/dist/devices/waterHeater.js +2 -82
  28. package/dist/dgram/coap.js +13 -126
  29. package/dist/dgram/dgram.js +2 -114
  30. package/dist/dgram/mb_coap.js +3 -41
  31. package/dist/dgram/mb_mdns.js +15 -80
  32. package/dist/dgram/mdns.js +137 -299
  33. package/dist/dgram/multicast.js +1 -62
  34. package/dist/dgram/unicast.js +0 -54
  35. package/dist/frontend.js +34 -413
  36. package/dist/frontendTypes.js +0 -45
  37. package/dist/helpers.js +0 -53
  38. package/dist/index.js +0 -25
  39. package/dist/logger/export.js +0 -1
  40. package/dist/matter/behaviors.js +0 -2
  41. package/dist/matter/clusters.js +0 -2
  42. package/dist/matter/devices.js +0 -2
  43. package/dist/matter/endpoints.js +0 -2
  44. package/dist/matter/export.js +0 -3
  45. package/dist/matter/types.js +0 -3
  46. package/dist/matterbridge.js +51 -873
  47. package/dist/matterbridgeAccessoryPlatform.js +0 -36
  48. package/dist/matterbridgeBehaviors.js +5 -71
  49. package/dist/matterbridgeDeviceTypes.js +17 -630
  50. package/dist/matterbridgeDynamicPlatform.js +0 -36
  51. package/dist/matterbridgeEndpoint.js +58 -1412
  52. package/dist/matterbridgeEndpointHelpers.js +10 -368
  53. package/dist/matterbridgePlatform.js +1 -341
  54. package/dist/matterbridgeTypes.js +0 -26
  55. package/dist/pluginManager.js +3 -325
  56. package/dist/shelly.js +7 -168
  57. package/dist/storage/export.js +0 -1
  58. package/dist/update.js +0 -69
  59. package/dist/utils/colorUtils.js +2 -97
  60. package/dist/utils/commandLine.js +6 -55
  61. package/dist/utils/copyDirectory.js +1 -38
  62. package/dist/utils/createDirectory.js +0 -33
  63. package/dist/utils/createZip.js +2 -47
  64. package/dist/utils/deepCopy.js +0 -39
  65. package/dist/utils/deepEqual.js +1 -72
  66. package/dist/utils/error.js +0 -41
  67. package/dist/utils/export.js +0 -1
  68. package/dist/utils/hex.js +0 -124
  69. package/dist/utils/inspector.js +200 -0
  70. package/dist/utils/isvalid.js +0 -101
  71. package/dist/utils/jestHelpers.js +3 -153
  72. package/dist/utils/network.js +5 -108
  73. package/dist/utils/spawn.js +0 -71
  74. package/dist/utils/tracker.js +229 -0
  75. package/dist/utils/wait.js +8 -60
  76. package/frontend/build/assets/index.js +4 -4
  77. package/frontend/build/assets/vendor_mdi.js +1 -1
  78. package/frontend/package.json +1 -1
  79. package/npm-shrinkwrap.json +44 -44
  80. package/package.json +2 -3
  81. package/dist/broadcastServer.d.ts +0 -105
  82. package/dist/broadcastServer.d.ts.map +0 -1
  83. package/dist/broadcastServer.js.map +0 -1
  84. package/dist/broadcastServerTypes.d.ts +0 -719
  85. package/dist/broadcastServerTypes.d.ts.map +0 -1
  86. package/dist/broadcastServerTypes.js.map +0 -1
  87. package/dist/cli.d.ts +0 -26
  88. package/dist/cli.d.ts.map +0 -1
  89. package/dist/cli.js.map +0 -1
  90. package/dist/cliEmitter.d.ts +0 -50
  91. package/dist/cliEmitter.d.ts.map +0 -1
  92. package/dist/cliEmitter.js.map +0 -1
  93. package/dist/cliHistory.d.ts +0 -74
  94. package/dist/cliHistory.d.ts.map +0 -1
  95. package/dist/cliHistory.js.map +0 -1
  96. package/dist/clusters/export.d.ts +0 -2
  97. package/dist/clusters/export.d.ts.map +0 -1
  98. package/dist/clusters/export.js.map +0 -1
  99. package/dist/defaultConfigSchema.d.ts +0 -28
  100. package/dist/defaultConfigSchema.d.ts.map +0 -1
  101. package/dist/defaultConfigSchema.js.map +0 -1
  102. package/dist/deviceManager.d.ts +0 -117
  103. package/dist/deviceManager.d.ts.map +0 -1
  104. package/dist/deviceManager.js.map +0 -1
  105. package/dist/devices/airConditioner.d.ts +0 -98
  106. package/dist/devices/airConditioner.d.ts.map +0 -1
  107. package/dist/devices/airConditioner.js.map +0 -1
  108. package/dist/devices/batteryStorage.d.ts +0 -48
  109. package/dist/devices/batteryStorage.d.ts.map +0 -1
  110. package/dist/devices/batteryStorage.js.map +0 -1
  111. package/dist/devices/cooktop.d.ts +0 -60
  112. package/dist/devices/cooktop.d.ts.map +0 -1
  113. package/dist/devices/cooktop.js.map +0 -1
  114. package/dist/devices/dishwasher.d.ts +0 -71
  115. package/dist/devices/dishwasher.d.ts.map +0 -1
  116. package/dist/devices/dishwasher.js.map +0 -1
  117. package/dist/devices/evse.d.ts +0 -75
  118. package/dist/devices/evse.d.ts.map +0 -1
  119. package/dist/devices/evse.js.map +0 -1
  120. package/dist/devices/export.d.ts +0 -17
  121. package/dist/devices/export.d.ts.map +0 -1
  122. package/dist/devices/export.js.map +0 -1
  123. package/dist/devices/extractorHood.d.ts +0 -46
  124. package/dist/devices/extractorHood.d.ts.map +0 -1
  125. package/dist/devices/extractorHood.js.map +0 -1
  126. package/dist/devices/heatPump.d.ts +0 -47
  127. package/dist/devices/heatPump.d.ts.map +0 -1
  128. package/dist/devices/heatPump.js.map +0 -1
  129. package/dist/devices/laundryDryer.d.ts +0 -67
  130. package/dist/devices/laundryDryer.d.ts.map +0 -1
  131. package/dist/devices/laundryDryer.js.map +0 -1
  132. package/dist/devices/laundryWasher.d.ts +0 -81
  133. package/dist/devices/laundryWasher.d.ts.map +0 -1
  134. package/dist/devices/laundryWasher.js.map +0 -1
  135. package/dist/devices/microwaveOven.d.ts +0 -168
  136. package/dist/devices/microwaveOven.d.ts.map +0 -1
  137. package/dist/devices/microwaveOven.js.map +0 -1
  138. package/dist/devices/oven.d.ts +0 -105
  139. package/dist/devices/oven.d.ts.map +0 -1
  140. package/dist/devices/oven.js.map +0 -1
  141. package/dist/devices/refrigerator.d.ts +0 -118
  142. package/dist/devices/refrigerator.d.ts.map +0 -1
  143. package/dist/devices/refrigerator.js.map +0 -1
  144. package/dist/devices/roboticVacuumCleaner.d.ts +0 -112
  145. package/dist/devices/roboticVacuumCleaner.d.ts.map +0 -1
  146. package/dist/devices/roboticVacuumCleaner.js.map +0 -1
  147. package/dist/devices/solarPower.d.ts +0 -40
  148. package/dist/devices/solarPower.d.ts.map +0 -1
  149. package/dist/devices/solarPower.js.map +0 -1
  150. package/dist/devices/speaker.d.ts +0 -87
  151. package/dist/devices/speaker.d.ts.map +0 -1
  152. package/dist/devices/speaker.js.map +0 -1
  153. package/dist/devices/temperatureControl.d.ts +0 -166
  154. package/dist/devices/temperatureControl.d.ts.map +0 -1
  155. package/dist/devices/temperatureControl.js.map +0 -1
  156. package/dist/devices/waterHeater.d.ts +0 -111
  157. package/dist/devices/waterHeater.d.ts.map +0 -1
  158. package/dist/devices/waterHeater.js.map +0 -1
  159. package/dist/dgram/coap.d.ts +0 -205
  160. package/dist/dgram/coap.d.ts.map +0 -1
  161. package/dist/dgram/coap.js.map +0 -1
  162. package/dist/dgram/dgram.d.ts +0 -141
  163. package/dist/dgram/dgram.d.ts.map +0 -1
  164. package/dist/dgram/dgram.js.map +0 -1
  165. package/dist/dgram/mb_coap.d.ts +0 -24
  166. package/dist/dgram/mb_coap.d.ts.map +0 -1
  167. package/dist/dgram/mb_coap.js.map +0 -1
  168. package/dist/dgram/mb_mdns.d.ts +0 -24
  169. package/dist/dgram/mb_mdns.d.ts.map +0 -1
  170. package/dist/dgram/mb_mdns.js.map +0 -1
  171. package/dist/dgram/mdns.d.ts +0 -290
  172. package/dist/dgram/mdns.d.ts.map +0 -1
  173. package/dist/dgram/mdns.js.map +0 -1
  174. package/dist/dgram/multicast.d.ts +0 -67
  175. package/dist/dgram/multicast.d.ts.map +0 -1
  176. package/dist/dgram/multicast.js.map +0 -1
  177. package/dist/dgram/unicast.d.ts +0 -56
  178. package/dist/dgram/unicast.d.ts.map +0 -1
  179. package/dist/dgram/unicast.js.map +0 -1
  180. package/dist/frontend.d.ts +0 -235
  181. package/dist/frontend.d.ts.map +0 -1
  182. package/dist/frontend.js.map +0 -1
  183. package/dist/frontendTypes.d.ts +0 -529
  184. package/dist/frontendTypes.d.ts.map +0 -1
  185. package/dist/frontendTypes.js.map +0 -1
  186. package/dist/helpers.d.ts +0 -48
  187. package/dist/helpers.d.ts.map +0 -1
  188. package/dist/helpers.js.map +0 -1
  189. package/dist/index.d.ts +0 -33
  190. package/dist/index.d.ts.map +0 -1
  191. package/dist/index.js.map +0 -1
  192. package/dist/logger/export.d.ts +0 -2
  193. package/dist/logger/export.d.ts.map +0 -1
  194. package/dist/logger/export.js.map +0 -1
  195. package/dist/matter/behaviors.d.ts +0 -2
  196. package/dist/matter/behaviors.d.ts.map +0 -1
  197. package/dist/matter/behaviors.js.map +0 -1
  198. package/dist/matter/clusters.d.ts +0 -2
  199. package/dist/matter/clusters.d.ts.map +0 -1
  200. package/dist/matter/clusters.js.map +0 -1
  201. package/dist/matter/devices.d.ts +0 -2
  202. package/dist/matter/devices.d.ts.map +0 -1
  203. package/dist/matter/devices.js.map +0 -1
  204. package/dist/matter/endpoints.d.ts +0 -2
  205. package/dist/matter/endpoints.d.ts.map +0 -1
  206. package/dist/matter/endpoints.js.map +0 -1
  207. package/dist/matter/export.d.ts +0 -5
  208. package/dist/matter/export.d.ts.map +0 -1
  209. package/dist/matter/export.js.map +0 -1
  210. package/dist/matter/types.d.ts +0 -3
  211. package/dist/matter/types.d.ts.map +0 -1
  212. package/dist/matter/types.js.map +0 -1
  213. package/dist/matterbridge.d.ts +0 -469
  214. package/dist/matterbridge.d.ts.map +0 -1
  215. package/dist/matterbridge.js.map +0 -1
  216. package/dist/matterbridgeAccessoryPlatform.d.ts +0 -42
  217. package/dist/matterbridgeAccessoryPlatform.d.ts.map +0 -1
  218. package/dist/matterbridgeAccessoryPlatform.js.map +0 -1
  219. package/dist/matterbridgeBehaviors.d.ts +0 -2399
  220. package/dist/matterbridgeBehaviors.d.ts.map +0 -1
  221. package/dist/matterbridgeBehaviors.js.map +0 -1
  222. package/dist/matterbridgeDeviceTypes.d.ts +0 -761
  223. package/dist/matterbridgeDeviceTypes.d.ts.map +0 -1
  224. package/dist/matterbridgeDeviceTypes.js.map +0 -1
  225. package/dist/matterbridgeDynamicPlatform.d.ts +0 -42
  226. package/dist/matterbridgeDynamicPlatform.d.ts.map +0 -1
  227. package/dist/matterbridgeDynamicPlatform.js.map +0 -1
  228. package/dist/matterbridgeEndpoint.d.ts +0 -1545
  229. package/dist/matterbridgeEndpoint.d.ts.map +0 -1
  230. package/dist/matterbridgeEndpoint.js.map +0 -1
  231. package/dist/matterbridgeEndpointHelpers.d.ts +0 -560
  232. package/dist/matterbridgeEndpointHelpers.d.ts.map +0 -1
  233. package/dist/matterbridgeEndpointHelpers.js.map +0 -1
  234. package/dist/matterbridgePlatform.d.ts +0 -402
  235. package/dist/matterbridgePlatform.d.ts.map +0 -1
  236. package/dist/matterbridgePlatform.js.map +0 -1
  237. package/dist/matterbridgeTypes.d.ts +0 -209
  238. package/dist/matterbridgeTypes.d.ts.map +0 -1
  239. package/dist/matterbridgeTypes.js.map +0 -1
  240. package/dist/pluginManager.d.ts +0 -353
  241. package/dist/pluginManager.d.ts.map +0 -1
  242. package/dist/pluginManager.js.map +0 -1
  243. package/dist/shelly.d.ts +0 -174
  244. package/dist/shelly.d.ts.map +0 -1
  245. package/dist/shelly.js.map +0 -1
  246. package/dist/storage/export.d.ts +0 -2
  247. package/dist/storage/export.d.ts.map +0 -1
  248. package/dist/storage/export.js.map +0 -1
  249. package/dist/update.d.ts +0 -75
  250. package/dist/update.d.ts.map +0 -1
  251. package/dist/update.js.map +0 -1
  252. package/dist/utils/colorUtils.d.ts +0 -99
  253. package/dist/utils/colorUtils.d.ts.map +0 -1
  254. package/dist/utils/colorUtils.js.map +0 -1
  255. package/dist/utils/commandLine.d.ts +0 -59
  256. package/dist/utils/commandLine.d.ts.map +0 -1
  257. package/dist/utils/commandLine.js.map +0 -1
  258. package/dist/utils/copyDirectory.d.ts +0 -33
  259. package/dist/utils/copyDirectory.d.ts.map +0 -1
  260. package/dist/utils/copyDirectory.js.map +0 -1
  261. package/dist/utils/createDirectory.d.ts +0 -34
  262. package/dist/utils/createDirectory.d.ts.map +0 -1
  263. package/dist/utils/createDirectory.js.map +0 -1
  264. package/dist/utils/createZip.d.ts +0 -39
  265. package/dist/utils/createZip.d.ts.map +0 -1
  266. package/dist/utils/createZip.js.map +0 -1
  267. package/dist/utils/deepCopy.d.ts +0 -32
  268. package/dist/utils/deepCopy.d.ts.map +0 -1
  269. package/dist/utils/deepCopy.js.map +0 -1
  270. package/dist/utils/deepEqual.d.ts +0 -54
  271. package/dist/utils/deepEqual.d.ts.map +0 -1
  272. package/dist/utils/deepEqual.js.map +0 -1
  273. package/dist/utils/error.d.ts +0 -44
  274. package/dist/utils/error.d.ts.map +0 -1
  275. package/dist/utils/error.js.map +0 -1
  276. package/dist/utils/export.d.ts +0 -13
  277. package/dist/utils/export.d.ts.map +0 -1
  278. package/dist/utils/export.js.map +0 -1
  279. package/dist/utils/hex.d.ts +0 -89
  280. package/dist/utils/hex.d.ts.map +0 -1
  281. package/dist/utils/hex.js.map +0 -1
  282. package/dist/utils/isvalid.d.ts +0 -103
  283. package/dist/utils/isvalid.d.ts.map +0 -1
  284. package/dist/utils/isvalid.js.map +0 -1
  285. package/dist/utils/jestHelpers.d.ts +0 -137
  286. package/dist/utils/jestHelpers.d.ts.map +0 -1
  287. package/dist/utils/jestHelpers.js.map +0 -1
  288. package/dist/utils/network.d.ts +0 -115
  289. package/dist/utils/network.d.ts.map +0 -1
  290. package/dist/utils/network.js.map +0 -1
  291. package/dist/utils/spawn.d.ts +0 -35
  292. package/dist/utils/spawn.d.ts.map +0 -1
  293. package/dist/utils/spawn.js.map +0 -1
  294. package/dist/utils/wait.d.ts +0 -54
  295. package/dist/utils/wait.d.ts.map +0 -1
  296. package/dist/utils/wait.js.map +0 -1
@@ -1,86 +1,17 @@
1
- /**
2
- * This file contains the CLI history page generator.
3
- *
4
- * @file cliHistory.ts
5
- * @author Luca Liguori
6
- * @created 2025-10-09
7
- * @version 1.0.1
8
- * @license Apache-2.0
9
- *
10
- * Copyright 2025, 2026, 2027 Luca Liguori.
11
- *
12
- * Licensed under the Apache License, Version 2.0 (the "License");
13
- * you may not use this file except in compliance with the License.
14
- * You may obtain a copy of the License at
15
- *
16
- * http://www.apache.org/licenses/LICENSE-2.0
17
- *
18
- * Unless required by applicable law or agreed to in writing, software
19
- * distributed under the License is distributed on an "AS IS" BASIS,
20
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21
- * See the License for the specific language governing permissions and
22
- * limitations under the License.
23
- */
24
- // eslint-disable-next-line no-console
25
1
  if (process.argv.includes('--loader') || process.argv.includes('-loader'))
26
2
  console.log('\u001B[32mCli history loaded.\u001B[40;0m');
27
3
  import { writeFileSync } from 'node:fs';
28
4
  import path from 'node:path';
29
5
  import os from 'node:os';
30
- // History for 8h at 1 sample each 10 seconds = 2880 entries
31
- export const historySize = 2880;
32
- export let historyIndex = 0;
33
- /**
34
- * Sets the history index.
35
- *
36
- * @param {number} index - The new history index.
37
- */
38
- export function setHistoryIndex(index) {
39
- if (!Number.isFinite(index) || !Number.isSafeInteger(index)) {
40
- throw new TypeError('historyIndex must be a finite, safe integer.');
41
- }
42
- if (index < 0 || index >= historySize) {
43
- throw new RangeError(`historyIndex must be between 0 and ${historySize - 1}.`);
44
- }
45
- historyIndex = index;
46
- }
47
- export const history = Array.from({ length: historySize }, () => ({
48
- timestamp: 0,
49
- cpu: 0,
50
- peakCpu: 0,
51
- processCpu: 0,
52
- peakProcessCpu: 0,
53
- rss: 0,
54
- peakRss: 0,
55
- heapUsed: 0,
56
- peakHeapUsed: 0,
57
- heapTotal: 0,
58
- peakHeapTotal: 0,
59
- external: 0,
60
- peakExternal: 0,
61
- arrayBuffers: 0,
62
- peakArrayBuffers: 0,
63
- }));
64
- /**
65
- * Generates a static HTML dashboard displaying CPU and memory history.
66
- *
67
- * @param {GenerateHistoryPageOptions} [options] - Optional configuration for output path, page title, and refresh interval.
68
- *
69
- * @returns {string | undefined} The absolute path to the generated HTML file, or undefined if no samples exist.
70
- */
6
+ import { Tracker } from './utils/tracker.js';
71
7
  export function generateHistoryPage(options = {}) {
72
8
  const pageTitle = options.pageTitle ?? 'Matterbridge CPU & Memory History';
73
9
  const hostname = options.hostname ?? os.hostname();
74
10
  const outputPath = path.resolve(options.outputPath ?? path.join(process.cwd(), 'history.html'));
75
- const bufferLength = history.length;
76
- if (bufferLength === 0) {
77
- return undefined;
78
- }
79
- const startIndex = ((Math.trunc(historyIndex) % bufferLength) + bufferLength) % bufferLength;
80
11
  const normalizedHistory = [];
81
- for (let offset = 0; offset < bufferLength; offset += 1) {
82
- const index = (startIndex + offset) % bufferLength;
83
- const entry = history[index];
12
+ for (let offset = 0; offset < Tracker.historySize; offset += 1) {
13
+ const index = (Tracker.historyIndex + offset) % Tracker.historySize;
14
+ const entry = Tracker.history[index];
84
15
  if (!entry || entry.timestamp === 0)
85
16
  continue;
86
17
  normalizedHistory.push(entry);
@@ -88,7 +19,7 @@ export function generateHistoryPage(options = {}) {
88
19
  if (normalizedHistory.length === 0) {
89
20
  return undefined;
90
21
  }
91
- const peakCpu = Math.max(...normalizedHistory.map((entry) => entry.peakCpu ?? entry.cpu));
22
+ const peakOsCpu = Math.max(...normalizedHistory.map((entry) => entry.peakOsCpu ?? entry.osCpu));
92
23
  const peakProcessCpu = Math.max(...normalizedHistory.map((entry) => entry.peakProcessCpu ?? entry.processCpu));
93
24
  const peakRss = Math.max(...normalizedHistory.map((entry) => entry.peakRss ?? entry.rss));
94
25
  const peakHeapUsed = Math.max(...normalizedHistory.map((entry) => entry.peakHeapUsed ?? entry.heapUsed));
@@ -100,7 +31,7 @@ export function generateHistoryPage(options = {}) {
100
31
  const summary = {
101
32
  entries: normalizedHistory.length,
102
33
  timeRange: `${new Date(firstTimestamp).toLocaleString()} → ${new Date(lastTimestamp).toLocaleString()}`,
103
- peakCpu,
34
+ peakOsCpu,
104
35
  peakProcessCpu,
105
36
  peakRss,
106
37
  peakHeapUsed,
@@ -332,7 +263,7 @@ export function generateHistoryPage(options = {}) {
332
263
  const summaryEntries = [
333
264
  { label: 'Samples', value: SUMMARY_DATA.entries.toLocaleString() },
334
265
  { label: 'Time Range', value: SUMMARY_DATA.timeRange },
335
- { label: 'Host CPU Peak', value: SUMMARY_DATA.peakCpu.toFixed(2) + ' %' },
266
+ { label: 'Host CPU Peak', value: SUMMARY_DATA.peakOsCpu.toFixed(2) + ' %' },
336
267
  { label: 'Process CPU Peak', value: SUMMARY_DATA.peakProcessCpu.toFixed(2) + ' %' },
337
268
  { label: 'RSS Peak', value: formatBytes(SUMMARY_DATA.peakRss) },
338
269
  { label: 'Heap Used Peak', value: formatBytes(SUMMARY_DATA.peakHeapUsed) },
@@ -353,8 +284,8 @@ export function generateHistoryPage(options = {}) {
353
284
  const row = document.createElement('tr');
354
285
  const cells = [
355
286
  new Date(entry.timestamp).toLocaleString(),
356
- entry.cpu.toFixed(2),
357
- entry.peakCpu.toFixed(2),
287
+ entry.osCpu.toFixed(2),
288
+ entry.peakOsCpu.toFixed(2),
358
289
  (Number.isFinite(entry.processCpu) ? entry.processCpu : 0).toFixed(2),
359
290
  (
360
291
  Number.isFinite(entry.peakProcessCpu)
@@ -379,16 +310,12 @@ export function generateHistoryPage(options = {}) {
379
310
  });
380
311
 
381
312
  const cpuPeakValue = HISTORY_DATA.reduce(function (acc, entry) {
382
- return Math.max(acc, Number.isFinite(entry.peakCpu) ? entry.peakCpu : 0, Number.isFinite(entry.cpu) ? entry.cpu : 0);
313
+ return Math.max(acc, Number.isFinite(entry.peakOsCpu) ? entry.peakOsCpu : 0, Number.isFinite(entry.osCpu) ? entry.osCpu : 0);
383
314
  }, 0);
384
315
  const cpuMaxYAxis = cpuPeakValue > 0 ? cpuPeakValue * 1.05 : undefined;
385
316
 
386
317
  const processCpuPeakValue = HISTORY_DATA.reduce(function (acc, entry) {
387
- return Math.max(
388
- acc,
389
- Number.isFinite(entry.peakProcessCpu) ? entry.peakProcessCpu : 0,
390
- Number.isFinite(entry.processCpu) ? entry.processCpu : 0
391
- );
318
+ return Math.max(acc, Number.isFinite(entry.peakProcessCpu) ? entry.peakProcessCpu : 0, Number.isFinite(entry.processCpu) ? entry.processCpu : 0);
392
319
  }, 0);
393
320
  const processCpuMaxYAxis = processCpuPeakValue > 0 ? processCpuPeakValue * 1.05 : undefined;
394
321
  const useProcessCpuDecimals = (processCpuMaxYAxis ?? 0) <= 3;
@@ -455,14 +382,14 @@ export function generateHistoryPage(options = {}) {
455
382
  {
456
383
  label: 'Host CPU %',
457
384
  values: HISTORY_DATA.map(function (entry) {
458
- return Number.isFinite(entry.cpu) ? Number(entry.cpu.toFixed(2)) : 0;
385
+ return Number.isFinite(entry.osCpu) ? Number(entry.osCpu.toFixed(2)) : 0;
459
386
  }),
460
387
  color: '#38bdf8',
461
388
  fill: 'rgba(56, 189, 248, 0.18)',
462
389
  markPeaks: true,
463
390
  markerPeakValues: HISTORY_DATA.map(function (entry) {
464
- if (Number.isFinite(entry.peakCpu)) return entry.peakCpu;
465
- if (Number.isFinite(entry.cpu)) return entry.cpu;
391
+ if (Number.isFinite(entry.peakOsCpu)) return entry.peakOsCpu;
392
+ if (Number.isFinite(entry.osCpu)) return entry.osCpu;
466
393
  return Number.NEGATIVE_INFINITY;
467
394
  }),
468
395
  markerRadius: 2.5
@@ -470,7 +397,7 @@ export function generateHistoryPage(options = {}) {
470
397
  {
471
398
  label: 'Host Peak CPU %',
472
399
  values: HISTORY_DATA.map(function (entry) {
473
- return Number.isFinite(entry.peakCpu) ? Number(entry.peakCpu.toFixed(2)) : 0;
400
+ return Number.isFinite(entry.peakOsCpu) ? Number(entry.peakOsCpu.toFixed(2)) : 0;
474
401
  }),
475
402
  color: '#facc15',
476
403
  dashed: [6, 4]
@@ -856,13 +783,6 @@ export function generateHistoryPage(options = {}) {
856
783
  writeFileSync(outputPath, html, { encoding: 'utf-8' });
857
784
  return outputPath;
858
785
  }
859
- /**
860
- * Escapes HTML special characters to prevent breaking embedded markup.
861
- *
862
- * @param {string} input - The string to escape.
863
- * @returns {string} The escaped string safe for HTML contexts.
864
- */
865
786
  function escapeHtml(input) {
866
787
  return input.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/"/g, '&quot;').replace(/'/g, '&#39;');
867
788
  }
868
- //# sourceMappingURL=cliHistory.js.map
@@ -1,3 +1 @@
1
1
  export {};
2
- // Nothing to export right now, but this file is here to make it easier to add exports in the future
3
- //# sourceMappingURL=export.js.map
@@ -1,26 +1,3 @@
1
- /**
2
- * This file contains the default config for the plugins.
3
- *
4
- * @file defaultConfigSchema.ts
5
- * @author Luca Liguori
6
- * @created 2024-05-07
7
- * @version 1.0.1
8
- * @license Apache-2.0
9
- *
10
- * Copyright 2024, 2025, 2026 Luca Liguori.
11
- *
12
- * Licensed under the Apache License, Version 2.0 (the "License");
13
- * you may not use this file except in compliance with the License.
14
- * You may obtain a copy of the License at
15
- *
16
- * http://www.apache.org/licenses/LICENSE-2.0
17
- *
18
- * Unless required by applicable law or agreed to in writing, software
19
- * distributed under the License is distributed on an "AS IS" BASIS,
20
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21
- * See the License for the specific language governing permissions and
22
- * limitations under the License.
23
- */
24
1
  export const zigbee2mqtt_config = {
25
2
  name: 'matterbridge-zigbee2mqtt',
26
3
  type: 'DynamicPlatform',
@@ -82,4 +59,3 @@ export const shelly_config = {
82
59
  debugWs: false,
83
60
  unregisterOnShutdown: false,
84
61
  };
85
- //# sourceMappingURL=defaultConfigSchema.js.map
@@ -1,43 +1,13 @@
1
- /**
2
- * This file contains the DeviceManager class.
3
- *
4
- * @file devices.ts
5
- * @author Luca Liguori
6
- * @created 2024-07-26
7
- * @version 1.0.11
8
- * @license Apache-2.0
9
- *
10
- * Copyright 2024, 2025, 2026 Luca Liguori.
11
- *
12
- * Licensed under the Apache License, Version 2.0 (the "License");
13
- * you may not use this file except in compliance with the License.
14
- * You may obtain a copy of the License at
15
- *
16
- * http://www.apache.org/licenses/LICENSE-2.0
17
- *
18
- * Unless required by applicable law or agreed to in writing, software
19
- * distributed under the License is distributed on an "AS IS" BASIS,
20
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21
- * See the License for the specific language governing permissions and
22
- * limitations under the License.
23
- */
24
- // AnsiLogger module
25
1
  import { AnsiLogger, BLUE, CYAN, db, debugStringify, er, wr } from 'node-ansi-logger';
26
2
  import { dev } from './matterbridgeTypes.js';
27
3
  import { BroadcastServer } from './broadcastServer.js';
28
4
  import { hasParameter } from './utils/commandLine.js';
29
- /**
30
- * Manages Matterbridge devices.
31
- */
32
5
  export class DeviceManager {
33
6
  _devices = new Map();
34
7
  log;
35
8
  server;
36
- /**
37
- * Creates an instance of DeviceManager.
38
- */
39
9
  constructor() {
40
- this.log = new AnsiLogger({ logName: 'DeviceManager', logTimestampFormat: 4 /* TimestampFormat.TIME_MILLIS */, logLevel: hasParameter('debug') ? "debug" /* LogLevel.DEBUG */ : "info" /* LogLevel.INFO */ });
10
+ this.log = new AnsiLogger({ logName: 'DeviceManager', logTimestampFormat: 4, logLevel: hasParameter('debug') ? "debug" : "info" });
41
11
  this.log.debug('Matterbridge device manager starting...');
42
12
  this.server = new BroadcastServer('devices', this.log);
43
13
  this.server.on('broadcast_message', this.msgHandler.bind(this));
@@ -77,47 +47,18 @@ export class DeviceManager {
77
47
  }
78
48
  }
79
49
  }
80
- /**
81
- * Gets the number of devices.
82
- *
83
- * @returns {number} The number of devices.
84
- */
85
50
  get length() {
86
51
  return this._devices.size;
87
52
  }
88
- /**
89
- * Gets the number of devices.
90
- *
91
- * @returns {number} The number of devices.
92
- */
93
53
  get size() {
94
54
  return this._devices.size;
95
55
  }
96
- /**
97
- * Checks if a device with the specified unique ID exists.
98
- *
99
- * @param {string} uniqueId - The unique ID of the device.
100
- * @returns {boolean} True if the device exists, false otherwise.
101
- */
102
56
  has(uniqueId) {
103
57
  return this._devices.has(uniqueId);
104
58
  }
105
- /**
106
- * Gets a device by its unique ID.
107
- *
108
- * @param {string} uniqueId - The unique ID of the device.
109
- * @returns {MatterbridgeEndpoint | undefined} The device, or undefined if not found.
110
- */
111
59
  get(uniqueId) {
112
60
  return this._devices.get(uniqueId);
113
61
  }
114
- /**
115
- * Adds a device to the manager.
116
- *
117
- * @param {MatterbridgeEndpoint} device - The device to add.
118
- * @returns {MatterbridgeEndpoint} The added device.
119
- * @throws {Error} If the device does not have a unique ID.
120
- */
121
62
  set(device) {
122
63
  if (!device.uniqueId)
123
64
  throw new Error(`The device ${dev}${device.deviceName}${er} has not been initialized: uniqueId is required`);
@@ -126,13 +67,6 @@ export class DeviceManager {
126
67
  this._devices.set(device.uniqueId, device);
127
68
  return device;
128
69
  }
129
- /**
130
- * Removes a device from the manager.
131
- *
132
- * @param {MatterbridgeEndpoint} device - The device to remove.
133
- * @returns {boolean} True if the device was removed, false otherwise.
134
- * @throws {Error} If the device does not have a unique ID.
135
- */
136
70
  remove(device) {
137
71
  if (!device.uniqueId)
138
72
  throw new Error(`The device ${dev}${device.deviceName}${er} has not been initialized: uniqueId is required`);
@@ -140,66 +74,15 @@ export class DeviceManager {
140
74
  this.log.error(`The device ${dev}${device.deviceName}${er} with uniqueId ${BLUE}${device.uniqueId}${er} serialNumber ${BLUE}${device.serialNumber}${er} is not registered in the device manager`);
141
75
  return this._devices.delete(device.uniqueId);
142
76
  }
143
- /**
144
- * Clears all devices from the manager.
145
- */
146
77
  clear() {
147
78
  this._devices.clear();
148
79
  }
149
- /**
150
- * Gets an array of all devices.
151
- *
152
- * @returns {MatterbridgeEndpoint[]} An array of all devices.
153
- */
154
80
  array() {
155
81
  return Array.from(this._devices.values());
156
82
  }
157
- /**
158
- * Gets an array of all devices suitable for serialization.
159
- *
160
- * @param {string} [pluginName] - Optional plugin name to filter devices (not used currently).
161
- * @returns {ApiDevices[]} An array of all devices.
162
- */
163
- /*
164
- baseArray(pluginName?: string): ApiDevices[] {
165
- const devices: ApiDevices[] = [];
166
- for (const device of this.matterbridge.devices.array()) {
167
- // Filter by pluginName if provided
168
- if (pluginName && pluginName !== device.plugin) continue;
169
- // Check if the device has the required properties
170
- if (!device.plugin || !device.deviceType || !device.name || !device.deviceName || !device.serialNumber || !device.uniqueId || !device.lifecycle.isReady) continue;
171
- devices.push({
172
- pluginName: device.plugin,
173
- type: device.name + ' (0x' + device.deviceType.toString(16).padStart(4, '0') + ')',
174
- endpoint: device.number,
175
- name: device.deviceName,
176
- serial: device.serialNumber,
177
- productUrl: device.productUrl,
178
- configUrl: device.configUrl,
179
- uniqueId: device.uniqueId,
180
- reachable: this.getReachability(device),
181
- powerSource: this.getPowerSource(device),
182
- matter: device.mode === 'server' && device.serverNode ? this.matterbridge.getServerNodeData(device.serverNode) : undefined,
183
- cluster: this.getClusterTextFromDevice(device),
184
- });
185
- }
186
- return devices;
187
- }
188
- */
189
- /**
190
- * Iterates over all devices.
191
- *
192
- * @returns {IterableIterator<MatterbridgeEndpoint>} An iterator for the devices.
193
- */
194
83
  [Symbol.iterator]() {
195
84
  return this._devices.values();
196
85
  }
197
- /**
198
- * Asynchronously iterates over each device and calls the provided callback function.
199
- *
200
- * @param {(device: MatterbridgeEndpoint) => Promise<void>} callback - The callback function to call with each device.
201
- * @returns {Promise<void>} A promise that resolves when all callbacks have been called.
202
- */
203
86
  async forEach(callback) {
204
87
  if (this.size === 0)
205
88
  return;
@@ -213,13 +96,7 @@ export class DeviceManager {
213
96
  });
214
97
  await Promise.all(tasks);
215
98
  }
216
- /**
217
- * Sets the log level.
218
- *
219
- * @param {LogLevel} logLevel - The log level to set.
220
- */
221
99
  set logLevel(logLevel) {
222
100
  this.log.logLevel = logLevel;
223
101
  }
224
102
  }
225
- //# sourceMappingURL=deviceManager.js.map
@@ -1,64 +1,8 @@
1
- /**
2
- * @description This file contains the AirConditioner class.
3
- * @file src/devices/airConditioner.ts
4
- * @author Luca Liguori
5
- * @created 2025-09-04
6
- * @version 1.0.0
7
- * @license Apache-2.0
8
- *
9
- * Copyright 2025, 2026, 2027 Luca Liguori.
10
- *
11
- * Licensed under the Apache License, Version 2.0 (the "License");
12
- * you may not use this file except in compliance with the License.
13
- * You may obtain a copy of the License at
14
- *
15
- * http://www.apache.org/licenses/LICENSE-2.0
16
- *
17
- * Unless required by applicable law or agreed to in writing, software
18
- * distributed under the License is distributed on an "AS IS" BASIS,
19
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20
- * See the License for the specific language governing permissions and
21
- * limitations under the License.
22
- */
23
- // Imports from @matter
24
1
  import { ThermostatUserInterfaceConfiguration } from '@matter/main/clusters/thermostat-user-interface-configuration';
25
- // Matterbridge
26
2
  import { FanControl } from '@matter/main/clusters/fan-control';
27
3
  import { airConditioner, powerSource } from '../matterbridgeDeviceTypes.js';
28
4
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
29
5
  export class AirConditioner extends MatterbridgeEndpoint {
30
- /**
31
- * Creates an instance of the AirConditioner class.
32
- *
33
- * A Room Air Conditioner is a device which at a minimum is capable of being turned on and off and of controlling the temperature in the living space.
34
- * A Room Air Conditioner MAY also support additional capabilities via endpoint composition.
35
- * The DF (Dead Front) feature is required for the On/Off cluster in this device type.
36
- *
37
- * @param {string} name - The name of the air conditioner.
38
- * @param {string} serial - The serial number of the air conditioner.
39
- * @param {AirConditionerOptions} [options] - Optional configuration values. Missing fields use defaults.
40
- *
41
- * Options defaults:
42
- * - localTemperature: 23
43
- * - occupiedHeatingSetpoint: 21
44
- * - occupiedCoolingSetpoint: 25
45
- * - minSetpointDeadBand: 1
46
- * - minHeatSetpointLimit: 0
47
- * - maxHeatSetpointLimit: 50
48
- * - minCoolSetpointLimit: 0
49
- * - maxCoolSetpointLimit: 50
50
- * - temperatureDisplayMode: Celsius
51
- * - keypadLockout: NoLockout
52
- * - scheduleProgrammingVisibility: ScheduleProgrammingPermitted
53
- * - fanMode: Off
54
- * - fanModeSequence: OffLowMedHighAuto
55
- * - percentSetting: 0
56
- * - percentCurrent: 0
57
- *
58
- * @returns {AirConditioner} The AirConditioner instance.
59
- *
60
- * @remarks Not supported by Google Home.
61
- */
62
6
  constructor(name, serial, options = {}) {
63
7
  const { localTemperature = 23, occupiedHeatingSetpoint = 21, occupiedCoolingSetpoint = 25, minSetpointDeadBand = 1, minHeatSetpointLimit = 0, maxHeatSetpointLimit = 50, minCoolSetpointLimit = 0, maxCoolSetpointLimit = 50, temperatureDisplayMode = ThermostatUserInterfaceConfiguration.TemperatureDisplayMode.Celsius, keypadLockout = ThermostatUserInterfaceConfiguration.KeypadLockout.NoLockout, scheduleProgrammingVisibility = ThermostatUserInterfaceConfiguration.ScheduleProgrammingVisibility.ScheduleProgrammingPermitted, fanMode = FanControl.FanMode.Off, fanModeSequence = FanControl.FanModeSequence.OffLowMedHighAuto, percentSetting = 0, percentCurrent = 0, } = options;
64
8
  super([airConditioner, powerSource], { uniqueStorageKey: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` }, true);
@@ -71,4 +15,3 @@ export class AirConditioner extends MatterbridgeEndpoint {
71
15
  this.createDefaultFanControlClusterServer(fanMode, fanModeSequence, percentSetting, percentCurrent);
72
16
  }
73
17
  }
74
- //# sourceMappingURL=airConditioner.js.map
@@ -1,53 +1,9 @@
1
- /**
2
- * @description This file contains the BatteryStorage class.
3
- * @file src/devices/batteryStorage.ts
4
- * @author Luca Liguori
5
- * @contributor Ludovic BOUÉ
6
- * @created 2025-06-20
7
- * @version 1.0.0
8
- * @license Apache-2.0
9
- *
10
- * Copyright 2025, 2026, 2027 Luca Liguori.
11
- *
12
- * Licensed under the Apache License, Version 2.0 (the "License");
13
- * you may not use this file except in compliance with the License.
14
- * You may obtain a copy of the License at
15
- *
16
- * http://www.apache.org/licenses/LICENSE-2.0
17
- *
18
- * Unless required by applicable law or agreed to in writing, software
19
- * distributed under the License is distributed on an "AS IS" BASIS,
20
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21
- * See the License for the specific language governing permissions and
22
- * limitations under the License.
23
- */
24
- // @matter
25
1
  import { PowerSourceTag } from '@matter/main';
26
2
  import { DeviceEnergyManagement } from '@matter/main/clusters/device-energy-management';
27
3
  import { PowerSource } from '@matter/main/clusters/power-source';
28
- // Matterbridge
29
4
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
30
5
  import { deviceEnergyManagement, electricalSensor, batteryStorage, powerSource } from '../matterbridgeDeviceTypes.js';
31
6
  export class BatteryStorage extends MatterbridgeEndpoint {
32
- /**
33
- * Creates an instance of the BatteryStorage class.
34
- *
35
- * @param {string} name - The name of the BatteryStorage.
36
- * @param {string} serial - The serial number of the BatteryStorage.
37
- * @param {number} [batPercentRemaining] - The percentage of battery remaining, defaults to `100` if not provided.
38
- * @param {PowerSource.BatChargeLevel} [batChargeLevel] - The battery charge level (default: PowerSource.BatChargeLevel.Ok).
39
- * @param {number} voltage - The voltage value in millivolts.
40
- * @param {number} current - The current value in milliamperes.
41
- * @param {number} power - The power value in milliwatts.
42
- * @param {number} energyImported - The total production value in mW/h.
43
- * @param {number} energyExported - The total production value in mW/h.
44
- * @param {number} [absMinPower] - Indicate the minimum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
45
- * @param {number} [absMaxPower] - Indicate the maximum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
46
- *
47
- * @remarks
48
- * - A battery storage inverter that can charge its battery at a maximum power of 2000W and can
49
- * discharge the battery at a maximum power of 3000W, would have a absMinPower: -3000W, absMaxPower: 2000W.
50
- */
51
7
  constructor(name, serial, batPercentRemaining = 100, batChargeLevel = PowerSource.BatChargeLevel.Ok, voltage = null, current = null, power = null, energyImported = null, energyExported = null, absMinPower = 0, absMaxPower = 0) {
52
8
  super([batteryStorage, electricalSensor, deviceEnergyManagement], { id: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` }, true);
53
9
  this.createDefaultIdentifyClusterServer()
@@ -58,12 +14,10 @@ export class BatteryStorage extends MatterbridgeEndpoint {
58
14
  .createDefaultDeviceEnergyManagementClusterServer(DeviceEnergyManagement.EsaType.BatteryStorage, true, DeviceEnergyManagement.EsaState.Online, absMinPower, absMaxPower)
59
15
  .createDefaultDeviceEnergyManagementModeClusterServer()
60
16
  .addRequiredClusterServers();
61
- // Add separate PowerSource child devices cause in matter.js the PowerSource cluster is not supported with both features Wired and Battery.
62
- // Probably this is also an error in the specification...
63
17
  this.addChildDeviceType('BatteryPowerSource', powerSource, {
64
18
  tagList: [{ mfgCode: null, namespaceId: PowerSourceTag.Battery.namespaceId, tag: PowerSourceTag.Battery.tag, label: null }],
65
19
  })
66
- .createDefaultPowerSourceRechargeableBatteryClusterServer(batPercentRemaining, batChargeLevel, 24_000) // Battery voltage in mV (24V).
20
+ .createDefaultPowerSourceRechargeableBatteryClusterServer(batPercentRemaining, batChargeLevel, 24_000)
67
21
  .addRequiredClusterServers();
68
22
  this.addChildDeviceType('GridPowerSource', powerSource, {
69
23
  tagList: [{ mfgCode: null, namespaceId: PowerSourceTag.Grid.namespaceId, tag: PowerSourceTag.Grid.tag, label: null }],
@@ -72,4 +26,3 @@ export class BatteryStorage extends MatterbridgeEndpoint {
72
26
  .addRequiredClusterServers();
73
27
  }
74
28
  }
75
- //# sourceMappingURL=batteryStorage.js.map
@@ -1,45 +1,7 @@
1
- /**
2
- * @description This file contains the Cooktop class.
3
- * @file src/devices/cooktop.ts
4
- * @author Luca Liguori
5
- * @created 2025-05-25
6
- * @version 1.1.0
7
- * @license Apache-2.0
8
- *
9
- * Copyright 2025, 2026, 2027 Luca Liguori.
10
- *
11
- * Licensed under the Apache License, Version 2.0 (the "License");
12
- * you may not use this file except in compliance with the License.
13
- * You may obtain a copy of the License at
14
- *
15
- * http://www.apache.org/licenses/LICENSE-2.0
16
- *
17
- * Unless required by applicable law or agreed to in writing, software
18
- * distributed under the License is distributed on an "AS IS" BASIS,
19
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20
- * See the License for the specific language governing permissions and
21
- * limitations under the License.
22
- */
23
- // Matterbridge
24
1
  import { cookSurface, cooktop, powerSource } from '../matterbridgeDeviceTypes.js';
25
2
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
26
3
  import { createLevelTemperatureControlClusterServer } from './temperatureControl.js';
27
4
  export class Cooktop extends MatterbridgeEndpoint {
28
- /**
29
- * Creates an instance of the Cooktop class.
30
- *
31
- * @param {string} name - The name of the cooktop.
32
- * @param {string} serial - The serial number of the cooktop.
33
- *
34
- * @remarks
35
- * 13.8 A cooktop is a cooking surface that heats food either by transferring currents from an electromagnetic
36
- * field located below the glass surface directly to the magnetic induction cookware placed
37
- * above or through traditional gas or electric burners.
38
- *
39
- * 13.8.4 A Cooktop SHALL be composed of zero or more endpoints with the Cook Surface device type.
40
- * An Cooktop is always defined via endpoint composition.
41
- * - Use `addSurface` to add one or more surfaces to the cooktop.
42
- */
43
5
  constructor(name, serial) {
44
6
  super([cooktop, powerSource], { uniqueStorageKey: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` }, true);
45
7
  this.createDefaultIdentifyClusterServer();
@@ -48,22 +10,6 @@ export class Cooktop extends MatterbridgeEndpoint {
48
10
  this.createOffOnlyOnOffClusterServer(true);
49
11
  this.addFixedLabel('composed', 'Cooktop');
50
12
  }
51
- /**
52
- * Adds a surface to the cooktop.
53
- *
54
- * @param {string} name - The name of the surface.
55
- * @param {Semtag[]} tagList - The tagList associated with the surface.
56
- * @param {number} selectedTemperatureLevel - The selected temperature level as an index of the supportedTemperatureLevels array. Defaults to 2 (which corresponds to 'Level 3').
57
- * @param {string[]} supportedTemperatureLevels - The list of supported temperature levels for the surface. Defaults to ['Level 1', 'Level 2', 'Level 3', 'Level 4', 'Level 5'].
58
- *
59
- * @returns {MatterbridgeEndpoint} The MatterbridgeEndpoint instance representing the surface.
60
- *
61
- * @remarks
62
- * 13.7 A Cook Surface device type represents a heating object on a cooktop or other similar device. It
63
- * SHALL only be used when composed as part of another device type.
64
- *
65
- * The OnOff cluster is off only mandatory for all Cook Surface devices!
66
- */
67
13
  addSurface(name, tagList, selectedTemperatureLevel = 2, supportedTemperatureLevels = ['Level 1', 'Level 2', 'Level 3', 'Level 4', 'Level 5']) {
68
14
  const surface = this.addChildDeviceType(name, cookSurface, { tagList }, true);
69
15
  surface.log.logName = name;
@@ -73,4 +19,3 @@ export class Cooktop extends MatterbridgeEndpoint {
73
19
  return surface;
74
20
  }
75
21
  }
76
- //# sourceMappingURL=cooktop.js.map