matterbridge 3.4.7-dev-20260112-bd9e311 → 3.4.7

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 +4 -0
  2. package/README-MACOS-PLIST.md +2 -4
  3. package/dist/broadcastServer.d.ts +115 -0
  4. package/dist/broadcastServer.d.ts.map +1 -0
  5. package/dist/broadcastServer.js +117 -0
  6. package/dist/broadcastServer.js.map +1 -0
  7. package/dist/broadcastServerTypes.d.ts +43 -0
  8. package/dist/broadcastServerTypes.d.ts.map +1 -0
  9. package/dist/broadcastServerTypes.js +24 -0
  10. package/dist/broadcastServerTypes.js.map +1 -0
  11. package/dist/cli.d.ts +24 -0
  12. package/dist/cli.d.ts.map +1 -0
  13. package/dist/cli.js +97 -1
  14. package/dist/cli.js.map +1 -0
  15. package/dist/cliEmitter.d.ts +36 -0
  16. package/dist/cliEmitter.d.ts.map +1 -0
  17. package/dist/cliEmitter.js +37 -0
  18. package/dist/cliEmitter.js.map +1 -0
  19. package/dist/cliHistory.d.ts +42 -0
  20. package/dist/cliHistory.d.ts.map +1 -0
  21. package/dist/cliHistory.js +38 -0
  22. package/dist/cliHistory.js.map +1 -0
  23. package/dist/clusters/export.d.ts +1 -0
  24. package/dist/clusters/export.d.ts.map +1 -0
  25. package/dist/clusters/export.js +2 -0
  26. package/dist/clusters/export.js.map +1 -0
  27. package/dist/deviceManager.d.ts +108 -0
  28. package/dist/deviceManager.d.ts.map +1 -0
  29. package/dist/deviceManager.js +113 -1
  30. package/dist/deviceManager.js.map +1 -0
  31. package/dist/devices/airConditioner.d.ts +75 -0
  32. package/dist/devices/airConditioner.d.ts.map +1 -0
  33. package/dist/devices/airConditioner.js +57 -0
  34. package/dist/devices/airConditioner.js.map +1 -0
  35. package/dist/devices/batteryStorage.d.ts +43 -0
  36. package/dist/devices/batteryStorage.d.ts.map +1 -0
  37. package/dist/devices/batteryStorage.js +48 -1
  38. package/dist/devices/batteryStorage.js.map +1 -0
  39. package/dist/devices/cooktop.d.ts +55 -0
  40. package/dist/devices/cooktop.d.ts.map +1 -0
  41. package/dist/devices/cooktop.js +56 -0
  42. package/dist/devices/cooktop.js.map +1 -0
  43. package/dist/devices/dishwasher.d.ts +55 -0
  44. package/dist/devices/dishwasher.d.ts.map +1 -0
  45. package/dist/devices/dishwasher.js +57 -0
  46. package/dist/devices/dishwasher.js.map +1 -0
  47. package/dist/devices/evse.d.ts +57 -0
  48. package/dist/devices/evse.d.ts.map +1 -0
  49. package/dist/devices/evse.js +74 -10
  50. package/dist/devices/evse.js.map +1 -0
  51. package/dist/devices/export.d.ts +1 -0
  52. package/dist/devices/export.d.ts.map +1 -0
  53. package/dist/devices/export.js +5 -0
  54. package/dist/devices/export.js.map +1 -0
  55. package/dist/devices/extractorHood.d.ts +41 -0
  56. package/dist/devices/extractorHood.d.ts.map +1 -0
  57. package/dist/devices/extractorHood.js +43 -0
  58. package/dist/devices/extractorHood.js.map +1 -0
  59. package/dist/devices/heatPump.d.ts +43 -0
  60. package/dist/devices/heatPump.d.ts.map +1 -0
  61. package/dist/devices/heatPump.js +50 -2
  62. package/dist/devices/heatPump.js.map +1 -0
  63. package/dist/devices/laundryDryer.d.ts +58 -0
  64. package/dist/devices/laundryDryer.d.ts.map +1 -0
  65. package/dist/devices/laundryDryer.js +62 -3
  66. package/dist/devices/laundryDryer.js.map +1 -0
  67. package/dist/devices/laundryWasher.d.ts +64 -0
  68. package/dist/devices/laundryWasher.d.ts.map +1 -0
  69. package/dist/devices/laundryWasher.js +70 -4
  70. package/dist/devices/laundryWasher.js.map +1 -0
  71. package/dist/devices/microwaveOven.d.ts +77 -1
  72. package/dist/devices/microwaveOven.d.ts.map +1 -0
  73. package/dist/devices/microwaveOven.js +88 -5
  74. package/dist/devices/microwaveOven.js.map +1 -0
  75. package/dist/devices/oven.d.ts +82 -0
  76. package/dist/devices/oven.d.ts.map +1 -0
  77. package/dist/devices/oven.js +85 -0
  78. package/dist/devices/oven.js.map +1 -0
  79. package/dist/devices/refrigerator.d.ts +100 -0
  80. package/dist/devices/refrigerator.d.ts.map +1 -0
  81. package/dist/devices/refrigerator.js +102 -0
  82. package/dist/devices/refrigerator.js.map +1 -0
  83. package/dist/devices/roboticVacuumCleaner.d.ts +83 -0
  84. package/dist/devices/roboticVacuumCleaner.d.ts.map +1 -0
  85. package/dist/devices/roboticVacuumCleaner.js +100 -9
  86. package/dist/devices/roboticVacuumCleaner.js.map +1 -0
  87. package/dist/devices/solarPower.d.ts +36 -0
  88. package/dist/devices/solarPower.d.ts.map +1 -0
  89. package/dist/devices/solarPower.js +38 -0
  90. package/dist/devices/solarPower.js.map +1 -0
  91. package/dist/devices/speaker.d.ts +79 -0
  92. package/dist/devices/speaker.d.ts.map +1 -0
  93. package/dist/devices/speaker.js +84 -0
  94. package/dist/devices/speaker.js.map +1 -0
  95. package/dist/devices/temperatureControl.d.ts +21 -0
  96. package/dist/devices/temperatureControl.d.ts.map +1 -0
  97. package/dist/devices/temperatureControl.js +24 -3
  98. package/dist/devices/temperatureControl.js.map +1 -0
  99. package/dist/devices/waterHeater.d.ts +74 -0
  100. package/dist/devices/waterHeater.d.ts.map +1 -0
  101. package/dist/devices/waterHeater.js +82 -2
  102. package/dist/devices/waterHeater.js.map +1 -0
  103. package/dist/dgram/coap.d.ts +171 -0
  104. package/dist/dgram/coap.d.ts.map +1 -0
  105. package/dist/dgram/coap.js +126 -13
  106. package/dist/dgram/coap.js.map +1 -0
  107. package/dist/dgram/dgram.d.ts +99 -0
  108. package/dist/dgram/dgram.d.ts.map +1 -0
  109. package/dist/dgram/dgram.js +114 -2
  110. package/dist/dgram/dgram.js.map +1 -0
  111. package/dist/dgram/mb_coap.d.ts +23 -0
  112. package/dist/dgram/mb_coap.d.ts.map +1 -0
  113. package/dist/dgram/mb_coap.js +41 -3
  114. package/dist/dgram/mb_coap.js.map +1 -0
  115. package/dist/dgram/mb_mdns.d.ts +23 -0
  116. package/dist/dgram/mb_mdns.d.ts.map +1 -0
  117. package/dist/dgram/mb_mdns.js +80 -24
  118. package/dist/dgram/mb_mdns.js.map +1 -0
  119. package/dist/dgram/mdns.d.ts +187 -4
  120. package/dist/dgram/mdns.d.ts.map +1 -0
  121. package/dist/dgram/mdns.js +371 -139
  122. package/dist/dgram/mdns.js.map +1 -0
  123. package/dist/dgram/multicast.d.ts +49 -0
  124. package/dist/dgram/multicast.d.ts.map +1 -0
  125. package/dist/dgram/multicast.js +62 -1
  126. package/dist/dgram/multicast.js.map +1 -0
  127. package/dist/dgram/unicast.d.ts +53 -0
  128. package/dist/dgram/unicast.d.ts.map +1 -0
  129. package/dist/dgram/unicast.js +60 -0
  130. package/dist/dgram/unicast.js.map +1 -0
  131. package/dist/frontend.d.ts +187 -0
  132. package/dist/frontend.d.ts.map +1 -0
  133. package/dist/frontend.js +485 -38
  134. package/dist/frontend.js.map +1 -0
  135. package/dist/frontendTypes.d.ts +57 -0
  136. package/dist/frontendTypes.d.ts.map +1 -0
  137. package/dist/frontendTypes.js +45 -0
  138. package/dist/frontendTypes.js.map +1 -0
  139. package/dist/helpers.d.ts +43 -0
  140. package/dist/helpers.d.ts.map +1 -0
  141. package/dist/helpers.js +53 -0
  142. package/dist/helpers.js.map +1 -0
  143. package/dist/index.d.ts +23 -0
  144. package/dist/index.d.ts.map +1 -0
  145. package/dist/index.js +25 -0
  146. package/dist/index.js.map +1 -0
  147. package/dist/jestutils/export.d.ts +1 -0
  148. package/dist/jestutils/export.d.ts.map +1 -0
  149. package/dist/jestutils/export.js +1 -0
  150. package/dist/jestutils/export.js.map +1 -0
  151. package/dist/jestutils/jestHelpers.d.ts +255 -0
  152. package/dist/jestutils/jestHelpers.d.ts.map +1 -0
  153. package/dist/jestutils/jestHelpers.js +371 -14
  154. package/dist/jestutils/jestHelpers.js.map +1 -0
  155. package/dist/logger/export.d.ts +1 -0
  156. package/dist/logger/export.d.ts.map +1 -0
  157. package/dist/logger/export.js +1 -0
  158. package/dist/logger/export.js.map +1 -0
  159. package/dist/matter/behaviors.d.ts +1 -0
  160. package/dist/matter/behaviors.d.ts.map +1 -0
  161. package/dist/matter/behaviors.js +2 -0
  162. package/dist/matter/behaviors.js.map +1 -0
  163. package/dist/matter/clusters.d.ts +1 -0
  164. package/dist/matter/clusters.d.ts.map +1 -0
  165. package/dist/matter/clusters.js +2 -0
  166. package/dist/matter/clusters.js.map +1 -0
  167. package/dist/matter/devices.d.ts +1 -0
  168. package/dist/matter/devices.d.ts.map +1 -0
  169. package/dist/matter/devices.js +2 -0
  170. package/dist/matter/devices.js.map +1 -0
  171. package/dist/matter/endpoints.d.ts +1 -0
  172. package/dist/matter/endpoints.d.ts.map +1 -0
  173. package/dist/matter/endpoints.js +2 -0
  174. package/dist/matter/endpoints.js.map +1 -0
  175. package/dist/matter/export.d.ts +1 -0
  176. package/dist/matter/export.d.ts.map +1 -0
  177. package/dist/matter/export.js +3 -0
  178. package/dist/matter/export.js.map +1 -0
  179. package/dist/matter/types.d.ts +1 -0
  180. package/dist/matter/types.d.ts.map +1 -0
  181. package/dist/matter/types.js +3 -0
  182. package/dist/matter/types.js.map +1 -0
  183. package/dist/matterNode.d.ts +258 -0
  184. package/dist/matterNode.d.ts.map +1 -0
  185. package/dist/matterNode.js +369 -8
  186. package/dist/matterNode.js.map +1 -0
  187. package/dist/matterbridge.d.ts +353 -0
  188. package/dist/matterbridge.d.ts.map +1 -0
  189. package/dist/matterbridge.js +824 -46
  190. package/dist/matterbridge.js.map +1 -0
  191. package/dist/matterbridgeAccessoryPlatform.d.ts +36 -0
  192. package/dist/matterbridgeAccessoryPlatform.d.ts.map +1 -0
  193. package/dist/matterbridgeAccessoryPlatform.js +38 -0
  194. package/dist/matterbridgeAccessoryPlatform.js.map +1 -0
  195. package/dist/matterbridgeBehaviors.d.ts +24 -0
  196. package/dist/matterbridgeBehaviors.d.ts.map +1 -0
  197. package/dist/matterbridgeBehaviors.js +68 -5
  198. package/dist/matterbridgeBehaviors.js.map +1 -0
  199. package/dist/matterbridgeDeviceTypes.d.ts +603 -0
  200. package/dist/matterbridgeDeviceTypes.d.ts.map +1 -0
  201. package/dist/matterbridgeDeviceTypes.js +635 -14
  202. package/dist/matterbridgeDeviceTypes.js.map +1 -0
  203. package/dist/matterbridgeDynamicPlatform.d.ts +36 -0
  204. package/dist/matterbridgeDynamicPlatform.d.ts.map +1 -0
  205. package/dist/matterbridgeDynamicPlatform.js +38 -0
  206. package/dist/matterbridgeDynamicPlatform.js.map +1 -0
  207. package/dist/matterbridgeEndpoint.d.ts +1332 -0
  208. package/dist/matterbridgeEndpoint.d.ts.map +1 -0
  209. package/dist/matterbridgeEndpoint.js +1457 -53
  210. package/dist/matterbridgeEndpoint.js.map +1 -0
  211. package/dist/matterbridgeEndpointHelpers.d.ts +425 -0
  212. package/dist/matterbridgeEndpointHelpers.d.ts.map +1 -0
  213. package/dist/matterbridgeEndpointHelpers.js +483 -20
  214. package/dist/matterbridgeEndpointHelpers.js.map +1 -0
  215. package/dist/matterbridgeEndpointTypes.d.ts +70 -0
  216. package/dist/matterbridgeEndpointTypes.d.ts.map +1 -0
  217. package/dist/matterbridgeEndpointTypes.js +25 -0
  218. package/dist/matterbridgeEndpointTypes.js.map +1 -0
  219. package/dist/matterbridgePlatform.d.ts +425 -0
  220. package/dist/matterbridgePlatform.d.ts.map +1 -0
  221. package/dist/matterbridgePlatform.js +451 -1
  222. package/dist/matterbridgePlatform.js.map +1 -0
  223. package/dist/matterbridgeTypes.d.ts +46 -0
  224. package/dist/matterbridgeTypes.d.ts.map +1 -0
  225. package/dist/matterbridgeTypes.js +26 -0
  226. package/dist/matterbridgeTypes.js.map +1 -0
  227. package/dist/pluginManager.d.ts +305 -0
  228. package/dist/pluginManager.d.ts.map +1 -0
  229. package/dist/pluginManager.js +341 -5
  230. package/dist/pluginManager.js.map +1 -0
  231. package/dist/shelly.d.ts +157 -0
  232. package/dist/shelly.d.ts.map +1 -0
  233. package/dist/shelly.js +178 -7
  234. package/dist/shelly.js.map +1 -0
  235. package/dist/storage/export.d.ts +1 -0
  236. package/dist/storage/export.d.ts.map +1 -0
  237. package/dist/storage/export.js +1 -0
  238. package/dist/storage/export.js.map +1 -0
  239. package/dist/update.d.ts +75 -0
  240. package/dist/update.d.ts.map +1 -0
  241. package/dist/update.js +93 -1
  242. package/dist/update.js.map +1 -0
  243. package/dist/utils/colorUtils.d.ts +77 -0
  244. package/dist/utils/colorUtils.d.ts.map +1 -0
  245. package/dist/utils/colorUtils.js +97 -2
  246. package/dist/utils/colorUtils.js.map +1 -0
  247. package/dist/utils/commandLine.d.ts +60 -0
  248. package/dist/utils/commandLine.d.ts.map +1 -0
  249. package/dist/utils/commandLine.js +60 -0
  250. package/dist/utils/commandLine.js.map +1 -0
  251. package/dist/utils/copyDirectory.d.ts +33 -0
  252. package/dist/utils/copyDirectory.d.ts.map +1 -0
  253. package/dist/utils/copyDirectory.js +37 -0
  254. package/dist/utils/copyDirectory.js.map +1 -0
  255. package/dist/utils/createDirectory.d.ts +32 -0
  256. package/dist/utils/createDirectory.d.ts.map +1 -0
  257. package/dist/utils/createDirectory.js +33 -0
  258. package/dist/utils/createDirectory.js.map +1 -0
  259. package/dist/utils/createZip.d.ts +38 -0
  260. package/dist/utils/createZip.d.ts.map +1 -0
  261. package/dist/utils/createZip.js +47 -2
  262. package/dist/utils/createZip.js.map +1 -0
  263. package/dist/utils/deepCopy.d.ts +31 -0
  264. package/dist/utils/deepCopy.d.ts.map +1 -0
  265. package/dist/utils/deepCopy.js +39 -0
  266. package/dist/utils/deepCopy.js.map +1 -0
  267. package/dist/utils/deepEqual.d.ts +53 -0
  268. package/dist/utils/deepEqual.d.ts.map +1 -0
  269. package/dist/utils/deepEqual.js +72 -1
  270. package/dist/utils/deepEqual.js.map +1 -0
  271. package/dist/utils/error.d.ts +42 -0
  272. package/dist/utils/error.d.ts.map +1 -0
  273. package/dist/utils/error.js +42 -0
  274. package/dist/utils/error.js.map +1 -0
  275. package/dist/utils/export.d.ts +1 -0
  276. package/dist/utils/export.d.ts.map +1 -0
  277. package/dist/utils/export.js +1 -0
  278. package/dist/utils/export.js.map +1 -0
  279. package/dist/utils/format.d.ts +49 -0
  280. package/dist/utils/format.d.ts.map +1 -0
  281. package/dist/utils/format.js +49 -0
  282. package/dist/utils/format.js.map +1 -0
  283. package/dist/utils/hex.d.ts +85 -0
  284. package/dist/utils/hex.d.ts.map +1 -0
  285. package/dist/utils/hex.js +124 -0
  286. package/dist/utils/hex.js.map +1 -0
  287. package/dist/utils/inspector.d.ts +63 -0
  288. package/dist/utils/inspector.d.ts.map +1 -0
  289. package/dist/utils/inspector.js +69 -1
  290. package/dist/utils/inspector.js.map +1 -0
  291. package/dist/utils/isValid.d.ts +93 -0
  292. package/dist/utils/isValid.d.ts.map +1 -0
  293. package/dist/utils/isValid.js +93 -0
  294. package/dist/utils/isValid.js.map +1 -0
  295. package/dist/utils/network.d.ts +116 -0
  296. package/dist/utils/network.d.ts.map +1 -0
  297. package/dist/utils/network.js +126 -5
  298. package/dist/utils/network.js.map +1 -0
  299. package/dist/utils/spawn.d.ts +32 -0
  300. package/dist/utils/spawn.d.ts.map +1 -0
  301. package/dist/utils/spawn.js +71 -1
  302. package/dist/utils/spawn.js.map +1 -0
  303. package/dist/utils/tracker.d.ts +56 -0
  304. package/dist/utils/tracker.d.ts.map +1 -0
  305. package/dist/utils/tracker.js +64 -1
  306. package/dist/utils/tracker.js.map +1 -0
  307. package/dist/utils/wait.d.ts +51 -0
  308. package/dist/utils/wait.d.ts.map +1 -0
  309. package/dist/utils/wait.js +60 -8
  310. package/dist/utils/wait.js.map +1 -0
  311. package/dist/workerGlobalPrefix.d.ts +24 -0
  312. package/dist/workerGlobalPrefix.d.ts.map +1 -0
  313. package/dist/workerGlobalPrefix.js +37 -5
  314. package/dist/workerGlobalPrefix.js.map +1 -0
  315. package/dist/workerTypes.d.ts +25 -0
  316. package/dist/workerTypes.d.ts.map +1 -0
  317. package/dist/workerTypes.js +24 -0
  318. package/dist/workerTypes.js.map +1 -0
  319. package/dist/workers.d.ts +61 -0
  320. package/dist/workers.d.ts.map +1 -0
  321. package/dist/workers.js +68 -4
  322. package/dist/workers.js.map +1 -0
  323. package/npm-shrinkwrap.json +115 -115
  324. package/package.json +2 -1
  325. package/packages/dgram/dist/coap.d.ts +171 -0
  326. package/packages/dgram/dist/coap.d.ts.map +1 -0
  327. package/packages/dgram/dist/coap.js +126 -13
  328. package/packages/dgram/dist/coap.js.map +1 -0
  329. package/packages/dgram/dist/dgram.d.ts +99 -0
  330. package/packages/dgram/dist/dgram.d.ts.map +1 -0
  331. package/packages/dgram/dist/dgram.js +115 -3
  332. package/packages/dgram/dist/dgram.js.map +1 -0
  333. package/packages/dgram/dist/export.d.ts +1 -0
  334. package/packages/dgram/dist/export.d.ts.map +1 -0
  335. package/packages/dgram/dist/export.js +1 -0
  336. package/packages/dgram/dist/export.js.map +1 -0
  337. package/packages/dgram/dist/mdns.d.ts +187 -4
  338. package/packages/dgram/dist/mdns.d.ts.map +1 -0
  339. package/packages/dgram/dist/mdns.js +371 -139
  340. package/packages/dgram/dist/mdns.js.map +1 -0
  341. package/packages/dgram/dist/multicast.d.ts +49 -0
  342. package/packages/dgram/dist/multicast.d.ts.map +1 -0
  343. package/packages/dgram/dist/multicast.js +62 -1
  344. package/packages/dgram/dist/multicast.js.map +1 -0
  345. package/packages/dgram/dist/unicast.d.ts +53 -0
  346. package/packages/dgram/dist/unicast.d.ts.map +1 -0
  347. package/packages/dgram/dist/unicast.js +60 -0
  348. package/packages/dgram/dist/unicast.js.map +1 -0
  349. package/packages/jest-utils/dist/export.d.ts +1 -0
  350. package/packages/jest-utils/dist/export.d.ts.map +1 -0
  351. package/packages/jest-utils/dist/export.js +1 -0
  352. package/packages/jest-utils/dist/export.js.map +1 -0
  353. package/packages/jest-utils/dist/jestHelpers.d.ts +56 -0
  354. package/packages/jest-utils/dist/jestHelpers.d.ts.map +1 -0
  355. package/packages/jest-utils/dist/jestHelpers.js +62 -1
  356. package/packages/jest-utils/dist/jestHelpers.js.map +1 -0
  357. package/packages/utils/dist/colorUtils.d.ts +77 -0
  358. package/packages/utils/dist/colorUtils.d.ts.map +1 -0
  359. package/packages/utils/dist/colorUtils.js +97 -2
  360. package/packages/utils/dist/colorUtils.js.map +1 -0
  361. package/packages/utils/dist/commandLine.d.ts +60 -0
  362. package/packages/utils/dist/commandLine.d.ts.map +1 -0
  363. package/packages/utils/dist/commandLine.js +60 -0
  364. package/packages/utils/dist/commandLine.js.map +1 -0
  365. package/packages/utils/dist/copyDirectory.d.ts +33 -0
  366. package/packages/utils/dist/copyDirectory.d.ts.map +1 -0
  367. package/packages/utils/dist/copyDirectory.js +37 -0
  368. package/packages/utils/dist/copyDirectory.js.map +1 -0
  369. package/packages/utils/dist/createDirectory.d.ts +32 -0
  370. package/packages/utils/dist/createDirectory.d.ts.map +1 -0
  371. package/packages/utils/dist/createDirectory.js +33 -0
  372. package/packages/utils/dist/createDirectory.js.map +1 -0
  373. package/packages/utils/dist/createZip.d.ts +38 -0
  374. package/packages/utils/dist/createZip.d.ts.map +1 -0
  375. package/packages/utils/dist/createZip.js +47 -2
  376. package/packages/utils/dist/createZip.js.map +1 -0
  377. package/packages/utils/dist/deepCopy.d.ts +31 -0
  378. package/packages/utils/dist/deepCopy.d.ts.map +1 -0
  379. package/packages/utils/dist/deepCopy.js +39 -0
  380. package/packages/utils/dist/deepCopy.js.map +1 -0
  381. package/packages/utils/dist/deepEqual.d.ts +53 -0
  382. package/packages/utils/dist/deepEqual.d.ts.map +1 -0
  383. package/packages/utils/dist/deepEqual.js +73 -1
  384. package/packages/utils/dist/deepEqual.js.map +1 -0
  385. package/packages/utils/dist/error.d.ts +42 -0
  386. package/packages/utils/dist/error.d.ts.map +1 -0
  387. package/packages/utils/dist/error.js +42 -0
  388. package/packages/utils/dist/error.js.map +1 -0
  389. package/packages/utils/dist/export.d.ts +1 -0
  390. package/packages/utils/dist/export.d.ts.map +1 -0
  391. package/packages/utils/dist/export.js +1 -0
  392. package/packages/utils/dist/export.js.map +1 -0
  393. package/packages/utils/dist/format.d.ts +49 -0
  394. package/packages/utils/dist/format.d.ts.map +1 -0
  395. package/packages/utils/dist/format.js +49 -0
  396. package/packages/utils/dist/format.js.map +1 -0
  397. package/packages/utils/dist/githubVersion.d.ts +32 -0
  398. package/packages/utils/dist/githubVersion.d.ts.map +1 -0
  399. package/packages/utils/dist/githubVersion.js +34 -1
  400. package/packages/utils/dist/githubVersion.js.map +1 -0
  401. package/packages/utils/dist/hex.d.ts +85 -0
  402. package/packages/utils/dist/hex.d.ts.map +1 -0
  403. package/packages/utils/dist/hex.js +124 -0
  404. package/packages/utils/dist/hex.js.map +1 -0
  405. package/packages/utils/dist/inspector.d.ts +63 -0
  406. package/packages/utils/dist/inspector.d.ts.map +1 -0
  407. package/packages/utils/dist/inspector.js +69 -1
  408. package/packages/utils/dist/inspector.js.map +1 -0
  409. package/packages/utils/dist/isValid.d.ts +93 -0
  410. package/packages/utils/dist/isValid.d.ts.map +1 -0
  411. package/packages/utils/dist/isValid.js +93 -0
  412. package/packages/utils/dist/isValid.js.map +1 -0
  413. package/packages/utils/dist/network.d.ts +93 -0
  414. package/packages/utils/dist/network.d.ts.map +1 -0
  415. package/packages/utils/dist/network.js +99 -3
  416. package/packages/utils/dist/network.js.map +1 -0
  417. package/packages/utils/dist/npmRoot.d.ts +28 -0
  418. package/packages/utils/dist/npmRoot.d.ts.map +1 -0
  419. package/packages/utils/dist/npmRoot.js +28 -0
  420. package/packages/utils/dist/npmRoot.js.map +1 -0
  421. package/packages/utils/dist/npmVersion.d.ts +32 -0
  422. package/packages/utils/dist/npmVersion.d.ts.map +1 -0
  423. package/packages/utils/dist/npmVersion.js +34 -1
  424. package/packages/utils/dist/npmVersion.js.map +1 -0
  425. package/packages/utils/dist/tracker.d.ts +56 -0
  426. package/packages/utils/dist/tracker.d.ts.map +1 -0
  427. package/packages/utils/dist/tracker.js +64 -1
  428. package/packages/utils/dist/tracker.js.map +1 -0
  429. package/packages/utils/dist/wait.d.ts +51 -0
  430. package/packages/utils/dist/wait.d.ts.map +1 -0
  431. package/packages/utils/dist/wait.js +60 -8
  432. package/packages/utils/dist/wait.js.map +1 -0
  433. package/packages/vitest-utils/dist/export.d.ts +1 -0
  434. package/packages/vitest-utils/dist/export.d.ts.map +1 -0
  435. package/packages/vitest-utils/dist/export.js +1 -0
  436. package/packages/vitest-utils/dist/export.js.map +1 -0
  437. package/packages/vitest-utils/dist/vitestHelpers.d.ts +37 -0
  438. package/packages/vitest-utils/dist/vitestHelpers.d.ts.map +1 -0
  439. package/packages/vitest-utils/dist/vitestHelpers.js +43 -1
  440. package/packages/vitest-utils/dist/vitestHelpers.js.map +1 -0
  441. package/bmc-button.svg +0 -22
  442. package/packages/dgram/bmc-button.svg +0 -22
  443. package/packages/dgram/matterbridge.svg +0 -50
  444. package/packages/jest-utils/bmc-button.svg +0 -22
  445. package/packages/jest-utils/matterbridge.svg +0 -50
  446. package/packages/utils/bmc-button.svg +0 -22
  447. package/packages/utils/matterbridge.svg +0 -50
  448. package/packages/vitest-utils/bmc-button.svg +0 -22
  449. package/packages/vitest-utils/matterbridge.svg +0 -50
@@ -1,10 +1,39 @@
1
+ /**
2
+ * This file contains the Inspector class.
3
+ *
4
+ * @file inspector.ts
5
+ * @author Luca Liguori
6
+ * @created 2025-10-12
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
+ */
1
24
  import EventEmitter from 'node:events';
2
25
  interface InspectorEvents {
26
+ /** Start the inspector */
3
27
  start: [];
28
+ /** Stop the inspector */
4
29
  stop: [];
30
+ /** Take a heap snapshot */
5
31
  snapshot: [];
32
+ /** Heap snapshot done */
6
33
  snapshot_done: [];
34
+ /** Run garbage collector */
7
35
  gc: [type?: 'major' | 'minor', execution?: 'sync' | 'async'];
36
+ /** Garbage collection done */
8
37
  gc_done: [type: 'major' | 'minor', execution: 'sync' | 'async'];
9
38
  }
10
39
  export declare class Inspector extends EventEmitter<InspectorEvents> {
@@ -16,9 +45,43 @@ export declare class Inspector extends EventEmitter<InspectorEvents> {
16
45
  private snapshotInProgress;
17
46
  private log;
18
47
  constructor(name?: string, debug?: boolean, verbose?: boolean);
48
+ /**
49
+ * Starts the inspector for heap sampling.
50
+ *
51
+ * This function is called when the -inspect parameter is passed to matterbridge.
52
+ *
53
+ * The -snapshotinterval parameter can be used to set the heap snapshot interval. Default is undefined. Minimum is 30000 ms.
54
+ * The snapshot is saved in the heap_profiles directory that is created in the current working directory.
55
+ * The snapshot can be analyzed using vscode or Chrome DevTools or other tools that support heap snapshots.
56
+ */
19
57
  start(): Promise<void>;
58
+ /**
59
+ * Stops the heap sampling and saves the profile to a file in the heap_profiles directory.
60
+ * This function is called when the inspector is stopped.
61
+ */
20
62
  stop(): Promise<void>;
63
+ /**
64
+ * Takes a heap snapshot and saves it to the file name 'heap_snapshots/<timestamp>.heapsnapshot'.
65
+ * If triggers a full garbage collection before and after taking the snapshot to reduce noise.
66
+ *
67
+ * This function is called periodically based on the -snapshotinterval parameter.
68
+ * The -snapshotinterval parameter must at least 30000 ms.
69
+ * The snapshot is saved in the heap_snapshots directory that is created in the current working directory.
70
+ * The snapshot can be analyzed using vscode or Chrome DevTools or other tools that support heap snapshots.
71
+ */
21
72
  takeHeapSnapshot(): Promise<void>;
73
+ /**
74
+ * Manually trigger garbage collection to free memory (if exposed with --expose-gc)
75
+ *
76
+ * @param {'major' | 'minor'} type - The type of garbage collection to perform ('major' or 'minor'). Default is 'major'.
77
+ * @param {'sync' | 'async'} execution - The execution mode of garbage collection ('sync' or 'async'). Default is 'async'.
78
+ *
79
+ * @remarks
80
+ * - major collection refers to old-generation mark-sweep/mark-compact cycles.
81
+ * - minor collection refers to young-generation collections (scavenges).
82
+ * - sync execution blocks the main thread until GC is complete, which can cause pauses.
83
+ */
22
84
  runGarbageCollector(type?: 'major' | 'minor', execution?: 'sync' | 'async'): void;
23
85
  }
24
86
  export {};
87
+ //# sourceMappingURL=inspector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inspector.d.ts","sourceRoot":"","sources":["../src/inspector.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;GAsBG;AAMH,OAAO,YAAY,MAAM,aAAa,CAAC;AAMvC,UAAU,eAAe;IACvB,0BAA0B;IAC1B,KAAK,EAAE,EAAE,CAAC;IACV,yBAAyB;IACzB,IAAI,EAAE,EAAE,CAAC;IACT,2BAA2B;IAC3B,QAAQ,EAAE,EAAE,CAAC;IACb,yBAAyB;IACzB,aAAa,EAAE,EAAE,CAAC;IAClB,4BAA4B;IAC5B,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,OAAO,GAAG,OAAO,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC;IAC7D,8BAA8B;IAC9B,OAAO,EAAE,CAAC,IAAI,EAAE,OAAO,GAAG,OAAO,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC;CACjE;AAED,qBAAa,SAAU,SAAQ,YAAY,CAAC,eAAe,CAAC;IAQxD,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,OAAO;IAT1B,OAAO,CAAC,OAAO,CAAsB;IACrC,OAAO,CAAC,gBAAgB,CAAC,CAAiB;IAE1C,OAAO,CAAC,kBAAkB,CAAS;IACnC,OAAO,CAAC,GAAG,CAAa;gBAGL,IAAI,GAAE,MAAoB,EAC1B,KAAK,GAAE,OAAe,EACtB,OAAO,GAAE,OAAe;IA6B3C;;;;;;;;OAQG;IACG,KAAK;IAmDX;;;OAGG;IACG,IAAI;IAuCV;;;;;;;;OAQG;IACG,gBAAgB;IAsEtB;;;;;;;;;;OAUG;IACH,mBAAmB,CAAC,IAAI,GAAE,OAAO,GAAG,OAAiB,EAAE,SAAS,GAAE,MAAM,GAAG,OAAiB;CAe7F"}
@@ -1,3 +1,27 @@
1
+ /**
2
+ * This file contains the Inspector class.
3
+ *
4
+ * @file inspector.ts
5
+ * @author Luca Liguori
6
+ * @created 2025-10-12
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
+ /* eslint-disable no-console */
1
25
  if (process.argv.includes('--loader') || process.argv.includes('-loader'))
2
26
  console.log('\u001B[32mInspector loaded.\u001B[40;0m');
3
27
  import EventEmitter from 'node:events';
@@ -21,7 +45,7 @@ export class Inspector extends EventEmitter {
21
45
  if (process.argv.includes('--verbose') || process.argv.includes('-verbose')) {
22
46
  this.verbose = true;
23
47
  }
24
- this.log = new AnsiLogger({ logName: this.name, logTimestampFormat: 4, logLevel: this.debug ? "debug" : "info" });
48
+ this.log = new AnsiLogger({ logName: this.name, logTimestampFormat: 4 /* TimestampFormat.TIME_MILLIS */, logLevel: this.debug ? "debug" /* LogLevel.DEBUG */ : "info" /* LogLevel.INFO */ });
25
49
  this.log.logNameColor = YELLOW;
26
50
  this.on('start', () => {
27
51
  this.start();
@@ -36,6 +60,15 @@ export class Inspector extends EventEmitter {
36
60
  this.runGarbageCollector();
37
61
  });
38
62
  }
63
+ /**
64
+ * Starts the inspector for heap sampling.
65
+ *
66
+ * This function is called when the -inspect parameter is passed to matterbridge.
67
+ *
68
+ * The -snapshotinterval parameter can be used to set the heap snapshot interval. Default is undefined. Minimum is 30000 ms.
69
+ * The snapshot is saved in the heap_profiles directory that is created in the current working directory.
70
+ * The snapshot can be analyzed using vscode or Chrome DevTools or other tools that support heap snapshots.
71
+ */
39
72
  async start() {
40
73
  if (this.session) {
41
74
  this.log.warn('Inspector session already active.');
@@ -44,7 +77,9 @@ export class Inspector extends EventEmitter {
44
77
  const { Session } = await import('node:inspector');
45
78
  const { mkdirSync } = await import('node:fs');
46
79
  this.log.debug(`Starting heap sampling...`);
80
+ // Create the heap profiles directory if it doesn't exist
47
81
  mkdirSync('heap_profiles', { recursive: true });
82
+ // Create the heap snapshots directory if it doesn't exist
48
83
  mkdirSync('heap_snapshots', { recursive: true });
49
84
  try {
50
85
  this.session = new Session();
@@ -53,6 +88,7 @@ export class Inspector extends EventEmitter {
53
88
  this.session?.post('HeapProfiler.startSampling', (err) => (err ? reject(err) : resolve()));
54
89
  });
55
90
  this.log.debug(`Started heap sampling`);
91
+ // Set an interval to take heap snapshots
56
92
  const { getIntParameter } = await import('./commandLine.js');
57
93
  const interval = getIntParameter('snapshotinterval');
58
94
  if (interval && interval >= 30000) {
@@ -81,6 +117,10 @@ export class Inspector extends EventEmitter {
81
117
  return;
82
118
  }
83
119
  }
120
+ /**
121
+ * Stops the heap sampling and saves the profile to a file in the heap_profiles directory.
122
+ * This function is called when the inspector is stopped.
123
+ */
84
124
  async stop() {
85
125
  if (!this.session) {
86
126
  this.log.warn('No active inspector session.');
@@ -91,7 +131,9 @@ export class Inspector extends EventEmitter {
91
131
  this.log.debug(`Stopping heap sampling...`);
92
132
  if (this.snapshotInterval) {
93
133
  this.log.debug(`Clearing heap snapshot interval...`);
134
+ // Clear the snapshot interval if it exists
94
135
  clearInterval(this.snapshotInterval);
136
+ // Take a final heap snapshot before stopping
95
137
  await this.takeHeapSnapshot();
96
138
  }
97
139
  try {
@@ -113,6 +155,15 @@ export class Inspector extends EventEmitter {
113
155
  this.log.debug(`Stopped heap sampling`);
114
156
  }
115
157
  }
158
+ /**
159
+ * Takes a heap snapshot and saves it to the file name 'heap_snapshots/<timestamp>.heapsnapshot'.
160
+ * If triggers a full garbage collection before and after taking the snapshot to reduce noise.
161
+ *
162
+ * This function is called periodically based on the -snapshotinterval parameter.
163
+ * The -snapshotinterval parameter must at least 30000 ms.
164
+ * The snapshot is saved in the heap_snapshots directory that is created in the current working directory.
165
+ * The snapshot can be analyzed using vscode or Chrome DevTools or other tools that support heap snapshots.
166
+ */
116
167
  async takeHeapSnapshot() {
117
168
  if (!this.session) {
118
169
  this.log.warn('No active inspector session.');
@@ -128,6 +179,7 @@ export class Inspector extends EventEmitter {
128
179
  const path = await import('node:path');
129
180
  const safeTimestamp = new Date().toISOString().replace(/[<>:"/\\|?*]/g, '-');
130
181
  const filename = path.join('heap_snapshots', `${safeTimestamp}.heapsnapshot`);
182
+ // Trigger a garbage collection before taking the snapshot to reduce noise
131
183
  this.runGarbageCollector('minor', 'async');
132
184
  this.runGarbageCollector('major', 'async');
133
185
  if (this.debug)
@@ -140,13 +192,16 @@ export class Inspector extends EventEmitter {
140
192
  };
141
193
  stream.once('error', onStreamError);
142
194
  const chunksListener = (notification) => {
195
+ // notification.params.chunk is a string; write directly to the stream
143
196
  if (!stream.write(notification.params.chunk)) {
197
+ // If backpressure engages, it's fine; the stream will buffer internally. We don't block the inspector.
144
198
  }
145
199
  };
146
200
  this.session.on('HeapProfiler.addHeapSnapshotChunk', chunksListener);
147
201
  try {
148
202
  await new Promise((resolve) => {
149
203
  this.session?.post('HeapProfiler.takeHeapSnapshot', (err) => {
204
+ // Detach chunk listener and close the stream, then perform post-actions
150
205
  this.session?.off('HeapProfiler.addHeapSnapshotChunk', chunksListener);
151
206
  const finalize = () => {
152
207
  if (!err && !streamErrored) {
@@ -163,6 +218,7 @@ export class Inspector extends EventEmitter {
163
218
  }
164
219
  resolve();
165
220
  };
221
+ // End stream and wait for finish or error
166
222
  try {
167
223
  stream.end(() => finalize());
168
224
  }
@@ -177,6 +233,17 @@ export class Inspector extends EventEmitter {
177
233
  this.snapshotInProgress = false;
178
234
  }
179
235
  }
236
+ /**
237
+ * Manually trigger garbage collection to free memory (if exposed with --expose-gc)
238
+ *
239
+ * @param {'major' | 'minor'} type - The type of garbage collection to perform ('major' or 'minor'). Default is 'major'.
240
+ * @param {'sync' | 'async'} execution - The execution mode of garbage collection ('sync' or 'async'). Default is 'async'.
241
+ *
242
+ * @remarks
243
+ * - major collection refers to old-generation mark-sweep/mark-compact cycles.
244
+ * - minor collection refers to young-generation collections (scavenges).
245
+ * - sync execution blocks the main thread until GC is complete, which can cause pauses.
246
+ */
180
247
  runGarbageCollector(type = 'major', execution = 'async') {
181
248
  if (global.gc && typeof global.gc === 'function') {
182
249
  try {
@@ -198,3 +265,4 @@ export class Inspector extends EventEmitter {
198
265
  }
199
266
  }
200
267
  }
268
+ //# sourceMappingURL=inspector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inspector.js","sourceRoot":"","sources":["../src/inspector.ts"],"names":[],"mappings":"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"}
@@ -1,10 +1,103 @@
1
+ /**
2
+ * This file contains the validation functions.
3
+ *
4
+ * @file isValid.ts
5
+ * @author Luca Liguori
6
+ * @created 2025-02-16
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
+ /**
25
+ * Checks if a given string is a valid IPv4 address.
26
+ *
27
+ * @param {string} ipv4Address - The string to be checked.
28
+ * @returns {boolean} - Returns true if the string is a valid IPv4 address, otherwise returns false.
29
+ */
1
30
  export declare function isValidIpv4Address(ipv4Address: string): boolean;
31
+ /**
32
+ * Checks if a value is a valid number within the specified range.
33
+ *
34
+ * @param {unknown} value - The value to be checked.
35
+ * @param {number} min - The minimum value allowed (optional).
36
+ * @param {number} max - The maximum value allowed (optional).
37
+ * @returns {value is number} Returns true if the value is a valid number within the specified range, otherwise false.
38
+ */
2
39
  export declare function isValidNumber(value: unknown, min?: number, max?: number): value is number;
40
+ /**
41
+ * Checks if a value is a valid boolean.
42
+ *
43
+ * @param {unknown} value - The value to be checked.
44
+ * @returns {value is boolean} `true` if the value is a valid boolean, `false` otherwise.
45
+ */
3
46
  export declare function isValidBoolean(value: unknown): value is boolean;
47
+ /**
48
+ * Checks if a value is a valid string.
49
+ *
50
+ * @param {unknown} value - The value to be checked.
51
+ * @param {number} minLength - The min string length (optional).
52
+ * @param {number} maxLength - The max string length (optional).
53
+ * @returns {value is string} A boolean indicating whether the value is a valid string.
54
+ */
4
55
  export declare function isValidString(value: unknown, minLength?: number, maxLength?: number): value is string;
56
+ /**
57
+ * Checks if a value is a valid RegExp.
58
+ *
59
+ * @param {unknown} value - The value to be checked.
60
+ * @returns {value is RegExp} A boolean indicating whether the value is a valid RegExp.
61
+ */
5
62
  export declare function isValidRegExp(value: unknown): value is RegExp;
63
+ /**
64
+ * Checks if a value is a valid object.
65
+ *
66
+ * @param {unknown} value - The value to be checked.
67
+ * @param {number} minLength - The min number of keys (optional).
68
+ * @param {number} maxLength - The max number of keys (optional).
69
+ * @returns {value is object} A boolean indicating whether the value is a valid object.
70
+ */
6
71
  export declare function isValidObject(value: unknown, minLength?: number, maxLength?: number): value is object;
72
+ /**
73
+ * Checks if a value is a valid array.
74
+ *
75
+ * @param {unknown} value - The value to be checked.
76
+ * @param {number} minLength - The min number of elements (optional).
77
+ * @param {number} maxLength - The max number of elements (optional).
78
+ * @returns {value is unknown[]} A boolean indicating whether the value is a valid array.
79
+ */
7
80
  export declare function isValidArray(value: unknown, minLength?: number, maxLength?: number): value is unknown[];
81
+ /**
82
+ * Checks if the given value is null.
83
+ *
84
+ * @param {unknown} value - The value to check.
85
+ * @returns {value is null} `true` if the value is null, `false` otherwise.
86
+ */
8
87
  export declare function isValidNull(value: unknown): value is null;
88
+ /**
89
+ * Checks if a value is undefined.
90
+ *
91
+ * @param {unknown} value - The value to check.
92
+ * @returns {value is undefined} `true` if the value is undefined, `false` otherwise.
93
+ */
9
94
  export declare function isValidUndefined(value: unknown): value is undefined;
95
+ /**
96
+ * Converts a semantic version string like "6.11.0-1011-raspi" to a numeric version code like 61100.
97
+ * Format: major * 10000 + minor * 100 + patch
98
+ *
99
+ * @param {string} versionString The version string to parse
100
+ * @returns {number | undefined} A numeric version code or undefined if parsing fails
101
+ */
10
102
  export declare function parseVersionString(versionString: string): number | undefined;
103
+ //# sourceMappingURL=isValid.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isValid.d.ts","sourceRoot":"","sources":["../src/isValid.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;GAsBG;AAEH;;;;;GAKG;AACH,wBAAgB,kBAAkB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAI/D;AAED;;;;;;;GAOG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,OAAO,EAAE,GAAG,CAAC,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,KAAK,IAAI,MAAM,CAKzF;AAED;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI,OAAO,CAE/D;AAED;;;;;;;GAOG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,KAAK,IAAI,MAAM,CAKrG;AAED;;;;;GAKG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI,MAAM,CAE7D;AAED;;;;;;;GAOG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,KAAK,IAAI,MAAM,CAMrG;AAED;;;;;;;GAOG;AACH,wBAAgB,YAAY,CAAC,KAAK,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,KAAK,IAAI,OAAO,EAAE,CAKvG;AAED;;;;;GAKG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI,IAAI,CAEzD;AAED;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI,SAAS,CAEnE;AAED;;;;;;GAMG;AACH,wBAAgB,kBAAkB,CAAC,aAAa,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAgB5E"}
@@ -1,7 +1,44 @@
1
+ /**
2
+ * This file contains the validation functions.
3
+ *
4
+ * @file isValid.ts
5
+ * @author Luca Liguori
6
+ * @created 2025-02-16
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
+ /**
25
+ * Checks if a given string is a valid IPv4 address.
26
+ *
27
+ * @param {string} ipv4Address - The string to be checked.
28
+ * @returns {boolean} - Returns true if the string is a valid IPv4 address, otherwise returns false.
29
+ */
1
30
  export function isValidIpv4Address(ipv4Address) {
2
31
  const ipv4Regex = /^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;
3
32
  return ipv4Regex.test(ipv4Address);
4
33
  }
34
+ /**
35
+ * Checks if a value is a valid number within the specified range.
36
+ *
37
+ * @param {unknown} value - The value to be checked.
38
+ * @param {number} min - The minimum value allowed (optional).
39
+ * @param {number} max - The maximum value allowed (optional).
40
+ * @returns {value is number} Returns true if the value is a valid number within the specified range, otherwise false.
41
+ */
5
42
  export function isValidNumber(value, min, max) {
6
43
  if (value === undefined || value === null || typeof value !== 'number' || Number.isNaN(value) || !Number.isFinite(value))
7
44
  return false;
@@ -11,9 +48,23 @@ export function isValidNumber(value, min, max) {
11
48
  return false;
12
49
  return true;
13
50
  }
51
+ /**
52
+ * Checks if a value is a valid boolean.
53
+ *
54
+ * @param {unknown} value - The value to be checked.
55
+ * @returns {value is boolean} `true` if the value is a valid boolean, `false` otherwise.
56
+ */
14
57
  export function isValidBoolean(value) {
15
58
  return value !== undefined && value !== null && typeof value === 'boolean';
16
59
  }
60
+ /**
61
+ * Checks if a value is a valid string.
62
+ *
63
+ * @param {unknown} value - The value to be checked.
64
+ * @param {number} minLength - The min string length (optional).
65
+ * @param {number} maxLength - The max string length (optional).
66
+ * @returns {value is string} A boolean indicating whether the value is a valid string.
67
+ */
17
68
  export function isValidString(value, minLength, maxLength) {
18
69
  if (value === undefined || value === null || typeof value !== 'string')
19
70
  return false;
@@ -23,9 +74,23 @@ export function isValidString(value, minLength, maxLength) {
23
74
  return false;
24
75
  return true;
25
76
  }
77
+ /**
78
+ * Checks if a value is a valid RegExp.
79
+ *
80
+ * @param {unknown} value - The value to be checked.
81
+ * @returns {value is RegExp} A boolean indicating whether the value is a valid RegExp.
82
+ */
26
83
  export function isValidRegExp(value) {
27
84
  return value !== undefined && value !== null && value instanceof RegExp;
28
85
  }
86
+ /**
87
+ * Checks if a value is a valid object.
88
+ *
89
+ * @param {unknown} value - The value to be checked.
90
+ * @param {number} minLength - The min number of keys (optional).
91
+ * @param {number} maxLength - The max number of keys (optional).
92
+ * @returns {value is object} A boolean indicating whether the value is a valid object.
93
+ */
29
94
  export function isValidObject(value, minLength, maxLength) {
30
95
  if (value === undefined || value === null || typeof value !== 'object' || Array.isArray(value))
31
96
  return false;
@@ -36,6 +101,14 @@ export function isValidObject(value, minLength, maxLength) {
36
101
  return false;
37
102
  return true;
38
103
  }
104
+ /**
105
+ * Checks if a value is a valid array.
106
+ *
107
+ * @param {unknown} value - The value to be checked.
108
+ * @param {number} minLength - The min number of elements (optional).
109
+ * @param {number} maxLength - The max number of elements (optional).
110
+ * @returns {value is unknown[]} A boolean indicating whether the value is a valid array.
111
+ */
39
112
  export function isValidArray(value, minLength, maxLength) {
40
113
  if (value === undefined || value === null || !Array.isArray(value))
41
114
  return false;
@@ -45,12 +118,31 @@ export function isValidArray(value, minLength, maxLength) {
45
118
  return false;
46
119
  return true;
47
120
  }
121
+ /**
122
+ * Checks if the given value is null.
123
+ *
124
+ * @param {unknown} value - The value to check.
125
+ * @returns {value is null} `true` if the value is null, `false` otherwise.
126
+ */
48
127
  export function isValidNull(value) {
49
128
  return value === null;
50
129
  }
130
+ /**
131
+ * Checks if a value is undefined.
132
+ *
133
+ * @param {unknown} value - The value to check.
134
+ * @returns {value is undefined} `true` if the value is undefined, `false` otherwise.
135
+ */
51
136
  export function isValidUndefined(value) {
52
137
  return value === undefined;
53
138
  }
139
+ /**
140
+ * Converts a semantic version string like "6.11.0-1011-raspi" to a numeric version code like 61100.
141
+ * Format: major * 10000 + minor * 100 + patch
142
+ *
143
+ * @param {string} versionString The version string to parse
144
+ * @returns {number | undefined} A numeric version code or undefined if parsing fails
145
+ */
54
146
  export function parseVersionString(versionString) {
55
147
  if (!isValidString(versionString))
56
148
  return undefined;
@@ -67,3 +159,4 @@ export function parseVersionString(versionString) {
67
159
  }
68
160
  return major * 10000 + minor * 100 + patch;
69
161
  }
162
+ //# sourceMappingURL=isValid.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isValid.js","sourceRoot":"","sources":["../src/isValid.ts"],"names":[],"mappings":"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"}
@@ -1,12 +1,105 @@
1
+ /**
2
+ * @description This file contains the network functions.
3
+ * @file network.ts
4
+ * @author Luca Liguori
5
+ * @created 2024-02-17
6
+ * @version 1.0.3
7
+ * @license Apache-2.0
8
+ *
9
+ * Copyright 2024, 2025, 2026 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
+ /**
24
+ * Retrieves the first non-internal network interface details.
25
+ *
26
+ * @returns {os.NetworkInterfaceInfo | undefined} The details of the selected network interface, or undefined if not found.
27
+ */
1
28
  export declare function getInterfaceDetails(): {
2
29
  interfaceName: string;
3
30
  ipv4Address: string | undefined;
4
31
  ipv6Address: string | undefined;
5
32
  macAddress: string | undefined;
6
33
  } | undefined;
34
+ /**
35
+ * Retrieves the first non-internal network interface name.
36
+ *
37
+ * @returns {string | undefined} The name of the selected network interface, or undefined if not found.
38
+ */
7
39
  export declare function getInterfaceName(): string | undefined;
40
+ /**
41
+ * Retrieves the IPv4 address of the first non-internal network interface.
42
+ *
43
+ * @returns {string | undefined} The IPv4 address of the selected network interface, or undefined if not found.
44
+ *
45
+ * @remarks
46
+ * Type of ipv4 addresses:
47
+ * - 192.168.x.x, 10.x.x.x, 172.16–31.x.x: RFC 1918 = Private networks
48
+ * - 172.16.0.0 → 172.31.255.255: RFC 1918 = Private IP address used inside local networks, VMs, WSL2 and containers
49
+ * - 169.254.0.0 → 169.254.255.255: APIPA = Automatic Private IP Addressing used when a device fails to obtain an IP address via DHCP
50
+ * - 100.64.0.0 → 100.127.255.255: CGNAT = Carrier-Grade NAT RFC 6598 = Shared Address Space
51
+ */
8
52
  export declare function getIpv4InterfaceAddress(): string | undefined;
53
+ /**
54
+ * Retrieves the IPv6 address of the first non-internal network interface.
55
+ *
56
+ * If `scope` is true, appends a zone id (scope) for link-local addresses when
57
+ * available:
58
+ * - On Windows: uses `%<scopeid>` (e.g. `...%11`)
59
+ * - On other platforms: uses `%<interfaceName>` (e.g. `...%eth0`)
60
+ *
61
+ * @param {boolean} [scope] - Whether to append a zone id when available.
62
+ * @returns {string | undefined} The IPv6 address of the selected network interface, or undefined if not found.
63
+ *
64
+ * @remarks
65
+ * Type of IPv6 addresses (preferred order for Matter)
66
+ *
67
+ * fd00::/8
68
+ * - IPv6 ULA (Unique Local Address)
69
+ * - Private IPv6 networks (RFC 4193)
70
+ * - ✔ PREFERRED
71
+ *
72
+ * 2000::/3
73
+ * - Global Unicast IPv6
74
+ * - Publicly routable IPv6
75
+ * - ⚠ OPTIONAL (advanced setups only)
76
+ *
77
+ * fe80::/10
78
+ * - IPv6 Link-Local
79
+ * - Interface-scoped only, non-routable
80
+ */
9
81
  export declare function getIpv6InterfaceAddress(scope?: boolean): string | undefined;
82
+ /**
83
+ * Retrieves the mac address of the first non-internal network interface.
84
+ *
85
+ * @returns {string | undefined} The mac address, or undefined if not found.
86
+ */
10
87
  export declare function getMacAddress(): string | undefined;
88
+ /**
89
+ * Logs the available network interfaces and their details.
90
+ *
91
+ * @returns {void}
92
+ */
11
93
  export declare function logInterfaces(): void;
94
+ /**
95
+ * Resolves the given hostname to an IP address.
96
+ *
97
+ * @param {string} hostname - The hostname to resolve.
98
+ * @param {0 | 4 | 6} [family] - The address family to use (0 for any, 4 for IPv4, 6 for IPv6). Default is 4.
99
+ * @returns {Promise<string | null>} - A promise that resolves to the IP address or null if not found.
100
+ *
101
+ * @remarks
102
+ * This function uses DNS lookup to resolve the hostname, which can take some time to complete.
103
+ */
12
104
  export declare function resolveHostname(hostname: string, family?: 0 | 4 | 6): Promise<string | null>;
105
+ //# sourceMappingURL=network.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"network.d.ts","sourceRoot":"","sources":["../src/network.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAQH;;;;GAIG;AACH,wBAAgB,mBAAmB,IAAI;IAAE,aAAa,EAAE,MAAM,CAAC;IAAC,WAAW,EAAE,MAAM,GAAG,SAAS,CAAC;IAAC,WAAW,EAAE,MAAM,GAAG,SAAS,CAAC;IAAC,UAAU,EAAE,MAAM,GAAG,SAAS,CAAA;CAAE,GAAG,SAAS,CAkB7K;AAED;;;;GAIG;AACH,wBAAgB,gBAAgB,IAAI,MAAM,GAAG,SAAS,CAOrD;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,uBAAuB,IAAI,MAAM,GAAG,SAAS,CAO5D;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,wBAAgB,uBAAuB,CAAC,KAAK,GAAE,OAAe,GAAG,MAAM,GAAG,SAAS,CAoBlF;AAED;;;;GAIG;AACH,wBAAgB,aAAa,IAAI,MAAM,GAAG,SAAS,CAOlD;AAED;;;;GAIG;AACH,wBAAgB,aAAa,IAAI,IAAI,CAmBpC;AAED;;;;;;;;;GASG;AACH,wBAAsB,eAAe,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAE,CAAC,GAAG,CAAC,GAAG,CAAK,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAQrG"}