matterbridge 3.4.7 → 3.5.0-dev-20260113-96c82db

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 (449) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/dist/broadcastServer.d.ts +0 -115
  3. package/dist/broadcastServer.js +0 -117
  4. package/dist/broadcastServerTypes.d.ts +0 -43
  5. package/dist/broadcastServerTypes.js +0 -24
  6. package/dist/cli.d.ts +0 -24
  7. package/dist/cli.js +1 -97
  8. package/dist/cliEmitter.d.ts +0 -36
  9. package/dist/cliEmitter.js +0 -37
  10. package/dist/cliHistory.d.ts +0 -42
  11. package/dist/cliHistory.js +0 -38
  12. package/dist/clusters/export.d.ts +0 -1
  13. package/dist/clusters/export.js +0 -2
  14. package/dist/deviceManager.d.ts +0 -108
  15. package/dist/deviceManager.js +1 -113
  16. package/dist/devices/airConditioner.d.ts +0 -75
  17. package/dist/devices/airConditioner.js +0 -57
  18. package/dist/devices/batteryStorage.d.ts +0 -43
  19. package/dist/devices/batteryStorage.js +1 -48
  20. package/dist/devices/cooktop.d.ts +0 -55
  21. package/dist/devices/cooktop.js +0 -56
  22. package/dist/devices/dishwasher.d.ts +0 -55
  23. package/dist/devices/dishwasher.js +0 -57
  24. package/dist/devices/evse.d.ts +0 -57
  25. package/dist/devices/evse.js +10 -74
  26. package/dist/devices/export.d.ts +0 -1
  27. package/dist/devices/export.js +0 -5
  28. package/dist/devices/extractorHood.d.ts +0 -41
  29. package/dist/devices/extractorHood.js +0 -43
  30. package/dist/devices/heatPump.d.ts +0 -43
  31. package/dist/devices/heatPump.js +2 -50
  32. package/dist/devices/laundryDryer.d.ts +0 -58
  33. package/dist/devices/laundryDryer.js +3 -62
  34. package/dist/devices/laundryWasher.d.ts +0 -64
  35. package/dist/devices/laundryWasher.js +4 -70
  36. package/dist/devices/microwaveOven.d.ts +1 -77
  37. package/dist/devices/microwaveOven.js +5 -88
  38. package/dist/devices/oven.d.ts +0 -82
  39. package/dist/devices/oven.js +0 -85
  40. package/dist/devices/refrigerator.d.ts +0 -100
  41. package/dist/devices/refrigerator.js +0 -102
  42. package/dist/devices/roboticVacuumCleaner.d.ts +0 -83
  43. package/dist/devices/roboticVacuumCleaner.js +9 -100
  44. package/dist/devices/solarPower.d.ts +0 -36
  45. package/dist/devices/solarPower.js +0 -38
  46. package/dist/devices/speaker.d.ts +0 -79
  47. package/dist/devices/speaker.js +0 -84
  48. package/dist/devices/temperatureControl.d.ts +0 -21
  49. package/dist/devices/temperatureControl.js +3 -24
  50. package/dist/devices/waterHeater.d.ts +0 -74
  51. package/dist/devices/waterHeater.js +2 -82
  52. package/dist/dgram/coap.d.ts +0 -171
  53. package/dist/dgram/coap.js +13 -126
  54. package/dist/dgram/dgram.d.ts +0 -99
  55. package/dist/dgram/dgram.js +2 -114
  56. package/dist/dgram/mb_coap.d.ts +0 -23
  57. package/dist/dgram/mb_coap.js +3 -41
  58. package/dist/dgram/mb_mdns.d.ts +0 -23
  59. package/dist/dgram/mb_mdns.js +24 -80
  60. package/dist/dgram/mdns.d.ts +4 -187
  61. package/dist/dgram/mdns.js +139 -371
  62. package/dist/dgram/multicast.d.ts +0 -49
  63. package/dist/dgram/multicast.js +1 -62
  64. package/dist/dgram/unicast.d.ts +0 -53
  65. package/dist/dgram/unicast.js +0 -60
  66. package/dist/frontend.d.ts +0 -187
  67. package/dist/frontend.js +38 -485
  68. package/dist/frontendTypes.d.ts +0 -57
  69. package/dist/frontendTypes.js +0 -45
  70. package/dist/helpers.d.ts +0 -43
  71. package/dist/helpers.js +0 -53
  72. package/dist/index.d.ts +0 -23
  73. package/dist/index.js +0 -25
  74. package/dist/jestutils/export.d.ts +0 -1
  75. package/dist/jestutils/export.js +0 -1
  76. package/dist/jestutils/jestHelpers.d.ts +0 -255
  77. package/dist/jestutils/jestHelpers.js +14 -371
  78. package/dist/logger/export.d.ts +0 -1
  79. package/dist/logger/export.js +0 -1
  80. package/dist/matter/behaviors.d.ts +0 -1
  81. package/dist/matter/behaviors.js +0 -2
  82. package/dist/matter/clusters.d.ts +0 -1
  83. package/dist/matter/clusters.js +0 -2
  84. package/dist/matter/devices.d.ts +0 -1
  85. package/dist/matter/devices.js +0 -2
  86. package/dist/matter/endpoints.d.ts +0 -1
  87. package/dist/matter/endpoints.js +0 -2
  88. package/dist/matter/export.d.ts +0 -1
  89. package/dist/matter/export.js +0 -3
  90. package/dist/matter/types.d.ts +0 -1
  91. package/dist/matter/types.js +0 -3
  92. package/dist/matterNode.d.ts +0 -258
  93. package/dist/matterNode.js +8 -369
  94. package/dist/matterbridge.d.ts +0 -353
  95. package/dist/matterbridge.js +46 -824
  96. package/dist/matterbridgeAccessoryPlatform.d.ts +0 -36
  97. package/dist/matterbridgeAccessoryPlatform.js +0 -38
  98. package/dist/matterbridgeBehaviors.d.ts +0 -24
  99. package/dist/matterbridgeBehaviors.js +5 -68
  100. package/dist/matterbridgeDeviceTypes.d.ts +0 -603
  101. package/dist/matterbridgeDeviceTypes.js +14 -635
  102. package/dist/matterbridgeDynamicPlatform.d.ts +0 -36
  103. package/dist/matterbridgeDynamicPlatform.js +0 -38
  104. package/dist/matterbridgeEndpoint.d.ts +0 -1332
  105. package/dist/matterbridgeEndpoint.js +53 -1457
  106. package/dist/matterbridgeEndpointHelpers.d.ts +0 -425
  107. package/dist/matterbridgeEndpointHelpers.js +20 -483
  108. package/dist/matterbridgeEndpointTypes.d.ts +0 -70
  109. package/dist/matterbridgeEndpointTypes.js +0 -25
  110. package/dist/matterbridgePlatform.d.ts +0 -425
  111. package/dist/matterbridgePlatform.js +1 -451
  112. package/dist/matterbridgeTypes.d.ts +0 -46
  113. package/dist/matterbridgeTypes.js +0 -26
  114. package/dist/pluginManager.d.ts +0 -305
  115. package/dist/pluginManager.js +5 -341
  116. package/dist/shelly.d.ts +0 -157
  117. package/dist/shelly.js +7 -178
  118. package/dist/storage/export.d.ts +0 -1
  119. package/dist/storage/export.js +0 -1
  120. package/dist/update.d.ts +0 -75
  121. package/dist/update.js +1 -93
  122. package/dist/utils/colorUtils.d.ts +0 -77
  123. package/dist/utils/colorUtils.js +2 -97
  124. package/dist/utils/commandLine.d.ts +0 -60
  125. package/dist/utils/commandLine.js +0 -60
  126. package/dist/utils/copyDirectory.d.ts +0 -33
  127. package/dist/utils/copyDirectory.js +0 -37
  128. package/dist/utils/createDirectory.d.ts +0 -32
  129. package/dist/utils/createDirectory.js +0 -33
  130. package/dist/utils/createZip.d.ts +0 -38
  131. package/dist/utils/createZip.js +2 -47
  132. package/dist/utils/deepCopy.d.ts +0 -31
  133. package/dist/utils/deepCopy.js +0 -39
  134. package/dist/utils/deepEqual.d.ts +0 -53
  135. package/dist/utils/deepEqual.js +1 -72
  136. package/dist/utils/error.d.ts +0 -42
  137. package/dist/utils/error.js +0 -42
  138. package/dist/utils/export.d.ts +0 -1
  139. package/dist/utils/export.js +0 -1
  140. package/dist/utils/format.d.ts +0 -49
  141. package/dist/utils/format.js +0 -49
  142. package/dist/utils/hex.d.ts +0 -85
  143. package/dist/utils/hex.js +0 -124
  144. package/dist/utils/inspector.d.ts +0 -63
  145. package/dist/utils/inspector.js +1 -69
  146. package/dist/utils/isValid.d.ts +0 -93
  147. package/dist/utils/isValid.js +0 -93
  148. package/dist/utils/network.d.ts +0 -116
  149. package/dist/utils/network.js +5 -126
  150. package/dist/utils/spawn.d.ts +0 -32
  151. package/dist/utils/spawn.js +1 -71
  152. package/dist/utils/tracker.d.ts +0 -56
  153. package/dist/utils/tracker.js +1 -64
  154. package/dist/utils/wait.d.ts +0 -51
  155. package/dist/utils/wait.js +8 -60
  156. package/dist/workerGlobalPrefix.d.ts +0 -24
  157. package/dist/workerGlobalPrefix.js +5 -37
  158. package/dist/workerTypes.d.ts +0 -25
  159. package/dist/workerTypes.js +0 -24
  160. package/dist/workers.d.ts +0 -61
  161. package/dist/workers.js +4 -68
  162. package/npm-shrinkwrap.json +1500 -11420
  163. package/package.json +1 -7
  164. package/dist/broadcastServer.d.ts.map +0 -1
  165. package/dist/broadcastServer.js.map +0 -1
  166. package/dist/broadcastServerTypes.d.ts.map +0 -1
  167. package/dist/broadcastServerTypes.js.map +0 -1
  168. package/dist/cli.d.ts.map +0 -1
  169. package/dist/cli.js.map +0 -1
  170. package/dist/cliEmitter.d.ts.map +0 -1
  171. package/dist/cliEmitter.js.map +0 -1
  172. package/dist/cliHistory.d.ts.map +0 -1
  173. package/dist/cliHistory.js.map +0 -1
  174. package/dist/clusters/export.d.ts.map +0 -1
  175. package/dist/clusters/export.js.map +0 -1
  176. package/dist/deviceManager.d.ts.map +0 -1
  177. package/dist/deviceManager.js.map +0 -1
  178. package/dist/devices/airConditioner.d.ts.map +0 -1
  179. package/dist/devices/airConditioner.js.map +0 -1
  180. package/dist/devices/batteryStorage.d.ts.map +0 -1
  181. package/dist/devices/batteryStorage.js.map +0 -1
  182. package/dist/devices/cooktop.d.ts.map +0 -1
  183. package/dist/devices/cooktop.js.map +0 -1
  184. package/dist/devices/dishwasher.d.ts.map +0 -1
  185. package/dist/devices/dishwasher.js.map +0 -1
  186. package/dist/devices/evse.d.ts.map +0 -1
  187. package/dist/devices/evse.js.map +0 -1
  188. package/dist/devices/export.d.ts.map +0 -1
  189. package/dist/devices/export.js.map +0 -1
  190. package/dist/devices/extractorHood.d.ts.map +0 -1
  191. package/dist/devices/extractorHood.js.map +0 -1
  192. package/dist/devices/heatPump.d.ts.map +0 -1
  193. package/dist/devices/heatPump.js.map +0 -1
  194. package/dist/devices/laundryDryer.d.ts.map +0 -1
  195. package/dist/devices/laundryDryer.js.map +0 -1
  196. package/dist/devices/laundryWasher.d.ts.map +0 -1
  197. package/dist/devices/laundryWasher.js.map +0 -1
  198. package/dist/devices/microwaveOven.d.ts.map +0 -1
  199. package/dist/devices/microwaveOven.js.map +0 -1
  200. package/dist/devices/oven.d.ts.map +0 -1
  201. package/dist/devices/oven.js.map +0 -1
  202. package/dist/devices/refrigerator.d.ts.map +0 -1
  203. package/dist/devices/refrigerator.js.map +0 -1
  204. package/dist/devices/roboticVacuumCleaner.d.ts.map +0 -1
  205. package/dist/devices/roboticVacuumCleaner.js.map +0 -1
  206. package/dist/devices/solarPower.d.ts.map +0 -1
  207. package/dist/devices/solarPower.js.map +0 -1
  208. package/dist/devices/speaker.d.ts.map +0 -1
  209. package/dist/devices/speaker.js.map +0 -1
  210. package/dist/devices/temperatureControl.d.ts.map +0 -1
  211. package/dist/devices/temperatureControl.js.map +0 -1
  212. package/dist/devices/waterHeater.d.ts.map +0 -1
  213. package/dist/devices/waterHeater.js.map +0 -1
  214. package/dist/dgram/coap.d.ts.map +0 -1
  215. package/dist/dgram/coap.js.map +0 -1
  216. package/dist/dgram/dgram.d.ts.map +0 -1
  217. package/dist/dgram/dgram.js.map +0 -1
  218. package/dist/dgram/mb_coap.d.ts.map +0 -1
  219. package/dist/dgram/mb_coap.js.map +0 -1
  220. package/dist/dgram/mb_mdns.d.ts.map +0 -1
  221. package/dist/dgram/mb_mdns.js.map +0 -1
  222. package/dist/dgram/mdns.d.ts.map +0 -1
  223. package/dist/dgram/mdns.js.map +0 -1
  224. package/dist/dgram/multicast.d.ts.map +0 -1
  225. package/dist/dgram/multicast.js.map +0 -1
  226. package/dist/dgram/unicast.d.ts.map +0 -1
  227. package/dist/dgram/unicast.js.map +0 -1
  228. package/dist/frontend.d.ts.map +0 -1
  229. package/dist/frontend.js.map +0 -1
  230. package/dist/frontendTypes.d.ts.map +0 -1
  231. package/dist/frontendTypes.js.map +0 -1
  232. package/dist/helpers.d.ts.map +0 -1
  233. package/dist/helpers.js.map +0 -1
  234. package/dist/index.d.ts.map +0 -1
  235. package/dist/index.js.map +0 -1
  236. package/dist/jestutils/export.d.ts.map +0 -1
  237. package/dist/jestutils/export.js.map +0 -1
  238. package/dist/jestutils/jestHelpers.d.ts.map +0 -1
  239. package/dist/jestutils/jestHelpers.js.map +0 -1
  240. package/dist/logger/export.d.ts.map +0 -1
  241. package/dist/logger/export.js.map +0 -1
  242. package/dist/matter/behaviors.d.ts.map +0 -1
  243. package/dist/matter/behaviors.js.map +0 -1
  244. package/dist/matter/clusters.d.ts.map +0 -1
  245. package/dist/matter/clusters.js.map +0 -1
  246. package/dist/matter/devices.d.ts.map +0 -1
  247. package/dist/matter/devices.js.map +0 -1
  248. package/dist/matter/endpoints.d.ts.map +0 -1
  249. package/dist/matter/endpoints.js.map +0 -1
  250. package/dist/matter/export.d.ts.map +0 -1
  251. package/dist/matter/export.js.map +0 -1
  252. package/dist/matter/types.d.ts.map +0 -1
  253. package/dist/matter/types.js.map +0 -1
  254. package/dist/matterNode.d.ts.map +0 -1
  255. package/dist/matterNode.js.map +0 -1
  256. package/dist/matterbridge.d.ts.map +0 -1
  257. package/dist/matterbridge.js.map +0 -1
  258. package/dist/matterbridgeAccessoryPlatform.d.ts.map +0 -1
  259. package/dist/matterbridgeAccessoryPlatform.js.map +0 -1
  260. package/dist/matterbridgeBehaviors.d.ts.map +0 -1
  261. package/dist/matterbridgeBehaviors.js.map +0 -1
  262. package/dist/matterbridgeDeviceTypes.d.ts.map +0 -1
  263. package/dist/matterbridgeDeviceTypes.js.map +0 -1
  264. package/dist/matterbridgeDynamicPlatform.d.ts.map +0 -1
  265. package/dist/matterbridgeDynamicPlatform.js.map +0 -1
  266. package/dist/matterbridgeEndpoint.d.ts.map +0 -1
  267. package/dist/matterbridgeEndpoint.js.map +0 -1
  268. package/dist/matterbridgeEndpointHelpers.d.ts.map +0 -1
  269. package/dist/matterbridgeEndpointHelpers.js.map +0 -1
  270. package/dist/matterbridgeEndpointTypes.d.ts.map +0 -1
  271. package/dist/matterbridgeEndpointTypes.js.map +0 -1
  272. package/dist/matterbridgePlatform.d.ts.map +0 -1
  273. package/dist/matterbridgePlatform.js.map +0 -1
  274. package/dist/matterbridgeTypes.d.ts.map +0 -1
  275. package/dist/matterbridgeTypes.js.map +0 -1
  276. package/dist/pluginManager.d.ts.map +0 -1
  277. package/dist/pluginManager.js.map +0 -1
  278. package/dist/shelly.d.ts.map +0 -1
  279. package/dist/shelly.js.map +0 -1
  280. package/dist/storage/export.d.ts.map +0 -1
  281. package/dist/storage/export.js.map +0 -1
  282. package/dist/update.d.ts.map +0 -1
  283. package/dist/update.js.map +0 -1
  284. package/dist/utils/colorUtils.d.ts.map +0 -1
  285. package/dist/utils/colorUtils.js.map +0 -1
  286. package/dist/utils/commandLine.d.ts.map +0 -1
  287. package/dist/utils/commandLine.js.map +0 -1
  288. package/dist/utils/copyDirectory.d.ts.map +0 -1
  289. package/dist/utils/copyDirectory.js.map +0 -1
  290. package/dist/utils/createDirectory.d.ts.map +0 -1
  291. package/dist/utils/createDirectory.js.map +0 -1
  292. package/dist/utils/createZip.d.ts.map +0 -1
  293. package/dist/utils/createZip.js.map +0 -1
  294. package/dist/utils/deepCopy.d.ts.map +0 -1
  295. package/dist/utils/deepCopy.js.map +0 -1
  296. package/dist/utils/deepEqual.d.ts.map +0 -1
  297. package/dist/utils/deepEqual.js.map +0 -1
  298. package/dist/utils/error.d.ts.map +0 -1
  299. package/dist/utils/error.js.map +0 -1
  300. package/dist/utils/export.d.ts.map +0 -1
  301. package/dist/utils/export.js.map +0 -1
  302. package/dist/utils/format.d.ts.map +0 -1
  303. package/dist/utils/format.js.map +0 -1
  304. package/dist/utils/hex.d.ts.map +0 -1
  305. package/dist/utils/hex.js.map +0 -1
  306. package/dist/utils/inspector.d.ts.map +0 -1
  307. package/dist/utils/inspector.js.map +0 -1
  308. package/dist/utils/isValid.d.ts.map +0 -1
  309. package/dist/utils/isValid.js.map +0 -1
  310. package/dist/utils/network.d.ts.map +0 -1
  311. package/dist/utils/network.js.map +0 -1
  312. package/dist/utils/spawn.d.ts.map +0 -1
  313. package/dist/utils/spawn.js.map +0 -1
  314. package/dist/utils/tracker.d.ts.map +0 -1
  315. package/dist/utils/tracker.js.map +0 -1
  316. package/dist/utils/wait.d.ts.map +0 -1
  317. package/dist/utils/wait.js.map +0 -1
  318. package/dist/workerGlobalPrefix.d.ts.map +0 -1
  319. package/dist/workerGlobalPrefix.js.map +0 -1
  320. package/dist/workerTypes.d.ts.map +0 -1
  321. package/dist/workerTypes.js.map +0 -1
  322. package/dist/workers.d.ts.map +0 -1
  323. package/dist/workers.js.map +0 -1
  324. package/frontend/index.html +0 -15
  325. package/frontend/package-lock.json +0 -7553
  326. package/packages/dgram/LICENSE +0 -202
  327. package/packages/dgram/dist/coap.d.ts +0 -205
  328. package/packages/dgram/dist/coap.d.ts.map +0 -1
  329. package/packages/dgram/dist/coap.js +0 -365
  330. package/packages/dgram/dist/coap.js.map +0 -1
  331. package/packages/dgram/dist/dgram.d.ts +0 -144
  332. package/packages/dgram/dist/dgram.d.ts.map +0 -1
  333. package/packages/dgram/dist/dgram.js +0 -367
  334. package/packages/dgram/dist/dgram.js.map +0 -1
  335. package/packages/dgram/dist/export.d.ts +0 -6
  336. package/packages/dgram/dist/export.d.ts.map +0 -1
  337. package/packages/dgram/dist/export.js +0 -6
  338. package/packages/dgram/dist/export.js.map +0 -1
  339. package/packages/dgram/dist/mdns.d.ts +0 -371
  340. package/packages/dgram/dist/mdns.d.ts.map +0 -1
  341. package/packages/dgram/dist/mdns.js +0 -934
  342. package/packages/dgram/dist/mdns.js.map +0 -1
  343. package/packages/dgram/dist/multicast.d.ts +0 -67
  344. package/packages/dgram/dist/multicast.d.ts.map +0 -1
  345. package/packages/dgram/dist/multicast.js +0 -180
  346. package/packages/dgram/dist/multicast.js.map +0 -1
  347. package/packages/dgram/dist/unicast.d.ts +0 -64
  348. package/packages/dgram/dist/unicast.d.ts.map +0 -1
  349. package/packages/dgram/dist/unicast.js +0 -100
  350. package/packages/dgram/dist/unicast.js.map +0 -1
  351. package/packages/dgram/package.json +0 -110
  352. package/packages/jest-utils/LICENSE +0 -202
  353. package/packages/jest-utils/dist/export.d.ts +0 -2
  354. package/packages/jest-utils/dist/export.d.ts.map +0 -1
  355. package/packages/jest-utils/dist/export.js +0 -2
  356. package/packages/jest-utils/dist/export.js.map +0 -1
  357. package/packages/jest-utils/dist/jestHelpers.d.ts +0 -77
  358. package/packages/jest-utils/dist/jestHelpers.d.ts.map +0 -1
  359. package/packages/jest-utils/dist/jestHelpers.js +0 -138
  360. package/packages/jest-utils/dist/jestHelpers.js.map +0 -1
  361. package/packages/jest-utils/package.json +0 -109
  362. package/packages/utils/LICENSE +0 -202
  363. package/packages/utils/dist/colorUtils.d.ts +0 -101
  364. package/packages/utils/dist/colorUtils.d.ts.map +0 -1
  365. package/packages/utils/dist/colorUtils.js +0 -282
  366. package/packages/utils/dist/colorUtils.js.map +0 -1
  367. package/packages/utils/dist/commandLine.d.ts +0 -66
  368. package/packages/utils/dist/commandLine.d.ts.map +0 -1
  369. package/packages/utils/dist/commandLine.js +0 -123
  370. package/packages/utils/dist/commandLine.js.map +0 -1
  371. package/packages/utils/dist/copyDirectory.d.ts +0 -35
  372. package/packages/utils/dist/copyDirectory.d.ts.map +0 -1
  373. package/packages/utils/dist/copyDirectory.js +0 -76
  374. package/packages/utils/dist/copyDirectory.js.map +0 -1
  375. package/packages/utils/dist/createDirectory.d.ts +0 -34
  376. package/packages/utils/dist/createDirectory.d.ts.map +0 -1
  377. package/packages/utils/dist/createDirectory.js +0 -54
  378. package/packages/utils/dist/createDirectory.js.map +0 -1
  379. package/packages/utils/dist/createZip.d.ts +0 -39
  380. package/packages/utils/dist/createZip.d.ts.map +0 -1
  381. package/packages/utils/dist/createZip.js +0 -114
  382. package/packages/utils/dist/createZip.js.map +0 -1
  383. package/packages/utils/dist/deepCopy.d.ts +0 -32
  384. package/packages/utils/dist/deepCopy.d.ts.map +0 -1
  385. package/packages/utils/dist/deepCopy.js +0 -79
  386. package/packages/utils/dist/deepCopy.js.map +0 -1
  387. package/packages/utils/dist/deepEqual.d.ts +0 -54
  388. package/packages/utils/dist/deepEqual.d.ts.map +0 -1
  389. package/packages/utils/dist/deepEqual.js +0 -130
  390. package/packages/utils/dist/deepEqual.js.map +0 -1
  391. package/packages/utils/dist/error.d.ts +0 -45
  392. package/packages/utils/dist/error.d.ts.map +0 -1
  393. package/packages/utils/dist/error.js +0 -54
  394. package/packages/utils/dist/error.js.map +0 -1
  395. package/packages/utils/dist/export.d.ts +0 -16
  396. package/packages/utils/dist/export.d.ts.map +0 -1
  397. package/packages/utils/dist/export.js +0 -16
  398. package/packages/utils/dist/export.js.map +0 -1
  399. package/packages/utils/dist/format.d.ts +0 -53
  400. package/packages/utils/dist/format.d.ts.map +0 -1
  401. package/packages/utils/dist/format.js +0 -78
  402. package/packages/utils/dist/format.js.map +0 -1
  403. package/packages/utils/dist/githubVersion.d.ts +0 -43
  404. package/packages/utils/dist/githubVersion.d.ts.map +0 -1
  405. package/packages/utils/dist/githubVersion.js +0 -70
  406. package/packages/utils/dist/githubVersion.js.map +0 -1
  407. package/packages/utils/dist/hex.d.ts +0 -89
  408. package/packages/utils/dist/hex.d.ts.map +0 -1
  409. package/packages/utils/dist/hex.js +0 -242
  410. package/packages/utils/dist/hex.js.map +0 -1
  411. package/packages/utils/dist/inspector.d.ts +0 -87
  412. package/packages/utils/dist/inspector.d.ts.map +0 -1
  413. package/packages/utils/dist/inspector.js +0 -268
  414. package/packages/utils/dist/inspector.js.map +0 -1
  415. package/packages/utils/dist/isValid.d.ts +0 -103
  416. package/packages/utils/dist/isValid.d.ts.map +0 -1
  417. package/packages/utils/dist/isValid.js +0 -162
  418. package/packages/utils/dist/isValid.js.map +0 -1
  419. package/packages/utils/dist/network.d.ts +0 -105
  420. package/packages/utils/dist/network.d.ts.map +0 -1
  421. package/packages/utils/dist/network.js +0 -201
  422. package/packages/utils/dist/network.js.map +0 -1
  423. package/packages/utils/dist/npmRoot.d.ts +0 -29
  424. package/packages/utils/dist/npmRoot.d.ts.map +0 -1
  425. package/packages/utils/dist/npmRoot.js +0 -41
  426. package/packages/utils/dist/npmRoot.js.map +0 -1
  427. package/packages/utils/dist/npmVersion.d.ts +0 -33
  428. package/packages/utils/dist/npmVersion.d.ts.map +0 -1
  429. package/packages/utils/dist/npmVersion.js +0 -76
  430. package/packages/utils/dist/npmVersion.js.map +0 -1
  431. package/packages/utils/dist/tracker.d.ts +0 -108
  432. package/packages/utils/dist/tracker.d.ts.map +0 -1
  433. package/packages/utils/dist/tracker.js +0 -264
  434. package/packages/utils/dist/tracker.js.map +0 -1
  435. package/packages/utils/dist/wait.d.ts +0 -54
  436. package/packages/utils/dist/wait.d.ts.map +0 -1
  437. package/packages/utils/dist/wait.js +0 -125
  438. package/packages/utils/dist/wait.js.map +0 -1
  439. package/packages/utils/package.json +0 -110
  440. package/packages/vitest-utils/LICENSE +0 -202
  441. package/packages/vitest-utils/dist/export.d.ts +0 -2
  442. package/packages/vitest-utils/dist/export.d.ts.map +0 -1
  443. package/packages/vitest-utils/dist/export.js +0 -2
  444. package/packages/vitest-utils/dist/export.js.map +0 -1
  445. package/packages/vitest-utils/dist/vitestHelpers.d.ts +0 -58
  446. package/packages/vitest-utils/dist/vitestHelpers.d.ts.map +0 -1
  447. package/packages/vitest-utils/dist/vitestHelpers.js +0 -119
  448. package/packages/vitest-utils/dist/vitestHelpers.js.map +0 -1
  449. package/packages/vitest-utils/package.json +0 -109
@@ -1,40 +1,9 @@
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.1.2
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 } 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
- * Converts a MatterbridgeEndpoint to a BaseDevice.
31
- *
32
- * @param {MatterbridgeEndpoint} device The MatterbridgeEndpoint to convert.
33
- * @returns {BaseDevice} The converted BaseDevice.
34
- */
35
5
  export function toBaseDevice(device) {
36
6
  return {
37
- // MatterbridgeEndpoint properties
38
7
  mode: device.mode,
39
8
  plugin: device.plugin,
40
9
  configUrl: device.configUrl,
@@ -54,25 +23,18 @@ export function toBaseDevice(device) {
54
23
  originalId: device.originalId,
55
24
  name: device.name,
56
25
  deviceType: device.deviceType,
57
- // Endpoint properties
58
26
  number: device.number,
59
27
  id: device.id,
60
28
  };
61
29
  }
62
- /**
63
- * Manages Matterbridge devices.
64
- */
65
30
  export class DeviceManager {
66
31
  _devices = new Map();
67
32
  log;
68
33
  server;
69
34
  debug = hasParameter('debug') || hasParameter('verbose');
70
35
  verbose = hasParameter('verbose');
71
- /**
72
- * Creates an instance of DeviceManager.
73
- */
74
36
  constructor() {
75
- this.log = new AnsiLogger({ logName: 'DeviceManager', logTimestampFormat: 4 /* TimestampFormat.TIME_MILLIS */, logLevel: hasParameter('debug') ? "debug" /* LogLevel.DEBUG */ : "info" /* LogLevel.INFO */ });
37
+ this.log = new AnsiLogger({ logName: 'DeviceManager', logTimestampFormat: 4, logLevel: hasParameter('debug') ? "debug" : "info" });
76
38
  this.log.debug('Matterbridge device manager starting...');
77
39
  this.server = new BroadcastServer('devices', this.log);
78
40
  this.server.on('broadcast_message', this.msgHandler.bind(this));
@@ -128,47 +90,18 @@ export class DeviceManager {
128
90
  }
129
91
  }
130
92
  }
131
- /**
132
- * Gets the number of devices.
133
- *
134
- * @returns {number} The number of devices.
135
- */
136
93
  get length() {
137
94
  return this._devices.size;
138
95
  }
139
- /**
140
- * Gets the number of devices.
141
- *
142
- * @returns {number} The number of devices.
143
- */
144
96
  get size() {
145
97
  return this._devices.size;
146
98
  }
147
- /**
148
- * Checks if a device with the specified unique ID exists.
149
- *
150
- * @param {string} uniqueId - The unique ID of the device.
151
- * @returns {boolean} True if the device exists, false otherwise.
152
- */
153
99
  has(uniqueId) {
154
100
  return this._devices.has(uniqueId);
155
101
  }
156
- /**
157
- * Gets a device by its unique ID.
158
- *
159
- * @param {string} uniqueId - The unique ID of the device.
160
- * @returns {MatterbridgeEndpoint | undefined} The device, or undefined if not found.
161
- */
162
102
  get(uniqueId) {
163
103
  return this._devices.get(uniqueId);
164
104
  }
165
- /**
166
- * Adds a device to the manager.
167
- *
168
- * @param {MatterbridgeEndpoint} device - The device to add.
169
- * @returns {MatterbridgeEndpoint} The added device.
170
- * @throws {Error} If the device does not have a unique ID.
171
- */
172
105
  set(device) {
173
106
  if (!device.uniqueId)
174
107
  throw new Error(`The device ${dev}${device.deviceName}${er} has not been initialized: uniqueId is required`);
@@ -177,13 +110,6 @@ export class DeviceManager {
177
110
  this._devices.set(device.uniqueId, device);
178
111
  return device;
179
112
  }
180
- /**
181
- * Removes a device from the manager.
182
- *
183
- * @param {MatterbridgeEndpoint} device - The device to remove.
184
- * @returns {boolean} True if the device was removed, false otherwise.
185
- * @throws {Error} If the device does not have a unique ID.
186
- */
187
113
  remove(device) {
188
114
  if (!device.uniqueId)
189
115
  throw new Error(`The device ${dev}${device.deviceName}${er} has not been initialized: uniqueId is required`);
@@ -191,59 +117,27 @@ export class DeviceManager {
191
117
  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`);
192
118
  return this._devices.delete(device.uniqueId);
193
119
  }
194
- /**
195
- * Clears all devices from the manager.
196
- */
197
120
  clear() {
198
121
  this._devices.clear();
199
122
  }
200
- /**
201
- * Converts a MatterbridgeEndpoint to a BaseDevice.
202
- *
203
- * @param {MatterbridgeEndpoint} device The MatterbridgeEndpoint to convert.
204
- * @returns {BaseDevice} The converted BaseDevice.
205
- */
206
123
  toBaseDevice(device) {
207
124
  return toBaseDevice(device);
208
125
  }
209
- /**
210
- * Gets an array of all devices.
211
- *
212
- * @returns {MatterbridgeEndpoint[]} An array of all devices.
213
- */
214
126
  array() {
215
127
  return Array.from(this._devices.values());
216
128
  }
217
- /**
218
- * Gets a base array of all devices suitable for serialization.
219
- *
220
- * @param {string} [pluginName] - Optional plugin name to filter devices.
221
- * @returns {ApiDevices[]} A base array of all devices.
222
- */
223
129
  baseArray(pluginName) {
224
130
  const devices = [];
225
131
  for (const device of Array.from(this._devices.values())) {
226
- // Filter by pluginName if provided
227
132
  if (pluginName && pluginName !== device.plugin)
228
133
  continue;
229
134
  devices.push(this.toBaseDevice(device));
230
135
  }
231
136
  return devices;
232
137
  }
233
- /**
234
- * Iterates over all devices.
235
- *
236
- * @returns {IterableIterator<MatterbridgeEndpoint>} An iterator for the devices.
237
- */
238
138
  [Symbol.iterator]() {
239
139
  return this._devices.values();
240
140
  }
241
- /**
242
- * Asynchronously iterates over each device and calls the provided callback function.
243
- *
244
- * @param {(device: MatterbridgeEndpoint) => Promise<void>} callback - The callback function to call with each device.
245
- * @returns {Promise<void>} A promise that resolves when all callbacks have been called.
246
- */
247
141
  async forEach(callback) {
248
142
  if (this.size === 0)
249
143
  return;
@@ -257,13 +151,7 @@ export class DeviceManager {
257
151
  });
258
152
  await Promise.all(tasks);
259
153
  }
260
- /**
261
- * Sets the log level.
262
- *
263
- * @param {LogLevel} logLevel - The log level to set.
264
- */
265
154
  set logLevel(logLevel) {
266
155
  this.log.logLevel = logLevel;
267
156
  }
268
157
  }
269
- //# sourceMappingURL=deviceManager.js.map
@@ -1,98 +1,23 @@
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
1
  import { ThermostatUserInterfaceConfiguration } from '@matter/types/clusters/thermostat-user-interface-configuration';
24
2
  import { FanControl } from '@matter/types/clusters/fan-control';
25
3
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
26
- /**
27
- * Options for configuring an {@link AirConditioner} instance.
28
- *
29
- * All temperatures in °C. Typical valid range 0–50 unless otherwise noted.
30
- */
31
4
  export interface AirConditionerOptions {
32
- /** Local ambient temperature (°C). Default 23. */
33
5
  localTemperature?: number;
34
- /** Occupied heating setpoint (°C). Default 21. */
35
6
  occupiedHeatingSetpoint?: number;
36
- /** Occupied cooling setpoint (°C). Default 25. */
37
7
  occupiedCoolingSetpoint?: number;
38
- /** Minimum setpoint dead band (°C). Default 1. */
39
8
  minSetpointDeadBand?: number;
40
- /** Minimum heat setpoint limit (°C). Default 0. */
41
9
  minHeatSetpointLimit?: number;
42
- /** Maximum heat setpoint limit (°C). Default 50. */
43
10
  maxHeatSetpointLimit?: number;
44
- /** Minimum cool setpoint limit (°C). Default 0. */
45
11
  minCoolSetpointLimit?: number;
46
- /** Maximum cool setpoint limit (°C). Default 50. */
47
12
  maxCoolSetpointLimit?: number;
48
- /** Temperature display mode. Default Celsius. */
49
13
  temperatureDisplayMode?: ThermostatUserInterfaceConfiguration.TemperatureDisplayMode;
50
- /** Keypad lockout mode. Default NoLockout. */
51
14
  keypadLockout?: ThermostatUserInterfaceConfiguration.KeypadLockout;
52
- /** Schedule programming visibility. Default ScheduleProgrammingPermitted. */
53
15
  scheduleProgrammingVisibility?: ThermostatUserInterfaceConfiguration.ScheduleProgrammingVisibility;
54
- /** Fan mode. Default Off. */
55
16
  fanMode?: FanControl.FanMode;
56
- /** Fan mode sequence. Default OffLowMedHighAuto. */
57
17
  fanModeSequence?: FanControl.FanModeSequence;
58
- /** Target fan percent setting (0–100). Default 0. */
59
18
  percentSetting?: number;
60
- /** Current fan percent (0–100). Default 0. */
61
19
  percentCurrent?: number;
62
20
  }
63
21
  export declare class AirConditioner extends MatterbridgeEndpoint {
64
- /**
65
- * Creates an instance of the AirConditioner class.
66
- *
67
- * 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.
68
- * A Room Air Conditioner MAY also support additional capabilities via endpoint composition.
69
- * The DF (Dead Front) feature is required for the On/Off cluster in this device type.
70
- *
71
- * @param {string} name - The name of the air conditioner.
72
- * @param {string} serial - The serial number of the air conditioner.
73
- * @param {AirConditionerOptions} [options] - Optional configuration values. Missing fields use defaults.
74
- *
75
- * Options defaults:
76
- * - localTemperature: 23
77
- * - occupiedHeatingSetpoint: 21
78
- * - occupiedCoolingSetpoint: 25
79
- * - minSetpointDeadBand: 1
80
- * - minHeatSetpointLimit: 0
81
- * - maxHeatSetpointLimit: 50
82
- * - minCoolSetpointLimit: 0
83
- * - maxCoolSetpointLimit: 50
84
- * - temperatureDisplayMode: Celsius
85
- * - keypadLockout: NoLockout
86
- * - scheduleProgrammingVisibility: ScheduleProgrammingPermitted
87
- * - fanMode: Off
88
- * - fanModeSequence: OffLowMedHighAuto
89
- * - percentSetting: 0
90
- * - percentCurrent: 0
91
- *
92
- * @returns {AirConditioner} The AirConditioner instance.
93
- *
94
- * @remarks Not supported by Google Home.
95
- */
96
22
  constructor(name: string, serial: string, options?: AirConditionerOptions);
97
23
  }
98
- //# sourceMappingURL=airConditioner.d.ts.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/types/clusters/thermostat-user-interface-configuration';
25
2
  import { FanControl } from '@matter/types/clusters/fan-control';
26
- // Matterbridge
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], { id: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` });
@@ -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,48 +1,5 @@
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
1
  import { PowerSource } from '@matter/types/clusters/power-source';
25
2
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
26
3
  export declare class BatteryStorage extends MatterbridgeEndpoint {
27
- /**
28
- * Creates an instance of the BatteryStorage class.
29
- *
30
- * @param {string} name - The name of the BatteryStorage.
31
- * @param {string} serial - The serial number of the BatteryStorage.
32
- * @param {number} [batPercentRemaining] - The percentage of battery remaining, defaults to `100` if not provided.
33
- * @param {PowerSource.BatChargeLevel} [batChargeLevel] - The battery charge level (default: PowerSource.BatChargeLevel.Ok).
34
- * @param {number} voltage - The voltage value in millivolts.
35
- * @param {number} current - The current value in milliamperes.
36
- * @param {number} power - The power value in milliwatts.
37
- * @param {number} energyImported - The total production value in mW/h.
38
- * @param {number} energyExported - 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
- * - A battery storage inverter that can charge its battery at a maximum power of 2000W and can
44
- * discharge the battery at a maximum power of 3000W, would have a absMinPower: -3000W, absMaxPower: 2000W.
45
- */
46
4
  constructor(name: string, serial: string, batPercentRemaining?: number, batChargeLevel?: PowerSource.BatChargeLevel, voltage?: number | bigint | null, current?: number | bigint | null, power?: number | bigint | null, energyImported?: number | bigint | null, energyExported?: number | bigint | null, absMinPower?: number, absMaxPower?: number);
47
5
  }
48
- //# sourceMappingURL=batteryStorage.d.ts.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/node';
26
2
  import { DeviceEnergyManagement } from '@matter/types/clusters/device-energy-management';
27
3
  import { PowerSource } from '@matter/types/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(' ', '')}` });
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,61 +1,6 @@
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
1
  import { Semtag } from '@matter/types';
24
2
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
25
3
  export declare class Cooktop extends MatterbridgeEndpoint {
26
- /**
27
- * Creates an instance of the Cooktop class.
28
- *
29
- * @param {string} name - The name of the cooktop.
30
- * @param {string} serial - The serial number of the cooktop.
31
- *
32
- * @remarks
33
- * 13.8 A cooktop is a cooking surface that heats food either by transferring currents from an electromagnetic
34
- * field located below the glass surface directly to the magnetic induction cookware placed
35
- * above or through traditional gas or electric burners.
36
- *
37
- * 13.8.4 A Cooktop SHALL be composed of zero or more endpoints with the Cook Surface device type.
38
- * An Cooktop is always defined via endpoint composition.
39
- * - Use `addSurface` to add one or more surfaces to the cooktop.
40
- */
41
4
  constructor(name: string, serial: string);
42
- /**
43
- * Adds a surface to the cooktop.
44
- *
45
- * @param {string} name - The name of the surface.
46
- * @param {Semtag[]} tagList - The tagList associated with the surface.
47
- * @param {number} selectedTemperatureLevel - The selected temperature level as an index of the supportedTemperatureLevels array. Defaults to 2 (which corresponds to 'Level 3').
48
- * @param {string[]} supportedTemperatureLevels - The list of supported temperature levels for the surface. Defaults to ['Level 1', 'Level 2', 'Level 3', 'Level 4', 'Level 5'].
49
- *
50
- * @returns {MatterbridgeEndpoint} The MatterbridgeEndpoint instance representing the surface.
51
- *
52
- * @remarks
53
- * 13.7 A Cook Surface device type represents a heating object on a cooktop or other similar device. It
54
- * SHALL only be used when composed as part of another device type.
55
- *
56
- * The OffOnly feature is required for the On/Off cluster in this device type due to safety requirements.
57
- * TemperatureLevel is the only valid temperature control mode.
58
- */
59
5
  addSurface(name: string, tagList: Semtag[], selectedTemperatureLevel?: number, supportedTemperatureLevels?: string[]): MatterbridgeEndpoint;
60
6
  }
61
- //# sourceMappingURL=cooktop.d.ts.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], { id: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` });
45
7
  this.createDefaultIdentifyClusterServer();
@@ -48,23 +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 OffOnly feature is required for the On/Off cluster in this device type due to safety requirements.
66
- * TemperatureLevel is the only valid temperature control mode.
67
- */
68
13
  addSurface(name, tagList, selectedTemperatureLevel = 2, supportedTemperatureLevels = ['Level 1', 'Level 2', 'Level 3', 'Level 4', 'Level 5']) {
69
14
  const surface = this.addChildDeviceType(name, cookSurface, { tagList }, true);
70
15
  surface.log.logName = name;
@@ -74,4 +19,3 @@ export class Cooktop extends MatterbridgeEndpoint {
74
19
  return surface;
75
20
  }
76
21
  }
77
- //# sourceMappingURL=cooktop.js.map