@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
@@ -5,6 +5,7 @@ import MultiSearch from "../../../Types/BaseDatabase/MultiSearch";
5
5
  import ServiceModel from "../../../Models/DatabaseModels/Service";
6
6
  import HostModel from "../../../Models/DatabaseModels/Host";
7
7
  import DockerHostModel from "../../../Models/DatabaseModels/DockerHost";
8
+ import PodmanHostModel from "../../../Models/DatabaseModels/PodmanHost";
8
9
  import KubernetesClusterModel from "../../../Models/DatabaseModels/KubernetesCluster";
9
10
  import ServerlessFunctionModel from "../../../Models/DatabaseModels/ServerlessFunction";
10
11
  import CloudResourceModel from "../../../Models/DatabaseModels/CloudResource";
@@ -12,6 +13,7 @@ import RumApplicationModel from "../../../Models/DatabaseModels/RumApplication";
12
13
  import ServiceService from "../../Services/ServiceService";
13
14
  import HostService from "../../Services/HostService";
14
15
  import DockerHostService from "../../Services/DockerHostService";
16
+ import PodmanHostService from "../../Services/PodmanHostService";
15
17
  import KubernetesClusterService from "../../Services/KubernetesClusterService";
16
18
  import ServerlessFunctionService from "../../Services/ServerlessFunctionService";
17
19
  import CloudResourceService from "../../Services/CloudResourceService";
@@ -34,6 +36,7 @@ export const RESOURCE_FACET_KEYS: ReadonlySet<string> = new Set([
34
36
  "serviceId",
35
37
  "hostId",
36
38
  "dockerHostId",
39
+ "podmanHostId",
37
40
  "kubernetesClusterId",
38
41
  "serverlessFunctionId",
39
42
  "cloudResourceId",
@@ -118,6 +121,13 @@ export default class ResourceFacetResolver {
118
121
  searchText,
119
122
  limit,
120
123
  );
124
+ case "podmanHostId":
125
+ return ResourceFacetResolver.queryPodmanHosts(
126
+ projectId,
127
+ spec.counts,
128
+ searchText,
129
+ limit,
130
+ );
121
131
  case "kubernetesClusterId":
122
132
  return ResourceFacetResolver.queryKubernetesClusters(
123
133
  projectId,
@@ -260,6 +270,45 @@ export default class ResourceFacetResolver {
260
270
  );
261
271
  }
262
272
 
273
+ private static async queryPodmanHosts(
274
+ projectId: ObjectID,
275
+ counts: Map<string, number>,
276
+ searchText: string | undefined,
277
+ limit: number,
278
+ ): Promise<Array<ResolvedFacetValue>> {
279
+ const query: Record<string, unknown> = { projectId };
280
+ if (searchText) {
281
+ query["name"] = new MultiSearch({
282
+ fields: ["name", "hostIdentifier"],
283
+ value: searchText,
284
+ });
285
+ }
286
+
287
+ const podmanHosts: Array<PodmanHostModel> = await PodmanHostService.findBy({
288
+ query: query as any,
289
+ select: {
290
+ _id: true,
291
+ name: true,
292
+ hostIdentifier: true,
293
+ },
294
+ limit: new PositiveNumber(limit),
295
+ skip: new PositiveNumber(0),
296
+ props: { isRoot: true },
297
+ });
298
+
299
+ return ResourceFacetResolver.mergeCounts(
300
+ podmanHosts.map(
301
+ (p: PodmanHostModel): { id: string; displayName: string } => {
302
+ return {
303
+ id: p._id ? p._id.toString() : "",
304
+ displayName: p.name || p.hostIdentifier || "Unknown",
305
+ };
306
+ },
307
+ ),
308
+ counts,
309
+ );
310
+ }
311
+
263
312
  private static async queryKubernetesClusters(
264
313
  projectId: ObjectID,
265
314
  counts: Map<string, number>,
@@ -163,6 +163,16 @@ export default class TelemetryUtil {
163
163
  };
164
164
  }
165
165
 
166
+ public static getAttributesForPodmanHostIdAndHostName(data: {
167
+ podmanHostId: ObjectID;
168
+ hostName: string;
169
+ }): Dictionary<AttributeType> {
170
+ return {
171
+ "oneuptime.podman.host.id": data.podmanHostId.toString(),
172
+ "oneuptime.podman.host.name": data.hostName,
173
+ };
174
+ }
175
+
166
176
  public static getAttributesForKubernetesClusterIdAndName(data: {
167
177
  kubernetesClusterId: ObjectID;
168
178
  clusterName: string;
@@ -533,6 +533,92 @@ export default class TelemetryEntity {
533
533
  return { entityType: EntityType.KubernetesDeployment, id };
534
534
  },
535
535
 
536
+ // proxmox.cluster — proxmox.cluster.name only (see proxmoxClusterIdentity).
537
+ (attrs: EntityAttributes) => {
538
+ const id: Dictionary<string> | null =
539
+ TelemetryEntity.proxmoxClusterIdentity(attrs);
540
+ return id ? { entityType: EntityType.ProxmoxCluster, id } : null;
541
+ },
542
+
543
+ // proxmox.node — cluster + proxmox.node.name.
544
+ (attrs: EntityAttributes) => {
545
+ const nodeName: string | null = TelemetryEntity.str(
546
+ attrs,
547
+ "proxmox.node.name",
548
+ );
549
+ if (!nodeName) {
550
+ return null;
551
+ }
552
+ const id: Dictionary<string> = {
553
+ ...(TelemetryEntity.proxmoxClusterIdentity(attrs) || {}),
554
+ "proxmox.node.name": nodeName,
555
+ };
556
+ return { entityType: EntityType.ProxmoxNode, id };
557
+ },
558
+
559
+ /*
560
+ * proxmox.guest — cluster + proxmox.guest.vmid. The node name is
561
+ * deliberately NOT part of guest identity: vmids are cluster-unique
562
+ * and a live migration moves a guest between nodes without changing
563
+ * what it is, so folding the node in would fork the key on every
564
+ * migration. Guest name/type are descriptive (a guest can be renamed).
565
+ */
566
+ (attrs: EntityAttributes) => {
567
+ const vmid: string | null = TelemetryEntity.str(
568
+ attrs,
569
+ "proxmox.guest.vmid",
570
+ );
571
+ if (!vmid) {
572
+ return null;
573
+ }
574
+ const id: Dictionary<string> = {
575
+ ...(TelemetryEntity.proxmoxClusterIdentity(attrs) || {}),
576
+ "proxmox.guest.vmid": vmid,
577
+ };
578
+ return { entityType: EntityType.ProxmoxGuest, id };
579
+ },
580
+
581
+ /*
582
+ * ceph.cluster — ceph.cluster.name only. `ceph.cluster.fsid` is
583
+ * descriptive, not identity: the typed Postgres row (CephCluster) and
584
+ * the read side (`EntityKey.keyForCephCluster`) are name-based, and
585
+ * the fsid is only optionally stamped by the agent.
586
+ */
587
+ (attrs: EntityAttributes) => {
588
+ const name: string | null = TelemetryEntity.str(
589
+ attrs,
590
+ "ceph.cluster.name",
591
+ );
592
+ return name
593
+ ? {
594
+ entityType: EntityType.CephCluster,
595
+ id: { "ceph.cluster.name": name },
596
+ }
597
+ : null;
598
+ },
599
+
600
+ /*
601
+ * docker.swarm.cluster — docker.swarm.cluster.name only, mirroring the
602
+ * proxmox/ceph cluster identity: the typed Postgres row
603
+ * (DockerSwarmCluster) and the read side
604
+ * (`EntityKey.keyForDockerSwarmCluster`) are name-based, and the agent
605
+ * stamps `docker.swarm.cluster.name` on every signal. Node/Service/Task
606
+ * identity is NOT derived from resource attributes (inventory arrives as
607
+ * separate JSON-line log records), so only the cluster entity flows here.
608
+ */
609
+ (attrs: EntityAttributes) => {
610
+ const name: string | null = TelemetryEntity.str(
611
+ attrs,
612
+ "docker.swarm.cluster.name",
613
+ );
614
+ return name
615
+ ? {
616
+ entityType: EntityType.DockerSwarmCluster,
617
+ id: { "docker.swarm.cluster.name": name },
618
+ }
619
+ : null;
620
+ },
621
+
536
622
  /*
537
623
  * container — container.id. High-churn: flows as a membership key but
538
624
  * is membership-only by default (not promoted to a registry row
@@ -652,6 +738,8 @@ export default class TelemetryEntity {
652
738
  "container.image.tag",
653
739
  "container.image.tags",
654
740
  ],
741
+ [EntityType.ProxmoxGuest]: ["proxmox.guest.name", "proxmox.guest.type"],
742
+ [EntityType.CephCluster]: ["ceph.cluster.fsid"],
655
743
  };
656
744
 
657
745
  private static descriptiveAttributesFor(
@@ -739,6 +827,25 @@ export default class TelemetryEntity {
739
827
  return null;
740
828
  }
741
829
 
830
+ /*
831
+ * Proxmox cluster identity — proxmox.cluster.name only, mirroring
832
+ * k8sClusterIdentity above: the typed Postgres row (ProxmoxCluster) and
833
+ * the read side (`EntityKey.keyForProxmoxCluster`) are name-based, and
834
+ * the attribute is the user-configured join key our agent stamps on
835
+ * every resource (see Internal/Roadmap/ProxmoxCephProducts.md §1). This
836
+ * identity is also folded into the composite proxmox node/guest
837
+ * identities, which must stay name-based with it.
838
+ */
839
+ private static proxmoxClusterIdentity(
840
+ attrs: EntityAttributes,
841
+ ): Dictionary<string> | null {
842
+ const name: string | null = this.str(attrs, "proxmox.cluster.name");
843
+ if (name) {
844
+ return { "proxmox.cluster.name": name };
845
+ }
846
+ return null;
847
+ }
848
+
742
849
  /** Copy `key` from attrs into `id` (canonicalized) when scalar & present. */
743
850
  private static addIfPresent(
744
851
  id: Dictionary<string>,
@@ -24,16 +24,14 @@ import { OTLPMetricExporter } from "@opentelemetry/exporter-metrics-otlp-proto";
24
24
  import { OTLPTraceExporter } from "@opentelemetry/exporter-trace-otlp-proto";
25
25
  import { AWSXRayIdGenerator } from "@opentelemetry/id-generator-aws-xray";
26
26
  import { CompressionAlgorithm } from "@opentelemetry/otlp-exporter-base";
27
- import { Resource } from "@opentelemetry/resources";
27
+ import { Resource, resourceFromAttributes } from "@opentelemetry/resources";
28
28
  import {
29
29
  BatchLogRecordProcessor,
30
30
  LoggerProvider,
31
31
  LogRecordProcessor,
32
32
  type LoggerProviderConfig,
33
33
  } from "@opentelemetry/sdk-logs";
34
- import type { Resource as LogsResource } from "@opentelemetry/sdk-logs/node_modules/@opentelemetry/resources/build/src/Resource";
35
34
  import {
36
- Aggregation,
37
35
  MeterProvider,
38
36
  PeriodicExportingMetricReader,
39
37
  } from "@opentelemetry/sdk-metrics";
@@ -56,7 +54,7 @@ import GracefulShutdown, { ShutdownPriority } from "./GracefulShutdown";
56
54
  import ContextSpanProcessor from "./Telemetry/ContextSpanProcessor";
57
55
  import RuntimeMetrics from "./Telemetry/RuntimeMetrics";
58
56
 
59
- type ResourceWithRawAttributes = LogsResource & {
57
+ type ResourceWithRawAttributes = Resource & {
60
58
  getRawAttributes?: () => Array<[string, AttributeValue | undefined]>;
61
59
  };
62
60
 
@@ -165,7 +163,7 @@ export default class Telemetry {
165
163
  }
166
164
 
167
165
  public static getResource(data: { serviceName: string }): Resource {
168
- return new Resource({
166
+ return resourceFromAttributes({
169
167
  [ATTR_SERVICE_NAME]: data.serviceName,
170
168
  [ATTR_SERVICE_VERSION]: AppVersion,
171
169
  ["deployment.environment"]: Env,
@@ -203,20 +201,11 @@ export default class Telemetry {
203
201
  compression: CompressionAlgorithm.GZIP,
204
202
  }) as unknown as PushMetricExporter;
205
203
 
206
- // Force an SDK-side aggregation selector that matches the modern metrics API.
207
- if (
208
- typeof (metricExporter as { selectAggregation?: unknown })
209
- .selectAggregation === "function"
210
- ) {
211
- (
212
- metricExporter as unknown as {
213
- selectAggregation: (..._args: Array<unknown>) => Aggregation;
214
- }
215
- ).selectAggregation = () => {
216
- return Aggregation.Default();
217
- };
218
- }
219
-
204
+ /*
205
+ * No aggregation-selector shim is needed anymore: the OTLP metric
206
+ * exporter and the sdk-metrics package now come from the same release
207
+ * line, so the exporter's default selector already matches the SDK.
208
+ */
220
209
  this.metricReader = new PeriodicExportingMetricReader({
221
210
  exporter: metricExporter,
222
211
  });
@@ -0,0 +1,194 @@
1
+ import BillingInvoiceAPI from "../../../Server/API/BillingInvoiceAPI";
2
+ import BillingInvoiceService from "../../../Server/Services/BillingInvoiceService";
3
+ import BillingService from "../../../Server/Services/BillingService";
4
+ import ProjectService from "../../../Server/Services/ProjectService";
5
+ import {
6
+ NextFunction,
7
+ OneUptimeRequest,
8
+ OneUptimeResponse,
9
+ } from "../../../Server/Utils/Express";
10
+ import Response from "../../../Server/Utils/Response";
11
+ import { mockRouter } from "./Helpers";
12
+ import { describe, expect, it } from "@jest/globals";
13
+ import BadDataException from "../../../Types/Exception/BadDataException";
14
+ import ObjectID from "../../../Types/ObjectID";
15
+ import Permission, { UserPermission } from "../../../Types/Permission";
16
+ import BillingInvoice from "../../../Models/DatabaseModels/BillingInvoice";
17
+ import Project from "../../../Models/DatabaseModels/Project";
18
+
19
+ jest.mock("../../../Server/Utils/Express", () => {
20
+ return {
21
+ getRouter: () => {
22
+ return mockRouter;
23
+ },
24
+ };
25
+ });
26
+
27
+ jest.mock("../../../Server/Utils/Response", () => {
28
+ return {
29
+ sendEntityArrayResponse: jest.fn().mockImplementation((...args: []) => {
30
+ return args;
31
+ }),
32
+ sendJsonObjectResponse: jest.fn().mockImplementation((...args: []) => {
33
+ return args;
34
+ }),
35
+ sendEmptySuccessResponse: jest.fn(),
36
+ sendEntityResponse: jest.fn().mockImplementation((...args: []) => {
37
+ return args;
38
+ }),
39
+ sendErrorResponse: jest.fn().mockImplementation((...args: []) => {
40
+ return args;
41
+ }),
42
+ };
43
+ });
44
+
45
+ jest.mock("../../../Server/EnvironmentConfig", () => {
46
+ return {
47
+ ...jest.requireActual("../../../Server/EnvironmentConfig"),
48
+ IsBillingEnabled: true,
49
+ };
50
+ });
51
+
52
+ jest.mock("../../../Server/Services/BillingInvoiceService");
53
+ jest.mock("../../../Server/Services/BillingService");
54
+ jest.mock("../../../Server/Services/ProjectService");
55
+
56
+ describe("BillingInvoiceAPI", () => {
57
+ let mockRequest: OneUptimeRequest;
58
+ let mockResponse: OneUptimeResponse;
59
+ let nextFunction: NextFunction;
60
+
61
+ const projectId: ObjectID = ObjectID.generate();
62
+ const projectCustomerId: string = "cus_own_project";
63
+ const invoiceId: string = "in_123";
64
+
65
+ let project: Project;
66
+
67
+ beforeEach(() => {
68
+ new BillingInvoiceAPI();
69
+
70
+ project = new Project();
71
+ project.id = projectId;
72
+ project.paymentProviderCustomerId = projectCustomerId;
73
+ project.paymentProviderSubscriptionId = "sub_123";
74
+
75
+ jest
76
+ .spyOn(BillingInvoiceAPI.prototype, "getPermissionsForTenant")
77
+ .mockResolvedValue([
78
+ {
79
+ permission: Permission.EditInvoices,
80
+ } as UserPermission,
81
+ ]);
82
+
83
+ ProjectService.findOneById = jest.fn().mockResolvedValue(project);
84
+ BillingInvoiceService.findOneBy = jest
85
+ .fn()
86
+ .mockResolvedValue(new BillingInvoice());
87
+ BillingInvoiceService.updateOneBy = jest.fn().mockResolvedValue(undefined);
88
+ BillingInvoiceService.refreshSubscriptionStatus = jest
89
+ .fn()
90
+ .mockResolvedValue(undefined);
91
+ BillingService.payInvoice = jest.fn().mockResolvedValue({
92
+ id: invoiceId,
93
+ status: "paid",
94
+ });
95
+
96
+ mockRequest = {
97
+ tenantId: projectId,
98
+ body: {
99
+ data: {
100
+ paymentProviderInvoiceId: invoiceId,
101
+ paymentProviderCustomerId: projectCustomerId,
102
+ },
103
+ },
104
+ } as unknown as OneUptimeRequest;
105
+ mockResponse = {
106
+ send: jest.fn(),
107
+ json: jest.fn(),
108
+ status: jest.fn().mockReturnThis(),
109
+ } as unknown as OneUptimeResponse;
110
+ nextFunction = jest.fn();
111
+ });
112
+
113
+ afterEach(() => {
114
+ jest.restoreAllMocks();
115
+ });
116
+
117
+ describe("POST /billing-invoices/pay", () => {
118
+ it("should reject a customer id that does not belong to the project", async () => {
119
+ mockRequest.body["data"] = {
120
+ paymentProviderInvoiceId: invoiceId,
121
+ paymentProviderCustomerId: "cus_victim_tenant",
122
+ };
123
+
124
+ await mockRouter
125
+ .match("post", "/billing-invoices/pay")
126
+ .handlerFunction(mockRequest, mockResponse, nextFunction);
127
+
128
+ expect(nextFunction).toHaveBeenCalledWith(
129
+ new BadDataException("Customer ID does not belong to this project"),
130
+ );
131
+ expect(BillingService.payInvoice).not.toHaveBeenCalled();
132
+ expect(BillingInvoiceService.updateOneBy).not.toHaveBeenCalled();
133
+ });
134
+
135
+ it("should reject an invoice that does not belong to the project", async () => {
136
+ BillingInvoiceService.findOneBy = jest.fn().mockResolvedValue(null);
137
+
138
+ await mockRouter
139
+ .match("post", "/billing-invoices/pay")
140
+ .handlerFunction(mockRequest, mockResponse, nextFunction);
141
+
142
+ expect(BillingInvoiceService.findOneBy).toHaveBeenCalledWith(
143
+ expect.objectContaining({
144
+ query: {
145
+ projectId: projectId,
146
+ paymentProviderInvoiceId: invoiceId,
147
+ },
148
+ /*
149
+ * ignoreHooks is required: BillingInvoiceService.onBeforeFind
150
+ * throws without props.tenantId and would re-sync all invoices
151
+ * from Stripe on every pay attempt.
152
+ */
153
+ props: expect.objectContaining({
154
+ ignoreHooks: true,
155
+ }),
156
+ }),
157
+ );
158
+ expect(nextFunction).toHaveBeenCalledWith(
159
+ new BadDataException("Invoice not found for this project"),
160
+ );
161
+ expect(BillingService.payInvoice).not.toHaveBeenCalled();
162
+ expect(BillingInvoiceService.updateOneBy).not.toHaveBeenCalled();
163
+ });
164
+
165
+ it("should pay with the project's own customer id and scope the status update to the project", async () => {
166
+ // body omits the customer id — the project's own customer is charged.
167
+ mockRequest.body["data"] = {
168
+ paymentProviderInvoiceId: invoiceId,
169
+ };
170
+
171
+ await mockRouter
172
+ .match("post", "/billing-invoices/pay")
173
+ .handlerFunction(mockRequest, mockResponse, nextFunction);
174
+
175
+ expect(nextFunction).not.toHaveBeenCalled();
176
+ expect(BillingService.payInvoice).toHaveBeenCalledWith(
177
+ projectCustomerId,
178
+ invoiceId,
179
+ );
180
+ expect(BillingInvoiceService.updateOneBy).toHaveBeenCalledWith(
181
+ expect.objectContaining({
182
+ query: {
183
+ projectId: projectId,
184
+ paymentProviderInvoiceId: invoiceId,
185
+ },
186
+ }),
187
+ );
188
+ expect(Response.sendEmptySuccessResponse).toHaveBeenCalledWith(
189
+ mockRequest,
190
+ mockResponse,
191
+ );
192
+ });
193
+ });
194
+ });
@@ -1,4 +1,6 @@
1
1
  import ProjectAPI from "../../../Server/API/ProjectAPI";
2
+ import BillingService from "../../../Server/Services/BillingService";
3
+ import ProjectService from "../../../Server/Services/ProjectService";
2
4
  import TeamMemberService from "../../../Server/Services/TeamMemberService";
3
5
  import {
4
6
  NextFunction,
@@ -15,6 +17,17 @@ import ObjectID from "../../../Types/ObjectID";
15
17
  import PositiveNumber from "../../../Types/PositiveNumber";
16
18
  import Project from "../../../Models/DatabaseModels/Project";
17
19
  import TeamMember from "../../../Models/DatabaseModels/TeamMember";
20
+ import BadDataException from "../../../Types/Exception/BadDataException";
21
+ import Permission, { UserPermission } from "../../../Types/Permission";
22
+
23
+ jest.mock("../../../Server/EnvironmentConfig", () => {
24
+ return {
25
+ ...jest.requireActual("../../../Server/EnvironmentConfig"),
26
+ IsBillingEnabled: true,
27
+ };
28
+ });
29
+
30
+ jest.mock("../../../Server/Services/BillingService");
18
31
 
19
32
  jest.mock("../../../Server/Utils/Express", () => {
20
33
  return {
@@ -216,4 +229,82 @@ describe("ProjectAPI", () => {
216
229
  expect(nextFunction).toHaveBeenCalledWith(authError);
217
230
  });
218
231
  });
232
+
233
+ describe("PUT /project/:id/change-plan", () => {
234
+ const planId: string = "plan_123";
235
+
236
+ const tenantMismatchError: BadDataException = new BadDataException(
237
+ "Project ID in the URL does not match the project the request is authenticated for",
238
+ );
239
+
240
+ beforeEach(() => {
241
+ ProjectService.findOneById = jest.fn().mockResolvedValue({
242
+ paymentProviderCustomerId: "cus_123",
243
+ } as Project);
244
+ ProjectService.changePlan = jest.fn().mockResolvedValue(undefined);
245
+ BillingService.hasPaymentMethods = jest.fn().mockResolvedValue(true);
246
+ });
247
+
248
+ it("should reject when the URL project id does not match the authenticated tenant", async () => {
249
+ const victimProjectId: ObjectID = ObjectID.generate();
250
+ const attackerProjectId: ObjectID = ObjectID.generate();
251
+
252
+ mockRequest.params = { id: victimProjectId.toString() };
253
+ mockRequest.tenantId = attackerProjectId;
254
+ mockRequest.body = { data: { paymentProviderPlanId: planId } };
255
+
256
+ await mockRouter
257
+ .match("put", "/project/:id/change-plan")
258
+ .handlerFunction(mockRequest, mockResponse, nextFunction);
259
+
260
+ expect(nextFunction).toHaveBeenCalledWith(tenantMismatchError);
261
+ expect(ProjectService.changePlan).not.toHaveBeenCalled();
262
+ // the foreign project must not even be looked up.
263
+ expect(ProjectService.findOneById).not.toHaveBeenCalled();
264
+ });
265
+
266
+ it("should reject when the request has no authenticated tenant", async () => {
267
+ const projectId: ObjectID = ObjectID.generate();
268
+
269
+ mockRequest.params = { id: projectId.toString() };
270
+ mockRequest.body = { data: { paymentProviderPlanId: planId } };
271
+
272
+ await mockRouter
273
+ .match("put", "/project/:id/change-plan")
274
+ .handlerFunction(mockRequest, mockResponse, nextFunction);
275
+
276
+ expect(nextFunction).toHaveBeenCalledWith(tenantMismatchError);
277
+ expect(ProjectService.changePlan).not.toHaveBeenCalled();
278
+ });
279
+
280
+ it("should change the plan of the authenticated tenant's own project", async () => {
281
+ const projectId: ObjectID = ObjectID.generate();
282
+
283
+ mockRequest.params = { id: projectId.toString() };
284
+ mockRequest.tenantId = projectId;
285
+ mockRequest.body = { data: { paymentProviderPlanId: planId } };
286
+
287
+ jest
288
+ .spyOn(ProjectAPI.prototype, "getPermissionsForTenant")
289
+ .mockResolvedValue([
290
+ {
291
+ permission: Permission.ProjectOwner,
292
+ } as UserPermission,
293
+ ]);
294
+
295
+ await mockRouter
296
+ .match("put", "/project/:id/change-plan")
297
+ .handlerFunction(mockRequest, mockResponse, nextFunction);
298
+
299
+ expect(nextFunction).not.toHaveBeenCalled();
300
+ expect(ProjectService.changePlan).toHaveBeenCalledWith({
301
+ projectId: projectId,
302
+ paymentProviderPlanId: planId,
303
+ });
304
+ expect(Response.sendEmptySuccessResponse).toHaveBeenCalledWith(
305
+ mockRequest,
306
+ mockResponse,
307
+ );
308
+ });
309
+ });
219
310
  });