matterbridge 3.4.0 → 3.4.1-dev-20251126-9e86094

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 (322) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/broadcastServer.js +1 -93
  3. package/dist/broadcastServerTypes.js +0 -24
  4. package/dist/cli.js +1 -97
  5. package/dist/cliEmitter.js +0 -37
  6. package/dist/cliHistory.js +0 -38
  7. package/dist/clusters/export.js +0 -2
  8. package/dist/defaultConfigSchema.js +0 -24
  9. package/dist/deviceManager.js +1 -113
  10. package/dist/devices/airConditioner.js +0 -57
  11. package/dist/devices/batteryStorage.js +1 -48
  12. package/dist/devices/cooktop.js +0 -56
  13. package/dist/devices/dishwasher.js +0 -57
  14. package/dist/devices/evse.js +10 -74
  15. package/dist/devices/export.js +0 -5
  16. package/dist/devices/extractorHood.js +0 -43
  17. package/dist/devices/heatPump.js +2 -50
  18. package/dist/devices/laundryDryer.js +3 -62
  19. package/dist/devices/laundryWasher.js +4 -70
  20. package/dist/devices/microwaveOven.js +5 -88
  21. package/dist/devices/oven.js +0 -85
  22. package/dist/devices/refrigerator.js +0 -102
  23. package/dist/devices/roboticVacuumCleaner.js +9 -100
  24. package/dist/devices/solarPower.js +0 -38
  25. package/dist/devices/speaker.js +0 -84
  26. package/dist/devices/temperatureControl.js +3 -24
  27. package/dist/devices/waterHeater.js +2 -82
  28. package/dist/dgram/coap.js +13 -126
  29. package/dist/dgram/dgram.js +2 -114
  30. package/dist/dgram/mb_coap.js +3 -41
  31. package/dist/dgram/mb_mdns.js +15 -80
  32. package/dist/dgram/mdns.js +137 -299
  33. package/dist/dgram/multicast.js +1 -62
  34. package/dist/dgram/unicast.js +0 -54
  35. package/dist/frontend.js +35 -455
  36. package/dist/frontendTypes.js +0 -45
  37. package/dist/helpers.js +0 -53
  38. package/dist/index.js +0 -25
  39. package/dist/jestutils/export.js +0 -1
  40. package/dist/jestutils/jestHelpers.js +13 -352
  41. package/dist/logger/export.js +0 -1
  42. package/dist/matter/behaviors.js +0 -2
  43. package/dist/matter/clusters.js +0 -2
  44. package/dist/matter/devices.js +0 -2
  45. package/dist/matter/endpoints.js +0 -2
  46. package/dist/matter/export.js +0 -3
  47. package/dist/matter/types.js +0 -3
  48. package/dist/matterNode.js +8 -369
  49. package/dist/matterbridge.js +46 -787
  50. package/dist/matterbridgeAccessoryPlatform.js +0 -38
  51. package/dist/matterbridgeBehaviors.js +5 -68
  52. package/dist/matterbridgeDeviceTypes.js +14 -635
  53. package/dist/matterbridgeDynamicPlatform.js +0 -38
  54. package/dist/matterbridgeEndpoint.js +53 -1444
  55. package/dist/matterbridgeEndpointHelpers.js +20 -483
  56. package/dist/matterbridgeEndpointTypes.js +0 -25
  57. package/dist/matterbridgePlatform.js +1 -439
  58. package/dist/matterbridgeTypes.js +0 -26
  59. package/dist/pluginManager.js +5 -340
  60. package/dist/shelly.js +7 -168
  61. package/dist/storage/export.js +0 -1
  62. package/dist/update.js +0 -69
  63. package/dist/utils/colorUtils.js +2 -97
  64. package/dist/utils/commandLine.js +0 -60
  65. package/dist/utils/copyDirectory.js +0 -37
  66. package/dist/utils/createDirectory.js +0 -33
  67. package/dist/utils/createZip.js +2 -47
  68. package/dist/utils/deepCopy.js +0 -39
  69. package/dist/utils/deepEqual.js +1 -72
  70. package/dist/utils/error.js +0 -41
  71. package/dist/utils/export.js +0 -1
  72. package/dist/utils/format.js +0 -49
  73. package/dist/utils/hex.js +0 -124
  74. package/dist/utils/inspector.js +1 -69
  75. package/dist/utils/isvalid.js +0 -101
  76. package/dist/utils/network.js +5 -96
  77. package/dist/utils/spawn.js +1 -71
  78. package/dist/utils/tracker.js +1 -64
  79. package/dist/utils/wait.js +8 -60
  80. package/frontend/build/assets/index.js +4 -4
  81. package/frontend/build/assets/vendor_mui.js +1 -1
  82. package/frontend/build/assets/vendor_node_modules.js +19 -83
  83. package/frontend/build/assets/vendor_qrcode.js +1 -9
  84. package/frontend/build/assets/vendor_rjsf.js +1 -9
  85. package/frontend/package-lock.json +229 -439
  86. package/frontend/package.json +15 -15
  87. package/npm-shrinkwrap.json +165 -231
  88. package/package.json +2 -3
  89. package/dist/broadcastServer.d.ts +0 -115
  90. package/dist/broadcastServer.d.ts.map +0 -1
  91. package/dist/broadcastServer.js.map +0 -1
  92. package/dist/broadcastServerTypes.d.ts +0 -838
  93. package/dist/broadcastServerTypes.d.ts.map +0 -1
  94. package/dist/broadcastServerTypes.js.map +0 -1
  95. package/dist/cli.d.ts +0 -30
  96. package/dist/cli.d.ts.map +0 -1
  97. package/dist/cli.js.map +0 -1
  98. package/dist/cliEmitter.d.ts +0 -50
  99. package/dist/cliEmitter.d.ts.map +0 -1
  100. package/dist/cliEmitter.js.map +0 -1
  101. package/dist/cliHistory.d.ts +0 -48
  102. package/dist/cliHistory.d.ts.map +0 -1
  103. package/dist/cliHistory.js.map +0 -1
  104. package/dist/clusters/export.d.ts +0 -2
  105. package/dist/clusters/export.d.ts.map +0 -1
  106. package/dist/clusters/export.js.map +0 -1
  107. package/dist/defaultConfigSchema.d.ts +0 -28
  108. package/dist/defaultConfigSchema.d.ts.map +0 -1
  109. package/dist/defaultConfigSchema.js.map +0 -1
  110. package/dist/deviceManager.d.ts +0 -135
  111. package/dist/deviceManager.d.ts.map +0 -1
  112. package/dist/deviceManager.js.map +0 -1
  113. package/dist/devices/airConditioner.d.ts +0 -98
  114. package/dist/devices/airConditioner.d.ts.map +0 -1
  115. package/dist/devices/airConditioner.js.map +0 -1
  116. package/dist/devices/batteryStorage.d.ts +0 -48
  117. package/dist/devices/batteryStorage.d.ts.map +0 -1
  118. package/dist/devices/batteryStorage.js.map +0 -1
  119. package/dist/devices/cooktop.d.ts +0 -61
  120. package/dist/devices/cooktop.d.ts.map +0 -1
  121. package/dist/devices/cooktop.js.map +0 -1
  122. package/dist/devices/dishwasher.d.ts +0 -71
  123. package/dist/devices/dishwasher.d.ts.map +0 -1
  124. package/dist/devices/dishwasher.js.map +0 -1
  125. package/dist/devices/evse.d.ts +0 -76
  126. package/dist/devices/evse.d.ts.map +0 -1
  127. package/dist/devices/evse.js.map +0 -1
  128. package/dist/devices/export.d.ts +0 -17
  129. package/dist/devices/export.d.ts.map +0 -1
  130. package/dist/devices/export.js.map +0 -1
  131. package/dist/devices/extractorHood.d.ts +0 -46
  132. package/dist/devices/extractorHood.d.ts.map +0 -1
  133. package/dist/devices/extractorHood.js.map +0 -1
  134. package/dist/devices/heatPump.d.ts +0 -47
  135. package/dist/devices/heatPump.d.ts.map +0 -1
  136. package/dist/devices/heatPump.js.map +0 -1
  137. package/dist/devices/laundryDryer.d.ts +0 -67
  138. package/dist/devices/laundryDryer.d.ts.map +0 -1
  139. package/dist/devices/laundryDryer.js.map +0 -1
  140. package/dist/devices/laundryWasher.d.ts +0 -81
  141. package/dist/devices/laundryWasher.d.ts.map +0 -1
  142. package/dist/devices/laundryWasher.js.map +0 -1
  143. package/dist/devices/microwaveOven.d.ts +0 -168
  144. package/dist/devices/microwaveOven.d.ts.map +0 -1
  145. package/dist/devices/microwaveOven.js.map +0 -1
  146. package/dist/devices/oven.d.ts +0 -105
  147. package/dist/devices/oven.d.ts.map +0 -1
  148. package/dist/devices/oven.js.map +0 -1
  149. package/dist/devices/refrigerator.d.ts +0 -118
  150. package/dist/devices/refrigerator.d.ts.map +0 -1
  151. package/dist/devices/refrigerator.js.map +0 -1
  152. package/dist/devices/roboticVacuumCleaner.d.ts +0 -112
  153. package/dist/devices/roboticVacuumCleaner.d.ts.map +0 -1
  154. package/dist/devices/roboticVacuumCleaner.js.map +0 -1
  155. package/dist/devices/solarPower.d.ts +0 -40
  156. package/dist/devices/solarPower.d.ts.map +0 -1
  157. package/dist/devices/solarPower.js.map +0 -1
  158. package/dist/devices/speaker.d.ts +0 -87
  159. package/dist/devices/speaker.d.ts.map +0 -1
  160. package/dist/devices/speaker.js.map +0 -1
  161. package/dist/devices/temperatureControl.d.ts +0 -166
  162. package/dist/devices/temperatureControl.d.ts.map +0 -1
  163. package/dist/devices/temperatureControl.js.map +0 -1
  164. package/dist/devices/waterHeater.d.ts +0 -111
  165. package/dist/devices/waterHeater.d.ts.map +0 -1
  166. package/dist/devices/waterHeater.js.map +0 -1
  167. package/dist/dgram/coap.d.ts +0 -205
  168. package/dist/dgram/coap.d.ts.map +0 -1
  169. package/dist/dgram/coap.js.map +0 -1
  170. package/dist/dgram/dgram.d.ts +0 -141
  171. package/dist/dgram/dgram.d.ts.map +0 -1
  172. package/dist/dgram/dgram.js.map +0 -1
  173. package/dist/dgram/mb_coap.d.ts +0 -24
  174. package/dist/dgram/mb_coap.d.ts.map +0 -1
  175. package/dist/dgram/mb_coap.js.map +0 -1
  176. package/dist/dgram/mb_mdns.d.ts +0 -24
  177. package/dist/dgram/mb_mdns.d.ts.map +0 -1
  178. package/dist/dgram/mb_mdns.js.map +0 -1
  179. package/dist/dgram/mdns.d.ts +0 -290
  180. package/dist/dgram/mdns.d.ts.map +0 -1
  181. package/dist/dgram/mdns.js.map +0 -1
  182. package/dist/dgram/multicast.d.ts +0 -67
  183. package/dist/dgram/multicast.d.ts.map +0 -1
  184. package/dist/dgram/multicast.js.map +0 -1
  185. package/dist/dgram/unicast.d.ts +0 -56
  186. package/dist/dgram/unicast.d.ts.map +0 -1
  187. package/dist/dgram/unicast.js.map +0 -1
  188. package/dist/frontend.d.ts +0 -238
  189. package/dist/frontend.d.ts.map +0 -1
  190. package/dist/frontend.js.map +0 -1
  191. package/dist/frontendTypes.d.ts +0 -529
  192. package/dist/frontendTypes.d.ts.map +0 -1
  193. package/dist/frontendTypes.js.map +0 -1
  194. package/dist/helpers.d.ts +0 -48
  195. package/dist/helpers.d.ts.map +0 -1
  196. package/dist/helpers.js.map +0 -1
  197. package/dist/index.d.ts +0 -34
  198. package/dist/index.d.ts.map +0 -1
  199. package/dist/index.js.map +0 -1
  200. package/dist/jestutils/export.d.ts +0 -2
  201. package/dist/jestutils/export.d.ts.map +0 -1
  202. package/dist/jestutils/export.js.map +0 -1
  203. package/dist/jestutils/jestHelpers.d.ts +0 -303
  204. package/dist/jestutils/jestHelpers.d.ts.map +0 -1
  205. package/dist/jestutils/jestHelpers.js.map +0 -1
  206. package/dist/logger/export.d.ts +0 -2
  207. package/dist/logger/export.d.ts.map +0 -1
  208. package/dist/logger/export.js.map +0 -1
  209. package/dist/matter/behaviors.d.ts +0 -2
  210. package/dist/matter/behaviors.d.ts.map +0 -1
  211. package/dist/matter/behaviors.js.map +0 -1
  212. package/dist/matter/clusters.d.ts +0 -2
  213. package/dist/matter/clusters.d.ts.map +0 -1
  214. package/dist/matter/clusters.js.map +0 -1
  215. package/dist/matter/devices.d.ts +0 -2
  216. package/dist/matter/devices.d.ts.map +0 -1
  217. package/dist/matter/devices.js.map +0 -1
  218. package/dist/matter/endpoints.d.ts +0 -2
  219. package/dist/matter/endpoints.d.ts.map +0 -1
  220. package/dist/matter/endpoints.js.map +0 -1
  221. package/dist/matter/export.d.ts +0 -5
  222. package/dist/matter/export.d.ts.map +0 -1
  223. package/dist/matter/export.js.map +0 -1
  224. package/dist/matter/types.d.ts +0 -3
  225. package/dist/matter/types.d.ts.map +0 -1
  226. package/dist/matter/types.js.map +0 -1
  227. package/dist/matterNode.d.ts +0 -342
  228. package/dist/matterNode.d.ts.map +0 -1
  229. package/dist/matterNode.js.map +0 -1
  230. package/dist/matterbridge.d.ts +0 -473
  231. package/dist/matterbridge.d.ts.map +0 -1
  232. package/dist/matterbridge.js.map +0 -1
  233. package/dist/matterbridgeAccessoryPlatform.d.ts +0 -41
  234. package/dist/matterbridgeAccessoryPlatform.d.ts.map +0 -1
  235. package/dist/matterbridgeAccessoryPlatform.js.map +0 -1
  236. package/dist/matterbridgeBehaviors.d.ts +0 -2404
  237. package/dist/matterbridgeBehaviors.d.ts.map +0 -1
  238. package/dist/matterbridgeBehaviors.js.map +0 -1
  239. package/dist/matterbridgeDeviceTypes.d.ts +0 -698
  240. package/dist/matterbridgeDeviceTypes.d.ts.map +0 -1
  241. package/dist/matterbridgeDeviceTypes.js.map +0 -1
  242. package/dist/matterbridgeDynamicPlatform.d.ts +0 -41
  243. package/dist/matterbridgeDynamicPlatform.d.ts.map +0 -1
  244. package/dist/matterbridgeDynamicPlatform.js.map +0 -1
  245. package/dist/matterbridgeEndpoint.d.ts +0 -1507
  246. package/dist/matterbridgeEndpoint.d.ts.map +0 -1
  247. package/dist/matterbridgeEndpoint.js.map +0 -1
  248. package/dist/matterbridgeEndpointHelpers.d.ts +0 -787
  249. package/dist/matterbridgeEndpointHelpers.d.ts.map +0 -1
  250. package/dist/matterbridgeEndpointHelpers.js.map +0 -1
  251. package/dist/matterbridgeEndpointTypes.d.ts +0 -166
  252. package/dist/matterbridgeEndpointTypes.d.ts.map +0 -1
  253. package/dist/matterbridgeEndpointTypes.js.map +0 -1
  254. package/dist/matterbridgePlatform.d.ts +0 -524
  255. package/dist/matterbridgePlatform.d.ts.map +0 -1
  256. package/dist/matterbridgePlatform.js.map +0 -1
  257. package/dist/matterbridgeTypes.d.ts +0 -251
  258. package/dist/matterbridgeTypes.d.ts.map +0 -1
  259. package/dist/matterbridgeTypes.js.map +0 -1
  260. package/dist/pluginManager.d.ts +0 -371
  261. package/dist/pluginManager.d.ts.map +0 -1
  262. package/dist/pluginManager.js.map +0 -1
  263. package/dist/shelly.d.ts +0 -174
  264. package/dist/shelly.d.ts.map +0 -1
  265. package/dist/shelly.js.map +0 -1
  266. package/dist/storage/export.d.ts +0 -2
  267. package/dist/storage/export.d.ts.map +0 -1
  268. package/dist/storage/export.js.map +0 -1
  269. package/dist/update.d.ts +0 -75
  270. package/dist/update.d.ts.map +0 -1
  271. package/dist/update.js.map +0 -1
  272. package/dist/utils/colorUtils.d.ts +0 -101
  273. package/dist/utils/colorUtils.d.ts.map +0 -1
  274. package/dist/utils/colorUtils.js.map +0 -1
  275. package/dist/utils/commandLine.d.ts +0 -66
  276. package/dist/utils/commandLine.d.ts.map +0 -1
  277. package/dist/utils/commandLine.js.map +0 -1
  278. package/dist/utils/copyDirectory.d.ts +0 -35
  279. package/dist/utils/copyDirectory.d.ts.map +0 -1
  280. package/dist/utils/copyDirectory.js.map +0 -1
  281. package/dist/utils/createDirectory.d.ts +0 -34
  282. package/dist/utils/createDirectory.d.ts.map +0 -1
  283. package/dist/utils/createDirectory.js.map +0 -1
  284. package/dist/utils/createZip.d.ts +0 -39
  285. package/dist/utils/createZip.d.ts.map +0 -1
  286. package/dist/utils/createZip.js.map +0 -1
  287. package/dist/utils/deepCopy.d.ts +0 -32
  288. package/dist/utils/deepCopy.d.ts.map +0 -1
  289. package/dist/utils/deepCopy.js.map +0 -1
  290. package/dist/utils/deepEqual.d.ts +0 -54
  291. package/dist/utils/deepEqual.d.ts.map +0 -1
  292. package/dist/utils/deepEqual.js.map +0 -1
  293. package/dist/utils/error.d.ts +0 -44
  294. package/dist/utils/error.d.ts.map +0 -1
  295. package/dist/utils/error.js.map +0 -1
  296. package/dist/utils/export.d.ts +0 -13
  297. package/dist/utils/export.d.ts.map +0 -1
  298. package/dist/utils/export.js.map +0 -1
  299. package/dist/utils/format.d.ts +0 -53
  300. package/dist/utils/format.d.ts.map +0 -1
  301. package/dist/utils/format.js.map +0 -1
  302. package/dist/utils/hex.d.ts +0 -89
  303. package/dist/utils/hex.d.ts.map +0 -1
  304. package/dist/utils/hex.js.map +0 -1
  305. package/dist/utils/inspector.d.ts +0 -87
  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 +0 -103
  309. package/dist/utils/isvalid.d.ts.map +0 -1
  310. package/dist/utils/isvalid.js.map +0 -1
  311. package/dist/utils/network.d.ts +0 -111
  312. package/dist/utils/network.d.ts.map +0 -1
  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.map +0 -1
  320. package/dist/utils/wait.d.ts +0 -54
  321. package/dist/utils/wait.d.ts.map +0 -1
  322. package/dist/utils/wait.js.map +0 -1
package/CHANGELOG.md CHANGED
@@ -28,6 +28,22 @@ Advantages:
28
28
  - individual plugin isolation in childbridge mode;
29
29
  - ability to update the plugin in childbridge mode without restarting matterbridge;
30
30
 
31
+ ## [3.4.1] - 2025-11-30
32
+
33
+ ### Added
34
+
35
+ ### Changed
36
+
37
+ - [package]: Updated dependencies.
38
+ - [frontend]: Updated dependencies.
39
+ - [frontend]: Bumped `frontend` version to 3.3.2.
40
+
41
+ ### Fixed
42
+
43
+ - [frontend]: Fixed when the user put special characters in password. Thanks Dabern (https://github.com/Luligu/matterbridge/issues/443).
44
+
45
+ <a href="https://www.buymeacoffee.com/luligugithub"><img src="bmc-button.svg" alt="Buy me a coffee" width="80"></a>
46
+
31
47
  ## [3.4.0] - 2025-11-26
32
48
 
33
49
  ### Development Breaking Changes
@@ -1,36 +1,9 @@
1
- /**
2
- * This file contains the BroadcastServer class.
3
- *
4
- * @file broadcastServer.ts
5
- * @author Luca Liguori
6
- * @created 2025-10-05
7
- * @version 1.0.3
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
- // eslint-disable-next-line no-console
25
1
  if (process.argv.includes('--loader') || process.argv.includes('-loader'))
26
2
  console.log('\u001B[32mBroadcastServer loaded.\u001B[40;0m');
27
3
  import { EventEmitter } from 'node:events';
28
4
  import { BroadcastChannel } from 'node:worker_threads';
29
5
  import { CYAN, db, debugStringify } from 'node-ansi-logger';
30
6
  import { hasParameter } from './utils/commandLine.js';
31
- /**
32
- * BroadcastServer class to handle broadcast messages between workers with BroadcastChannel.
33
- */
34
7
  export class BroadcastServer extends EventEmitter {
35
8
  name;
36
9
  log;
@@ -38,13 +11,6 @@ export class BroadcastServer extends EventEmitter {
38
11
  broadcastChannel;
39
12
  debug = hasParameter('debug') || hasParameter('verbose');
40
13
  verbose = hasParameter('verbose');
41
- /**
42
- * Creates an instance of BroadcastServer.
43
- *
44
- * @param {string} name - The name of the broadcast server.
45
- * @param {AnsiLogger} log - The logger instance to use for logging.
46
- * @param {string} channel - The channel name for the broadcast. Default is 'broadcast-channel'.
47
- */
48
14
  constructor(name, log, channel = 'broadcast-channel') {
49
15
  super();
50
16
  this.name = name;
@@ -53,72 +19,30 @@ export class BroadcastServer extends EventEmitter {
53
19
  this.broadcastChannel = new BroadcastChannel(this.channel);
54
20
  this.broadcastChannel.onmessage = this.broadcastMessageHandler.bind(this);
55
21
  }
56
- /**
57
- * Closes the broadcast channel.
58
- *
59
- * @returns {void}
60
- */
61
22
  close() {
62
- // @ts-expect-error: wrong type definition in node.d.ts
63
23
  this.broadcastChannel.onmessage = null;
64
24
  this.broadcastChannel.close();
65
25
  }
66
- /**
67
- * Generates a unique ID with range 100000-999999.
68
- *
69
- * @returns {number} - A unique ID between 100000 and 999999
70
- */
71
26
  getUniqueId() {
72
- return Math.floor(Math.random() * (999999 - 100000 + 1)) + 100000; // random int between 100000 and 999999
27
+ return Math.floor(Math.random() * (999999 - 100000 + 1)) + 100000;
73
28
  }
74
- /**
75
- * Type guard to check if a message is a request of a specific type.
76
- *
77
- * @param {unknown} msg - The message to check.
78
- * @param {T} type - The type to check against.
79
- * @returns {msg is WorkerRequest<T>} True if the message is a request of the specified type.
80
- */
81
29
  isWorkerRequest(msg, type) {
82
30
  return typeof msg === 'object' && msg !== null && 'id' in msg && 'timestamp' in msg && 'type' in msg && msg.type === type && !('response' in msg) && 'src' in msg && 'dst' in msg;
83
31
  }
84
- /**
85
- * Type guard to check if a message is a response of a specific type.
86
- *
87
- * @param {unknown} msg - The message to check.
88
- * @param {T} type - The type to check against.
89
- * @returns {msg is WorkerResponse<T>} True if the message is a response of the specified type.
90
- */
91
32
  isWorkerResponse(msg, type) {
92
33
  return typeof msg === 'object' && msg !== null && 'id' in msg && 'timestamp' in msg && 'type' in msg && msg.type === type && 'response' in msg && 'src' in msg && 'dst' in msg;
93
34
  }
94
- /**
95
- * Handles incoming broadcast messages.
96
- *
97
- * @param {MessageEvent} event - The message event containing the broadcast message.
98
- * @returns {void}
99
- */
100
35
  broadcastMessageHandler(event) {
101
36
  const data = event.data;
102
37
  if (this.verbose && (data.dst === this.name || data.dst === 'all'))
103
38
  this.log.debug(`Server ${CYAN}${this.name}${db} received broadcast message: ${debugStringify(data)}`);
104
39
  this.emit('broadcast_message', data);
105
40
  }
106
- /**
107
- * Broadcast a message to all workers.
108
- *
109
- * @param {WorkerMessage} message - The message to broadcast.
110
- */
111
41
  broadcast(message) {
112
42
  if (this.verbose)
113
43
  this.log.debug(`Broadcasting message: ${debugStringify(message)}`);
114
44
  this.broadcastChannel.postMessage(message);
115
45
  }
116
- /**
117
- * Broadcast a request message to all workers.
118
- *
119
- * @param {WorkerRequest<T>} message - The typed request message to broadcast.
120
- * @returns {void}
121
- */
122
46
  request(message) {
123
47
  if (message.id === undefined) {
124
48
  message.id = this.getUniqueId();
@@ -134,12 +58,6 @@ export class BroadcastServer extends EventEmitter {
134
58
  this.log.debug(`Broadcasting request message: ${debugStringify(message)}`);
135
59
  this.broadcastChannel.postMessage(message);
136
60
  }
137
- /**
138
- * Broadcast a response message to all workers.
139
- *
140
- * @param {WorkerResponse<T>} message - The typed response message to broadcast.
141
- * @returns {void}
142
- */
143
61
  respond(message) {
144
62
  if (message.timestamp === undefined) {
145
63
  message.timestamp = Date.now();
@@ -152,15 +70,6 @@ export class BroadcastServer extends EventEmitter {
152
70
  this.log.debug(`Broadcasting response message: ${debugStringify(message)}`);
153
71
  this.broadcastChannel.postMessage(message);
154
72
  }
155
- /**
156
- * Fetch data from a worker.
157
- * It broadcasts a request message and waits for a response with the same id.
158
- *
159
- * @param {WorkerRequest<T>} message - The typed request message to broadcast.
160
- * @param {number} timeout - The timeout in milliseconds to wait for a response. Default is 250ms.
161
- * @returns {Promise<WorkerResponse<T>>} A promise that resolves with the response from the worker or rejects on timeout.
162
- * @throws {Error} If the fetch operation times out after 250ms.
163
- */
164
73
  async fetch(message, timeout = 250) {
165
74
  if (message.id === undefined) {
166
75
  message.id = this.getUniqueId();
@@ -193,4 +102,3 @@ export class BroadcastServer extends EventEmitter {
193
102
  });
194
103
  }
195
104
  }
196
- //# sourceMappingURL=broadcastServer.js.map
@@ -1,25 +1 @@
1
- /**
2
- * This file contains the BroadcastServer types.
3
- *
4
- * @file broadcastServerTypes.ts
5
- * @author Luca Liguori
6
- * @created 2025-10-05
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
  export {};
25
- //# sourceMappingURL=broadcastServerTypes.js.map
package/dist/cli.js CHANGED
@@ -1,33 +1,6 @@
1
- /**
2
- * This file contains the CLI entry point of Matterbridge.
3
- *
4
- * @file cli.ts
5
- * @author Luca Liguori
6
- * @created 2023-12-29
7
- * @version 3.0.0
8
- * @license Apache-2.0
9
- *
10
- * Copyright 2023, 2024, 2025 Luca Liguori.
11
- *
12
- * Licensed under the Apache License, Version 2.0 (the "License");
13
- * you may not use this file except in compliance with the License.
14
- * You may obtain a copy of the License at
15
- *
16
- * http://www.apache.org/licenses/LICENSE-2.0
17
- *
18
- * Unless required by applicable law or agreed to in writing, software
19
- * distributed under the License is distributed on an "AS IS" BASIS,
20
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21
- * See the License for the specific language governing permissions and
22
- * limitations under the License.
23
- */
24
- /* eslint-disable no-console */
25
- /* eslint-disable n/no-process-exit */
26
1
  if (process.argv.includes('--loader') || process.argv.includes('-loader'))
27
2
  console.log('\u001B[32mCli loaded.\u001B[40;0m');
28
- // AnsiLogger module
29
3
  import { AnsiLogger } from 'node-ansi-logger';
30
- // Cli
31
4
  import { cliEmitter } from './cliEmitter.js';
32
5
  import { hasParameter, hasAnyParameter } from './utils/commandLine.js';
33
6
  import { inspectError } from './utils/error.js';
@@ -37,10 +10,7 @@ import { formatBytes, formatUptime } from './utils/format.js';
37
10
  export let instance;
38
11
  export const tracker = new Tracker('Cli', false, false);
39
12
  export const inspector = new Inspector('Cli', false, false);
40
- const log = new AnsiLogger({ logName: 'Cli', logTimestampFormat: 4 /* TimestampFormat.TIME_MILLIS */, logLevel: hasParameter('debug') ? "debug" /* LogLevel.DEBUG */ : "info" /* LogLevel.INFO */ });
41
- /**
42
- * Starts the CPU and memory tracker.
43
- */
13
+ const log = new AnsiLogger({ logName: 'Cli', logTimestampFormat: 4, logLevel: hasParameter('debug') ? "debug" : "info" });
44
14
  function startCpuMemoryCheck() {
45
15
  log.debug(`Cpu memory check starting...`);
46
16
  tracker.start();
@@ -53,50 +23,26 @@ function startCpuMemoryCheck() {
53
23
  });
54
24
  log.debug(`Cpu memory check started`);
55
25
  }
56
- /**
57
- * Stops the CPU and memory tracker.
58
- */
59
26
  function stopCpuMemoryCheck() {
60
27
  log.debug(`Cpu memory check stopping...`);
61
28
  tracker.stop();
62
29
  tracker.removeAllListeners();
63
30
  log.debug(`Cpu memory check stopped`);
64
31
  }
65
- /**
66
- * Starts the inspector for heap sampling.
67
- * This function is called when the -inspect parameter is passed.
68
- */
69
32
  async function startInspector() {
70
33
  await inspector.start();
71
34
  }
72
- /**
73
- * Stops the heap sampling and saves the profile.
74
- * This function is called when the -inspect parameter is passed.
75
- */
76
35
  async function stopInspector() {
77
36
  await inspector.stop();
78
37
  }
79
- /**
80
- * Takes a heap snapshot
81
- */
82
38
  async function takeHeapSnapshot() {
83
39
  await inspector.takeHeapSnapshot();
84
40
  }
85
- /**
86
- * Triggers a manual garbage collection.
87
- * This function is working only if the node process is started with --expose_gc.
88
- *
89
- * @remarks To check the effect of the garbage collection, add also --trace_gc or --trace_gc_verbose.
90
- */
91
41
  function triggerGarbageCollection() {
92
42
  inspector.runGarbageCollector();
93
43
  }
94
- /**
95
- * Registers event handlers for the Matterbridge instance.
96
- */
97
44
  function registerHandlers() {
98
45
  log.debug('Registering event handlers...');
99
- // istanbul ignore next cause registerHandlers is called only if instance is defined
100
46
  if (!instance)
101
47
  return;
102
48
  instance.on('shutdown', () => shutdown());
@@ -110,9 +56,6 @@ function registerHandlers() {
110
56
  instance.on('triggergarbagecollection', () => triggerGarbageCollection());
111
57
  log.debug('Registered event handlers');
112
58
  }
113
- /**
114
- * Shuts down the Matterbridge instance and exits the process.
115
- */
116
59
  async function shutdown() {
117
60
  log.debug('Received shutdown event, exiting...');
118
61
  if (hasParameter('inspect'))
@@ -121,56 +64,26 @@ async function shutdown() {
121
64
  cliEmitter.emit('shutdown');
122
65
  process.exit(0);
123
66
  }
124
- /**
125
- * Restarts the Matterbridge instance.
126
- */
127
67
  async function restart() {
128
68
  log.debug('Received restart event, loading...');
129
69
  const { Matterbridge } = await import('./matterbridge.js');
130
70
  instance = await Matterbridge.loadInstance(true);
131
71
  registerHandlers();
132
72
  }
133
- /**
134
- * Updates the Matterbridge instance.
135
- */
136
73
  async function update() {
137
74
  log.debug('Received update event, updating...');
138
- // TODO: Implement update logic outside of matterbridge
139
75
  const { Matterbridge } = await import('./matterbridge.js');
140
76
  instance = await Matterbridge.loadInstance(true);
141
77
  registerHandlers();
142
78
  }
143
- /**
144
- * Starts the CPU and memory check when the -startmemorycheck parameter is passed.
145
- */
146
79
  function start() {
147
80
  log.debug('Received start memory check event');
148
81
  startCpuMemoryCheck();
149
82
  }
150
- /**
151
- * Stops the CPU and memory check when the -stopmemorycheck parameter is passed.
152
- */
153
83
  function stop() {
154
84
  log.debug('Received stop memory check event');
155
85
  stopCpuMemoryCheck();
156
86
  }
157
- /**
158
- * Main function that initializes the Matterbridge instance and starts the CLI.
159
- *
160
- * @remarks
161
- *
162
- * Debug parameters:
163
- *
164
- * --debug enables debug logging.
165
- *
166
- * --verbose enables verbose logging.
167
- *
168
- * --loader enables loader logging.
169
- *
170
- * --inspect enables the inspector for heap sampling.
171
- *
172
- * --snapshotinterval <milliseconds> can be used to set the heap snapshot interval. Default is undefined. Minimum is 30000 ms.
173
- */
174
87
  async function main() {
175
88
  log.debug(`Cli main() started`);
176
89
  startCpuMemoryCheck();
@@ -180,7 +93,6 @@ async function main() {
180
93
  const { Matterbridge } = await import('./matterbridge.js');
181
94
  instance = await Matterbridge.loadInstance(true);
182
95
  log.debug(`***Matterbridge.loadInstance(true) exited`);
183
- // Check if the instance needs to shut down from parseCommandLine()
184
96
  if (!instance || instance.shutdown) {
185
97
  shutdown();
186
98
  }
@@ -198,18 +110,11 @@ main().catch((error) => {
198
110
  inspectError(log, 'Matterbridge.loadInstance() failed with error', error);
199
111
  shutdown();
200
112
  });
201
- /**
202
- * Displays the version.
203
- */
204
113
  async function version() {
205
- // Dynamic JSON import (Node >= 20) with import attributes
206
114
  const { default: pkg } = await import('../package.json', { with: { type: 'json' } });
207
115
  console.log(`Matterbridge version ${pkg.version}`);
208
116
  process.exit(0);
209
117
  }
210
- /**
211
- * Displays the help.
212
- */
213
118
  function help() {
214
119
  console.log(`
215
120
  Usage: matterbridge [options] [command]
@@ -263,4 +168,3 @@ function help() {
263
168
  `);
264
169
  process.exit(0);
265
170
  }
266
- //# sourceMappingURL=cli.js.map
@@ -1,49 +1,12 @@
1
- /**
2
- * This file contains the CLI emitter.
3
- *
4
- * @file cliEmitter.ts
5
- * @author Luca Liguori
6
- * @created 2025-07-04
7
- * @version 1.0.2
8
- * @license Apache-2.0
9
- *
10
- * Copyright 2025, 2026, 2027 Luca Liguori.
11
- *
12
- * Licensed under the Apache License, Version 2.0 (the "License");
13
- * you may not use this file except in compliance with the License.
14
- * You may obtain a copy of the License at
15
- *
16
- * http://www.apache.org/licenses/LICENSE-2.0
17
- *
18
- * Unless required by applicable law or agreed to in writing, software
19
- * distributed under the License is distributed on an "AS IS" BASIS,
20
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21
- * See the License for the specific language governing permissions and
22
- * limitations under the License.
23
- */
24
- // eslint-disable-next-line no-console
25
1
  if (process.argv.includes('--loader') || process.argv.includes('-loader'))
26
2
  console.log('\u001B[32mCli emitter loaded.\u001B[40;0m');
27
3
  import { EventEmitter } from 'node:events';
28
4
  export const cliEmitter = new EventEmitter();
29
5
  export let lastOsCpuUsage = 0;
30
6
  export let lastProcessCpuUsage = 0;
31
- /**
32
- * Sets the last os CPU usage.
33
- *
34
- * @param {number} val - The os CPU usage percentage to set.
35
- * @returns {void}
36
- */
37
7
  export function setLastOsCpuUsage(val) {
38
8
  lastOsCpuUsage = val;
39
9
  }
40
- /**
41
- * Sets the last process CPU usage.
42
- *
43
- * @param {number} val - The process CPU usage percentage to set.
44
- * @returns {void}
45
- */
46
10
  export function setLastProcessCpuUsage(val) {
47
11
  lastProcessCpuUsage = val;
48
12
  }
49
- //# sourceMappingURL=cliEmitter.js.map
@@ -1,40 +1,9 @@
1
- /**
2
- * This file contains the CLI history page generator.
3
- *
4
- * @file cliHistory.ts
5
- * @author Luca Liguori
6
- * @created 2025-10-09
7
- * @version 1.0.1
8
- * @license Apache-2.0
9
- *
10
- * Copyright 2025, 2026, 2027 Luca Liguori.
11
- *
12
- * Licensed under the Apache License, Version 2.0 (the "License");
13
- * you may not use this file except in compliance with the License.
14
- * You may obtain a copy of the License at
15
- *
16
- * http://www.apache.org/licenses/LICENSE-2.0
17
- *
18
- * Unless required by applicable law or agreed to in writing, software
19
- * distributed under the License is distributed on an "AS IS" BASIS,
20
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21
- * See the License for the specific language governing permissions and
22
- * limitations under the License.
23
- */
24
- // eslint-disable-next-line no-console
25
1
  if (process.argv.includes('--loader') || process.argv.includes('-loader'))
26
2
  console.log('\u001B[32mCli history loaded.\u001B[40;0m');
27
3
  import { writeFileSync } from 'node:fs';
28
4
  import path from 'node:path';
29
5
  import os from 'node:os';
30
6
  import { Tracker } from './utils/tracker.js';
31
- /**
32
- * Generates a static HTML dashboard displaying CPU and memory history.
33
- *
34
- * @param {GenerateHistoryPageOptions} [options] - Optional configuration for output path, page title, and refresh interval.
35
- *
36
- * @returns {string | undefined} The absolute path to the generated HTML file, or undefined if no samples exist.
37
- */
38
7
  export function generateHistoryPage(options = {}) {
39
8
  const pageTitle = options.pageTitle ?? 'Matterbridge CPU & Memory History';
40
9
  const hostname = options.hostname ?? os.hostname();
@@ -814,13 +783,6 @@ export function generateHistoryPage(options = {}) {
814
783
  writeFileSync(outputPath, html, { encoding: 'utf-8' });
815
784
  return outputPath;
816
785
  }
817
- /**
818
- * Escapes HTML special characters to prevent breaking embedded markup.
819
- *
820
- * @param {string} input - The string to escape.
821
- * @returns {string} The escaped string safe for HTML contexts.
822
- */
823
786
  function escapeHtml(input) {
824
787
  return input.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/"/g, '&quot;').replace(/'/g, '&#39;');
825
788
  }
826
- //# sourceMappingURL=cliHistory.js.map
@@ -1,3 +1 @@
1
1
  export {};
2
- // Nothing to export right now, but this file is here to make it easier to add exports in the future
3
- //# sourceMappingURL=export.js.map
@@ -1,26 +1,3 @@
1
- /**
2
- * This file contains the default config for the plugins.
3
- *
4
- * @file defaultConfigSchema.ts
5
- * @author Luca Liguori
6
- * @created 2024-05-07
7
- * @version 1.0.1
8
- * @license Apache-2.0
9
- *
10
- * Copyright 2024, 2025, 2026 Luca Liguori.
11
- *
12
- * Licensed under the Apache License, Version 2.0 (the "License");
13
- * you may not use this file except in compliance with the License.
14
- * You may obtain a copy of the License at
15
- *
16
- * http://www.apache.org/licenses/LICENSE-2.0
17
- *
18
- * Unless required by applicable law or agreed to in writing, software
19
- * distributed under the License is distributed on an "AS IS" BASIS,
20
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21
- * See the License for the specific language governing permissions and
22
- * limitations under the License.
23
- */
24
1
  export const zigbee2mqtt_config = {
25
2
  name: 'matterbridge-zigbee2mqtt',
26
3
  type: 'DynamicPlatform',
@@ -82,4 +59,3 @@ export const shelly_config = {
82
59
  debugWs: false,
83
60
  unregisterOnShutdown: false,
84
61
  };
85
- //# sourceMappingURL=defaultConfigSchema.js.map