matterbridge 3.5.0 → 3.5.1-dev-20260122-6461be3

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 (330) hide show
  1. package/CHANGELOG.md +18 -0
  2. package/README-DOCKER.md +4 -2
  3. package/README.md +4 -1
  4. package/bin/mb_coap.js +1 -1
  5. package/bin/mb_mdns.js +1 -1
  6. package/dist/broadcastServer.d.ts +0 -115
  7. package/dist/broadcastServer.js +1 -119
  8. package/dist/broadcastServerTypes.d.ts +0 -43
  9. package/dist/broadcastServerTypes.js +0 -24
  10. package/dist/cli.d.ts +1 -26
  11. package/dist/cli.js +2 -102
  12. package/dist/cliEmitter.d.ts +0 -36
  13. package/dist/cliEmitter.js +0 -37
  14. package/dist/cliHistory.d.ts +0 -42
  15. package/dist/cliHistory.js +1 -39
  16. package/dist/clusters/export.d.ts +0 -1
  17. package/dist/clusters/export.js +0 -2
  18. package/dist/deviceManager.d.ts +0 -108
  19. package/dist/deviceManager.js +2 -114
  20. package/dist/devices/airConditioner.d.ts +0 -75
  21. package/dist/devices/airConditioner.js +0 -57
  22. package/dist/devices/batteryStorage.d.ts +0 -43
  23. package/dist/devices/batteryStorage.js +1 -48
  24. package/dist/devices/cooktop.d.ts +0 -55
  25. package/dist/devices/cooktop.js +0 -56
  26. package/dist/devices/dishwasher.d.ts +0 -55
  27. package/dist/devices/dishwasher.js +0 -57
  28. package/dist/devices/evse.d.ts +0 -57
  29. package/dist/devices/evse.js +10 -74
  30. package/dist/devices/export.d.ts +0 -1
  31. package/dist/devices/export.js +0 -5
  32. package/dist/devices/extractorHood.d.ts +0 -41
  33. package/dist/devices/extractorHood.js +0 -43
  34. package/dist/devices/heatPump.d.ts +0 -43
  35. package/dist/devices/heatPump.js +2 -50
  36. package/dist/devices/laundryDryer.d.ts +0 -58
  37. package/dist/devices/laundryDryer.js +3 -62
  38. package/dist/devices/laundryWasher.d.ts +0 -64
  39. package/dist/devices/laundryWasher.js +4 -70
  40. package/dist/devices/microwaveOven.d.ts +1 -77
  41. package/dist/devices/microwaveOven.js +5 -88
  42. package/dist/devices/oven.d.ts +0 -82
  43. package/dist/devices/oven.js +0 -85
  44. package/dist/devices/refrigerator.d.ts +0 -100
  45. package/dist/devices/refrigerator.js +0 -102
  46. package/dist/devices/roboticVacuumCleaner.d.ts +0 -83
  47. package/dist/devices/roboticVacuumCleaner.js +9 -100
  48. package/dist/devices/solarPower.d.ts +0 -36
  49. package/dist/devices/solarPower.js +0 -38
  50. package/dist/devices/speaker.d.ts +0 -79
  51. package/dist/devices/speaker.js +0 -84
  52. package/dist/devices/temperatureControl.d.ts +0 -21
  53. package/dist/devices/temperatureControl.js +3 -24
  54. package/dist/devices/waterHeater.d.ts +0 -74
  55. package/dist/devices/waterHeater.js +2 -82
  56. package/dist/frontend.d.ts +4 -187
  57. package/dist/frontend.js +89 -505
  58. package/dist/frontendTypes.d.ts +0 -57
  59. package/dist/frontendTypes.js +0 -45
  60. package/dist/helpers.d.ts +0 -43
  61. package/dist/helpers.js +1 -54
  62. package/dist/index.d.ts +0 -23
  63. package/dist/index.js +0 -25
  64. package/dist/jestutils/export.d.ts +0 -1
  65. package/dist/jestutils/export.js +0 -1
  66. package/dist/jestutils/jestHelpers.d.ts +0 -255
  67. package/dist/jestutils/jestHelpers.js +16 -379
  68. package/dist/logger/export.d.ts +0 -1
  69. package/dist/logger/export.js +0 -1
  70. package/dist/matter/behaviors.d.ts +0 -1
  71. package/dist/matter/behaviors.js +0 -2
  72. package/dist/matter/clusters.d.ts +0 -1
  73. package/dist/matter/clusters.js +0 -2
  74. package/dist/matter/devices.d.ts +0 -1
  75. package/dist/matter/devices.js +0 -2
  76. package/dist/matter/endpoints.d.ts +0 -1
  77. package/dist/matter/endpoints.js +0 -2
  78. package/dist/matter/export.d.ts +0 -1
  79. package/dist/matter/export.js +0 -2
  80. package/dist/matter/types.d.ts +0 -1
  81. package/dist/matter/types.js +0 -2
  82. package/dist/matterNode.d.ts +0 -258
  83. package/dist/matterNode.js +9 -364
  84. package/dist/matterbridge.d.ts +0 -362
  85. package/dist/matterbridge.js +75 -864
  86. package/dist/matterbridgeAccessoryPlatform.d.ts +0 -36
  87. package/dist/matterbridgeAccessoryPlatform.js +0 -38
  88. package/dist/matterbridgeBehaviors.d.ts +0 -24
  89. package/dist/matterbridgeBehaviors.js +5 -68
  90. package/dist/matterbridgeDeviceTypes.d.ts +0 -649
  91. package/dist/matterbridgeDeviceTypes.js +6 -673
  92. package/dist/matterbridgeDynamicPlatform.d.ts +0 -36
  93. package/dist/matterbridgeDynamicPlatform.js +0 -38
  94. package/dist/matterbridgeEndpoint.d.ts +2 -1332
  95. package/dist/matterbridgeEndpoint.js +94 -1459
  96. package/dist/matterbridgeEndpointHelpers.d.ts +0 -425
  97. package/dist/matterbridgeEndpointHelpers.js +22 -487
  98. package/dist/matterbridgeEndpointTypes.d.ts +0 -70
  99. package/dist/matterbridgeEndpointTypes.js +0 -25
  100. package/dist/matterbridgePlatform.d.ts +0 -425
  101. package/dist/matterbridgePlatform.js +2 -453
  102. package/dist/matterbridgeTypes.d.ts +0 -46
  103. package/dist/matterbridgeTypes.js +0 -26
  104. package/dist/mb_coap.d.ts +1 -0
  105. package/dist/{dgram/mb_coap.js → mb_coap.js} +3 -41
  106. package/dist/mb_mdns.d.ts +1 -0
  107. package/dist/{dgram/mb_mdns.js → mb_mdns.js} +47 -81
  108. package/dist/pluginManager.d.ts +0 -305
  109. package/dist/pluginManager.js +8 -345
  110. package/dist/shelly.d.ts +0 -157
  111. package/dist/shelly.js +7 -178
  112. package/dist/spawn.d.ts +1 -0
  113. package/dist/{utils/spawn.js → spawn.js} +3 -73
  114. package/dist/storage/export.d.ts +0 -1
  115. package/dist/storage/export.js +0 -1
  116. package/dist/update.d.ts +0 -75
  117. package/dist/update.js +7 -100
  118. package/dist/utils/export.d.ts +1 -13
  119. package/dist/utils/export.js +1 -13
  120. package/dist/workerGlobalPrefix.d.ts +0 -24
  121. package/dist/workerGlobalPrefix.js +6 -40
  122. package/dist/workerTypes.d.ts +0 -25
  123. package/dist/workerTypes.js +0 -24
  124. package/dist/workers.d.ts +0 -61
  125. package/dist/workers.js +4 -68
  126. package/npm-shrinkwrap.json +80 -50
  127. package/package.json +8 -8
  128. package/dist/broadcastServer.d.ts.map +0 -1
  129. package/dist/broadcastServer.js.map +0 -1
  130. package/dist/broadcastServerTypes.d.ts.map +0 -1
  131. package/dist/broadcastServerTypes.js.map +0 -1
  132. package/dist/cli.d.ts.map +0 -1
  133. package/dist/cli.js.map +0 -1
  134. package/dist/cliEmitter.d.ts.map +0 -1
  135. package/dist/cliEmitter.js.map +0 -1
  136. package/dist/cliHistory.d.ts.map +0 -1
  137. package/dist/cliHistory.js.map +0 -1
  138. package/dist/clusters/export.d.ts.map +0 -1
  139. package/dist/clusters/export.js.map +0 -1
  140. package/dist/deviceManager.d.ts.map +0 -1
  141. package/dist/deviceManager.js.map +0 -1
  142. package/dist/devices/airConditioner.d.ts.map +0 -1
  143. package/dist/devices/airConditioner.js.map +0 -1
  144. package/dist/devices/batteryStorage.d.ts.map +0 -1
  145. package/dist/devices/batteryStorage.js.map +0 -1
  146. package/dist/devices/cooktop.d.ts.map +0 -1
  147. package/dist/devices/cooktop.js.map +0 -1
  148. package/dist/devices/dishwasher.d.ts.map +0 -1
  149. package/dist/devices/dishwasher.js.map +0 -1
  150. package/dist/devices/evse.d.ts.map +0 -1
  151. package/dist/devices/evse.js.map +0 -1
  152. package/dist/devices/export.d.ts.map +0 -1
  153. package/dist/devices/export.js.map +0 -1
  154. package/dist/devices/extractorHood.d.ts.map +0 -1
  155. package/dist/devices/extractorHood.js.map +0 -1
  156. package/dist/devices/heatPump.d.ts.map +0 -1
  157. package/dist/devices/heatPump.js.map +0 -1
  158. package/dist/devices/laundryDryer.d.ts.map +0 -1
  159. package/dist/devices/laundryDryer.js.map +0 -1
  160. package/dist/devices/laundryWasher.d.ts.map +0 -1
  161. package/dist/devices/laundryWasher.js.map +0 -1
  162. package/dist/devices/microwaveOven.d.ts.map +0 -1
  163. package/dist/devices/microwaveOven.js.map +0 -1
  164. package/dist/devices/oven.d.ts.map +0 -1
  165. package/dist/devices/oven.js.map +0 -1
  166. package/dist/devices/refrigerator.d.ts.map +0 -1
  167. package/dist/devices/refrigerator.js.map +0 -1
  168. package/dist/devices/roboticVacuumCleaner.d.ts.map +0 -1
  169. package/dist/devices/roboticVacuumCleaner.js.map +0 -1
  170. package/dist/devices/solarPower.d.ts.map +0 -1
  171. package/dist/devices/solarPower.js.map +0 -1
  172. package/dist/devices/speaker.d.ts.map +0 -1
  173. package/dist/devices/speaker.js.map +0 -1
  174. package/dist/devices/temperatureControl.d.ts.map +0 -1
  175. package/dist/devices/temperatureControl.js.map +0 -1
  176. package/dist/devices/waterHeater.d.ts.map +0 -1
  177. package/dist/devices/waterHeater.js.map +0 -1
  178. package/dist/dgram/coap.d.ts +0 -205
  179. package/dist/dgram/coap.d.ts.map +0 -1
  180. package/dist/dgram/coap.js +0 -365
  181. package/dist/dgram/coap.js.map +0 -1
  182. package/dist/dgram/dgram.d.ts +0 -144
  183. package/dist/dgram/dgram.d.ts.map +0 -1
  184. package/dist/dgram/dgram.js +0 -363
  185. package/dist/dgram/dgram.js.map +0 -1
  186. package/dist/dgram/mb_coap.d.ts +0 -24
  187. package/dist/dgram/mb_coap.d.ts.map +0 -1
  188. package/dist/dgram/mb_coap.js.map +0 -1
  189. package/dist/dgram/mb_mdns.d.ts +0 -24
  190. package/dist/dgram/mb_mdns.d.ts.map +0 -1
  191. package/dist/dgram/mb_mdns.js.map +0 -1
  192. package/dist/dgram/mdns.d.ts +0 -371
  193. package/dist/dgram/mdns.d.ts.map +0 -1
  194. package/dist/dgram/mdns.js +0 -934
  195. package/dist/dgram/mdns.js.map +0 -1
  196. package/dist/dgram/multicast.d.ts +0 -67
  197. package/dist/dgram/multicast.d.ts.map +0 -1
  198. package/dist/dgram/multicast.js +0 -179
  199. package/dist/dgram/multicast.js.map +0 -1
  200. package/dist/dgram/unicast.d.ts +0 -64
  201. package/dist/dgram/unicast.d.ts.map +0 -1
  202. package/dist/dgram/unicast.js +0 -100
  203. package/dist/dgram/unicast.js.map +0 -1
  204. package/dist/frontend.d.ts.map +0 -1
  205. package/dist/frontend.js.map +0 -1
  206. package/dist/frontendTypes.d.ts.map +0 -1
  207. package/dist/frontendTypes.js.map +0 -1
  208. package/dist/helpers.d.ts.map +0 -1
  209. package/dist/helpers.js.map +0 -1
  210. package/dist/index.d.ts.map +0 -1
  211. package/dist/index.js.map +0 -1
  212. package/dist/jestutils/export.d.ts.map +0 -1
  213. package/dist/jestutils/export.js.map +0 -1
  214. package/dist/jestutils/jestHelpers.d.ts.map +0 -1
  215. package/dist/jestutils/jestHelpers.js.map +0 -1
  216. package/dist/logger/export.d.ts.map +0 -1
  217. package/dist/logger/export.js.map +0 -1
  218. package/dist/matter/behaviors.d.ts.map +0 -1
  219. package/dist/matter/behaviors.js.map +0 -1
  220. package/dist/matter/clusters.d.ts.map +0 -1
  221. package/dist/matter/clusters.js.map +0 -1
  222. package/dist/matter/devices.d.ts.map +0 -1
  223. package/dist/matter/devices.js.map +0 -1
  224. package/dist/matter/endpoints.d.ts.map +0 -1
  225. package/dist/matter/endpoints.js.map +0 -1
  226. package/dist/matter/export.d.ts.map +0 -1
  227. package/dist/matter/export.js.map +0 -1
  228. package/dist/matter/types.d.ts.map +0 -1
  229. package/dist/matter/types.js.map +0 -1
  230. package/dist/matterNode.d.ts.map +0 -1
  231. package/dist/matterNode.js.map +0 -1
  232. package/dist/matterbridge.d.ts.map +0 -1
  233. package/dist/matterbridge.js.map +0 -1
  234. package/dist/matterbridgeAccessoryPlatform.d.ts.map +0 -1
  235. package/dist/matterbridgeAccessoryPlatform.js.map +0 -1
  236. package/dist/matterbridgeBehaviors.d.ts.map +0 -1
  237. package/dist/matterbridgeBehaviors.js.map +0 -1
  238. package/dist/matterbridgeDeviceTypes.d.ts.map +0 -1
  239. package/dist/matterbridgeDeviceTypes.js.map +0 -1
  240. package/dist/matterbridgeDynamicPlatform.d.ts.map +0 -1
  241. package/dist/matterbridgeDynamicPlatform.js.map +0 -1
  242. package/dist/matterbridgeEndpoint.d.ts.map +0 -1
  243. package/dist/matterbridgeEndpoint.js.map +0 -1
  244. package/dist/matterbridgeEndpointHelpers.d.ts.map +0 -1
  245. package/dist/matterbridgeEndpointHelpers.js.map +0 -1
  246. package/dist/matterbridgeEndpointTypes.d.ts.map +0 -1
  247. package/dist/matterbridgeEndpointTypes.js.map +0 -1
  248. package/dist/matterbridgePlatform.d.ts.map +0 -1
  249. package/dist/matterbridgePlatform.js.map +0 -1
  250. package/dist/matterbridgeTypes.d.ts.map +0 -1
  251. package/dist/matterbridgeTypes.js.map +0 -1
  252. package/dist/pluginManager.d.ts.map +0 -1
  253. package/dist/pluginManager.js.map +0 -1
  254. package/dist/shelly.d.ts.map +0 -1
  255. package/dist/shelly.js.map +0 -1
  256. package/dist/storage/export.d.ts.map +0 -1
  257. package/dist/storage/export.js.map +0 -1
  258. package/dist/update.d.ts.map +0 -1
  259. package/dist/update.js.map +0 -1
  260. package/dist/utils/colorUtils.d.ts +0 -101
  261. package/dist/utils/colorUtils.d.ts.map +0 -1
  262. package/dist/utils/colorUtils.js +0 -282
  263. package/dist/utils/colorUtils.js.map +0 -1
  264. package/dist/utils/commandLine.d.ts +0 -66
  265. package/dist/utils/commandLine.d.ts.map +0 -1
  266. package/dist/utils/commandLine.js +0 -123
  267. package/dist/utils/commandLine.js.map +0 -1
  268. package/dist/utils/copyDirectory.d.ts +0 -35
  269. package/dist/utils/copyDirectory.d.ts.map +0 -1
  270. package/dist/utils/copyDirectory.js +0 -76
  271. package/dist/utils/copyDirectory.js.map +0 -1
  272. package/dist/utils/createDirectory.d.ts +0 -34
  273. package/dist/utils/createDirectory.d.ts.map +0 -1
  274. package/dist/utils/createDirectory.js +0 -54
  275. package/dist/utils/createDirectory.js.map +0 -1
  276. package/dist/utils/createZip.d.ts +0 -39
  277. package/dist/utils/createZip.d.ts.map +0 -1
  278. package/dist/utils/createZip.js +0 -114
  279. package/dist/utils/createZip.js.map +0 -1
  280. package/dist/utils/deepCopy.d.ts +0 -32
  281. package/dist/utils/deepCopy.d.ts.map +0 -1
  282. package/dist/utils/deepCopy.js +0 -79
  283. package/dist/utils/deepCopy.js.map +0 -1
  284. package/dist/utils/deepEqual.d.ts +0 -54
  285. package/dist/utils/deepEqual.d.ts.map +0 -1
  286. package/dist/utils/deepEqual.js +0 -129
  287. package/dist/utils/deepEqual.js.map +0 -1
  288. package/dist/utils/error.d.ts +0 -45
  289. package/dist/utils/error.d.ts.map +0 -1
  290. package/dist/utils/error.js +0 -54
  291. package/dist/utils/error.js.map +0 -1
  292. package/dist/utils/export.d.ts.map +0 -1
  293. package/dist/utils/export.js.map +0 -1
  294. package/dist/utils/format.d.ts +0 -53
  295. package/dist/utils/format.d.ts.map +0 -1
  296. package/dist/utils/format.js +0 -78
  297. package/dist/utils/format.js.map +0 -1
  298. package/dist/utils/hex.d.ts +0 -89
  299. package/dist/utils/hex.d.ts.map +0 -1
  300. package/dist/utils/hex.js +0 -242
  301. package/dist/utils/hex.js.map +0 -1
  302. package/dist/utils/inspector.d.ts +0 -87
  303. package/dist/utils/inspector.d.ts.map +0 -1
  304. package/dist/utils/inspector.js +0 -268
  305. package/dist/utils/inspector.js.map +0 -1
  306. package/dist/utils/isValid.d.ts +0 -103
  307. package/dist/utils/isValid.d.ts.map +0 -1
  308. package/dist/utils/isValid.js +0 -162
  309. package/dist/utils/isValid.js.map +0 -1
  310. package/dist/utils/network.d.ts +0 -141
  311. package/dist/utils/network.d.ts.map +0 -1
  312. package/dist/utils/network.js +0 -314
  313. package/dist/utils/network.js.map +0 -1
  314. package/dist/utils/spawn.d.ts +0 -33
  315. package/dist/utils/spawn.d.ts.map +0 -1
  316. package/dist/utils/spawn.js.map +0 -1
  317. package/dist/utils/tracker.d.ts +0 -108
  318. package/dist/utils/tracker.d.ts.map +0 -1
  319. package/dist/utils/tracker.js +0 -264
  320. package/dist/utils/tracker.js.map +0 -1
  321. package/dist/utils/wait.d.ts +0 -54
  322. package/dist/utils/wait.d.ts.map +0 -1
  323. package/dist/utils/wait.js +0 -125
  324. package/dist/utils/wait.js.map +0 -1
  325. package/dist/workerGlobalPrefix.d.ts.map +0 -1
  326. package/dist/workerGlobalPrefix.js.map +0 -1
  327. package/dist/workerTypes.d.ts.map +0 -1
  328. package/dist/workerTypes.js.map +0 -1
  329. package/dist/workers.d.ts.map +0 -1
  330. package/dist/workers.js.map +0 -1
@@ -1,25 +1,3 @@
1
- /**
2
- * @description This file contains the Dishwasher class.
3
- * @file src/devices/dishwasher.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
1
  import { MaybePromise } from '@matter/general';
24
2
  import { OperationalState } from '@matter/types/clusters/operational-state';
25
3
  import { ModeBase } from '@matter/types/clusters/mode-base';
@@ -27,40 +5,8 @@ import { DishwasherMode } from '@matter/types/clusters/dishwasher-mode';
27
5
  import { DishwasherModeServer } from '@matter/node/behaviors/dishwasher-mode';
28
6
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
29
7
  export declare class Dishwasher extends MatterbridgeEndpoint {
30
- /**
31
- * Creates an instance of the DishWasher class.
32
- *
33
- * @param {string} name - The name of the dish washer.
34
- * @param {string} serial - The serial number of the dish washer.
35
- * @param {number} [currentMode] - The current mode of the dish washer. Defaults to 2 (Normal mode). Dead Front OnOff Cluster will set this to 2 when turned off. Persistent attribute.
36
- * @param {DishwasherMode.ModeOption[]} [supportedModes] - The supported modes of the dish washer. Defaults to a set of common modes (which include Light, Normal, Heavy). Fixed attribute.
37
- * @param {number} [selectedTemperatureLevel] - The selected temperature level as an index of the supportedTemperatureLevels array. Defaults to 1 (which corresponds to 'Warm').
38
- * @param {string[]} [supportedTemperatureLevels] - The supported temperature levels. Defaults to ['Cold', 'Warm', 'Hot', '30°', '40°', '60°', '80°']. Fixed attribute.
39
- * @param {number} [temperatureSetpoint] - The temperature setpoint * 100. Defaults to 40 * 100 (which corresponds to 40°C).
40
- * @param {number} [minTemperature] - The minimum temperature * 100. Defaults to 30 * 100 (which corresponds to 30°C). Fixed attribute.
41
- * @param {number} [maxTemperature] - The maximum temperature * 100. Defaults to 60 * 100 (which corresponds to 60°C). Fixed attribute.
42
- * @param {number} [step] - The step size for temperature changes. Defaults to 10 * 100 (which corresponds to 10°C). Fixed attribute.
43
- * @param {OperationalState.OperationalStateEnum} [operationalState] - The operational state of the laundry washer. Defaults to OperationalState.OperationalStateEnum.Off.
44
- *
45
- * Remarks:
46
- * - If `temperatureSetpoint` is provided, the `createNumberTemperatureControlClusterServer` method will be used to create the TemperatureControl Cluster Server with features TemperatureNumber and TemperatureStep.
47
- * - If `temperatureSetpoint` is not provided, the `createLevelTemperatureControlClusterServer` method will be used to create the TemperatureControl Cluster Server with feature TemperatureLevel.
48
- */
49
8
  constructor(name: string, serial: string, currentMode?: number, supportedModes?: DishwasherMode.ModeOption[], selectedTemperatureLevel?: number, supportedTemperatureLevels?: string[], temperatureSetpoint?: number, minTemperature?: number, maxTemperature?: number, step?: number, operationalState?: OperationalState.OperationalStateEnum);
50
- /**
51
- * Creates a default Dishwasher Mode Cluster Server.
52
- *
53
- * @param {number} currentMode - The current mode of the dishwasher. Persistent attribute.
54
- * @param {DishwasherMode.ModeOption[]} supportedModes - The supported modes of the dishwasher. Defaults to a set of common modes (Light, Normal, Heavy). Fixed attribute.
55
- *
56
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
57
- */
58
9
  createDefaultDishwasherModeClusterServer(currentMode?: number, supportedModes?: DishwasherMode.ModeOption[]): this;
59
- /**
60
- * Creates a default Dishwasher Alarm Cluster Server.
61
- *
62
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
63
- */
64
10
  createDefaultDishwasherAlarmClusterServer(): this;
65
11
  }
66
12
  export declare class MatterbridgeDishwasherModeServer extends DishwasherModeServer {
@@ -68,4 +14,3 @@ export declare class MatterbridgeDishwasherModeServer extends DishwasherModeServ
68
14
  protected handleOnOffChange(onOff: boolean): void;
69
15
  changeToMode(request: ModeBase.ChangeToModeRequest): MaybePromise<ModeBase.ChangeToModeResponse>;
70
16
  }
71
- //# sourceMappingURL=dishwasher.d.ts.map
@@ -1,54 +1,12 @@
1
- /**
2
- * @description This file contains the Dishwasher class.
3
- * @file src/devices/dishwasher.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
1
  import { ModeBase } from '@matter/types/clusters/mode-base';
24
2
  import { DishwasherMode } from '@matter/types/clusters/dishwasher-mode';
25
3
  import { DishwasherModeServer } from '@matter/node/behaviors/dishwasher-mode';
26
4
  import { DishwasherAlarmServer } from '@matter/node/behaviors/dishwasher-alarm';
27
- // Matterbridge
28
5
  import { dishwasher, powerSource } from '../matterbridgeDeviceTypes.js';
29
6
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
30
7
  import { MatterbridgeOnOffServer, MatterbridgeServer } from '../matterbridgeBehaviors.js';
31
8
  import { createLevelTemperatureControlClusterServer, createNumberTemperatureControlClusterServer } from './temperatureControl.js';
32
9
  export class Dishwasher extends MatterbridgeEndpoint {
33
- /**
34
- * Creates an instance of the DishWasher class.
35
- *
36
- * @param {string} name - The name of the dish washer.
37
- * @param {string} serial - The serial number of the dish washer.
38
- * @param {number} [currentMode] - The current mode of the dish washer. Defaults to 2 (Normal mode). Dead Front OnOff Cluster will set this to 2 when turned off. Persistent attribute.
39
- * @param {DishwasherMode.ModeOption[]} [supportedModes] - The supported modes of the dish washer. Defaults to a set of common modes (which include Light, Normal, Heavy). Fixed attribute.
40
- * @param {number} [selectedTemperatureLevel] - The selected temperature level as an index of the supportedTemperatureLevels array. Defaults to 1 (which corresponds to 'Warm').
41
- * @param {string[]} [supportedTemperatureLevels] - The supported temperature levels. Defaults to ['Cold', 'Warm', 'Hot', '30°', '40°', '60°', '80°']. Fixed attribute.
42
- * @param {number} [temperatureSetpoint] - The temperature setpoint * 100. Defaults to 40 * 100 (which corresponds to 40°C).
43
- * @param {number} [minTemperature] - The minimum temperature * 100. Defaults to 30 * 100 (which corresponds to 30°C). Fixed attribute.
44
- * @param {number} [maxTemperature] - The maximum temperature * 100. Defaults to 60 * 100 (which corresponds to 60°C). Fixed attribute.
45
- * @param {number} [step] - The step size for temperature changes. Defaults to 10 * 100 (which corresponds to 10°C). Fixed attribute.
46
- * @param {OperationalState.OperationalStateEnum} [operationalState] - The operational state of the laundry washer. Defaults to OperationalState.OperationalStateEnum.Off.
47
- *
48
- * Remarks:
49
- * - If `temperatureSetpoint` is provided, the `createNumberTemperatureControlClusterServer` method will be used to create the TemperatureControl Cluster Server with features TemperatureNumber and TemperatureStep.
50
- * - If `temperatureSetpoint` is not provided, the `createLevelTemperatureControlClusterServer` method will be used to create the TemperatureControl Cluster Server with feature TemperatureLevel.
51
- */
52
10
  constructor(name, serial, currentMode, supportedModes, selectedTemperatureLevel, supportedTemperatureLevels, temperatureSetpoint, minTemperature, maxTemperature, step, operationalState) {
53
11
  super([dishwasher, powerSource], { id: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` });
54
12
  this.createDefaultIdentifyClusterServer();
@@ -63,14 +21,6 @@ export class Dishwasher extends MatterbridgeEndpoint {
63
21
  createLevelTemperatureControlClusterServer(this, selectedTemperatureLevel, supportedTemperatureLevels);
64
22
  this.createDefaultOperationalStateClusterServer(operationalState);
65
23
  }
66
- /**
67
- * Creates a default Dishwasher Mode Cluster Server.
68
- *
69
- * @param {number} currentMode - The current mode of the dishwasher. Persistent attribute.
70
- * @param {DishwasherMode.ModeOption[]} supportedModes - The supported modes of the dishwasher. Defaults to a set of common modes (Light, Normal, Heavy). Fixed attribute.
71
- *
72
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
73
- */
74
24
  createDefaultDishwasherModeClusterServer(currentMode = 2, supportedModes = [
75
25
  { label: 'Light', mode: 1, modeTags: [{ value: DishwasherMode.ModeTag.Light }] },
76
26
  { label: 'Normal', mode: 2, modeTags: [{ value: DishwasherMode.ModeTag.Normal }] },
@@ -82,11 +32,6 @@ export class Dishwasher extends MatterbridgeEndpoint {
82
32
  });
83
33
  return this;
84
34
  }
85
- /**
86
- * Creates a default Dishwasher Alarm Cluster Server.
87
- *
88
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
89
- */
90
35
  createDefaultDishwasherAlarmClusterServer() {
91
36
  this.behaviors.require(DishwasherAlarmServer, {
92
37
  mask: { inflowError: true, drainError: true, doorError: true, tempTooLow: true, tempTooHigh: true, waterLevelError: true },
@@ -103,7 +48,6 @@ export class MatterbridgeDishwasherModeServer extends DishwasherModeServer {
103
48
  this.state.currentMode = 2;
104
49
  this.reactTo(this.agent.get(MatterbridgeOnOffServer).events.onOff$Changed, this.handleOnOffChange);
105
50
  }
106
- // Dead Front OnOff Cluster
107
51
  handleOnOffChange(onOff) {
108
52
  const device = this.endpoint.stateOf(MatterbridgeServer);
109
53
  if (onOff === false) {
@@ -127,4 +71,3 @@ export class MatterbridgeDishwasherModeServer extends DishwasherModeServer {
127
71
  }
128
72
  }
129
73
  }
130
- //# sourceMappingURL=dishwasher.js.map
@@ -1,26 +1,3 @@
1
- /**
2
- * @description This file contains the Evse class.
3
- * @file src/devices/energy-evse.ts
4
- * @author Luca Liguori
5
- * @contributor Ludovic BOUÉ
6
- * @created 2025-05-27
7
- * @version 1.1.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
1
  import { MaybePromise } from '@matter/general';
25
2
  import { EnergyEvseMode } from '@matter/types/clusters/energy-evse-mode';
26
3
  import { EnergyEvse } from '@matter/types/clusters/energy-evse';
@@ -29,41 +6,8 @@ import { EnergyEvseServer } from '@matter/node/behaviors/energy-evse';
29
6
  import { EnergyEvseModeServer } from '@matter/node/behaviors/energy-evse-mode';
30
7
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
31
8
  export declare class Evse extends MatterbridgeEndpoint {
32
- /**
33
- * Creates an instance of the EVSE class.
34
- *
35
- * @param {string} name - The name of the EVSE.
36
- * @param {string} serial - The serial number of the EVSE.
37
- * @param {number} [currentMode] - The current mode of the EnergyEvseMode cluster. Defaults to mode 1 (EnergyEvseMode.ModeTag.Manual).
38
- * @param {EnergyEvseMode.ModeOption[]} [supportedModes] - The supported modes for the EnergyEvseMode cluster. This is a fixed attribute that defaults to a predefined set of EnergyEvseMode cluster modes.
39
- * @param {EnergyEvse.State} [state] - The current state of the EVSE. Defaults to NotPluggedIn.
40
- * @param {EnergyEvse.SupplyState} [supplyState] - The supply state of the EVSE. Defaults to Disabled.
41
- * @param {EnergyEvse.FaultState} [faultState] - The fault state of the EVSE. Defaults to NoError.
42
- * @param {number} [voltage] - The voltage value in millivolts. Defaults to null if not provided.
43
- * @param {number} [current] - The current value in milliamperes. Defaults to null if not provided.
44
- * @param {number} [power] - The power value in milliwatts. Defaults to null if not provided.
45
- * @param {number} [energy] - The total consumption value in mW/h. Defaults to null if not provided.
46
- * @param {number} [absMinPower] - Indicate the minimum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
47
- * @param {number} [absMaxPower] - Indicate the maximum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
48
- */
49
9
  constructor(name: string, serial: string, currentMode?: number, supportedModes?: EnergyEvseMode.ModeOption[], state?: EnergyEvse.State, supplyState?: EnergyEvse.SupplyState, faultState?: EnergyEvse.FaultState, voltage?: number | bigint | null, current?: number | bigint | null, power?: number | bigint | null, energy?: number | bigint | null, absMinPower?: number, absMaxPower?: number);
50
- /**
51
- * Creates a default EnergyEvseServer Cluster Server.
52
- *
53
- * @param {EnergyEvse.State} [state] - The initial state of the EnergyEvse cluster. Defaults to EnergyEvse.State.NotPluggedIn.
54
- * @param {EnergyEvse.SupplyState} [supplyState] - The initial supply state of the EnergyEvse cluster. Defaults to EnergyEvse.SupplyState.ChargingEnabled.
55
- * @param {EnergyEvse.FaultState} [faultState] - The initial fault state of the EnergyEvse cluster. Defaults to EnergyEvse.FaultState.NoError.
56
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
57
- */
58
10
  createDefaultEnergyEvseClusterServer(state?: EnergyEvse.State, supplyState?: EnergyEvse.SupplyState, faultState?: EnergyEvse.FaultState): this;
59
- /**
60
- * Creates a default EnergyEvseMode Cluster Server.
61
- *
62
- * @param {number} [currentMode] - The current mode of the EnergyEvseMode cluster. Defaults to mode 1 (EnergyEvseMode.ModeTag.Manual).
63
- * @param {EnergyEvseMode.ModeOption[]} [supportedModes] - The supported modes for the EnergyEvseMode cluster. Defaults all EnergyEvseMode cluster modes.
64
- *
65
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
66
- */
67
11
  createDefaultEnergyEvseModeClusterServer(currentMode?: number, supportedModes?: EnergyEvseMode.ModeOption[]): this;
68
12
  }
69
13
  export declare class MatterbridgeEnergyEvseServer extends EnergyEvseServer {
@@ -73,4 +17,3 @@ export declare class MatterbridgeEnergyEvseServer extends EnergyEvseServer {
73
17
  export declare class MatterbridgeEnergyEvseModeServer extends EnergyEvseModeServer {
74
18
  changeToMode(request: ModeBase.ChangeToModeRequest): MaybePromise<ModeBase.ChangeToModeResponse>;
75
19
  }
76
- //# sourceMappingURL=evse.d.ts.map
@@ -1,54 +1,13 @@
1
- /**
2
- * @description This file contains the Evse class.
3
- * @file src/devices/energy-evse.ts
4
- * @author Luca Liguori
5
- * @contributor Ludovic BOUÉ
6
- * @created 2025-05-27
7
- * @version 1.1.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
1
  import { EnergyEvseMode } from '@matter/types/clusters/energy-evse-mode';
25
2
  import { EnergyEvse } from '@matter/types/clusters/energy-evse';
26
3
  import { DeviceEnergyManagement } from '@matter/types/clusters/device-energy-management';
27
4
  import { ModeBase } from '@matter/types/clusters/mode-base';
28
5
  import { EnergyEvseServer } from '@matter/node/behaviors/energy-evse';
29
6
  import { EnergyEvseModeServer } from '@matter/node/behaviors/energy-evse-mode';
30
- // Matterbridge
31
7
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
32
8
  import { MatterbridgeServer } from '../matterbridgeBehaviors.js';
33
9
  import { deviceEnergyManagement, electricalSensor, evse, powerSource } from '../matterbridgeDeviceTypes.js';
34
10
  export class Evse extends MatterbridgeEndpoint {
35
- /**
36
- * Creates an instance of the EVSE class.
37
- *
38
- * @param {string} name - The name of the EVSE.
39
- * @param {string} serial - The serial number of the EVSE.
40
- * @param {number} [currentMode] - The current mode of the EnergyEvseMode cluster. Defaults to mode 1 (EnergyEvseMode.ModeTag.Manual).
41
- * @param {EnergyEvseMode.ModeOption[]} [supportedModes] - The supported modes for the EnergyEvseMode cluster. This is a fixed attribute that defaults to a predefined set of EnergyEvseMode cluster modes.
42
- * @param {EnergyEvse.State} [state] - The current state of the EVSE. Defaults to NotPluggedIn.
43
- * @param {EnergyEvse.SupplyState} [supplyState] - The supply state of the EVSE. Defaults to Disabled.
44
- * @param {EnergyEvse.FaultState} [faultState] - The fault state of the EVSE. Defaults to NoError.
45
- * @param {number} [voltage] - The voltage value in millivolts. Defaults to null if not provided.
46
- * @param {number} [current] - The current value in milliamperes. Defaults to null if not provided.
47
- * @param {number} [power] - The power value in milliwatts. Defaults to null if not provided.
48
- * @param {number} [energy] - The total consumption value in mW/h. Defaults to null if not provided.
49
- * @param {number} [absMinPower] - Indicate the minimum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
50
- * @param {number} [absMaxPower] - Indicate the maximum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
51
- */
52
11
  constructor(name, serial, currentMode, supportedModes, state, supplyState, faultState, voltage = null, current = null, power = null, energy = null, absMinPower, absMaxPower) {
53
12
  super([evse, powerSource, electricalSensor, deviceEnergyManagement], { id: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` });
54
13
  this.createDefaultIdentifyClusterServer()
@@ -63,47 +22,30 @@ export class Evse extends MatterbridgeEndpoint {
63
22
  .createDefaultEnergyEvseModeClusterServer(currentMode, supportedModes)
64
23
  .addRequiredClusterServers();
65
24
  }
66
- /**
67
- * Creates a default EnergyEvseServer Cluster Server.
68
- *
69
- * @param {EnergyEvse.State} [state] - The initial state of the EnergyEvse cluster. Defaults to EnergyEvse.State.NotPluggedIn.
70
- * @param {EnergyEvse.SupplyState} [supplyState] - The initial supply state of the EnergyEvse cluster. Defaults to EnergyEvse.SupplyState.ChargingEnabled.
71
- * @param {EnergyEvse.FaultState} [faultState] - The initial fault state of the EnergyEvse cluster. Defaults to EnergyEvse.FaultState.NoError.
72
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
73
- */
74
25
  createDefaultEnergyEvseClusterServer(state, supplyState, faultState) {
75
26
  this.behaviors.require(MatterbridgeEnergyEvseServer, {
76
27
  state: state !== undefined ? state : EnergyEvse.State.NotPluggedIn,
77
28
  supplyState: supplyState !== undefined ? supplyState : EnergyEvse.SupplyState.ChargingEnabled,
78
29
  faultState: faultState !== undefined ? faultState : EnergyEvse.FaultState.NoError,
79
- chargingEnabledUntil: null, // Persistent attribute. A null value indicates the EVSE is always enabled for charging.
80
- circuitCapacity: 32_000, // Persistent attribute in mA. 32A in mA.
81
- minimumChargeCurrent: 6_000, // Persistent attribute in mA. 6A in mA.
82
- maximumChargeCurrent: 32_000, // Persistent attribute in mA. 32A in mA.
83
- userMaximumChargeCurrent: 32_000, // Persistent attribute in mA. 32A in mA.
84
- sessionId: null, // Persistent attribute
85
- sessionDuration: null, // Persistent attribute
86
- sessionEnergyCharged: null, // Persistent attribute
30
+ chargingEnabledUntil: null,
31
+ circuitCapacity: 32_000,
32
+ minimumChargeCurrent: 6_000,
33
+ maximumChargeCurrent: 32_000,
34
+ userMaximumChargeCurrent: 32_000,
35
+ sessionId: null,
36
+ sessionDuration: null,
37
+ sessionEnergyCharged: null,
87
38
  });
88
39
  return this;
89
40
  }
90
- /**
91
- * Creates a default EnergyEvseMode Cluster Server.
92
- *
93
- * @param {number} [currentMode] - The current mode of the EnergyEvseMode cluster. Defaults to mode 1 (EnergyEvseMode.ModeTag.Manual).
94
- * @param {EnergyEvseMode.ModeOption[]} [supportedModes] - The supported modes for the EnergyEvseMode cluster. Defaults all EnergyEvseMode cluster modes.
95
- *
96
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
97
- */
98
41
  createDefaultEnergyEvseModeClusterServer(currentMode, supportedModes) {
99
42
  this.behaviors.require(MatterbridgeEnergyEvseModeServer, {
100
43
  supportedModes: supportedModes ?? [
101
44
  { label: 'On demand', mode: 1, modeTags: [{ value: EnergyEvseMode.ModeTag.Manual }] },
102
45
  { label: 'Scheduled', mode: 2, modeTags: [{ value: EnergyEvseMode.ModeTag.TimeOfUse }] },
103
46
  { label: 'Solar charging', mode: 3, modeTags: [{ value: EnergyEvseMode.ModeTag.SolarCharging }] },
104
- // { label: 'Home to vehicle and Vehicle to home', mode: 4, modeTags: [{ value: EnergyEvseMode.ModeTag.V2X }] }, // This mode is not valid in charging only EVSEs
105
- ], // FixedAttribute
106
- currentMode: currentMode ?? 1, // Persistent attribute
47
+ ],
48
+ currentMode: currentMode ?? 1,
107
49
  });
108
50
  return this;
109
51
  }
@@ -118,8 +60,6 @@ export class MatterbridgeEnergyEvseServer extends EnergyEvseServer {
118
60
  if (this.state.state === EnergyEvse.State.PluggedInCharging) {
119
61
  this.state.state = EnergyEvse.State.PluggedInDemand;
120
62
  }
121
- // super.disable();
122
- // disable is not implemented in matter.js
123
63
  }
124
64
  enableCharging(request) {
125
65
  const device = this.endpoint.stateOf(MatterbridgeServer);
@@ -133,9 +73,6 @@ export class MatterbridgeEnergyEvseServer extends EnergyEvseServer {
133
73
  this.state.chargingEnabledUntil = request.chargingEnabledUntil;
134
74
  this.state.minimumChargeCurrent = request.minimumChargeCurrent;
135
75
  this.state.maximumChargeCurrent = request.maximumChargeCurrent;
136
- // The implementation should also stop the charging session at the required time and update the sessionId, sessionDuration, and sessionEnergyCharged attributes if needed.
137
- // super.enableCharging();
138
- // enableCharging is not implemented in matter.js
139
76
  }
140
77
  }
141
78
  export class MatterbridgeEnergyEvseModeServer extends EnergyEvseModeServer {
@@ -153,4 +90,3 @@ export class MatterbridgeEnergyEvseModeServer extends EnergyEvseModeServer {
153
90
  return { status: ModeBase.ModeChangeStatus.Success, statusText: 'Success' };
154
91
  }
155
92
  }
156
- //# sourceMappingURL=evse.js.map
@@ -14,4 +14,3 @@ export * from './evse.js';
14
14
  export * from './solarPower.js';
15
15
  export * from './batteryStorage.js';
16
16
  export * from './heatPump.js';
17
- //# sourceMappingURL=export.d.ts.map
@@ -1,8 +1,5 @@
1
- // Chapter 10. Media Device Types - Single class device types
2
1
  export * from './speaker.js';
3
- // Chapter 12. Robotic Device Types - Single class device types
4
2
  export * from './roboticVacuumCleaner.js';
5
- // Chapter 13. Appliances Device Types - Single class device types
6
3
  export * from './laundryWasher.js';
7
4
  export * from './laundryDryer.js';
8
5
  export * from './extractorHood.js';
@@ -12,10 +9,8 @@ export * from './oven.js';
12
9
  export * from './cooktop.js';
13
10
  export * from './refrigerator.js';
14
11
  export * from './airConditioner.js';
15
- // Chapter 14. Energy Device Types - Single class device types
16
12
  export * from './waterHeater.js';
17
13
  export * from './evse.js';
18
14
  export * from './solarPower.js';
19
15
  export * from './batteryStorage.js';
20
16
  export * from './heatPump.js';
21
- //# sourceMappingURL=export.js.map
@@ -1,46 +1,5 @@
1
- /**
2
- * @description This file contains the ExtractorHood class.
3
- * @file src/devices/extractorHood.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
1
  import { ResourceMonitoring } from '@matter/types/clusters/resource-monitoring';
24
2
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
25
3
  export declare class ExtractorHood extends MatterbridgeEndpoint {
26
- /**
27
- * Creates an instance of the ExtractorHood class.
28
- *
29
- * @param {string} name - The name of the extractor hood.
30
- * @param {string} serial - The serial number of the extractor hood.
31
- *
32
- * @param {number} [hepaCondition] - The initial HEPA filter condition (range 0-100). Default is 100.
33
- * @param {ResourceMonitoring.ChangeIndication} hepaChangeIndication - The initial HEPA filter change indication. Default is ResourceMonitoring.ChangeIndication.Ok.
34
- * @param {boolean | undefined} hepaInPlaceIndicator - The HEPA filter in-place indicator. Default is true.
35
- * @param {number | null | undefined} hepaLastChangedTime - The last time the HEPA filter was changed. Default is null.
36
- * @param {ResourceMonitoring.ReplacementProduct[]} hepaReplacementProductList - The list of HEPA filter replacement products. Default is an empty array.
37
-
38
- * @param {number} [activatedCarbonCondition] - The initial activated carbon filter condition (range 0-100). Default is 100.
39
- * @param {ResourceMonitoring.ChangeIndication} activatedCarbonChangeIndication - The initial activated carbon filter change indication. Default is ResourceMonitoring.ChangeIndication.Ok.
40
- * @param {boolean | undefined} activatedCarbonInPlaceIndicator - The activated carbon filter in-place indicator. Default is true.
41
- * @param {number | null | undefined} activatedCarbonLastChangedTime - The last time the activated carbon filter was changed. Default is null.
42
- * @param {ResourceMonitoring.ReplacementProduct[]} activatedCarbonReplacementProductList - The list of activated carbon filter replacement products. Default is an empty array.
43
- */
44
4
  constructor(name: string, serial: string, hepaCondition?: number, hepaChangeIndication?: ResourceMonitoring.ChangeIndication, hepaInPlaceIndicator?: boolean | undefined, hepaLastChangedTime?: number | null | undefined, hepaReplacementProductList?: ResourceMonitoring.ReplacementProduct[], activatedCarbonCondition?: number, activatedCarbonChangeIndication?: ResourceMonitoring.ChangeIndication, activatedCarbonInPlaceIndicator?: boolean | undefined, activatedCarbonLastChangedTime?: number | null | undefined, activatedCarbonReplacementProductList?: ResourceMonitoring.ReplacementProduct[]);
45
5
  }
46
- //# sourceMappingURL=extractorHood.d.ts.map
@@ -1,49 +1,7 @@
1
- /**
2
- * @description This file contains the ExtractorHood class.
3
- * @file src/devices/extractorHood.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
- // Imports from @matter
24
1
  import { ResourceMonitoring } from '@matter/types/clusters/resource-monitoring';
25
- // Matterbridge
26
2
  import { extractorHood, powerSource } from '../matterbridgeDeviceTypes.js';
27
3
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
28
4
  export class ExtractorHood extends MatterbridgeEndpoint {
29
- /**
30
- * Creates an instance of the ExtractorHood class.
31
- *
32
- * @param {string} name - The name of the extractor hood.
33
- * @param {string} serial - The serial number of the extractor hood.
34
- *
35
- * @param {number} [hepaCondition] - The initial HEPA filter condition (range 0-100). Default is 100.
36
- * @param {ResourceMonitoring.ChangeIndication} hepaChangeIndication - The initial HEPA filter change indication. Default is ResourceMonitoring.ChangeIndication.Ok.
37
- * @param {boolean | undefined} hepaInPlaceIndicator - The HEPA filter in-place indicator. Default is true.
38
- * @param {number | null | undefined} hepaLastChangedTime - The last time the HEPA filter was changed. Default is null.
39
- * @param {ResourceMonitoring.ReplacementProduct[]} hepaReplacementProductList - The list of HEPA filter replacement products. Default is an empty array.
40
-
41
- * @param {number} [activatedCarbonCondition] - The initial activated carbon filter condition (range 0-100). Default is 100.
42
- * @param {ResourceMonitoring.ChangeIndication} activatedCarbonChangeIndication - The initial activated carbon filter change indication. Default is ResourceMonitoring.ChangeIndication.Ok.
43
- * @param {boolean | undefined} activatedCarbonInPlaceIndicator - The activated carbon filter in-place indicator. Default is true.
44
- * @param {number | null | undefined} activatedCarbonLastChangedTime - The last time the activated carbon filter was changed. Default is null.
45
- * @param {ResourceMonitoring.ReplacementProduct[]} activatedCarbonReplacementProductList - The list of activated carbon filter replacement products. Default is an empty array.
46
- */
47
5
  constructor(name, serial, hepaCondition = 100, hepaChangeIndication = ResourceMonitoring.ChangeIndication.Ok, hepaInPlaceIndicator = true, hepaLastChangedTime = null, hepaReplacementProductList = [], activatedCarbonCondition = 100, activatedCarbonChangeIndication = ResourceMonitoring.ChangeIndication.Ok, activatedCarbonInPlaceIndicator = true, activatedCarbonLastChangedTime = null, activatedCarbonReplacementProductList = []) {
48
6
  super([extractorHood, powerSource], { id: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` });
49
7
  this.createDefaultIdentifyClusterServer();
@@ -75,4 +33,3 @@ export class ExtractorHood extends MatterbridgeEndpoint {
75
33
  });
76
34
  }
77
35
  }
78
- //# sourceMappingURL=extractorHood.js.map
@@ -1,47 +1,4 @@
1
- /**
2
- * @description This file contains the HeatPump class.
3
- * @file src/devices/heatPump.ts
4
- * @author Luca Liguori
5
- * @created 2025-06-29
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
1
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
24
2
  export declare class HeatPump extends MatterbridgeEndpoint {
25
- /**
26
- * Creates an instance of the HeatPump class.
27
- *
28
- * @param {string} name - The name of the HeatPump.
29
- * @param {string} serial - The serial number of the HeatPump.
30
- * @param {number} voltage - The voltage value in millivolts.
31
- * @param {number} current - The current value in milliamperes.
32
- * @param {number} power - The power value in milliwatts.
33
- * @param {number} energyImported - The total production value in mW/h.
34
- * @param {number} [absMinPower] - Indicate the minimum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
35
- * @param {number} [absMaxPower] - Indicate the maximum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
36
- *
37
- * @remarks
38
- * - The HeatPump includes clusters for power source, electrical power measurement, electrical energy measurement, and device energy management.
39
- * - It also includes child devices for flow temperature, return temperature, and a thermostat.
40
- * - The flow and return temperature sensors are set to default values of 45.00°C and 35.00°C respectively.
41
- * - The heating only thermostat is set up with a default temperature setpoint of 21.00°C.
42
- * - The device energy management cluster is set to `esaType` as `SpaceHeating`, `esaCanGenerate` as `false`, and `esaState` as `Online`.
43
- * - The absolute minimum and maximum power values can be set to indicate the range of power consumption for the heat pump.
44
- */
45
3
  constructor(name: string, serial: string, voltage?: number | bigint | null, current?: number | bigint | null, power?: number | bigint | null, energyImported?: number | bigint | null, absMinPower?: number, absMaxPower?: number);
46
4
  }
47
- //# sourceMappingURL=heatPump.d.ts.map
@@ -1,52 +1,8 @@
1
- /**
2
- * @description This file contains the HeatPump class.
3
- * @file src/devices/heatPump.ts
4
- * @author Luca Liguori
5
- * @created 2025-06-29
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
- // @matter
24
1
  import { NumberTag, PowerSourceTag } from '@matter/node';
25
2
  import { DeviceEnergyManagement } from '@matter/types/clusters/device-energy-management';
26
- // Matterbridge
27
3
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
28
4
  import { deviceEnergyManagement, electricalSensor, powerSource, heatPump, temperatureSensor, thermostatDevice } from '../matterbridgeDeviceTypes.js';
29
5
  export class HeatPump extends MatterbridgeEndpoint {
30
- /**
31
- * Creates an instance of the HeatPump class.
32
- *
33
- * @param {string} name - The name of the HeatPump.
34
- * @param {string} serial - The serial number of the HeatPump.
35
- * @param {number} voltage - The voltage value in millivolts.
36
- * @param {number} current - The current value in milliamperes.
37
- * @param {number} power - The power value in milliwatts.
38
- * @param {number} energyImported - The total production value in mW/h.
39
- * @param {number} [absMinPower] - Indicate the minimum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
40
- * @param {number} [absMaxPower] - Indicate the maximum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
41
- *
42
- * @remarks
43
- * - The HeatPump includes clusters for power source, electrical power measurement, electrical energy measurement, and device energy management.
44
- * - It also includes child devices for flow temperature, return temperature, and a thermostat.
45
- * - The flow and return temperature sensors are set to default values of 45.00°C and 35.00°C respectively.
46
- * - The heating only thermostat is set up with a default temperature setpoint of 21.00°C.
47
- * - The device energy management cluster is set to `esaType` as `SpaceHeating`, `esaCanGenerate` as `false`, and `esaState` as `Online`.
48
- * - The absolute minimum and maximum power values can be set to indicate the range of power consumption for the heat pump.
49
- */
50
6
  constructor(name, serial, voltage = null, current = null, power = null, energyImported = null, absMinPower = 0, absMaxPower = 0) {
51
7
  super([heatPump, powerSource, electricalSensor, deviceEnergyManagement], {
52
8
  tagList: [{ mfgCode: null, namespaceId: PowerSourceTag.Grid.namespaceId, tag: PowerSourceTag.Grid.tag, label: null }],
@@ -61,19 +17,16 @@ export class HeatPump extends MatterbridgeEndpoint {
61
17
  .createDefaultDeviceEnergyManagementClusterServer(DeviceEnergyManagement.EsaType.SpaceHeating, false, DeviceEnergyManagement.EsaState.Online, absMinPower, absMaxPower)
62
18
  .createDefaultDeviceEnergyManagementModeClusterServer()
63
19
  .addRequiredClusterServers();
64
- // Add the flow temperature sensor for the heat pump.
65
20
  this.addChildDeviceType('FlowTemperature', temperatureSensor, {
66
21
  tagList: [{ mfgCode: null, namespaceId: NumberTag.One.namespaceId, tag: NumberTag.One.tag, label: 'Flow' }],
67
22
  })
68
- .createDefaultTemperatureMeasurementClusterServer(4500) // Default flow temperature setpoint in hundredths of degrees Celsius (45.00°C).
23
+ .createDefaultTemperatureMeasurementClusterServer(4500)
69
24
  .addRequiredClusterServers();
70
- // Add the return temperature sensor for the heat pump.
71
25
  this.addChildDeviceType('ReturnTemperature', temperatureSensor, {
72
26
  tagList: [{ mfgCode: null, namespaceId: NumberTag.Two.namespaceId, tag: NumberTag.Two.tag, label: 'Return' }],
73
27
  })
74
- .createDefaultTemperatureMeasurementClusterServer(3500) // Default return temperature setpoint in hundredths of degrees Celsius (35.00°C).
28
+ .createDefaultTemperatureMeasurementClusterServer(3500)
75
29
  .addRequiredClusterServers();
76
- // Add the global thermostat for the heat pump.
77
30
  this.addChildDeviceType('Thermostat', thermostatDevice, {
78
31
  tagList: [{ mfgCode: null, namespaceId: NumberTag.One.namespaceId, tag: NumberTag.One.tag, label: 'Main Thermostat' }],
79
32
  })
@@ -81,4 +34,3 @@ export class HeatPump extends MatterbridgeEndpoint {
81
34
  .addRequiredClusterServers();
82
35
  }
83
36
  }
84
- //# sourceMappingURL=heatPump.js.map