@sonde/packs 0.1.0 → 0.1.1

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 (359) hide show
  1. package/.turbo/turbo-build.log +6 -0
  2. package/.turbo/turbo-test.log +814 -0
  3. package/.turbo/turbo-typecheck.log +4 -0
  4. package/CHANGELOG.md +10 -0
  5. package/dist/index.d.ts +16 -1
  6. package/dist/index.d.ts.map +1 -1
  7. package/dist/index.js +40 -2
  8. package/dist/index.js.map +1 -1
  9. package/dist/integrations/citrix.d.ts +13 -0
  10. package/dist/integrations/citrix.d.ts.map +1 -0
  11. package/dist/integrations/citrix.js +420 -0
  12. package/dist/integrations/citrix.js.map +1 -0
  13. package/dist/integrations/citrix.test.d.ts +2 -0
  14. package/dist/integrations/citrix.test.d.ts.map +1 -0
  15. package/dist/integrations/citrix.test.js +464 -0
  16. package/dist/integrations/citrix.test.js.map +1 -0
  17. package/dist/integrations/graph.d.ts +9 -0
  18. package/dist/integrations/graph.d.ts.map +1 -0
  19. package/dist/integrations/graph.js +290 -0
  20. package/dist/integrations/graph.js.map +1 -0
  21. package/dist/integrations/graph.test.d.ts +2 -0
  22. package/dist/integrations/graph.test.d.ts.map +1 -0
  23. package/dist/integrations/graph.test.js +356 -0
  24. package/dist/integrations/graph.test.js.map +1 -0
  25. package/dist/integrations/httpbin.d.ts +3 -0
  26. package/dist/integrations/httpbin.d.ts.map +1 -0
  27. package/dist/integrations/httpbin.js +70 -0
  28. package/dist/integrations/httpbin.js.map +1 -0
  29. package/dist/integrations/nutanix.d.ts +18 -0
  30. package/dist/integrations/nutanix.d.ts.map +1 -0
  31. package/dist/integrations/nutanix.js +1121 -0
  32. package/dist/integrations/nutanix.js.map +1 -0
  33. package/dist/integrations/nutanix.test.d.ts +2 -0
  34. package/dist/integrations/nutanix.test.d.ts.map +1 -0
  35. package/dist/integrations/nutanix.test.js +978 -0
  36. package/dist/integrations/nutanix.test.js.map +1 -0
  37. package/dist/integrations/proxmox.d.ts +12 -0
  38. package/dist/integrations/proxmox.d.ts.map +1 -0
  39. package/dist/integrations/proxmox.js +733 -0
  40. package/dist/integrations/proxmox.js.map +1 -0
  41. package/dist/integrations/proxmox.test.d.ts +2 -0
  42. package/dist/integrations/proxmox.test.d.ts.map +1 -0
  43. package/dist/integrations/proxmox.test.js +697 -0
  44. package/dist/integrations/proxmox.test.js.map +1 -0
  45. package/dist/integrations/servicenow.d.ts +3 -0
  46. package/dist/integrations/servicenow.d.ts.map +1 -0
  47. package/dist/integrations/servicenow.js +257 -0
  48. package/dist/integrations/servicenow.js.map +1 -0
  49. package/dist/integrations/servicenow.test.d.ts +2 -0
  50. package/dist/integrations/servicenow.test.d.ts.map +1 -0
  51. package/dist/integrations/servicenow.test.js +217 -0
  52. package/dist/integrations/servicenow.test.js.map +1 -0
  53. package/dist/integrations/splunk.d.ts +9 -0
  54. package/dist/integrations/splunk.d.ts.map +1 -0
  55. package/dist/integrations/splunk.js +242 -0
  56. package/dist/integrations/splunk.js.map +1 -0
  57. package/dist/integrations/splunk.test.d.ts +2 -0
  58. package/dist/integrations/splunk.test.d.ts.map +1 -0
  59. package/dist/integrations/splunk.test.js +323 -0
  60. package/dist/integrations/splunk.test.js.map +1 -0
  61. package/dist/mysql/index.d.ts +3 -0
  62. package/dist/mysql/index.d.ts.map +1 -0
  63. package/dist/mysql/index.js +13 -0
  64. package/dist/mysql/index.js.map +1 -0
  65. package/dist/mysql/manifest.d.ts +3 -0
  66. package/dist/mysql/manifest.d.ts.map +1 -0
  67. package/dist/mysql/manifest.js +69 -0
  68. package/dist/mysql/manifest.js.map +1 -0
  69. package/dist/mysql/probes/databases-list.d.ts +13 -0
  70. package/dist/mysql/probes/databases-list.d.ts.map +1 -0
  71. package/dist/mysql/probes/databases-list.js +31 -0
  72. package/dist/mysql/probes/databases-list.js.map +1 -0
  73. package/dist/mysql/probes/databases-list.test.d.ts +2 -0
  74. package/dist/mysql/probes/databases-list.test.d.ts.map +1 -0
  75. package/dist/mysql/probes/databases-list.test.js +54 -0
  76. package/dist/mysql/probes/databases-list.test.js.map +1 -0
  77. package/dist/mysql/probes/processlist.d.ts +18 -0
  78. package/dist/mysql/probes/processlist.d.ts.map +1 -0
  79. package/dist/mysql/probes/processlist.js +36 -0
  80. package/dist/mysql/probes/processlist.js.map +1 -0
  81. package/dist/mysql/probes/processlist.test.d.ts +2 -0
  82. package/dist/mysql/probes/processlist.test.d.ts.map +1 -0
  83. package/dist/mysql/probes/processlist.test.js +41 -0
  84. package/dist/mysql/probes/processlist.test.js.map +1 -0
  85. package/dist/mysql/probes/status.d.ts +14 -0
  86. package/dist/mysql/probes/status.d.ts.map +1 -0
  87. package/dist/mysql/probes/status.js +40 -0
  88. package/dist/mysql/probes/status.js.map +1 -0
  89. package/dist/mysql/probes/status.test.d.ts +2 -0
  90. package/dist/mysql/probes/status.test.d.ts.map +1 -0
  91. package/dist/mysql/probes/status.test.js +43 -0
  92. package/dist/mysql/probes/status.test.js.map +1 -0
  93. package/dist/nginx/index.d.ts +3 -0
  94. package/dist/nginx/index.d.ts.map +1 -0
  95. package/dist/nginx/index.js +13 -0
  96. package/dist/nginx/index.js.map +1 -0
  97. package/dist/nginx/manifest.d.ts +3 -0
  98. package/dist/nginx/manifest.d.ts.map +1 -0
  99. package/dist/nginx/manifest.js +68 -0
  100. package/dist/nginx/manifest.js.map +1 -0
  101. package/dist/nginx/probes/access-log-tail.d.ts +9 -0
  102. package/dist/nginx/probes/access-log-tail.d.ts.map +1 -0
  103. package/dist/nginx/probes/access-log-tail.js +14 -0
  104. package/dist/nginx/probes/access-log-tail.js.map +1 -0
  105. package/dist/nginx/probes/access-log-tail.test.d.ts +2 -0
  106. package/dist/nginx/probes/access-log-tail.test.d.ts.map +1 -0
  107. package/dist/nginx/probes/access-log-tail.test.js +40 -0
  108. package/dist/nginx/probes/access-log-tail.test.js.map +1 -0
  109. package/dist/nginx/probes/config-test.d.ts +8 -0
  110. package/dist/nginx/probes/config-test.d.ts.map +1 -0
  111. package/dist/nginx/probes/config-test.js +18 -0
  112. package/dist/nginx/probes/config-test.js.map +1 -0
  113. package/dist/nginx/probes/config-test.test.d.ts +2 -0
  114. package/dist/nginx/probes/config-test.test.d.ts.map +1 -0
  115. package/dist/nginx/probes/config-test.test.js +35 -0
  116. package/dist/nginx/probes/config-test.test.js.map +1 -0
  117. package/dist/nginx/probes/error-log-tail.d.ts +9 -0
  118. package/dist/nginx/probes/error-log-tail.d.ts.map +1 -0
  119. package/dist/nginx/probes/error-log-tail.js +14 -0
  120. package/dist/nginx/probes/error-log-tail.js.map +1 -0
  121. package/dist/nginx/probes/error-log-tail.test.d.ts +2 -0
  122. package/dist/nginx/probes/error-log-tail.test.d.ts.map +1 -0
  123. package/dist/nginx/probes/error-log-tail.test.js +34 -0
  124. package/dist/nginx/probes/error-log-tail.test.js.map +1 -0
  125. package/dist/postgres/index.d.ts +3 -0
  126. package/dist/postgres/index.d.ts.map +1 -0
  127. package/dist/postgres/index.js +13 -0
  128. package/dist/postgres/index.js.map +1 -0
  129. package/dist/postgres/manifest.d.ts +3 -0
  130. package/dist/postgres/manifest.d.ts.map +1 -0
  131. package/dist/postgres/manifest.js +90 -0
  132. package/dist/postgres/manifest.js.map +1 -0
  133. package/dist/postgres/probes/connections-active.d.ts +17 -0
  134. package/dist/postgres/probes/connections-active.d.ts.map +1 -0
  135. package/dist/postgres/probes/connections-active.js +37 -0
  136. package/dist/postgres/probes/connections-active.js.map +1 -0
  137. package/dist/postgres/probes/connections-active.test.d.ts +2 -0
  138. package/dist/postgres/probes/connections-active.test.d.ts.map +1 -0
  139. package/dist/postgres/probes/connections-active.test.js +36 -0
  140. package/dist/postgres/probes/connections-active.test.js.map +1 -0
  141. package/dist/postgres/probes/databases-list.d.ts +14 -0
  142. package/dist/postgres/probes/databases-list.d.ts.map +1 -0
  143. package/dist/postgres/probes/databases-list.js +34 -0
  144. package/dist/postgres/probes/databases-list.js.map +1 -0
  145. package/dist/postgres/probes/databases-list.test.d.ts +2 -0
  146. package/dist/postgres/probes/databases-list.test.d.ts.map +1 -0
  147. package/dist/postgres/probes/databases-list.test.js +49 -0
  148. package/dist/postgres/probes/databases-list.test.js.map +1 -0
  149. package/dist/postgres/probes/query-slow.d.ts +17 -0
  150. package/dist/postgres/probes/query-slow.d.ts.map +1 -0
  151. package/dist/postgres/probes/query-slow.js +37 -0
  152. package/dist/postgres/probes/query-slow.js.map +1 -0
  153. package/dist/postgres/probes/query-slow.test.d.ts +2 -0
  154. package/dist/postgres/probes/query-slow.test.d.ts.map +1 -0
  155. package/dist/postgres/probes/query-slow.test.js +30 -0
  156. package/dist/postgres/probes/query-slow.test.js.map +1 -0
  157. package/dist/proxmox/index.d.ts +3 -0
  158. package/dist/proxmox/index.d.ts.map +1 -0
  159. package/dist/proxmox/index.js +23 -0
  160. package/dist/proxmox/index.js.map +1 -0
  161. package/dist/proxmox/manifest.d.ts +3 -0
  162. package/dist/proxmox/manifest.d.ts.map +1 -0
  163. package/dist/proxmox/manifest.js +75 -0
  164. package/dist/proxmox/manifest.js.map +1 -0
  165. package/dist/proxmox/probes/ceph-status.d.ts +36 -0
  166. package/dist/proxmox/probes/ceph-status.d.ts.map +1 -0
  167. package/dist/proxmox/probes/ceph-status.js +71 -0
  168. package/dist/proxmox/probes/ceph-status.js.map +1 -0
  169. package/dist/proxmox/probes/ceph-status.test.d.ts +2 -0
  170. package/dist/proxmox/probes/ceph-status.test.d.ts.map +1 -0
  171. package/dist/proxmox/probes/ceph-status.test.js +115 -0
  172. package/dist/proxmox/probes/ceph-status.test.js.map +1 -0
  173. package/dist/proxmox/probes/cluster-config.d.ts +31 -0
  174. package/dist/proxmox/probes/cluster-config.d.ts.map +1 -0
  175. package/dist/proxmox/probes/cluster-config.js +72 -0
  176. package/dist/proxmox/probes/cluster-config.js.map +1 -0
  177. package/dist/proxmox/probes/cluster-config.test.d.ts +2 -0
  178. package/dist/proxmox/probes/cluster-config.test.d.ts.map +1 -0
  179. package/dist/proxmox/probes/cluster-config.test.js +107 -0
  180. package/dist/proxmox/probes/cluster-config.test.js.map +1 -0
  181. package/dist/proxmox/probes/ha-status.d.ts +18 -0
  182. package/dist/proxmox/probes/ha-status.d.ts.map +1 -0
  183. package/dist/proxmox/probes/ha-status.js +38 -0
  184. package/dist/proxmox/probes/ha-status.js.map +1 -0
  185. package/dist/proxmox/probes/ha-status.test.d.ts +2 -0
  186. package/dist/proxmox/probes/ha-status.test.d.ts.map +1 -0
  187. package/dist/proxmox/probes/ha-status.test.js +66 -0
  188. package/dist/proxmox/probes/ha-status.test.js.map +1 -0
  189. package/dist/proxmox/probes/lvm.d.ts +35 -0
  190. package/dist/proxmox/probes/lvm.d.ts.map +1 -0
  191. package/dist/proxmox/probes/lvm.js +75 -0
  192. package/dist/proxmox/probes/lvm.js.map +1 -0
  193. package/dist/proxmox/probes/lvm.test.d.ts +2 -0
  194. package/dist/proxmox/probes/lvm.test.d.ts.map +1 -0
  195. package/dist/proxmox/probes/lvm.test.js +128 -0
  196. package/dist/proxmox/probes/lvm.test.js.map +1 -0
  197. package/dist/proxmox/probes/lxc-config.d.ts +29 -0
  198. package/dist/proxmox/probes/lxc-config.d.ts.map +1 -0
  199. package/dist/proxmox/probes/lxc-config.js +67 -0
  200. package/dist/proxmox/probes/lxc-config.js.map +1 -0
  201. package/dist/proxmox/probes/lxc-config.test.d.ts +2 -0
  202. package/dist/proxmox/probes/lxc-config.test.d.ts.map +1 -0
  203. package/dist/proxmox/probes/lxc-config.test.js +77 -0
  204. package/dist/proxmox/probes/lxc-config.test.js.map +1 -0
  205. package/dist/proxmox/probes/lxc-list.d.ts +20 -0
  206. package/dist/proxmox/probes/lxc-list.d.ts.map +1 -0
  207. package/dist/proxmox/probes/lxc-list.js +49 -0
  208. package/dist/proxmox/probes/lxc-list.js.map +1 -0
  209. package/dist/proxmox/probes/lxc-list.test.d.ts +2 -0
  210. package/dist/proxmox/probes/lxc-list.test.d.ts.map +1 -0
  211. package/dist/proxmox/probes/lxc-list.test.js +51 -0
  212. package/dist/proxmox/probes/lxc-list.test.js.map +1 -0
  213. package/dist/proxmox/probes/vm-config.d.ts +21 -0
  214. package/dist/proxmox/probes/vm-config.d.ts.map +1 -0
  215. package/dist/proxmox/probes/vm-config.js +58 -0
  216. package/dist/proxmox/probes/vm-config.js.map +1 -0
  217. package/dist/proxmox/probes/vm-config.test.d.ts +2 -0
  218. package/dist/proxmox/probes/vm-config.test.d.ts.map +1 -0
  219. package/dist/proxmox/probes/vm-config.test.js +80 -0
  220. package/dist/proxmox/probes/vm-config.test.js.map +1 -0
  221. package/dist/proxmox/probes/vm-locks.d.ts +16 -0
  222. package/dist/proxmox/probes/vm-locks.d.ts.map +1 -0
  223. package/dist/proxmox/probes/vm-locks.js +35 -0
  224. package/dist/proxmox/probes/vm-locks.js.map +1 -0
  225. package/dist/proxmox/probes/vm-locks.test.d.ts +2 -0
  226. package/dist/proxmox/probes/vm-locks.test.d.ts.map +1 -0
  227. package/dist/proxmox/probes/vm-locks.test.js +54 -0
  228. package/dist/proxmox/probes/vm-locks.test.js.map +1 -0
  229. package/dist/redis/index.d.ts +3 -0
  230. package/dist/redis/index.d.ts.map +1 -0
  231. package/dist/redis/index.js +13 -0
  232. package/dist/redis/index.js.map +1 -0
  233. package/dist/redis/manifest.d.ts +3 -0
  234. package/dist/redis/manifest.d.ts.map +1 -0
  235. package/dist/redis/manifest.js +51 -0
  236. package/dist/redis/manifest.js.map +1 -0
  237. package/dist/redis/probes/info.d.ts +15 -0
  238. package/dist/redis/probes/info.d.ts.map +1 -0
  239. package/dist/redis/probes/info.js +32 -0
  240. package/dist/redis/probes/info.js.map +1 -0
  241. package/dist/redis/probes/info.test.d.ts +2 -0
  242. package/dist/redis/probes/info.test.d.ts.map +1 -0
  243. package/dist/redis/probes/info.test.js +64 -0
  244. package/dist/redis/probes/info.test.js.map +1 -0
  245. package/dist/redis/probes/keys-count.d.ts +13 -0
  246. package/dist/redis/probes/keys-count.d.ts.map +1 -0
  247. package/dist/redis/probes/keys-count.js +24 -0
  248. package/dist/redis/probes/keys-count.js.map +1 -0
  249. package/dist/redis/probes/keys-count.test.d.ts +2 -0
  250. package/dist/redis/probes/keys-count.test.d.ts.map +1 -0
  251. package/dist/redis/probes/keys-count.test.js +37 -0
  252. package/dist/redis/probes/keys-count.test.js.map +1 -0
  253. package/dist/redis/probes/memory-usage.d.ts +16 -0
  254. package/dist/redis/probes/memory-usage.d.ts.map +1 -0
  255. package/dist/redis/probes/memory-usage.js +31 -0
  256. package/dist/redis/probes/memory-usage.js.map +1 -0
  257. package/dist/redis/probes/memory-usage.test.d.ts +2 -0
  258. package/dist/redis/probes/memory-usage.test.d.ts.map +1 -0
  259. package/dist/redis/probes/memory-usage.test.js +48 -0
  260. package/dist/redis/probes/memory-usage.test.js.map +1 -0
  261. package/dist/runbooks/nutanix.d.ts +3 -0
  262. package/dist/runbooks/nutanix.d.ts.map +1 -0
  263. package/dist/runbooks/nutanix.js +619 -0
  264. package/dist/runbooks/nutanix.js.map +1 -0
  265. package/dist/runbooks/nutanix.test.d.ts +2 -0
  266. package/dist/runbooks/nutanix.test.d.ts.map +1 -0
  267. package/dist/runbooks/nutanix.test.js +971 -0
  268. package/dist/runbooks/nutanix.test.js.map +1 -0
  269. package/dist/runbooks/proxmox.d.ts +3 -0
  270. package/dist/runbooks/proxmox.d.ts.map +1 -0
  271. package/dist/runbooks/proxmox.js +451 -0
  272. package/dist/runbooks/proxmox.js.map +1 -0
  273. package/dist/runbooks/proxmox.test.d.ts +2 -0
  274. package/dist/runbooks/proxmox.test.d.ts.map +1 -0
  275. package/dist/runbooks/proxmox.test.js +700 -0
  276. package/dist/runbooks/proxmox.test.js.map +1 -0
  277. package/dist/signatures.d.ts +2 -0
  278. package/dist/signatures.d.ts.map +1 -0
  279. package/dist/signatures.js +2 -0
  280. package/dist/signatures.js.map +1 -0
  281. package/dist/types.d.ts +53 -0
  282. package/dist/types.d.ts.map +1 -1
  283. package/dist/validation.d.ts +6 -1
  284. package/dist/validation.d.ts.map +1 -1
  285. package/dist/validation.js +10 -1
  286. package/dist/validation.js.map +1 -1
  287. package/package.json +1 -1
  288. package/src/index.ts +60 -6
  289. package/src/integrations/citrix.test.ts +592 -0
  290. package/src/integrations/citrix.ts +557 -0
  291. package/src/integrations/graph.test.ts +478 -0
  292. package/src/integrations/graph.ts +413 -0
  293. package/src/integrations/httpbin.ts +72 -0
  294. package/src/integrations/nutanix.test.ts +1508 -0
  295. package/src/integrations/nutanix.ts +1460 -0
  296. package/src/integrations/proxmox.test.ts +1020 -0
  297. package/src/integrations/proxmox.ts +989 -0
  298. package/src/integrations/servicenow.test.ts +314 -0
  299. package/src/integrations/servicenow.ts +285 -0
  300. package/src/integrations/splunk.test.ts +440 -0
  301. package/src/integrations/splunk.ts +356 -0
  302. package/src/mysql/index.ts +14 -0
  303. package/src/mysql/manifest.ts +70 -0
  304. package/src/mysql/probes/databases-list.test.ts +62 -0
  305. package/src/mysql/probes/databases-list.ts +45 -0
  306. package/src/mysql/probes/processlist.test.ts +47 -0
  307. package/src/mysql/probes/processlist.ts +55 -0
  308. package/src/mysql/probes/status.test.ts +50 -0
  309. package/src/mysql/probes/status.ts +56 -0
  310. package/src/nginx/index.ts +14 -0
  311. package/src/nginx/manifest.ts +69 -0
  312. package/src/nginx/probes/access-log-tail.test.ts +51 -0
  313. package/src/nginx/probes/access-log-tail.ts +23 -0
  314. package/src/nginx/probes/config-test.test.ts +47 -0
  315. package/src/nginx/probes/config-test.ts +24 -0
  316. package/src/nginx/probes/error-log-tail.test.ts +44 -0
  317. package/src/nginx/probes/error-log-tail.ts +23 -0
  318. package/src/postgres/index.ts +14 -0
  319. package/src/postgres/manifest.ts +91 -0
  320. package/src/postgres/probes/connections-active.test.ts +42 -0
  321. package/src/postgres/probes/connections-active.ts +55 -0
  322. package/src/postgres/probes/databases-list.test.ts +57 -0
  323. package/src/postgres/probes/databases-list.ts +49 -0
  324. package/src/postgres/probes/query-slow.test.ts +37 -0
  325. package/src/postgres/probes/query-slow.ts +55 -0
  326. package/src/proxmox/index.ts +24 -0
  327. package/src/proxmox/manifest.ts +76 -0
  328. package/src/proxmox/probes/ceph-status.test.ts +126 -0
  329. package/src/proxmox/probes/ceph-status.ts +116 -0
  330. package/src/proxmox/probes/cluster-config.test.ts +118 -0
  331. package/src/proxmox/probes/cluster-config.ts +97 -0
  332. package/src/proxmox/probes/ha-status.test.ts +76 -0
  333. package/src/proxmox/probes/ha-status.ts +56 -0
  334. package/src/proxmox/probes/lvm.test.ts +140 -0
  335. package/src/proxmox/probes/lvm.ts +121 -0
  336. package/src/proxmox/probes/lxc-config.test.ts +89 -0
  337. package/src/proxmox/probes/lxc-config.ts +90 -0
  338. package/src/proxmox/probes/lxc-list.test.ts +60 -0
  339. package/src/proxmox/probes/lxc-list.ts +67 -0
  340. package/src/proxmox/probes/vm-config.test.ts +93 -0
  341. package/src/proxmox/probes/vm-config.ts +77 -0
  342. package/src/proxmox/probes/vm-locks.test.ts +63 -0
  343. package/src/proxmox/probes/vm-locks.ts +49 -0
  344. package/src/redis/index.ts +14 -0
  345. package/src/redis/manifest.ts +52 -0
  346. package/src/redis/probes/info.test.ts +73 -0
  347. package/src/redis/probes/info.ts +46 -0
  348. package/src/redis/probes/keys-count.test.ts +44 -0
  349. package/src/redis/probes/keys-count.ts +38 -0
  350. package/src/redis/probes/memory-usage.test.ts +54 -0
  351. package/src/redis/probes/memory-usage.ts +46 -0
  352. package/src/runbooks/nutanix.test.ts +1138 -0
  353. package/src/runbooks/nutanix.ts +941 -0
  354. package/src/runbooks/proxmox.test.ts +838 -0
  355. package/src/runbooks/proxmox.ts +626 -0
  356. package/src/signatures.ts +1 -0
  357. package/src/types.ts +62 -0
  358. package/src/validation.ts +21 -1
  359. package/tsconfig.tsbuildinfo +1 -0
@@ -0,0 +1,107 @@
1
+ import { describe, expect, it } from 'vitest';
2
+ import { clusterConfig, parseClusterConfig } from './cluster-config.js';
3
+ const SAMPLE_OUTPUT = `Cluster information
4
+ ~~~~~~~~~~~~~~~~~~
5
+ Name: mycluster
6
+ Config Version: 3
7
+ Transport: knet
8
+ Secure auth: on
9
+
10
+ Quorum information
11
+ ~~~~~~~~~~~~~~~~~~
12
+ Date: Mon Feb 17 10:00:00 2026
13
+ Quorum provider: corosync_votequorum
14
+ Nodes: 3
15
+ Node ID: 0x00000001
16
+ Ring ID: 1.123
17
+ Quorate: Yes
18
+
19
+ Votequorum information
20
+ ~~~~~~~~~~~~~~~~~~~~~~
21
+ Expected votes: 3
22
+ Highest expected: 3
23
+ Total votes: 3
24
+ Quorum: 2
25
+ Flags: Quorate
26
+
27
+ Membership information
28
+ ~~~~~~~~~~~~~~~~~~~~~~
29
+ Nodeid Votes Name
30
+ 1 1 pve01 (local)
31
+ 2 1 pve02
32
+ 3 1 pve03`;
33
+ describe('parseClusterConfig', () => {
34
+ it('extracts cluster name', () => {
35
+ const result = parseClusterConfig(SAMPLE_OUTPUT);
36
+ expect(result.clusterName).toBe('mycluster');
37
+ });
38
+ it('detects quorate status', () => {
39
+ const result = parseClusterConfig(SAMPLE_OUTPUT);
40
+ expect(result.quorate).toBe(true);
41
+ });
42
+ it('extracts vote counts', () => {
43
+ const result = parseClusterConfig(SAMPLE_OUTPUT);
44
+ expect(result.totalVotes).toBe(3);
45
+ expect(result.expectedVotes).toBe(3);
46
+ });
47
+ it('parses membership nodes', () => {
48
+ const result = parseClusterConfig(SAMPLE_OUTPUT);
49
+ expect(result.nodes).toHaveLength(3);
50
+ expect(result.nodes[0]).toEqual({
51
+ nodeId: '1',
52
+ name: 'pve01',
53
+ votes: 1,
54
+ local: true,
55
+ });
56
+ expect(result.nodes[1]).toEqual({
57
+ nodeId: '2',
58
+ name: 'pve02',
59
+ votes: 1,
60
+ local: false,
61
+ });
62
+ });
63
+ it('no warnings when quorate', () => {
64
+ const result = parseClusterConfig(SAMPLE_OUTPUT);
65
+ expect(result.warnings).toHaveLength(0);
66
+ });
67
+ it('warns when not quorate', () => {
68
+ const notQuorate = SAMPLE_OUTPUT.replace('Quorate: Yes', 'Quorate: No');
69
+ const result = parseClusterConfig(notQuorate);
70
+ expect(result.warnings).toContain('Cluster is not quorate');
71
+ });
72
+ it('handles single-node output', () => {
73
+ const singleNode = `Cluster information
74
+ ~~~~~~~~~~~~~~~~~~
75
+ Name: standalone
76
+
77
+ Quorum information
78
+ ~~~~~~~~~~~~~~~~~~
79
+ Quorate: Yes
80
+
81
+ Votequorum information
82
+ ~~~~~~~~~~~~~~~~~~~~~~
83
+ Expected votes: 1
84
+ Total votes: 1
85
+
86
+ Membership information
87
+ ~~~~~~~~~~~~~~~~~~~~~~
88
+ Nodeid Votes Name
89
+ 1 1 pve01 (local)`;
90
+ const result = parseClusterConfig(singleNode);
91
+ expect(result.nodes).toHaveLength(1);
92
+ expect(result.nodes[0]?.local).toBe(true);
93
+ });
94
+ });
95
+ describe('clusterConfig handler', () => {
96
+ it('calls pvecm status and returns parsed result', async () => {
97
+ const mockExec = async (cmd, args) => {
98
+ expect(cmd).toBe('pvecm');
99
+ expect(args).toEqual(['status']);
100
+ return SAMPLE_OUTPUT;
101
+ };
102
+ const result = (await clusterConfig(undefined, mockExec));
103
+ expect(result.clusterName).toBe('mycluster');
104
+ expect(result.nodes).toHaveLength(3);
105
+ });
106
+ });
107
+ //# sourceMappingURL=cluster-config.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cluster-config.test.js","sourceRoot":"","sources":["../../../src/proxmox/probes/cluster-config.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import type { ProbeHandler } from '../../types.js';
2
+ export interface HaResource {
3
+ sid: string;
4
+ state: string;
5
+ node: string;
6
+ request: string;
7
+ }
8
+ export interface HaStatusResult {
9
+ resources: HaResource[];
10
+ warnings: string[];
11
+ }
12
+ /**
13
+ * Runs `ha-manager status` and parses the output.
14
+ * Format: "quorum OK\nsid state node request\n..."
15
+ */
16
+ export declare const haStatus: ProbeHandler;
17
+ export declare function parseHaStatus(stdout: string): HaStatusResult;
18
+ //# sourceMappingURL=ha-status.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ha-status.d.ts","sourceRoot":"","sources":["../../../src/proxmox/probes/ha-status.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAEnD,MAAM,WAAW,UAAU;IACzB,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,UAAU,EAAE,CAAC;IACxB,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB;AAED;;;GAGG;AACH,eAAO,MAAM,QAAQ,EAAE,YAGtB,CAAC;AAEF,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,cAAc,CAgC5D"}
@@ -0,0 +1,38 @@
1
+ /**
2
+ * Runs `ha-manager status` and parses the output.
3
+ * Format: "quorum OK\nsid state node request\n..."
4
+ */
5
+ export const haStatus = async (_params, exec) => {
6
+ const stdout = await exec('ha-manager', ['status']);
7
+ return parseHaStatus(stdout);
8
+ };
9
+ export function parseHaStatus(stdout) {
10
+ const lines = stdout.trim().split('\n').filter(Boolean);
11
+ const resources = [];
12
+ const warnings = [];
13
+ for (const line of lines) {
14
+ // Skip header/quorum lines
15
+ if (line.startsWith('quorum') || line.startsWith('master'))
16
+ continue;
17
+ // Resource lines: "vm:100 started pve01 none"
18
+ const parts = line.trim().split(/\s+/);
19
+ if (parts.length < 2)
20
+ continue;
21
+ const sid = parts[0] ?? '';
22
+ // Skip if it doesn't look like a resource SID (e.g. vm:100, ct:200)
23
+ if (!sid.includes(':'))
24
+ continue;
25
+ const state = parts[1] ?? '';
26
+ const node = parts[2] ?? '';
27
+ const request = parts[3] ?? 'none';
28
+ resources.push({ sid, state, node, request });
29
+ if (state === 'error' || state === 'fence') {
30
+ warnings.push(`HA resource ${sid} in ${state} state on ${node}`);
31
+ }
32
+ if (state === 'stopped') {
33
+ warnings.push(`HA resource ${sid} is stopped`);
34
+ }
35
+ }
36
+ return { resources, warnings };
37
+ }
38
+ //# sourceMappingURL=ha-status.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ha-status.js","sourceRoot":"","sources":["../../../src/proxmox/probes/ha-status.ts"],"names":[],"mappings":"AAcA;;;GAGG;AACH,MAAM,CAAC,MAAM,QAAQ,GAAiB,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,EAAE;IAC5D,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,YAAY,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IACpD,OAAO,aAAa,CAAC,MAAM,CAAC,CAAC;AAC/B,CAAC,CAAC;AAEF,MAAM,UAAU,aAAa,CAAC,MAAc;IAC1C,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACxD,MAAM,SAAS,GAAiB,EAAE,CAAC;IACnC,MAAM,QAAQ,GAAa,EAAE,CAAC;IAE9B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,2BAA2B;QAC3B,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;YAAE,SAAS;QAErE,8CAA8C;QAC9C,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC;YAAE,SAAS;QAE/B,MAAM,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;QAC3B,oEAAoE;QACpE,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC;YAAE,SAAS;QAEjC,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;QAC7B,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;QAC5B,MAAM,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC;QAEnC,SAAS,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;QAE9C,IAAI,KAAK,KAAK,OAAO,IAAI,KAAK,KAAK,OAAO,EAAE,CAAC;YAC3C,QAAQ,CAAC,IAAI,CAAC,eAAe,GAAG,OAAO,KAAK,aAAa,IAAI,EAAE,CAAC,CAAC;QACnE,CAAC;QACD,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACxB,QAAQ,CAAC,IAAI,CAAC,eAAe,GAAG,aAAa,CAAC,CAAC;QACjD,CAAC;IACH,CAAC;IAED,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,CAAC;AACjC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=ha-status.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ha-status.test.d.ts","sourceRoot":"","sources":["../../../src/proxmox/probes/ha-status.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,66 @@
1
+ import { describe, expect, it } from 'vitest';
2
+ import { haStatus, parseHaStatus } from './ha-status.js';
3
+ const SAMPLE_OUTPUT = `quorum OK
4
+ master pve01 (192.168.1.1, 9dab1c9a)
5
+ vm:100 started pve01 none
6
+ vm:101 started pve02 none
7
+ ct:200 started pve01 none`;
8
+ describe('parseHaStatus', () => {
9
+ it('parses HA resource entries', () => {
10
+ const result = parseHaStatus(SAMPLE_OUTPUT);
11
+ expect(result.resources).toHaveLength(3);
12
+ expect(result.resources[0]).toEqual({
13
+ sid: 'vm:100',
14
+ state: 'started',
15
+ node: 'pve01',
16
+ request: 'none',
17
+ });
18
+ expect(result.resources[2]).toEqual({
19
+ sid: 'ct:200',
20
+ state: 'started',
21
+ node: 'pve01',
22
+ request: 'none',
23
+ });
24
+ });
25
+ it('flags error state', () => {
26
+ const output = `quorum OK
27
+ vm:100 error pve01 none`;
28
+ const result = parseHaStatus(output);
29
+ expect(result.warnings).toContain('HA resource vm:100 in error state on pve01');
30
+ });
31
+ it('flags fence state', () => {
32
+ const output = `quorum OK
33
+ vm:101 fence pve02 none`;
34
+ const result = parseHaStatus(output);
35
+ expect(result.warnings).toContain('HA resource vm:101 in fence state on pve02');
36
+ });
37
+ it('flags stopped resources', () => {
38
+ const output = `quorum OK
39
+ vm:100 stopped pve01 none`;
40
+ const result = parseHaStatus(output);
41
+ expect(result.warnings).toContain('HA resource vm:100 is stopped');
42
+ });
43
+ it('returns empty for no resources', () => {
44
+ const result = parseHaStatus('quorum OK');
45
+ expect(result.resources).toHaveLength(0);
46
+ expect(result.warnings).toHaveLength(0);
47
+ });
48
+ it('skips master/quorum lines', () => {
49
+ const result = parseHaStatus(SAMPLE_OUTPUT);
50
+ const sids = result.resources.map((r) => r.sid);
51
+ expect(sids).not.toContain('quorum');
52
+ expect(sids).not.toContain('master');
53
+ });
54
+ });
55
+ describe('haStatus handler', () => {
56
+ it('calls ha-manager status and returns parsed result', async () => {
57
+ const mockExec = async (cmd, args) => {
58
+ expect(cmd).toBe('ha-manager');
59
+ expect(args).toEqual(['status']);
60
+ return SAMPLE_OUTPUT;
61
+ };
62
+ const result = (await haStatus(undefined, mockExec));
63
+ expect(result.resources).toHaveLength(3);
64
+ });
65
+ });
66
+ //# sourceMappingURL=ha-status.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ha-status.test.js","sourceRoot":"","sources":["../../../src/proxmox/probes/ha-status.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,35 @@
1
+ import type { ProbeHandler } from '../../types.js';
2
+ export interface LogicalVolume {
3
+ name: string;
4
+ vgName: string;
5
+ size: string;
6
+ attrs: string;
7
+ pool: string;
8
+ dataPercent: string;
9
+ }
10
+ export interface VolumeGroup {
11
+ name: string;
12
+ size: string;
13
+ free: string;
14
+ pvCount: number;
15
+ lvCount: number;
16
+ }
17
+ export interface PhysicalVolume {
18
+ name: string;
19
+ vgName: string;
20
+ size: string;
21
+ free: string;
22
+ format: string;
23
+ }
24
+ export interface LvmResult {
25
+ logicalVolumes: LogicalVolume[];
26
+ volumeGroups: VolumeGroup[];
27
+ physicalVolumes: PhysicalVolume[];
28
+ warnings: string[];
29
+ }
30
+ /**
31
+ * Runs lvs, vgs, pvs with --reportformat json and returns structured LVM topology.
32
+ */
33
+ export declare const lvm: ProbeHandler;
34
+ export declare function parseLvm(lvsOut: string, vgsOut: string, pvsOut: string): LvmResult;
35
+ //# sourceMappingURL=lvm.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lvm.d.ts","sourceRoot":"","sources":["../../../src/proxmox/probes/lvm.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAEnD,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,SAAS;IACxB,cAAc,EAAE,aAAa,EAAE,CAAC;IAChC,YAAY,EAAE,WAAW,EAAE,CAAC;IAC5B,eAAe,EAAE,cAAc,EAAE,CAAC;IAClC,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB;AAED;;GAEG;AACH,eAAO,MAAM,GAAG,EAAE,YA4BjB,CAAC;AAEF,wBAAgB,QAAQ,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,SAAS,CAqDlF"}
@@ -0,0 +1,75 @@
1
+ /**
2
+ * Runs lvs, vgs, pvs with --reportformat json and returns structured LVM topology.
3
+ */
4
+ export const lvm = async (_params, exec) => {
5
+ const [lvsOut, vgsOut, pvsOut] = await Promise.all([
6
+ exec('lvs', [
7
+ '--reportformat',
8
+ 'json',
9
+ '--units',
10
+ 'b',
11
+ '-o',
12
+ 'lv_name,vg_name,lv_size,lv_attr,pool_lv,data_percent',
13
+ ]),
14
+ exec('vgs', [
15
+ '--reportformat',
16
+ 'json',
17
+ '--units',
18
+ 'b',
19
+ '-o',
20
+ 'vg_name,vg_size,vg_free,pv_count,lv_count',
21
+ ]),
22
+ exec('pvs', [
23
+ '--reportformat',
24
+ 'json',
25
+ '--units',
26
+ 'b',
27
+ '-o',
28
+ 'pv_name,vg_name,pv_size,pv_free,pv_fmt',
29
+ ]),
30
+ ]);
31
+ return parseLvm(lvsOut, vgsOut, pvsOut);
32
+ };
33
+ export function parseLvm(lvsOut, vgsOut, pvsOut) {
34
+ const warnings = [];
35
+ const lvsData = JSON.parse(lvsOut);
36
+ const logicalVolumes = (lvsData.report?.[0]?.lv ?? []).map((lv) => ({
37
+ name: lv.lv_name ?? '',
38
+ vgName: lv.vg_name ?? '',
39
+ size: lv.lv_size ?? '',
40
+ attrs: lv.lv_attr ?? '',
41
+ pool: lv.pool_lv ?? '',
42
+ dataPercent: lv.data_percent ?? '',
43
+ }));
44
+ const vgsData = JSON.parse(vgsOut);
45
+ const volumeGroups = (vgsData.report?.[0]?.vg ?? []).map((vg) => ({
46
+ name: vg.vg_name ?? '',
47
+ size: vg.vg_size ?? '',
48
+ free: vg.vg_free ?? '',
49
+ pvCount: Number(vg.pv_count ?? 0),
50
+ lvCount: Number(vg.lv_count ?? 0),
51
+ }));
52
+ const pvsData = JSON.parse(pvsOut);
53
+ const physicalVolumes = (pvsData.report?.[0]?.pv ?? []).map((pv) => ({
54
+ name: pv.pv_name ?? '',
55
+ vgName: pv.vg_name ?? '',
56
+ size: pv.pv_size ?? '',
57
+ free: pv.pv_free ?? '',
58
+ format: pv.pv_fmt ?? '',
59
+ }));
60
+ // Flag thin pools with high usage
61
+ for (const lv of logicalVolumes) {
62
+ if (lv.dataPercent && Number.parseFloat(lv.dataPercent) > 85) {
63
+ warnings.push(`Thin pool ${lv.name} is ${lv.dataPercent}% used`);
64
+ }
65
+ }
66
+ // Flag VGs with no free space
67
+ for (const vg of volumeGroups) {
68
+ const freeBytes = Number.parseInt(vg.free, 10);
69
+ if (!Number.isNaN(freeBytes) && freeBytes === 0) {
70
+ warnings.push(`Volume group ${vg.name} has no free space`);
71
+ }
72
+ }
73
+ return { logicalVolumes, volumeGroups, physicalVolumes, warnings };
74
+ }
75
+ //# sourceMappingURL=lvm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lvm.js","sourceRoot":"","sources":["../../../src/proxmox/probes/lvm.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=lvm.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lvm.test.d.ts","sourceRoot":"","sources":["../../../src/proxmox/probes/lvm.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,128 @@
1
+ import { describe, expect, it } from 'vitest';
2
+ import { lvm, parseLvm } from './lvm.js';
3
+ const LVS_OUTPUT = JSON.stringify({
4
+ report: [
5
+ {
6
+ lv: [
7
+ {
8
+ lv_name: 'data',
9
+ vg_name: 'pve',
10
+ lv_size: '200000000000B',
11
+ lv_attr: '-wi-a-----',
12
+ pool_lv: '',
13
+ data_percent: '',
14
+ },
15
+ {
16
+ lv_name: 'root',
17
+ vg_name: 'pve',
18
+ lv_size: '50000000000B',
19
+ lv_attr: '-wi-a-----',
20
+ pool_lv: '',
21
+ data_percent: '',
22
+ },
23
+ {
24
+ lv_name: 'thinpool',
25
+ vg_name: 'pve',
26
+ lv_size: '400000000000B',
27
+ lv_attr: 'twi-aotz--',
28
+ pool_lv: '',
29
+ data_percent: '92.50',
30
+ },
31
+ ],
32
+ },
33
+ ],
34
+ });
35
+ const VGS_OUTPUT = JSON.stringify({
36
+ report: [
37
+ {
38
+ vg: [
39
+ { vg_name: 'pve', vg_size: '500000000000B', vg_free: '0B', pv_count: '1', lv_count: '3' },
40
+ ],
41
+ },
42
+ ],
43
+ });
44
+ const PVS_OUTPUT = JSON.stringify({
45
+ report: [
46
+ {
47
+ pv: [
48
+ {
49
+ pv_name: '/dev/sda3',
50
+ vg_name: 'pve',
51
+ pv_size: '500000000000B',
52
+ pv_free: '0B',
53
+ pv_fmt: 'lvm2',
54
+ },
55
+ ],
56
+ },
57
+ ],
58
+ });
59
+ describe('parseLvm', () => {
60
+ it('parses LVM topology from JSON reports', () => {
61
+ const result = parseLvm(LVS_OUTPUT, VGS_OUTPUT, PVS_OUTPUT);
62
+ expect(result.logicalVolumes).toHaveLength(3);
63
+ expect(result.logicalVolumes[0]?.name).toBe('data');
64
+ expect(result.logicalVolumes[0]?.vgName).toBe('pve');
65
+ expect(result.volumeGroups).toHaveLength(1);
66
+ expect(result.volumeGroups[0]?.name).toBe('pve');
67
+ expect(result.physicalVolumes).toHaveLength(1);
68
+ expect(result.physicalVolumes[0]?.name).toBe('/dev/sda3');
69
+ expect(result.physicalVolumes[0]?.format).toBe('lvm2');
70
+ });
71
+ it('flags thin pool with high usage', () => {
72
+ const result = parseLvm(LVS_OUTPUT, VGS_OUTPUT, PVS_OUTPUT);
73
+ expect(result.warnings.some((w) => w.includes('thinpool') && w.includes('92.50'))).toBe(true);
74
+ });
75
+ it('flags VGs with no free space', () => {
76
+ const result = parseLvm(LVS_OUTPUT, VGS_OUTPUT, PVS_OUTPUT);
77
+ expect(result.warnings).toContain('Volume group pve has no free space');
78
+ });
79
+ it('does not flag healthy thin pools', () => {
80
+ const healthyLvs = JSON.stringify({
81
+ report: [
82
+ {
83
+ lv: [
84
+ {
85
+ lv_name: 'thinpool',
86
+ vg_name: 'pve',
87
+ lv_size: '400B',
88
+ lv_attr: 'twi-aotz--',
89
+ pool_lv: '',
90
+ data_percent: '50.00',
91
+ },
92
+ ],
93
+ },
94
+ ],
95
+ });
96
+ const healthyVgs = JSON.stringify({
97
+ report: [
98
+ {
99
+ vg: [{ vg_name: 'pve', vg_size: '500B', vg_free: '100B', pv_count: '1', lv_count: '1' }],
100
+ },
101
+ ],
102
+ });
103
+ const result = parseLvm(healthyLvs, healthyVgs, PVS_OUTPUT);
104
+ expect(result.warnings).toHaveLength(0);
105
+ });
106
+ });
107
+ describe('lvm handler', () => {
108
+ it('calls lvs, vgs, pvs with correct args', async () => {
109
+ const calls = [];
110
+ const mockExec = async (cmd, args) => {
111
+ calls.push({ cmd, args });
112
+ if (cmd === 'lvs')
113
+ return LVS_OUTPUT;
114
+ if (cmd === 'vgs')
115
+ return VGS_OUTPUT;
116
+ return PVS_OUTPUT;
117
+ };
118
+ const result = (await lvm(undefined, mockExec));
119
+ expect(result.logicalVolumes).toHaveLength(3);
120
+ expect(calls).toHaveLength(3);
121
+ expect(calls[0]?.cmd).toBe('lvs');
122
+ expect(calls[0]?.args).toContain('--reportformat');
123
+ expect(calls[0]?.args).toContain('json');
124
+ expect(calls[1]?.cmd).toBe('vgs');
125
+ expect(calls[2]?.cmd).toBe('pvs');
126
+ });
127
+ });
128
+ //# sourceMappingURL=lvm.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lvm.test.js","sourceRoot":"","sources":["../../../src/proxmox/probes/lvm.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,29 @@
1
+ import type { ProbeHandler } from '../../types.js';
2
+ export interface LxcMountpoint {
3
+ key: string;
4
+ storage: string;
5
+ volume: string;
6
+ mountpoint: string;
7
+ size: string;
8
+ }
9
+ export interface LxcConfigResult {
10
+ vmid: number;
11
+ config: Record<string, string>;
12
+ rootfs: {
13
+ storage: string;
14
+ size: string;
15
+ } | null;
16
+ mountpoints: LxcMountpoint[];
17
+ network: Array<{
18
+ key: string;
19
+ raw: string;
20
+ }>;
21
+ warnings: string[];
22
+ }
23
+ /**
24
+ * Runs `pct config {vmid}` and parses key: value output.
25
+ * Identifies rootfs storage, mountpoints, network config.
26
+ */
27
+ export declare const lxcConfig: ProbeHandler;
28
+ export declare function parseLxcConfig(stdout: string, vmid: number): LxcConfigResult;
29
+ //# sourceMappingURL=lxc-config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lxc-config.d.ts","sourceRoot":"","sources":["../../../src/proxmox/probes/lxc-config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAEnD,MAAM,WAAW,aAAa;IAC5B,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/B,MAAM,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IACjD,WAAW,EAAE,aAAa,EAAE,CAAC;IAC7B,OAAO,EAAE,KAAK,CAAC;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC7C,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB;AAED;;;GAGG;AACH,eAAO,MAAM,SAAS,EAAE,YAMvB,CAAC;AAEF,wBAAgB,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,eAAe,CA0D5E"}
@@ -0,0 +1,67 @@
1
+ /**
2
+ * Runs `pct config {vmid}` and parses key: value output.
3
+ * Identifies rootfs storage, mountpoints, network config.
4
+ */
5
+ export const lxcConfig = async (params, exec) => {
6
+ const vmid = params?.vmid;
7
+ if (vmid == null)
8
+ throw new Error('vmid parameter is required');
9
+ const stdout = await exec('pct', ['config', String(vmid)]);
10
+ return parseLxcConfig(stdout, vmid);
11
+ };
12
+ export function parseLxcConfig(stdout, vmid) {
13
+ const config = {};
14
+ const lines = stdout.trim().split('\n').filter(Boolean);
15
+ for (const line of lines) {
16
+ const colonIdx = line.indexOf(':');
17
+ if (colonIdx === -1)
18
+ continue;
19
+ const key = line.slice(0, colonIdx).trim();
20
+ const value = line.slice(colonIdx + 1).trim();
21
+ config[key] = value;
22
+ }
23
+ // Parse rootfs: "local-lvm:subvol-200-disk-0,size=8G"
24
+ let rootfs = null;
25
+ if (config.rootfs) {
26
+ const colonIdx = config.rootfs.indexOf(':');
27
+ if (colonIdx > -1) {
28
+ const storage = config.rootfs.slice(0, colonIdx);
29
+ const rest = config.rootfs.slice(colonIdx + 1);
30
+ const sizeMatch = rest.match(/size=(\S+)/);
31
+ rootfs = { storage, size: sizeMatch?.[1] ?? '' };
32
+ }
33
+ }
34
+ // Parse mp0–mp255 mountpoints
35
+ const mountpoints = [];
36
+ for (const [key, value] of Object.entries(config)) {
37
+ if (!/^mp\d+$/.test(key))
38
+ continue;
39
+ const colonIdx = value.indexOf(':');
40
+ if (colonIdx === -1)
41
+ continue;
42
+ const storage = value.slice(0, colonIdx);
43
+ const rest = value.slice(colonIdx + 1);
44
+ const commaIdx = rest.indexOf(',');
45
+ const volume = commaIdx > -1 ? rest.slice(0, commaIdx) : rest;
46
+ const optsPart = commaIdx > -1 ? rest.slice(commaIdx + 1) : '';
47
+ const mpMatch = optsPart.match(/mp=([^,]+)/);
48
+ const sizeMatch = optsPart.match(/size=(\S+)/);
49
+ mountpoints.push({
50
+ key,
51
+ storage,
52
+ volume,
53
+ mountpoint: mpMatch?.[1] ?? '',
54
+ size: sizeMatch?.[1] ?? '',
55
+ });
56
+ }
57
+ // Parse network interfaces
58
+ const network = [];
59
+ for (const [key, value] of Object.entries(config)) {
60
+ if (/^net\d+$/.test(key)) {
61
+ network.push({ key, raw: value });
62
+ }
63
+ }
64
+ const warnings = [];
65
+ return { vmid, config, rootfs, mountpoints, network, warnings };
66
+ }
67
+ //# sourceMappingURL=lxc-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lxc-config.js","sourceRoot":"","sources":["../../../src/proxmox/probes/lxc-config.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=lxc-config.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lxc-config.test.d.ts","sourceRoot":"","sources":["../../../src/proxmox/probes/lxc-config.test.ts"],"names":[],"mappings":""}