@oneuptime/common 11.0.1 → 11.0.3

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 (577) hide show
  1. package/Models/DatabaseModels/Alert.ts +276 -0
  2. package/Models/DatabaseModels/AlertLabelRule.ts +38 -0
  3. package/Models/DatabaseModels/AlertOwnerRule.ts +38 -0
  4. package/Models/DatabaseModels/CephCluster.ts +964 -0
  5. package/Models/DatabaseModels/CephClusterLabelRule.ts +514 -0
  6. package/Models/DatabaseModels/CephClusterOwnerRule.ts +596 -0
  7. package/Models/DatabaseModels/CephClusterOwnerTeam.ts +487 -0
  8. package/Models/DatabaseModels/CephClusterOwnerUser.ts +486 -0
  9. package/Models/DatabaseModels/CephResource.ts +809 -0
  10. package/Models/DatabaseModels/DockerSwarmCluster.ts +989 -0
  11. package/Models/DatabaseModels/DockerSwarmClusterLabelRule.ts +514 -0
  12. package/Models/DatabaseModels/DockerSwarmClusterOwnerRule.ts +596 -0
  13. package/Models/DatabaseModels/DockerSwarmClusterOwnerTeam.ts +487 -0
  14. package/Models/DatabaseModels/DockerSwarmClusterOwnerUser.ts +486 -0
  15. package/Models/DatabaseModels/DockerSwarmResource.ts +750 -0
  16. package/Models/DatabaseModels/Host.ts +64 -0
  17. package/Models/DatabaseModels/Incident.ts +276 -0
  18. package/Models/DatabaseModels/IncidentLabelRule.ts +38 -0
  19. package/Models/DatabaseModels/IncidentOwnerRule.ts +38 -0
  20. package/Models/DatabaseModels/IncidentTemplate.ts +56 -0
  21. package/Models/DatabaseModels/Index.ts +48 -0
  22. package/Models/DatabaseModels/PodmanHost.ts +859 -0
  23. package/Models/DatabaseModels/PodmanHostLabelRule.ts +514 -0
  24. package/Models/DatabaseModels/PodmanHostOwnerRule.ts +596 -0
  25. package/Models/DatabaseModels/PodmanHostOwnerTeam.ts +487 -0
  26. package/Models/DatabaseModels/PodmanHostOwnerUser.ts +486 -0
  27. package/Models/DatabaseModels/PodmanResource.ts +498 -0
  28. package/Models/DatabaseModels/ProxmoxCluster.ts +943 -0
  29. package/Models/DatabaseModels/ProxmoxClusterLabelRule.ts +514 -0
  30. package/Models/DatabaseModels/ProxmoxClusterOwnerRule.ts +596 -0
  31. package/Models/DatabaseModels/ProxmoxClusterOwnerTeam.ts +487 -0
  32. package/Models/DatabaseModels/ProxmoxClusterOwnerUser.ts +486 -0
  33. package/Models/DatabaseModels/ProxmoxResource.ts +726 -0
  34. package/Models/DatabaseModels/ScheduledMaintenance.ts +220 -0
  35. package/Models/DatabaseModels/ScheduledMaintenanceLabelRule.ts +38 -0
  36. package/Models/DatabaseModels/ScheduledMaintenanceOwnerRule.ts +38 -0
  37. package/Models/DatabaseModels/ScheduledMaintenanceTemplate.ts +56 -0
  38. package/Models/DatabaseModels/TelemetryException.ts +2 -0
  39. package/Server/API/BillingInvoiceAPI.ts +47 -7
  40. package/Server/API/CephResourceAPI.ts +134 -0
  41. package/Server/API/DashboardAPI.ts +135 -0
  42. package/Server/API/DockerSwarmResourceAPI.ts +137 -0
  43. package/Server/API/ProjectAPI.ts +15 -0
  44. package/Server/API/ProxmoxResourceAPI.ts +132 -0
  45. package/Server/API/ResellerPlanAPI.ts +17 -0
  46. package/Server/API/TelemetryAPI.ts +8 -1
  47. package/Server/Infrastructure/GlobalCache.ts +8 -2
  48. package/Server/Infrastructure/Postgres/SchemaMigrations/1781500000000-AddProxmoxAndCephClusterTables.ts +163 -0
  49. package/Server/Infrastructure/Postgres/SchemaMigrations/1781587937032-MigrationName.ts +3199 -0
  50. package/Server/Infrastructure/Postgres/SchemaMigrations/1781600000000-AddProxmoxCephV2Columns.ts +211 -0
  51. package/Server/Infrastructure/Postgres/SchemaMigrations/1781600000001-AddProxmoxCephActivityAndRules.ts +590 -0
  52. package/Server/Infrastructure/Postgres/SchemaMigrations/1781700000000-AddProxmoxCephV3Columns.ts +64 -0
  53. package/Server/Infrastructure/Postgres/SchemaMigrations/Index.ts +10 -0
  54. package/Server/Infrastructure/Redis.ts +40 -12
  55. package/Server/Services/AlertLabelRuleEngineService.ts +29 -0
  56. package/Server/Services/AlertOwnerRuleEngineService.ts +67 -0
  57. package/Server/Services/AnalyticsDatabaseService.ts +1 -1
  58. package/Server/Services/BillingService.ts +109 -21
  59. package/Server/Services/CephClusterLabelRuleEngineService.ts +200 -0
  60. package/Server/Services/CephClusterLabelRuleService.ts +14 -0
  61. package/Server/Services/CephClusterOwnerRuleEngineService.ts +218 -0
  62. package/Server/Services/CephClusterOwnerRuleService.ts +14 -0
  63. package/Server/Services/CephClusterOwnerTeamService.ts +10 -0
  64. package/Server/Services/CephClusterOwnerUserService.ts +10 -0
  65. package/Server/Services/CephClusterService.ts +401 -0
  66. package/Server/Services/CephResourceService.ts +383 -0
  67. package/Server/Services/CloudResourceService.ts +11 -3
  68. package/Server/Services/DockerHostService.ts +11 -3
  69. package/Server/Services/DockerSwarmClusterLabelRuleEngineService.ts +214 -0
  70. package/Server/Services/DockerSwarmClusterLabelRuleService.ts +14 -0
  71. package/Server/Services/DockerSwarmClusterOwnerRuleEngineService.ts +232 -0
  72. package/Server/Services/DockerSwarmClusterOwnerRuleService.ts +14 -0
  73. package/Server/Services/DockerSwarmClusterOwnerTeamService.ts +10 -0
  74. package/Server/Services/DockerSwarmClusterOwnerUserService.ts +10 -0
  75. package/Server/Services/DockerSwarmClusterService.ts +404 -0
  76. package/Server/Services/DockerSwarmResourceService.ts +381 -0
  77. package/Server/Services/ExceptionAggregationService.ts +3 -0
  78. package/Server/Services/HostService.ts +11 -3
  79. package/Server/Services/IncidentLabelRuleEngineService.ts +27 -0
  80. package/Server/Services/IncidentOwnerRuleEngineService.ts +67 -0
  81. package/Server/Services/IncidentService.ts +11 -0
  82. package/Server/Services/Index.ts +38 -0
  83. package/Server/Services/KubernetesClusterService.ts +11 -3
  84. package/Server/Services/LogAggregationService.ts +3 -0
  85. package/Server/Services/MetricAggregationService.ts +3 -0
  86. package/Server/Services/OpenTelemetryIngestService.ts +73 -0
  87. package/Server/Services/PodmanHostLabelRuleEngineService.ts +198 -0
  88. package/Server/Services/PodmanHostLabelRuleService.ts +14 -0
  89. package/Server/Services/PodmanHostOwnerRuleEngineService.ts +216 -0
  90. package/Server/Services/PodmanHostOwnerRuleService.ts +14 -0
  91. package/Server/Services/PodmanHostOwnerTeamService.ts +10 -0
  92. package/Server/Services/PodmanHostOwnerUserService.ts +10 -0
  93. package/Server/Services/PodmanHostService.ts +368 -0
  94. package/Server/Services/PodmanResourceService.ts +310 -0
  95. package/Server/Services/ProxmoxClusterLabelRuleEngineService.ts +204 -0
  96. package/Server/Services/ProxmoxClusterLabelRuleService.ts +14 -0
  97. package/Server/Services/ProxmoxClusterOwnerRuleEngineService.ts +222 -0
  98. package/Server/Services/ProxmoxClusterOwnerRuleService.ts +14 -0
  99. package/Server/Services/ProxmoxClusterOwnerTeamService.ts +10 -0
  100. package/Server/Services/ProxmoxClusterOwnerUserService.ts +10 -0
  101. package/Server/Services/ProxmoxClusterService.ts +382 -0
  102. package/Server/Services/ProxmoxResourceService.ts +404 -0
  103. package/Server/Services/RumApplicationService.ts +11 -3
  104. package/Server/Services/ScheduledMaintenanceLabelRuleEngineService.ts +29 -0
  105. package/Server/Services/ScheduledMaintenanceOwnerRuleEngineService.ts +67 -0
  106. package/Server/Services/ServerlessFunctionService.ts +11 -3
  107. package/Server/Services/TelemetryUsageBillingService.ts +59 -3
  108. package/Server/Services/TraceAggregationService.ts +3 -0
  109. package/Server/Types/AnalyticsDatabase/AggregateBy.ts +8 -23
  110. package/Server/Types/Database/Permissions/OwnerTableRegistry.ts +13 -0
  111. package/Server/Utils/Monitor/MonitorAlert.ts +55 -0
  112. package/Server/Utils/Monitor/MonitorClusterContext.ts +158 -0
  113. package/Server/Utils/Monitor/MonitorCriteriaEvaluator.ts +650 -4
  114. package/Server/Utils/Monitor/MonitorIncident.ts +175 -7
  115. package/Server/Utils/Monitor/MonitorMaintenanceSuppression.ts +56 -6
  116. package/Server/Utils/Monitor/MonitorTemplateUtil.ts +6 -1
  117. package/Server/Utils/Monitor/SeriesResourceLabels.ts +59 -0
  118. package/Server/Utils/Profiling.ts +37 -2
  119. package/Server/Utils/Telemetry/EntityRegistry.ts +4 -0
  120. package/Server/Utils/Telemetry/ProxmoxCephSnapshotScan.ts +1096 -0
  121. package/Server/Utils/Telemetry/ResourceFacetResolver.ts +49 -0
  122. package/Server/Utils/Telemetry/Telemetry.ts +10 -0
  123. package/Server/Utils/Telemetry/TelemetryEntity.ts +107 -0
  124. package/Server/Utils/Telemetry.ts +8 -19
  125. package/Tests/Server/API/BillingInvoiceAPI.test.ts +194 -0
  126. package/Tests/Server/API/ProjectAPI.test.ts +91 -0
  127. package/Tests/Server/API/ResellerPlanAPI.test.ts +207 -0
  128. package/Tests/Server/Infrastructure/GlobalCache.test.ts +100 -0
  129. package/Tests/Server/Services/BillingService.test.ts +323 -0
  130. package/Tests/Server/Services/CephResourceService.test.ts +264 -0
  131. package/Tests/Server/Services/ProxmoxResourceService.test.ts +326 -0
  132. package/Tests/Server/Utils/Monitor/MonitorCriteriaEvaluator.test.ts +322 -0
  133. package/Tests/Server/Utils/Monitor/MonitorMaintenanceSuppression.test.ts +14 -0
  134. package/Tests/Server/Utils/Telemetry/ProxmoxCephSnapshotScan.test.ts +879 -0
  135. package/Tests/Server/Utils/Telemetry/TelemetryEntity.test.ts +196 -0
  136. package/Tests/Types/DockerSwarm/DockerSwarmInventoryExtractor.test.ts +667 -0
  137. package/Tests/Types/Monitor/CephAlertTemplates.test.ts +1231 -0
  138. package/Tests/Types/Monitor/DockerSwarmAlertTemplates.test.ts +528 -0
  139. package/Tests/Types/Monitor/ProxmoxAlertTemplates.test.ts +732 -0
  140. package/Tests/Utils/Telemetry/EntityRelationship.test.ts +49 -0
  141. package/Tests/Utils/Telemetry/HeartbeatAvailability.test.ts +423 -0
  142. package/Types/BaseDatabase/AggregationIntervalUtil.ts +74 -0
  143. package/Types/Dashboard/DashboardComponentType.ts +11 -0
  144. package/Types/Dashboard/DashboardComponents/ComponentArgument.ts +4 -0
  145. package/Types/Dashboard/DashboardComponents/DashboardCephOsdListComponent.ts +15 -0
  146. package/Types/Dashboard/DashboardComponents/DashboardCephPoolListComponent.ts +14 -0
  147. package/Types/Dashboard/DashboardComponents/DashboardDockerSwarmNodeListComponent.ts +17 -0
  148. package/Types/Dashboard/DashboardComponents/DashboardDockerSwarmServiceListComponent.ts +17 -0
  149. package/Types/Dashboard/DashboardComponents/DashboardPodmanContainerListComponent.ts +16 -0
  150. package/Types/Dashboard/DashboardComponents/DashboardPodmanHostListComponent.ts +15 -0
  151. package/Types/Dashboard/DashboardComponents/DashboardPodmanImageListComponent.ts +16 -0
  152. package/Types/Dashboard/DashboardComponents/DashboardPodmanNetworkListComponent.ts +15 -0
  153. package/Types/Dashboard/DashboardComponents/DashboardPodmanVolumeListComponent.ts +15 -0
  154. package/Types/Dashboard/DashboardComponents/DashboardProxmoxGuestListComponent.ts +17 -0
  155. package/Types/Dashboard/DashboardComponents/DashboardProxmoxNodeListComponent.ts +16 -0
  156. package/Types/Dashboard/DashboardTemplates.ts +640 -0
  157. package/Types/DockerSwarm/DockerSwarmInventoryExtractor.ts +452 -0
  158. package/Types/Icon/IconProp.ts +3 -0
  159. package/Types/Monitor/CephAlertTemplates.ts +1647 -0
  160. package/Types/Monitor/CephMetricCatalog.ts +409 -0
  161. package/Types/Monitor/DockerSwarmAlertTemplates.ts +461 -0
  162. package/Types/Monitor/DockerSwarmMetricCatalog.ts +139 -0
  163. package/Types/Monitor/HostAlertTemplates.ts +455 -0
  164. package/Types/Monitor/HostMetricCatalog.ts +177 -0
  165. package/Types/Monitor/MetricMonitor/MetricMonitorResponse.ts +65 -0
  166. package/Types/Monitor/MonitorStep.ts +163 -0
  167. package/Types/Monitor/MonitorStepCephMonitor.ts +57 -0
  168. package/Types/Monitor/MonitorStepDockerSwarmMonitor.ts +74 -0
  169. package/Types/Monitor/MonitorStepHostMonitor.ts +30 -0
  170. package/Types/Monitor/MonitorStepPodmanMonitor.ts +38 -0
  171. package/Types/Monitor/MonitorStepProxmoxMonitor.ts +81 -0
  172. package/Types/Monitor/MonitorType.ts +71 -1
  173. package/Types/Monitor/PodmanAlertTemplates.ts +507 -0
  174. package/Types/Monitor/PodmanMetricCatalog.ts +226 -0
  175. package/Types/Monitor/ProxmoxAlertTemplates.ts +899 -0
  176. package/Types/Monitor/ProxmoxMetricCatalog.ts +382 -0
  177. package/Types/Permission.ts +1029 -104
  178. package/Types/Podman/PodmanInventoryExtractor.ts +343 -0
  179. package/Types/Telemetry/EntityType.ts +23 -0
  180. package/Types/Telemetry/ServiceType.ts +4 -0
  181. package/UI/Components/Icon/Icon.tsx +141 -0
  182. package/UI/Components/LogsViewer/LogsViewer.tsx +44 -1
  183. package/UI/Components/LogsViewer/components/LogsFacetSidebar.tsx +28 -0
  184. package/UI/Components/MonitorTemplateVariables/TemplateVariablesCatalog.ts +15 -5
  185. package/UI/Utils/Telemetry/Telemetry.ts +16 -21
  186. package/UI/Utils/TelemetryService.ts +8 -3
  187. package/Utils/Dashboard/Components/DashboardCephOsdListComponent.ts +63 -0
  188. package/Utils/Dashboard/Components/DashboardCephPoolListComponent.ts +32 -0
  189. package/Utils/Dashboard/Components/DashboardCephResourceListShared.ts +61 -0
  190. package/Utils/Dashboard/Components/DashboardDockerSwarmNodeListComponent.ts +70 -0
  191. package/Utils/Dashboard/Components/DashboardDockerSwarmResourceListShared.ts +61 -0
  192. package/Utils/Dashboard/Components/DashboardDockerSwarmServiceListComponent.ts +71 -0
  193. package/Utils/Dashboard/Components/DashboardPodmanContainerListComponent.ts +100 -0
  194. package/Utils/Dashboard/Components/DashboardPodmanHostListComponent.ts +88 -0
  195. package/Utils/Dashboard/Components/DashboardPodmanImageListComponent.ts +97 -0
  196. package/Utils/Dashboard/Components/DashboardPodmanNetworkListComponent.ts +87 -0
  197. package/Utils/Dashboard/Components/DashboardPodmanVolumeListComponent.ts +87 -0
  198. package/Utils/Dashboard/Components/DashboardProxmoxGuestListComponent.ts +69 -0
  199. package/Utils/Dashboard/Components/DashboardProxmoxNodeListComponent.ts +55 -0
  200. package/Utils/Dashboard/Components/DashboardProxmoxResourceListShared.ts +61 -0
  201. package/Utils/Dashboard/Components/Index.ts +79 -0
  202. package/Utils/Telemetry/EntityKey.ts +53 -0
  203. package/Utils/Telemetry/EntityRelationship.ts +6 -0
  204. package/Utils/Telemetry/HeartbeatAvailability.ts +262 -0
  205. package/build/dist/Models/DatabaseModels/Alert.js +270 -0
  206. package/build/dist/Models/DatabaseModels/Alert.js.map +1 -1
  207. package/build/dist/Models/DatabaseModels/AlertLabelRule.js +39 -0
  208. package/build/dist/Models/DatabaseModels/AlertLabelRule.js.map +1 -1
  209. package/build/dist/Models/DatabaseModels/AlertOwnerRule.js +39 -0
  210. package/build/dist/Models/DatabaseModels/AlertOwnerRule.js.map +1 -1
  211. package/build/dist/Models/DatabaseModels/CephCluster.js +992 -0
  212. package/build/dist/Models/DatabaseModels/CephCluster.js.map +1 -0
  213. package/build/dist/Models/DatabaseModels/CephClusterLabelRule.js +522 -0
  214. package/build/dist/Models/DatabaseModels/CephClusterLabelRule.js.map +1 -0
  215. package/build/dist/Models/DatabaseModels/CephClusterOwnerRule.js +603 -0
  216. package/build/dist/Models/DatabaseModels/CephClusterOwnerRule.js.map +1 -0
  217. package/build/dist/Models/DatabaseModels/CephClusterOwnerTeam.js +503 -0
  218. package/build/dist/Models/DatabaseModels/CephClusterOwnerTeam.js.map +1 -0
  219. package/build/dist/Models/DatabaseModels/CephClusterOwnerUser.js +502 -0
  220. package/build/dist/Models/DatabaseModels/CephClusterOwnerUser.js.map +1 -0
  221. package/build/dist/Models/DatabaseModels/CephResource.js +846 -0
  222. package/build/dist/Models/DatabaseModels/CephResource.js.map +1 -0
  223. package/build/dist/Models/DatabaseModels/DockerSwarmCluster.js +1018 -0
  224. package/build/dist/Models/DatabaseModels/DockerSwarmCluster.js.map +1 -0
  225. package/build/dist/Models/DatabaseModels/DockerSwarmClusterLabelRule.js +522 -0
  226. package/build/dist/Models/DatabaseModels/DockerSwarmClusterLabelRule.js.map +1 -0
  227. package/build/dist/Models/DatabaseModels/DockerSwarmClusterOwnerRule.js +603 -0
  228. package/build/dist/Models/DatabaseModels/DockerSwarmClusterOwnerRule.js.map +1 -0
  229. package/build/dist/Models/DatabaseModels/DockerSwarmClusterOwnerTeam.js +503 -0
  230. package/build/dist/Models/DatabaseModels/DockerSwarmClusterOwnerTeam.js.map +1 -0
  231. package/build/dist/Models/DatabaseModels/DockerSwarmClusterOwnerUser.js +502 -0
  232. package/build/dist/Models/DatabaseModels/DockerSwarmClusterOwnerUser.js.map +1 -0
  233. package/build/dist/Models/DatabaseModels/DockerSwarmResource.js +787 -0
  234. package/build/dist/Models/DatabaseModels/DockerSwarmResource.js.map +1 -0
  235. package/build/dist/Models/DatabaseModels/Host.js +63 -0
  236. package/build/dist/Models/DatabaseModels/Host.js.map +1 -1
  237. package/build/dist/Models/DatabaseModels/Incident.js +270 -0
  238. package/build/dist/Models/DatabaseModels/Incident.js.map +1 -1
  239. package/build/dist/Models/DatabaseModels/IncidentLabelRule.js +39 -0
  240. package/build/dist/Models/DatabaseModels/IncidentLabelRule.js.map +1 -1
  241. package/build/dist/Models/DatabaseModels/IncidentOwnerRule.js +39 -0
  242. package/build/dist/Models/DatabaseModels/IncidentOwnerRule.js.map +1 -1
  243. package/build/dist/Models/DatabaseModels/IncidentTemplate.js +54 -0
  244. package/build/dist/Models/DatabaseModels/IncidentTemplate.js.map +1 -1
  245. package/build/dist/Models/DatabaseModels/Index.js +48 -0
  246. package/build/dist/Models/DatabaseModels/Index.js.map +1 -1
  247. package/build/dist/Models/DatabaseModels/PodmanHost.js +885 -0
  248. package/build/dist/Models/DatabaseModels/PodmanHost.js.map +1 -0
  249. package/build/dist/Models/DatabaseModels/PodmanHostLabelRule.js +522 -0
  250. package/build/dist/Models/DatabaseModels/PodmanHostLabelRule.js.map +1 -0
  251. package/build/dist/Models/DatabaseModels/PodmanHostOwnerRule.js +603 -0
  252. package/build/dist/Models/DatabaseModels/PodmanHostOwnerRule.js.map +1 -0
  253. package/build/dist/Models/DatabaseModels/PodmanHostOwnerTeam.js +503 -0
  254. package/build/dist/Models/DatabaseModels/PodmanHostOwnerTeam.js.map +1 -0
  255. package/build/dist/Models/DatabaseModels/PodmanHostOwnerUser.js +502 -0
  256. package/build/dist/Models/DatabaseModels/PodmanHostOwnerUser.js.map +1 -0
  257. package/build/dist/Models/DatabaseModels/PodmanResource.js +526 -0
  258. package/build/dist/Models/DatabaseModels/PodmanResource.js.map +1 -0
  259. package/build/dist/Models/DatabaseModels/ProxmoxCluster.js +967 -0
  260. package/build/dist/Models/DatabaseModels/ProxmoxCluster.js.map +1 -0
  261. package/build/dist/Models/DatabaseModels/ProxmoxClusterLabelRule.js +522 -0
  262. package/build/dist/Models/DatabaseModels/ProxmoxClusterLabelRule.js.map +1 -0
  263. package/build/dist/Models/DatabaseModels/ProxmoxClusterOwnerRule.js +603 -0
  264. package/build/dist/Models/DatabaseModels/ProxmoxClusterOwnerRule.js.map +1 -0
  265. package/build/dist/Models/DatabaseModels/ProxmoxClusterOwnerTeam.js +503 -0
  266. package/build/dist/Models/DatabaseModels/ProxmoxClusterOwnerTeam.js.map +1 -0
  267. package/build/dist/Models/DatabaseModels/ProxmoxClusterOwnerUser.js +502 -0
  268. package/build/dist/Models/DatabaseModels/ProxmoxClusterOwnerUser.js.map +1 -0
  269. package/build/dist/Models/DatabaseModels/ProxmoxResource.js +761 -0
  270. package/build/dist/Models/DatabaseModels/ProxmoxResource.js.map +1 -0
  271. package/build/dist/Models/DatabaseModels/ScheduledMaintenance.js +216 -0
  272. package/build/dist/Models/DatabaseModels/ScheduledMaintenance.js.map +1 -1
  273. package/build/dist/Models/DatabaseModels/ScheduledMaintenanceLabelRule.js +39 -0
  274. package/build/dist/Models/DatabaseModels/ScheduledMaintenanceLabelRule.js.map +1 -1
  275. package/build/dist/Models/DatabaseModels/ScheduledMaintenanceOwnerRule.js +39 -0
  276. package/build/dist/Models/DatabaseModels/ScheduledMaintenanceOwnerRule.js.map +1 -1
  277. package/build/dist/Models/DatabaseModels/ScheduledMaintenanceTemplate.js +54 -0
  278. package/build/dist/Models/DatabaseModels/ScheduledMaintenanceTemplate.js.map +1 -1
  279. package/build/dist/Models/DatabaseModels/TelemetryException.js +2 -0
  280. package/build/dist/Models/DatabaseModels/TelemetryException.js.map +1 -1
  281. package/build/dist/Server/API/BillingInvoiceAPI.js +35 -5
  282. package/build/dist/Server/API/BillingInvoiceAPI.js.map +1 -1
  283. package/build/dist/Server/API/CephResourceAPI.js +98 -0
  284. package/build/dist/Server/API/CephResourceAPI.js.map +1 -0
  285. package/build/dist/Server/API/DashboardAPI.js +135 -0
  286. package/build/dist/Server/API/DashboardAPI.js.map +1 -1
  287. package/build/dist/Server/API/DockerSwarmResourceAPI.js +100 -0
  288. package/build/dist/Server/API/DockerSwarmResourceAPI.js.map +1 -0
  289. package/build/dist/Server/API/ProjectAPI.js +11 -0
  290. package/build/dist/Server/API/ProjectAPI.js.map +1 -1
  291. package/build/dist/Server/API/ProxmoxResourceAPI.js +95 -0
  292. package/build/dist/Server/API/ProxmoxResourceAPI.js.map +1 -0
  293. package/build/dist/Server/API/ResellerPlanAPI.js +17 -3
  294. package/build/dist/Server/API/ResellerPlanAPI.js.map +1 -1
  295. package/build/dist/Server/API/TelemetryAPI.js +8 -1
  296. package/build/dist/Server/API/TelemetryAPI.js.map +1 -1
  297. package/build/dist/Server/Infrastructure/GlobalCache.js +7 -2
  298. package/build/dist/Server/Infrastructure/GlobalCache.js.map +1 -1
  299. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781500000000-AddProxmoxAndCephClusterTables.js +76 -0
  300. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781500000000-AddProxmoxAndCephClusterTables.js.map +1 -0
  301. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781587937032-MigrationName.js +1100 -0
  302. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781587937032-MigrationName.js.map +1 -0
  303. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781600000000-AddProxmoxCephV2Columns.js +108 -0
  304. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781600000000-AddProxmoxCephV2Columns.js.map +1 -0
  305. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781600000001-AddProxmoxCephActivityAndRules.js +253 -0
  306. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781600000001-AddProxmoxCephActivityAndRules.js.map +1 -0
  307. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781700000000-AddProxmoxCephV3Columns.js +43 -0
  308. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781700000000-AddProxmoxCephV3Columns.js.map +1 -0
  309. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js +10 -0
  310. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js.map +1 -1
  311. package/build/dist/Server/Infrastructure/Redis.js +31 -8
  312. package/build/dist/Server/Infrastructure/Redis.js.map +1 -1
  313. package/build/dist/Server/Services/AlertLabelRuleEngineService.js +30 -4
  314. package/build/dist/Server/Services/AlertLabelRuleEngineService.js.map +1 -1
  315. package/build/dist/Server/Services/AlertOwnerRuleEngineService.js +62 -5
  316. package/build/dist/Server/Services/AlertOwnerRuleEngineService.js.map +1 -1
  317. package/build/dist/Server/Services/AnalyticsDatabaseService.js +1 -1
  318. package/build/dist/Server/Services/AnalyticsDatabaseService.js.map +1 -1
  319. package/build/dist/Server/Services/BillingService.js +85 -23
  320. package/build/dist/Server/Services/BillingService.js.map +1 -1
  321. package/build/dist/Server/Services/CephClusterLabelRuleEngineService.js +166 -0
  322. package/build/dist/Server/Services/CephClusterLabelRuleEngineService.js.map +1 -0
  323. package/build/dist/Server/Services/CephClusterLabelRuleService.js +13 -0
  324. package/build/dist/Server/Services/CephClusterLabelRuleService.js.map +1 -0
  325. package/build/dist/Server/Services/CephClusterOwnerRuleEngineService.js +186 -0
  326. package/build/dist/Server/Services/CephClusterOwnerRuleEngineService.js.map +1 -0
  327. package/build/dist/Server/Services/CephClusterOwnerRuleService.js +13 -0
  328. package/build/dist/Server/Services/CephClusterOwnerRuleService.js.map +1 -0
  329. package/build/dist/Server/Services/CephClusterOwnerTeamService.js +9 -0
  330. package/build/dist/Server/Services/CephClusterOwnerTeamService.js.map +1 -0
  331. package/build/dist/Server/Services/CephClusterOwnerUserService.js +9 -0
  332. package/build/dist/Server/Services/CephClusterOwnerUserService.js.map +1 -0
  333. package/build/dist/Server/Services/CephClusterService.js +353 -0
  334. package/build/dist/Server/Services/CephClusterService.js.map +1 -0
  335. package/build/dist/Server/Services/CephResourceService.js +257 -0
  336. package/build/dist/Server/Services/CephResourceService.js.map +1 -0
  337. package/build/dist/Server/Services/CloudResourceService.js +10 -2
  338. package/build/dist/Server/Services/CloudResourceService.js.map +1 -1
  339. package/build/dist/Server/Services/DockerHostService.js +10 -2
  340. package/build/dist/Server/Services/DockerHostService.js.map +1 -1
  341. package/build/dist/Server/Services/DockerSwarmClusterLabelRuleEngineService.js +168 -0
  342. package/build/dist/Server/Services/DockerSwarmClusterLabelRuleEngineService.js.map +1 -0
  343. package/build/dist/Server/Services/DockerSwarmClusterLabelRuleService.js +13 -0
  344. package/build/dist/Server/Services/DockerSwarmClusterLabelRuleService.js.map +1 -0
  345. package/build/dist/Server/Services/DockerSwarmClusterOwnerRuleEngineService.js +188 -0
  346. package/build/dist/Server/Services/DockerSwarmClusterOwnerRuleEngineService.js.map +1 -0
  347. package/build/dist/Server/Services/DockerSwarmClusterOwnerRuleService.js +13 -0
  348. package/build/dist/Server/Services/DockerSwarmClusterOwnerRuleService.js.map +1 -0
  349. package/build/dist/Server/Services/DockerSwarmClusterOwnerTeamService.js +9 -0
  350. package/build/dist/Server/Services/DockerSwarmClusterOwnerTeamService.js.map +1 -0
  351. package/build/dist/Server/Services/DockerSwarmClusterOwnerUserService.js +9 -0
  352. package/build/dist/Server/Services/DockerSwarmClusterOwnerUserService.js.map +1 -0
  353. package/build/dist/Server/Services/DockerSwarmClusterService.js +353 -0
  354. package/build/dist/Server/Services/DockerSwarmClusterService.js.map +1 -0
  355. package/build/dist/Server/Services/DockerSwarmResourceService.js +258 -0
  356. package/build/dist/Server/Services/DockerSwarmResourceService.js.map +1 -0
  357. package/build/dist/Server/Services/ExceptionAggregationService.js +3 -0
  358. package/build/dist/Server/Services/ExceptionAggregationService.js.map +1 -1
  359. package/build/dist/Server/Services/HostService.js +10 -2
  360. package/build/dist/Server/Services/HostService.js.map +1 -1
  361. package/build/dist/Server/Services/IncidentLabelRuleEngineService.js +28 -4
  362. package/build/dist/Server/Services/IncidentLabelRuleEngineService.js.map +1 -1
  363. package/build/dist/Server/Services/IncidentOwnerRuleEngineService.js +62 -5
  364. package/build/dist/Server/Services/IncidentOwnerRuleEngineService.js.map +1 -1
  365. package/build/dist/Server/Services/IncidentService.js +8 -0
  366. package/build/dist/Server/Services/IncidentService.js.map +1 -1
  367. package/build/dist/Server/Services/Index.js +38 -0
  368. package/build/dist/Server/Services/Index.js.map +1 -1
  369. package/build/dist/Server/Services/KubernetesClusterService.js +10 -2
  370. package/build/dist/Server/Services/KubernetesClusterService.js.map +1 -1
  371. package/build/dist/Server/Services/LogAggregationService.js +3 -0
  372. package/build/dist/Server/Services/LogAggregationService.js.map +1 -1
  373. package/build/dist/Server/Services/MetricAggregationService.js +3 -0
  374. package/build/dist/Server/Services/MetricAggregationService.js.map +1 -1
  375. package/build/dist/Server/Services/OpenTelemetryIngestService.js +69 -9
  376. package/build/dist/Server/Services/OpenTelemetryIngestService.js.map +1 -1
  377. package/build/dist/Server/Services/PodmanHostLabelRuleEngineService.js +166 -0
  378. package/build/dist/Server/Services/PodmanHostLabelRuleEngineService.js.map +1 -0
  379. package/build/dist/Server/Services/PodmanHostLabelRuleService.js +13 -0
  380. package/build/dist/Server/Services/PodmanHostLabelRuleService.js.map +1 -0
  381. package/build/dist/Server/Services/PodmanHostOwnerRuleEngineService.js +186 -0
  382. package/build/dist/Server/Services/PodmanHostOwnerRuleEngineService.js.map +1 -0
  383. package/build/dist/Server/Services/PodmanHostOwnerRuleService.js +13 -0
  384. package/build/dist/Server/Services/PodmanHostOwnerRuleService.js.map +1 -0
  385. package/build/dist/Server/Services/PodmanHostOwnerTeamService.js +9 -0
  386. package/build/dist/Server/Services/PodmanHostOwnerTeamService.js.map +1 -0
  387. package/build/dist/Server/Services/PodmanHostOwnerUserService.js +9 -0
  388. package/build/dist/Server/Services/PodmanHostOwnerUserService.js.map +1 -0
  389. package/build/dist/Server/Services/PodmanHostService.js +319 -0
  390. package/build/dist/Server/Services/PodmanHostService.js.map +1 -0
  391. package/build/dist/Server/Services/PodmanResourceService.js +196 -0
  392. package/build/dist/Server/Services/PodmanResourceService.js.map +1 -0
  393. package/build/dist/Server/Services/ProxmoxClusterLabelRuleEngineService.js +166 -0
  394. package/build/dist/Server/Services/ProxmoxClusterLabelRuleEngineService.js.map +1 -0
  395. package/build/dist/Server/Services/ProxmoxClusterLabelRuleService.js +13 -0
  396. package/build/dist/Server/Services/ProxmoxClusterLabelRuleService.js.map +1 -0
  397. package/build/dist/Server/Services/ProxmoxClusterOwnerRuleEngineService.js +186 -0
  398. package/build/dist/Server/Services/ProxmoxClusterOwnerRuleEngineService.js.map +1 -0
  399. package/build/dist/Server/Services/ProxmoxClusterOwnerRuleService.js +13 -0
  400. package/build/dist/Server/Services/ProxmoxClusterOwnerRuleService.js.map +1 -0
  401. package/build/dist/Server/Services/ProxmoxClusterOwnerTeamService.js +9 -0
  402. package/build/dist/Server/Services/ProxmoxClusterOwnerTeamService.js.map +1 -0
  403. package/build/dist/Server/Services/ProxmoxClusterOwnerUserService.js +9 -0
  404. package/build/dist/Server/Services/ProxmoxClusterOwnerUserService.js.map +1 -0
  405. package/build/dist/Server/Services/ProxmoxClusterService.js +337 -0
  406. package/build/dist/Server/Services/ProxmoxClusterService.js.map +1 -0
  407. package/build/dist/Server/Services/ProxmoxResourceService.js +285 -0
  408. package/build/dist/Server/Services/ProxmoxResourceService.js.map +1 -0
  409. package/build/dist/Server/Services/RumApplicationService.js +10 -2
  410. package/build/dist/Server/Services/RumApplicationService.js.map +1 -1
  411. package/build/dist/Server/Services/ScheduledMaintenanceLabelRuleEngineService.js +30 -4
  412. package/build/dist/Server/Services/ScheduledMaintenanceLabelRuleEngineService.js.map +1 -1
  413. package/build/dist/Server/Services/ScheduledMaintenanceOwnerRuleEngineService.js +62 -5
  414. package/build/dist/Server/Services/ScheduledMaintenanceOwnerRuleEngineService.js.map +1 -1
  415. package/build/dist/Server/Services/ServerlessFunctionService.js +10 -2
  416. package/build/dist/Server/Services/ServerlessFunctionService.js.map +1 -1
  417. package/build/dist/Server/Services/TelemetryUsageBillingService.js +43 -3
  418. package/build/dist/Server/Services/TelemetryUsageBillingService.js.map +1 -1
  419. package/build/dist/Server/Services/TraceAggregationService.js +3 -0
  420. package/build/dist/Server/Services/TraceAggregationService.js.map +1 -1
  421. package/build/dist/Server/Types/AnalyticsDatabase/AggregateBy.js +8 -25
  422. package/build/dist/Server/Types/AnalyticsDatabase/AggregateBy.js.map +1 -1
  423. package/build/dist/Server/Types/Database/Permissions/OwnerTableRegistry.js +13 -0
  424. package/build/dist/Server/Types/Database/Permissions/OwnerTableRegistry.js.map +1 -1
  425. package/build/dist/Server/Utils/Monitor/MonitorAlert.js +44 -0
  426. package/build/dist/Server/Utils/Monitor/MonitorAlert.js.map +1 -1
  427. package/build/dist/Server/Utils/Monitor/MonitorClusterContext.js +118 -0
  428. package/build/dist/Server/Utils/Monitor/MonitorClusterContext.js.map +1 -0
  429. package/build/dist/Server/Utils/Monitor/MonitorCriteriaEvaluator.js +422 -4
  430. package/build/dist/Server/Utils/Monitor/MonitorCriteriaEvaluator.js.map +1 -1
  431. package/build/dist/Server/Utils/Monitor/MonitorIncident.js +137 -8
  432. package/build/dist/Server/Utils/Monitor/MonitorIncident.js.map +1 -1
  433. package/build/dist/Server/Utils/Monitor/MonitorMaintenanceSuppression.js +32 -6
  434. package/build/dist/Server/Utils/Monitor/MonitorMaintenanceSuppression.js.map +1 -1
  435. package/build/dist/Server/Utils/Monitor/MonitorTemplateUtil.js +6 -1
  436. package/build/dist/Server/Utils/Monitor/MonitorTemplateUtil.js.map +1 -1
  437. package/build/dist/Server/Utils/Monitor/SeriesResourceLabels.js +39 -0
  438. package/build/dist/Server/Utils/Monitor/SeriesResourceLabels.js.map +1 -1
  439. package/build/dist/Server/Utils/Profiling.js +24 -3
  440. package/build/dist/Server/Utils/Profiling.js.map +1 -1
  441. package/build/dist/Server/Utils/Telemetry/EntityRegistry.js +4 -0
  442. package/build/dist/Server/Utils/Telemetry/EntityRegistry.js.map +1 -1
  443. package/build/dist/Server/Utils/Telemetry/ProxmoxCephSnapshotScan.js +854 -0
  444. package/build/dist/Server/Utils/Telemetry/ProxmoxCephSnapshotScan.js.map +1 -0
  445. package/build/dist/Server/Utils/Telemetry/ResourceFacetResolver.js +30 -0
  446. package/build/dist/Server/Utils/Telemetry/ResourceFacetResolver.js.map +1 -1
  447. package/build/dist/Server/Utils/Telemetry/Telemetry.js +6 -0
  448. package/build/dist/Server/Utils/Telemetry/Telemetry.js.map +1 -1
  449. package/build/dist/Server/Utils/Telemetry/TelemetryEntity.js +80 -0
  450. package/build/dist/Server/Utils/Telemetry/TelemetryEntity.js.map +1 -1
  451. package/build/dist/Server/Utils/Telemetry.js +8 -10
  452. package/build/dist/Server/Utils/Telemetry.js.map +1 -1
  453. package/build/dist/Types/BaseDatabase/AggregationIntervalUtil.js +69 -0
  454. package/build/dist/Types/BaseDatabase/AggregationIntervalUtil.js.map +1 -0
  455. package/build/dist/Types/Dashboard/DashboardComponentType.js +11 -0
  456. package/build/dist/Types/Dashboard/DashboardComponentType.js.map +1 -1
  457. package/build/dist/Types/Dashboard/DashboardComponents/ComponentArgument.js +4 -0
  458. package/build/dist/Types/Dashboard/DashboardComponents/ComponentArgument.js.map +1 -1
  459. package/build/dist/Types/Dashboard/DashboardComponents/DashboardCephOsdListComponent.js +2 -0
  460. package/build/dist/Types/Dashboard/DashboardComponents/DashboardCephOsdListComponent.js.map +1 -0
  461. package/build/dist/Types/Dashboard/DashboardComponents/DashboardCephPoolListComponent.js +2 -0
  462. package/build/dist/Types/Dashboard/DashboardComponents/DashboardCephPoolListComponent.js.map +1 -0
  463. package/build/dist/Types/Dashboard/DashboardComponents/DashboardDockerSwarmNodeListComponent.js +2 -0
  464. package/build/dist/Types/Dashboard/DashboardComponents/DashboardDockerSwarmNodeListComponent.js.map +1 -0
  465. package/build/dist/Types/Dashboard/DashboardComponents/DashboardDockerSwarmServiceListComponent.js +2 -0
  466. package/build/dist/Types/Dashboard/DashboardComponents/DashboardDockerSwarmServiceListComponent.js.map +1 -0
  467. package/build/dist/Types/Dashboard/DashboardComponents/DashboardPodmanContainerListComponent.js +2 -0
  468. package/build/dist/Types/Dashboard/DashboardComponents/DashboardPodmanContainerListComponent.js.map +1 -0
  469. package/build/dist/Types/Dashboard/DashboardComponents/DashboardPodmanHostListComponent.js +2 -0
  470. package/build/dist/Types/Dashboard/DashboardComponents/DashboardPodmanHostListComponent.js.map +1 -0
  471. package/build/dist/Types/Dashboard/DashboardComponents/DashboardPodmanImageListComponent.js +2 -0
  472. package/build/dist/Types/Dashboard/DashboardComponents/DashboardPodmanImageListComponent.js.map +1 -0
  473. package/build/dist/Types/Dashboard/DashboardComponents/DashboardPodmanNetworkListComponent.js +2 -0
  474. package/build/dist/Types/Dashboard/DashboardComponents/DashboardPodmanNetworkListComponent.js.map +1 -0
  475. package/build/dist/Types/Dashboard/DashboardComponents/DashboardPodmanVolumeListComponent.js +2 -0
  476. package/build/dist/Types/Dashboard/DashboardComponents/DashboardPodmanVolumeListComponent.js.map +1 -0
  477. package/build/dist/Types/Dashboard/DashboardComponents/DashboardProxmoxGuestListComponent.js +2 -0
  478. package/build/dist/Types/Dashboard/DashboardComponents/DashboardProxmoxGuestListComponent.js.map +1 -0
  479. package/build/dist/Types/Dashboard/DashboardComponents/DashboardProxmoxNodeListComponent.js +2 -0
  480. package/build/dist/Types/Dashboard/DashboardComponents/DashboardProxmoxNodeListComponent.js.map +1 -0
  481. package/build/dist/Types/Dashboard/DashboardTemplates.js +562 -0
  482. package/build/dist/Types/Dashboard/DashboardTemplates.js.map +1 -1
  483. package/build/dist/Types/DockerSwarm/DockerSwarmInventoryExtractor.js +359 -0
  484. package/build/dist/Types/DockerSwarm/DockerSwarmInventoryExtractor.js.map +1 -0
  485. package/build/dist/Types/Icon/IconProp.js +3 -0
  486. package/build/dist/Types/Icon/IconProp.js.map +1 -1
  487. package/build/dist/Types/Monitor/CephAlertTemplates.js +1379 -0
  488. package/build/dist/Types/Monitor/CephAlertTemplates.js.map +1 -0
  489. package/build/dist/Types/Monitor/CephMetricCatalog.js +353 -0
  490. package/build/dist/Types/Monitor/CephMetricCatalog.js.map +1 -0
  491. package/build/dist/Types/Monitor/DockerSwarmAlertTemplates.js +358 -0
  492. package/build/dist/Types/Monitor/DockerSwarmAlertTemplates.js.map +1 -0
  493. package/build/dist/Types/Monitor/DockerSwarmMetricCatalog.js +103 -0
  494. package/build/dist/Types/Monitor/DockerSwarmMetricCatalog.js.map +1 -0
  495. package/build/dist/Types/Monitor/HostAlertTemplates.js +365 -0
  496. package/build/dist/Types/Monitor/HostAlertTemplates.js.map +1 -0
  497. package/build/dist/Types/Monitor/HostMetricCatalog.js +138 -0
  498. package/build/dist/Types/Monitor/HostMetricCatalog.js.map +1 -0
  499. package/build/dist/Types/Monitor/MonitorStep.js +115 -0
  500. package/build/dist/Types/Monitor/MonitorStep.js.map +1 -1
  501. package/build/dist/Types/Monitor/MonitorStepCephMonitor.js +34 -0
  502. package/build/dist/Types/Monitor/MonitorStepCephMonitor.js.map +1 -0
  503. package/build/dist/Types/Monitor/MonitorStepDockerSwarmMonitor.js +21 -0
  504. package/build/dist/Types/Monitor/MonitorStepDockerSwarmMonitor.js.map +1 -0
  505. package/build/dist/Types/Monitor/MonitorStepHostMonitor.js +20 -0
  506. package/build/dist/Types/Monitor/MonitorStepHostMonitor.js.map +1 -0
  507. package/build/dist/Types/Monitor/MonitorStepPodmanMonitor.js +21 -0
  508. package/build/dist/Types/Monitor/MonitorStepPodmanMonitor.js.map +1 -0
  509. package/build/dist/Types/Monitor/MonitorStepProxmoxMonitor.js +36 -0
  510. package/build/dist/Types/Monitor/MonitorStepProxmoxMonitor.js.map +1 -0
  511. package/build/dist/Types/Monitor/MonitorType.js +66 -1
  512. package/build/dist/Types/Monitor/MonitorType.js.map +1 -1
  513. package/build/dist/Types/Monitor/PodmanAlertTemplates.js +410 -0
  514. package/build/dist/Types/Monitor/PodmanAlertTemplates.js.map +1 -0
  515. package/build/dist/Types/Monitor/PodmanMetricCatalog.js +192 -0
  516. package/build/dist/Types/Monitor/PodmanMetricCatalog.js.map +1 -0
  517. package/build/dist/Types/Monitor/ProxmoxAlertTemplates.js +743 -0
  518. package/build/dist/Types/Monitor/ProxmoxAlertTemplates.js.map +1 -0
  519. package/build/dist/Types/Monitor/ProxmoxMetricCatalog.js +320 -0
  520. package/build/dist/Types/Monitor/ProxmoxMetricCatalog.js.map +1 -0
  521. package/build/dist/Types/Permission.js +824 -0
  522. package/build/dist/Types/Permission.js.map +1 -1
  523. package/build/dist/Types/Podman/PodmanInventoryExtractor.js +293 -0
  524. package/build/dist/Types/Podman/PodmanInventoryExtractor.js.map +1 -0
  525. package/build/dist/Types/Telemetry/EntityType.js +23 -0
  526. package/build/dist/Types/Telemetry/EntityType.js.map +1 -1
  527. package/build/dist/Types/Telemetry/ServiceType.js +4 -0
  528. package/build/dist/Types/Telemetry/ServiceType.js.map +1 -1
  529. package/build/dist/UI/Components/Icon/Icon.js +49 -0
  530. package/build/dist/UI/Components/Icon/Icon.js.map +1 -1
  531. package/build/dist/UI/Components/LogsViewer/LogsViewer.js +30 -2
  532. package/build/dist/UI/Components/LogsViewer/LogsViewer.js.map +1 -1
  533. package/build/dist/UI/Components/LogsViewer/components/LogsFacetSidebar.js +22 -0
  534. package/build/dist/UI/Components/LogsViewer/components/LogsFacetSidebar.js.map +1 -1
  535. package/build/dist/UI/Components/MonitorTemplateVariables/TemplateVariablesCatalog.js +11 -1
  536. package/build/dist/UI/Components/MonitorTemplateVariables/TemplateVariablesCatalog.js.map +1 -1
  537. package/build/dist/UI/Utils/Telemetry/Telemetry.js +11 -10
  538. package/build/dist/UI/Utils/Telemetry/Telemetry.js.map +1 -1
  539. package/build/dist/UI/Utils/TelemetryService.js +6 -2
  540. package/build/dist/UI/Utils/TelemetryService.js.map +1 -1
  541. package/build/dist/Utils/Dashboard/Components/DashboardCephOsdListComponent.js +50 -0
  542. package/build/dist/Utils/Dashboard/Components/DashboardCephOsdListComponent.js.map +1 -0
  543. package/build/dist/Utils/Dashboard/Components/DashboardCephPoolListComponent.js +27 -0
  544. package/build/dist/Utils/Dashboard/Components/DashboardCephPoolListComponent.js.map +1 -0
  545. package/build/dist/Utils/Dashboard/Components/DashboardCephResourceListShared.js +46 -0
  546. package/build/dist/Utils/Dashboard/Components/DashboardCephResourceListShared.js.map +1 -0
  547. package/build/dist/Utils/Dashboard/Components/DashboardDockerSwarmNodeListComponent.js +55 -0
  548. package/build/dist/Utils/Dashboard/Components/DashboardDockerSwarmNodeListComponent.js.map +1 -0
  549. package/build/dist/Utils/Dashboard/Components/DashboardDockerSwarmResourceListShared.js +46 -0
  550. package/build/dist/Utils/Dashboard/Components/DashboardDockerSwarmResourceListShared.js.map +1 -0
  551. package/build/dist/Utils/Dashboard/Components/DashboardDockerSwarmServiceListComponent.js +55 -0
  552. package/build/dist/Utils/Dashboard/Components/DashboardDockerSwarmServiceListComponent.js.map +1 -0
  553. package/build/dist/Utils/Dashboard/Components/DashboardPodmanContainerListComponent.js +77 -0
  554. package/build/dist/Utils/Dashboard/Components/DashboardPodmanContainerListComponent.js.map +1 -0
  555. package/build/dist/Utils/Dashboard/Components/DashboardPodmanHostListComponent.js +71 -0
  556. package/build/dist/Utils/Dashboard/Components/DashboardPodmanHostListComponent.js.map +1 -0
  557. package/build/dist/Utils/Dashboard/Components/DashboardPodmanImageListComponent.js +77 -0
  558. package/build/dist/Utils/Dashboard/Components/DashboardPodmanImageListComponent.js.map +1 -0
  559. package/build/dist/Utils/Dashboard/Components/DashboardPodmanNetworkListComponent.js +68 -0
  560. package/build/dist/Utils/Dashboard/Components/DashboardPodmanNetworkListComponent.js.map +1 -0
  561. package/build/dist/Utils/Dashboard/Components/DashboardPodmanVolumeListComponent.js +68 -0
  562. package/build/dist/Utils/Dashboard/Components/DashboardPodmanVolumeListComponent.js.map +1 -0
  563. package/build/dist/Utils/Dashboard/Components/DashboardProxmoxGuestListComponent.js +55 -0
  564. package/build/dist/Utils/Dashboard/Components/DashboardProxmoxGuestListComponent.js.map +1 -0
  565. package/build/dist/Utils/Dashboard/Components/DashboardProxmoxNodeListComponent.js +42 -0
  566. package/build/dist/Utils/Dashboard/Components/DashboardProxmoxNodeListComponent.js.map +1 -0
  567. package/build/dist/Utils/Dashboard/Components/DashboardProxmoxResourceListShared.js +46 -0
  568. package/build/dist/Utils/Dashboard/Components/DashboardProxmoxResourceListShared.js.map +1 -0
  569. package/build/dist/Utils/Dashboard/Components/Index.js +44 -0
  570. package/build/dist/Utils/Dashboard/Components/Index.js.map +1 -1
  571. package/build/dist/Utils/Telemetry/EntityKey.js +41 -0
  572. package/build/dist/Utils/Telemetry/EntityKey.js.map +1 -1
  573. package/build/dist/Utils/Telemetry/EntityRelationship.js +3 -0
  574. package/build/dist/Utils/Telemetry/EntityRelationship.js.map +1 -1
  575. package/build/dist/Utils/Telemetry/HeartbeatAvailability.js +174 -0
  576. package/build/dist/Utils/Telemetry/HeartbeatAvailability.js.map +1 -0
  577. package/package.json +29 -21
@@ -0,0 +1,732 @@
1
+ import {
2
+ ProxmoxAlertTemplate,
3
+ ProxmoxAlertTemplateArgs,
4
+ getAllProxmoxAlertTemplates,
5
+ getProxmoxAlertTemplateById,
6
+ } from "../../../Types/Monitor/ProxmoxAlertTemplates";
7
+ import { getProxmoxMetricByMetricName } from "../../../Types/Monitor/ProxmoxMetricCatalog";
8
+ import MonitorStep from "../../../Types/Monitor/MonitorStep";
9
+ import MonitorStepProxmoxMonitor from "../../../Types/Monitor/MonitorStepProxmoxMonitor";
10
+ import MonitorCriteriaInstance from "../../../Types/Monitor/MonitorCriteriaInstance";
11
+ import { FilterType } from "../../../Types/Monitor/CriteriaFilter";
12
+ import MetricsAggregationType from "../../../Types/Metrics/MetricsAggregationType";
13
+ import RollingTime from "../../../Types/RollingTime/RollingTime";
14
+ import ObjectID from "../../../Types/ObjectID";
15
+
16
+ /*
17
+ * WI-20: lock in the Proxmox alert-template contracts (v2 WI-9 + the v3
18
+ * WI-24/25 additions). Two layers:
19
+ *
20
+ * 1. ENUMERATED invariants run over getAllProxmoxAlertTemplates(), so a
21
+ * newly added template is automatically covered: it must build a
22
+ * valid MonitorStep, reference only catalog metrics, resolve every
23
+ * criteria alias, group by raw datapoint labels (pve-exporter
24
+ * identity lives in datapoint labels — NEVER `resource.`-prefixed),
25
+ * and use disjoint fire/recover thresholds on the same alias.
26
+ *
27
+ * 2. A per-template expectation table pins the spec'd metric /
28
+ * aggregation / threshold / scope-filter decisions (v3 spec §WI-24:
29
+ * pve-guest-not-backed-up fires >0 / recovers =0 on
30
+ * pve_not_backed_up_total, cluster scope, no groupBy; §WI-25:
31
+ * pve-replication-failing groups by the replication job `id`).
32
+ * The table is exhaustive both ways — adding a template without a
33
+ * row here fails loudly, which is the point.
34
+ */
35
+
36
+ interface QueryExpectation {
37
+ metricName: string;
38
+ aggregation: MetricsAggregationType;
39
+ attributes: Record<string, string>;
40
+ }
41
+
42
+ interface ThresholdExpectation {
43
+ alias: string;
44
+ filterType: FilterType;
45
+ value: number;
46
+ }
47
+
48
+ interface TemplateExpectation {
49
+ id: string;
50
+ category: string;
51
+ severity: string;
52
+ rollingTime: RollingTime;
53
+ queries: Array<QueryExpectation>;
54
+ groupBy: string | null;
55
+ formula: string | null;
56
+ fire: ThresholdExpectation;
57
+ recover: ThresholdExpectation;
58
+ }
59
+
60
+ const EXPECTED_TEMPLATES: Array<TemplateExpectation> = [
61
+ {
62
+ id: "pve-node-offline",
63
+ category: "Availability",
64
+ severity: "Critical",
65
+ rollingTime: RollingTime.Past5Minutes,
66
+ queries: [
67
+ {
68
+ metricName: "pve_up",
69
+ aggregation: MetricsAggregationType.Min,
70
+ attributes: { "pve.scope": "node" },
71
+ },
72
+ ],
73
+ groupBy: "id",
74
+ formula: null,
75
+ fire: { alias: "node_up", filterType: FilterType.LessThan, value: 1 },
76
+ recover: {
77
+ alias: "node_up",
78
+ filterType: FilterType.GreaterThanOrEqualTo,
79
+ value: 1,
80
+ },
81
+ },
82
+ {
83
+ id: "pve-guest-down",
84
+ category: "Availability",
85
+ severity: "Warning",
86
+ rollingTime: RollingTime.Past5Minutes,
87
+ queries: [
88
+ {
89
+ metricName: "pve_up",
90
+ aggregation: MetricsAggregationType.Min,
91
+ attributes: { "pve.scope": "guest" },
92
+ },
93
+ ],
94
+ groupBy: "id",
95
+ formula: null,
96
+ fire: { alias: "guest_up", filterType: FilterType.LessThan, value: 1 },
97
+ recover: {
98
+ alias: "guest_up",
99
+ filterType: FilterType.GreaterThanOrEqualTo,
100
+ value: 1,
101
+ },
102
+ },
103
+ {
104
+ /*
105
+ * Quorum proxy: Σpve_up over node series ÷ Σpve_node_info (constant-1
106
+ * metadata series per node). Same-receiver ratio ⇒ Sum/Sum (the
107
+ * scrape multiple cancels); cluster-wide ⇒ NO groupBy.
108
+ */
109
+ id: "pve-quorum-risk",
110
+ category: "Availability",
111
+ severity: "Critical",
112
+ rollingTime: RollingTime.Past5Minutes,
113
+ queries: [
114
+ {
115
+ metricName: "pve_up",
116
+ aggregation: MetricsAggregationType.Sum,
117
+ attributes: { "pve.scope": "node" },
118
+ },
119
+ {
120
+ metricName: "pve_node_info",
121
+ aggregation: MetricsAggregationType.Sum,
122
+ attributes: { "pve.scope": "node" },
123
+ },
124
+ ],
125
+ groupBy: null,
126
+ formula: "(nodes_online / nodes_total) * 100",
127
+ fire: {
128
+ alias: "node_availability",
129
+ filterType: FilterType.LessThanOrEqualTo,
130
+ value: 50,
131
+ },
132
+ recover: {
133
+ alias: "node_availability",
134
+ filterType: FilterType.GreaterThan,
135
+ value: 50,
136
+ },
137
+ },
138
+ {
139
+ /*
140
+ * pve_cpu_usage_ratio is already a true 0..1 ratio (one series per
141
+ * node) ⇒ Avg, and the threshold stays in ratio units (0.9, not 90).
142
+ */
143
+ id: "pve-node-high-cpu",
144
+ category: "Node",
145
+ severity: "Warning",
146
+ rollingTime: RollingTime.Past5Minutes,
147
+ queries: [
148
+ {
149
+ metricName: "pve_cpu_usage_ratio",
150
+ aggregation: MetricsAggregationType.Avg,
151
+ attributes: { "pve.scope": "node" },
152
+ },
153
+ ],
154
+ groupBy: "id",
155
+ formula: null,
156
+ fire: { alias: "node_cpu", filterType: FilterType.GreaterThan, value: 0.9 },
157
+ recover: {
158
+ alias: "node_cpu",
159
+ filterType: FilterType.LessThanOrEqualTo,
160
+ value: 0.9,
161
+ },
162
+ },
163
+ {
164
+ id: "pve-node-high-memory",
165
+ category: "Node",
166
+ severity: "Warning",
167
+ rollingTime: RollingTime.Past5Minutes,
168
+ queries: [
169
+ {
170
+ metricName: "pve_memory_usage_bytes",
171
+ aggregation: MetricsAggregationType.Sum,
172
+ attributes: { "pve.scope": "node" },
173
+ },
174
+ {
175
+ metricName: "pve_memory_size_bytes",
176
+ aggregation: MetricsAggregationType.Sum,
177
+ attributes: { "pve.scope": "node" },
178
+ },
179
+ ],
180
+ groupBy: "id",
181
+ formula: "(used_mem / total_mem) * 100",
182
+ fire: {
183
+ alias: "node_memory_utilization",
184
+ filterType: FilterType.GreaterThan,
185
+ value: 85,
186
+ },
187
+ recover: {
188
+ alias: "node_memory_utilization",
189
+ filterType: FilterType.LessThanOrEqualTo,
190
+ value: 85,
191
+ },
192
+ },
193
+ {
194
+ id: "pve-guest-high-cpu",
195
+ category: "Guest",
196
+ severity: "Warning",
197
+ rollingTime: RollingTime.Past5Minutes,
198
+ queries: [
199
+ {
200
+ metricName: "pve_cpu_usage_ratio",
201
+ aggregation: MetricsAggregationType.Avg,
202
+ attributes: { "pve.scope": "guest" },
203
+ },
204
+ ],
205
+ groupBy: "id",
206
+ formula: null,
207
+ fire: {
208
+ alias: "guest_cpu",
209
+ filterType: FilterType.GreaterThan,
210
+ value: 0.9,
211
+ },
212
+ recover: {
213
+ alias: "guest_cpu",
214
+ filterType: FilterType.LessThanOrEqualTo,
215
+ value: 0.9,
216
+ },
217
+ },
218
+ {
219
+ id: "pve-storage-near-full",
220
+ category: "Storage",
221
+ severity: "Warning",
222
+ rollingTime: RollingTime.Past5Minutes,
223
+ queries: [
224
+ {
225
+ metricName: "pve_disk_usage_bytes",
226
+ aggregation: MetricsAggregationType.Sum,
227
+ attributes: { "pve.scope": "storage" },
228
+ },
229
+ {
230
+ metricName: "pve_disk_size_bytes",
231
+ aggregation: MetricsAggregationType.Sum,
232
+ attributes: { "pve.scope": "storage" },
233
+ },
234
+ ],
235
+ groupBy: "id",
236
+ formula: "(used_disk / total_disk) * 100",
237
+ fire: {
238
+ alias: "storage_utilization",
239
+ filterType: FilterType.GreaterThan,
240
+ value: 85,
241
+ },
242
+ recover: {
243
+ alias: "storage_utilization",
244
+ filterType: FilterType.LessThanOrEqualTo,
245
+ value: 85,
246
+ },
247
+ },
248
+ {
249
+ /*
250
+ * LXC-only via pve.type (qemu in-guest disk usage reads 0 without the
251
+ * QEMU guest agent — alerting on it would be a lie).
252
+ */
253
+ id: "pve-lxc-disk-near-full",
254
+ category: "Storage",
255
+ severity: "Warning",
256
+ rollingTime: RollingTime.Past5Minutes,
257
+ queries: [
258
+ {
259
+ metricName: "pve_disk_usage_bytes",
260
+ aggregation: MetricsAggregationType.Sum,
261
+ attributes: { "pve.type": "lxc" },
262
+ },
263
+ {
264
+ metricName: "pve_disk_size_bytes",
265
+ aggregation: MetricsAggregationType.Sum,
266
+ attributes: { "pve.type": "lxc" },
267
+ },
268
+ ],
269
+ groupBy: "id",
270
+ formula: "(used_disk / total_disk) * 100",
271
+ fire: {
272
+ alias: "lxc_disk_utilization",
273
+ filterType: FilterType.GreaterThan,
274
+ value: 90,
275
+ },
276
+ recover: {
277
+ alias: "lxc_disk_utilization",
278
+ filterType: FilterType.LessThanOrEqualTo,
279
+ value: 90,
280
+ },
281
+ },
282
+ {
283
+ /*
284
+ * Enum-series filter: pve_ha_state has one series per possible state
285
+ * (value 1 = current). state=error equality filter + Max per resource.
286
+ */
287
+ id: "pve-ha-state-error",
288
+ category: "HA",
289
+ severity: "Critical",
290
+ rollingTime: RollingTime.Past5Minutes,
291
+ queries: [
292
+ {
293
+ metricName: "pve_ha_state",
294
+ aggregation: MetricsAggregationType.Max,
295
+ attributes: { state: "error" },
296
+ },
297
+ ],
298
+ groupBy: "id",
299
+ formula: null,
300
+ fire: {
301
+ alias: "ha_error_state",
302
+ filterType: FilterType.GreaterThan,
303
+ value: 0,
304
+ },
305
+ recover: {
306
+ alias: "ha_error_state",
307
+ filterType: FilterType.EqualTo,
308
+ value: 0,
309
+ },
310
+ },
311
+ {
312
+ /*
313
+ * V3 WI-24: cluster-level backup-info gauge — one series, no `id`
314
+ * label ⇒ NO groupBy (one incident per cluster; per-guest naming
315
+ * belongs to pve_not_backed_up_info in the breakdown, not the alert).
316
+ */
317
+ id: "pve-guest-not-backed-up",
318
+ category: "Backup",
319
+ severity: "Warning",
320
+ rollingTime: RollingTime.Past5Minutes,
321
+ queries: [
322
+ {
323
+ metricName: "pve_not_backed_up_total",
324
+ aggregation: MetricsAggregationType.Max,
325
+ attributes: {},
326
+ },
327
+ ],
328
+ groupBy: null,
329
+ formula: null,
330
+ fire: {
331
+ alias: "guests_without_backup",
332
+ filterType: FilterType.GreaterThan,
333
+ value: 0,
334
+ },
335
+ recover: {
336
+ alias: "guests_without_backup",
337
+ filterType: FilterType.EqualTo,
338
+ value: 0,
339
+ },
340
+ },
341
+ {
342
+ /*
343
+ * V3 WI-25: replication series are labeled `id` with the replication
344
+ * JOB id (e.g. 100-0) — not a node/qemu/lxc resource id, so no
345
+ * pve.scope filter; groupBy `id` fires one incident per job.
346
+ */
347
+ id: "pve-replication-failing",
348
+ category: "Replication",
349
+ severity: "Critical",
350
+ rollingTime: RollingTime.Past5Minutes,
351
+ queries: [
352
+ {
353
+ metricName: "pve_replication_failed_syncs",
354
+ aggregation: MetricsAggregationType.Max,
355
+ attributes: {},
356
+ },
357
+ ],
358
+ groupBy: "id",
359
+ formula: null,
360
+ fire: {
361
+ alias: "replication_failed_syncs",
362
+ filterType: FilterType.GreaterThan,
363
+ value: 0,
364
+ },
365
+ recover: {
366
+ alias: "replication_failed_syncs",
367
+ filterType: FilterType.EqualTo,
368
+ value: 0,
369
+ },
370
+ },
371
+ ];
372
+
373
+ function buildArgs(): ProxmoxAlertTemplateArgs {
374
+ return {
375
+ clusterIdentifier: "pve-prod",
376
+ onlineMonitorStatusId: ObjectID.generate(),
377
+ offlineMonitorStatusId: ObjectID.generate(),
378
+ defaultIncidentSeverityId: ObjectID.generate(),
379
+ defaultAlertSeverityId: ObjectID.generate(),
380
+ monitorName: "Test Monitor",
381
+ };
382
+ }
383
+
384
+ function getProxmoxMonitor(step: MonitorStep): MonitorStepProxmoxMonitor {
385
+ const proxmoxMonitor: MonitorStepProxmoxMonitor | undefined =
386
+ step.data?.proxmoxMonitor;
387
+ if (!proxmoxMonitor) {
388
+ throw new Error("proxmoxMonitor missing from monitor step");
389
+ }
390
+ return proxmoxMonitor;
391
+ }
392
+
393
+ function getCriteriaInstances(
394
+ step: MonitorStep,
395
+ ): Array<MonitorCriteriaInstance> {
396
+ const instances: Array<MonitorCriteriaInstance> | undefined =
397
+ step.data?.monitorCriteria.data?.monitorCriteriaInstanceArray;
398
+ if (!instances || instances.length === 0) {
399
+ throw new Error("monitorCriteria missing from monitor step");
400
+ }
401
+ return instances;
402
+ }
403
+
404
+ // Aliases a criteria filter may legally reference: query + formula variables.
405
+ function getReferencableAliases(
406
+ monitor: MonitorStepProxmoxMonitor,
407
+ ): Set<string> {
408
+ const aliases: Set<string> = new Set<string>();
409
+ for (const queryConfig of monitor.metricViewConfig
410
+ .queryConfigs as Array<any>) {
411
+ aliases.add(queryConfig.metricAliasData.metricVariable);
412
+ }
413
+ for (const formulaConfig of (monitor.metricViewConfig.formulaConfigs ||
414
+ []) as Array<any>) {
415
+ aliases.add(formulaConfig.metricAliasData.metricVariable);
416
+ }
417
+ return aliases;
418
+ }
419
+
420
+ /*
421
+ * Fire and recover must be disjoint complements on the same alias —
422
+ * otherwise the monitor either flaps (overlap) or wedges (gap).
423
+ */
424
+ function isDisjointComplement(
425
+ fire: { filterType: FilterType; value: number },
426
+ recover: { filterType: FilterType; value: number },
427
+ ): boolean {
428
+ if (fire.value !== recover.value) {
429
+ return false;
430
+ }
431
+ switch (fire.filterType) {
432
+ case FilterType.GreaterThan:
433
+ return (
434
+ recover.filterType === FilterType.LessThanOrEqualTo ||
435
+ (fire.value === 0 && recover.filterType === FilterType.EqualTo)
436
+ );
437
+ case FilterType.GreaterThanOrEqualTo:
438
+ return recover.filterType === FilterType.LessThan;
439
+ case FilterType.LessThan:
440
+ return recover.filterType === FilterType.GreaterThanOrEqualTo;
441
+ case FilterType.LessThanOrEqualTo:
442
+ return recover.filterType === FilterType.GreaterThan;
443
+ default:
444
+ return false;
445
+ }
446
+ }
447
+
448
+ const ALL_TEMPLATES: Array<ProxmoxAlertTemplate> =
449
+ getAllProxmoxAlertTemplates();
450
+
451
+ describe("ProxmoxAlertTemplates - registry", () => {
452
+ test("template ids are unique and match the expectation table exactly", () => {
453
+ const ids: Array<string> = ALL_TEMPLATES.map((t: ProxmoxAlertTemplate) => {
454
+ return t.id;
455
+ });
456
+ expect(new Set(ids).size).toBe(ids.length);
457
+ // Exhaustive both ways: a new template must get an expectation row.
458
+ expect([...ids].sort()).toEqual(
459
+ EXPECTED_TEMPLATES.map((t: TemplateExpectation) => {
460
+ return t.id;
461
+ }).sort(),
462
+ );
463
+ });
464
+ });
465
+
466
+ describe("ProxmoxAlertTemplates - enumerated invariants (every template)", () => {
467
+ test.each(
468
+ ALL_TEMPLATES.map((t: ProxmoxAlertTemplate) => {
469
+ return [t.id, t];
470
+ }),
471
+ )("%s builds a valid MonitorStep", (_id: unknown, template: unknown) => {
472
+ const args: ProxmoxAlertTemplateArgs = buildArgs();
473
+ const step: MonitorStep = (template as ProxmoxAlertTemplate).getMonitorStep(
474
+ args,
475
+ );
476
+ const monitor: MonitorStepProxmoxMonitor = getProxmoxMonitor(step);
477
+
478
+ // The cluster attribute is injected from the template args.
479
+ expect(monitor.clusterIdentifier).toBe(args.clusterIdentifier);
480
+ expect(monitor.metricViewConfig.queryConfigs.length).toBeGreaterThan(0);
481
+
482
+ const instances: Array<MonitorCriteriaInstance> =
483
+ getCriteriaInstances(step);
484
+ expect(instances.length).toBeGreaterThanOrEqual(2);
485
+
486
+ /*
487
+ * Criteria are evaluated first-match-wins: every instance before
488
+ * the last is an unhealthy tier (creates incidents + alerts,
489
+ * flips to the offline status); the LAST is the recover instance
490
+ * (no incidents, flips to the online status).
491
+ */
492
+ const offlineInstances: Array<MonitorCriteriaInstance> = instances.slice(
493
+ 0,
494
+ -1,
495
+ );
496
+ const onlineInstance: MonitorCriteriaInstance =
497
+ instances[instances.length - 1]!;
498
+
499
+ for (const offline of offlineInstances) {
500
+ expect(offline.data?.monitorStatusId).toBe(args.offlineMonitorStatusId);
501
+ expect(offline.data?.createIncidents).toBe(true);
502
+ expect(offline.data?.createAlerts).toBe(true);
503
+ expect(offline.data?.incidents).toHaveLength(1);
504
+ expect(offline.data?.alerts).toHaveLength(1);
505
+ expect(offline.data?.incidents?.[0]?.autoResolveIncident).toBe(true);
506
+ expect(offline.data?.alerts?.[0]?.autoResolveAlert).toBe(true);
507
+ }
508
+
509
+ expect(onlineInstance.data?.monitorStatusId).toBe(
510
+ args.onlineMonitorStatusId,
511
+ );
512
+ expect(onlineInstance.data?.createIncidents).toBe(false);
513
+ expect(onlineInstance.data?.createAlerts).toBe(false);
514
+ expect(onlineInstance.data?.name).toBe("Healthy");
515
+ });
516
+
517
+ test.each(
518
+ ALL_TEMPLATES.map((t: ProxmoxAlertTemplate) => {
519
+ return [t.id, t];
520
+ }),
521
+ )(
522
+ "%s references only catalog metrics and resolvable aliases",
523
+ (_id: unknown, template: unknown) => {
524
+ const step: MonitorStep = (
525
+ template as ProxmoxAlertTemplate
526
+ ).getMonitorStep(buildArgs());
527
+ const monitor: MonitorStepProxmoxMonitor = getProxmoxMonitor(step);
528
+
529
+ for (const queryConfig of monitor.metricViewConfig
530
+ .queryConfigs as Array<any>) {
531
+ const metricName: string =
532
+ queryConfig.metricQueryData.filterData.metricName;
533
+ expect(getProxmoxMetricByMetricName(metricName)).toBeDefined();
534
+ }
535
+
536
+ const aliases: Set<string> = getReferencableAliases(monitor);
537
+ for (const instance of getCriteriaInstances(step)) {
538
+ for (const filter of instance.data?.filters || []) {
539
+ expect(aliases).toContain(
540
+ (filter as any).metricMonitorOptions.metricAlias,
541
+ );
542
+ }
543
+ }
544
+ },
545
+ );
546
+
547
+ test.each(
548
+ ALL_TEMPLATES.map((t: ProxmoxAlertTemplate) => {
549
+ return [t.id, t];
550
+ }),
551
+ )(
552
+ "%s groups by raw datapoint labels only (never resource.-prefixed)",
553
+ (_id: unknown, template: unknown) => {
554
+ const step: MonitorStep = (
555
+ template as ProxmoxAlertTemplate
556
+ ).getMonitorStep(buildArgs());
557
+ const monitor: MonitorStepProxmoxMonitor = getProxmoxMonitor(step);
558
+
559
+ for (const queryConfig of monitor.metricViewConfig
560
+ .queryConfigs as Array<any>) {
561
+ const groupBys: Array<string> =
562
+ queryConfig.metricQueryData.groupByAttributeKeys || [];
563
+ for (const key of groupBys) {
564
+ /*
565
+ * pve-exporter identity is the `id` DATAPOINT label. A
566
+ * `resource.`-prefixed key would match nothing in ClickHouse
567
+ * and collapse every resource into one mislabeled series.
568
+ */
569
+ expect(key).toBe("id");
570
+ }
571
+ }
572
+ },
573
+ );
574
+
575
+ test.each(
576
+ ALL_TEMPLATES.map((t: ProxmoxAlertTemplate) => {
577
+ return [t.id, t];
578
+ }),
579
+ )(
580
+ "%s has disjoint fire/recover thresholds on the same alias",
581
+ (_id: unknown, template: unknown) => {
582
+ const step: MonitorStep = (
583
+ template as ProxmoxAlertTemplate
584
+ ).getMonitorStep(buildArgs());
585
+ const instances: Array<MonitorCriteriaInstance> =
586
+ getCriteriaInstances(step);
587
+ const onlineFilters: Array<any> = (instances[instances.length - 1]!.data
588
+ ?.filters || []) as Array<any>;
589
+
590
+ for (const offline of instances.slice(0, -1)) {
591
+ for (const fireFilter of (offline.data?.filters || []) as Array<any>) {
592
+ const recoverFilter: any = onlineFilters.find((f: any) => {
593
+ return (
594
+ f.metricMonitorOptions.metricAlias ===
595
+ fireFilter.metricMonitorOptions.metricAlias
596
+ );
597
+ });
598
+ expect(recoverFilter).toBeDefined();
599
+ expect(
600
+ isDisjointComplement(
601
+ {
602
+ filterType: fireFilter.filterType,
603
+ value: fireFilter.value as number,
604
+ },
605
+ {
606
+ filterType: recoverFilter.filterType,
607
+ value: recoverFilter.value as number,
608
+ },
609
+ ),
610
+ ).toBe(true);
611
+ }
612
+ }
613
+ },
614
+ );
615
+
616
+ test.each(
617
+ ALL_TEMPLATES.map((t: ProxmoxAlertTemplate) => {
618
+ return [t.id, t];
619
+ }),
620
+ )(
621
+ "%s ratio queries use the same aggregation on both sides (same-receiver Sum/Sum contract)",
622
+ (_id: unknown, template: unknown) => {
623
+ const step: MonitorStep = (
624
+ template as ProxmoxAlertTemplate
625
+ ).getMonitorStep(buildArgs());
626
+ const monitor: MonitorStepProxmoxMonitor = getProxmoxMonitor(step);
627
+ const queryConfigs: Array<any> = monitor.metricViewConfig
628
+ .queryConfigs as Array<any>;
629
+ const formulaConfigs: Array<any> = (monitor.metricViewConfig
630
+ .formulaConfigs || []) as Array<any>;
631
+
632
+ if (formulaConfigs.length === 0) {
633
+ return;
634
+ }
635
+
636
+ // Ratio/formula templates: 2 queries, 1 formula, matching groupBys.
637
+ expect(queryConfigs).toHaveLength(2);
638
+ expect(formulaConfigs).toHaveLength(1);
639
+
640
+ const [numerator, denominator] = queryConfigs;
641
+ expect(numerator.metricQueryData.filterData.aggegationType).toBe(
642
+ denominator.metricQueryData.filterData.aggegationType,
643
+ );
644
+ /*
645
+ * Every Proxmox metric rides ONE receiver (the pve-exporter
646
+ * scrape), so ratios are same-receiver and must be Sum/Sum —
647
+ * except pve_cpu_usage_ratio-style single-series gauges, which
648
+ * never appear in formulas here.
649
+ */
650
+ expect(numerator.metricQueryData.filterData.aggegationType).toBe(
651
+ MetricsAggregationType.Sum,
652
+ );
653
+ expect(numerator.metricQueryData.groupByAttributeKeys || []).toEqual(
654
+ denominator.metricQueryData.groupByAttributeKeys || [],
655
+ );
656
+ // Both sides share the same attribute equality filters.
657
+ expect(numerator.metricQueryData.filterData.attributes).toEqual(
658
+ denominator.metricQueryData.filterData.attributes,
659
+ );
660
+ },
661
+ );
662
+ });
663
+
664
+ describe("ProxmoxAlertTemplates - spec table expectations", () => {
665
+ test.each(
666
+ EXPECTED_TEMPLATES.map((t: TemplateExpectation) => {
667
+ return [t.id, t];
668
+ }),
669
+ )(
670
+ "%s matches the spec'd metric/aggregation/threshold contract",
671
+ (_id: unknown, expected: unknown) => {
672
+ const tc: TemplateExpectation = expected as TemplateExpectation;
673
+ const template: ProxmoxAlertTemplate | undefined =
674
+ getProxmoxAlertTemplateById(tc.id);
675
+ expect(template).toBeDefined();
676
+
677
+ expect(template!.category).toBe(tc.category);
678
+ expect(template!.severity).toBe(tc.severity);
679
+
680
+ const step: MonitorStep = template!.getMonitorStep(buildArgs());
681
+ const monitor: MonitorStepProxmoxMonitor = getProxmoxMonitor(step);
682
+
683
+ expect(monitor.rollingTime).toBe(tc.rollingTime);
684
+
685
+ const queryConfigs: Array<any> = monitor.metricViewConfig
686
+ .queryConfigs as Array<any>;
687
+ expect(queryConfigs).toHaveLength(tc.queries.length);
688
+
689
+ for (let i: number = 0; i < tc.queries.length; i++) {
690
+ const expectedQuery: QueryExpectation = tc.queries[i]!;
691
+ const filterData: any = queryConfigs[i].metricQueryData.filterData;
692
+ expect(filterData.metricName).toBe(expectedQuery.metricName);
693
+ expect(filterData.aggegationType).toBe(expectedQuery.aggregation);
694
+ expect(filterData.attributes).toEqual(expectedQuery.attributes);
695
+
696
+ const groupBys: Array<string> =
697
+ queryConfigs[i].metricQueryData.groupByAttributeKeys || [];
698
+ expect(groupBys).toEqual(tc.groupBy ? [tc.groupBy] : []);
699
+ }
700
+
701
+ const formulaConfigs: Array<any> = (monitor.metricViewConfig
702
+ .formulaConfigs || []) as Array<any>;
703
+ if (tc.formula) {
704
+ expect(formulaConfigs).toHaveLength(1);
705
+ expect(formulaConfigs[0].metricFormulaData.metricFormula).toBe(
706
+ tc.formula,
707
+ );
708
+ expect(formulaConfigs[0].metricAliasData.metricVariable).toBe(
709
+ tc.fire.alias,
710
+ );
711
+ } else {
712
+ expect(formulaConfigs).toHaveLength(0);
713
+ }
714
+
715
+ const instances: Array<MonitorCriteriaInstance> =
716
+ getCriteriaInstances(step);
717
+ expect(instances).toHaveLength(2);
718
+
719
+ const fireFilter: any = (instances[0]!.data?.filters as Array<any>)[0];
720
+ expect(fireFilter.metricMonitorOptions.metricAlias).toBe(tc.fire.alias);
721
+ expect(fireFilter.filterType).toBe(tc.fire.filterType);
722
+ expect(fireFilter.value).toBe(tc.fire.value);
723
+
724
+ const recoverFilter: any = (instances[1]!.data?.filters as Array<any>)[0];
725
+ expect(recoverFilter.metricMonitorOptions.metricAlias).toBe(
726
+ tc.recover.alias,
727
+ );
728
+ expect(recoverFilter.filterType).toBe(tc.recover.filterType);
729
+ expect(recoverFilter.value).toBe(tc.recover.value);
730
+ },
731
+ );
732
+ });