@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,207 @@
1
+ import ResellerPlanAPI from "../../../Server/API/ResellerPlanAPI";
2
+ import ProjectService from "../../../Server/Services/ProjectService";
3
+ import ResellerPlanService from "../../../Server/Services/ResellerPlanService";
4
+ import {
5
+ NextFunction,
6
+ OneUptimeRequest,
7
+ OneUptimeResponse,
8
+ } from "../../../Server/Utils/Express";
9
+ import Response from "../../../Server/Utils/Response";
10
+ import { mockRouter } from "./Helpers";
11
+ import { describe, expect, it } from "@jest/globals";
12
+ import BadDataException from "../../../Types/Exception/BadDataException";
13
+ import ObjectID from "../../../Types/ObjectID";
14
+ import Project from "../../../Models/DatabaseModels/Project";
15
+ import ResellerPlan from "../../../Models/DatabaseModels/ResellerPlan";
16
+
17
+ jest.mock("../../../Server/Utils/Express", () => {
18
+ return {
19
+ getRouter: () => {
20
+ return mockRouter;
21
+ },
22
+ };
23
+ });
24
+
25
+ jest.mock("../../../Server/Utils/Response", () => {
26
+ return {
27
+ sendEntityArrayResponse: jest.fn().mockImplementation((...args: []) => {
28
+ return args;
29
+ }),
30
+ sendJsonObjectResponse: jest.fn().mockImplementation((...args: []) => {
31
+ return args;
32
+ }),
33
+ sendEmptySuccessResponse: jest.fn(),
34
+ sendEntityResponse: jest.fn().mockImplementation((...args: []) => {
35
+ return args;
36
+ }),
37
+ sendErrorResponse: jest.fn().mockImplementation((...args: []) => {
38
+ return args;
39
+ }),
40
+ };
41
+ });
42
+
43
+ jest.mock("../../../Server/Services/ResellerPlanService");
44
+ jest.mock("../../../Server/Services/ProjectService");
45
+ jest.mock("../../../Server/Services/BillingService");
46
+ jest.mock("../../../Server/Services/PromoCodeService");
47
+
48
+ describe("ResellerPlanAPI", () => {
49
+ let mockRequest: OneUptimeRequest;
50
+ let mockResponse: OneUptimeResponse;
51
+ let nextFunction: NextFunction;
52
+
53
+ const resellerExternalId: string = "reseller_a";
54
+ const resellerObjectId: ObjectID = ObjectID.generate();
55
+ const resellerPlanObjectId: ObjectID = ObjectID.generate();
56
+ const projectObjectId: ObjectID = ObjectID.generate();
57
+ const licenseKey: string = "license_123";
58
+
59
+ const mockResellerPlan: ResellerPlan = {
60
+ id: resellerPlanObjectId,
61
+ planId: "plan_basic",
62
+ reseller: {
63
+ id: resellerObjectId,
64
+ resellerId: resellerExternalId,
65
+ },
66
+ monitorLimit: 10,
67
+ teamMemberLimit: 5,
68
+ } as unknown as ResellerPlan;
69
+
70
+ beforeEach(() => {
71
+ new ResellerPlanAPI();
72
+
73
+ ResellerPlanService.findOneBy = jest
74
+ .fn()
75
+ .mockResolvedValue(mockResellerPlan);
76
+ ProjectService.findOneBy = jest.fn().mockResolvedValue(null);
77
+ ProjectService.updateOneById = jest.fn().mockResolvedValue(undefined);
78
+ ProjectService.deleteOneBy = jest.fn().mockResolvedValue(undefined);
79
+
80
+ mockRequest = {
81
+ params: { resellerId: resellerExternalId },
82
+ bearerTokenData: { resellerId: resellerExternalId },
83
+ body: {
84
+ action: "enhance_tier",
85
+ plan_id: "plan_basic",
86
+ uuid: licenseKey,
87
+ activation_email: "customer@example.com",
88
+ },
89
+ } as unknown as OneUptimeRequest;
90
+ mockResponse = {
91
+ send: jest.fn(),
92
+ json: jest.fn(),
93
+ status: jest.fn().mockReturnThis(),
94
+ } as unknown as OneUptimeResponse;
95
+ nextFunction = jest.fn();
96
+ });
97
+
98
+ afterEach(() => {
99
+ jest.restoreAllMocks();
100
+ });
101
+
102
+ describe("POST /reseller-plan/action/:resellerId", () => {
103
+ it("should scope the project lookup to the authenticated reseller on tier change", async () => {
104
+ await mockRouter
105
+ .match("post", "/reseller-plan/action/:resellerId")
106
+ .handlerFunction(mockRequest, mockResponse, nextFunction);
107
+
108
+ expect(ProjectService.findOneBy).toHaveBeenCalledWith(
109
+ expect.objectContaining({
110
+ query: {
111
+ resellerLicenseId: licenseKey,
112
+ resellerId: resellerObjectId,
113
+ },
114
+ }),
115
+ );
116
+ // license key belongs to another reseller -> scoped lookup finds nothing.
117
+ expect(nextFunction).toHaveBeenCalledWith(
118
+ new BadDataException("Project not found with this license key"),
119
+ );
120
+ expect(ProjectService.updateOneById).not.toHaveBeenCalled();
121
+ });
122
+
123
+ it("should not delete another reseller's project on refund", async () => {
124
+ mockRequest.body["action"] = "refund";
125
+
126
+ await mockRouter
127
+ .match("post", "/reseller-plan/action/:resellerId")
128
+ .handlerFunction(mockRequest, mockResponse, nextFunction);
129
+
130
+ expect(ProjectService.findOneBy).toHaveBeenCalledWith(
131
+ expect.objectContaining({
132
+ query: {
133
+ resellerLicenseId: licenseKey,
134
+ resellerId: resellerObjectId,
135
+ },
136
+ }),
137
+ );
138
+ expect(ProjectService.deleteOneBy).not.toHaveBeenCalled();
139
+ // refund is idempotent: respond as refunded without deleting anything.
140
+ expect(Response.sendJsonObjectResponse).toHaveBeenCalledWith(
141
+ mockRequest,
142
+ mockResponse,
143
+ {
144
+ message: "product refunded",
145
+ },
146
+ );
147
+ });
148
+
149
+ it("should update limits for the owning reseller's project", async () => {
150
+ ProjectService.findOneBy = jest.fn().mockResolvedValue({
151
+ id: projectObjectId,
152
+ } as Project);
153
+
154
+ await mockRouter
155
+ .match("post", "/reseller-plan/action/:resellerId")
156
+ .handlerFunction(mockRequest, mockResponse, nextFunction);
157
+
158
+ expect(nextFunction).not.toHaveBeenCalled();
159
+ expect(ProjectService.updateOneById).toHaveBeenCalledWith(
160
+ expect.objectContaining({
161
+ id: projectObjectId,
162
+ data: {
163
+ activeMonitorsLimit: 10,
164
+ seatLimit: 5,
165
+ resellerPlanId: resellerPlanObjectId,
166
+ },
167
+ }),
168
+ );
169
+ expect(Response.sendJsonObjectResponse).toHaveBeenCalledWith(
170
+ mockRequest,
171
+ mockResponse,
172
+ {
173
+ message: "product enhanced",
174
+ },
175
+ );
176
+ });
177
+
178
+ it("should delete the owning reseller's project on refund with a reseller-scoped query", async () => {
179
+ mockRequest.body["action"] = "refund";
180
+ ProjectService.findOneBy = jest.fn().mockResolvedValue({
181
+ id: projectObjectId,
182
+ } as Project);
183
+
184
+ await mockRouter
185
+ .match("post", "/reseller-plan/action/:resellerId")
186
+ .handlerFunction(mockRequest, mockResponse, nextFunction);
187
+
188
+ expect(nextFunction).not.toHaveBeenCalled();
189
+ expect(ProjectService.deleteOneBy).toHaveBeenCalledWith(
190
+ expect.objectContaining({
191
+ query: {
192
+ resellerLicenseId: licenseKey,
193
+ resellerId: resellerObjectId,
194
+ _id: projectObjectId.toString(),
195
+ },
196
+ }),
197
+ );
198
+ expect(Response.sendJsonObjectResponse).toHaveBeenCalledWith(
199
+ mockRequest,
200
+ mockResponse,
201
+ {
202
+ message: "product refunded",
203
+ },
204
+ );
205
+ });
206
+ });
207
+ });
@@ -0,0 +1,100 @@
1
+ import GlobalCache from "../../../Server/Infrastructure/GlobalCache";
2
+ import Redis from "../../../Server/Infrastructure/Redis";
3
+ import OneUptimeDate from "../../../Types/Date";
4
+ import DatabaseNotConnectedException from "../../../Types/Exception/DatabaseNotConnectedException";
5
+
6
+ jest.mock("../../../Server/Infrastructure/Redis", () => {
7
+ return {
8
+ __esModule: true,
9
+ default: {
10
+ getClient: jest.fn(),
11
+ isConnected: jest.fn(),
12
+ },
13
+ };
14
+ });
15
+
16
+ type MockClient = {
17
+ set: jest.Mock;
18
+ expire: jest.Mock;
19
+ get: jest.Mock;
20
+ };
21
+
22
+ describe("GlobalCache.setString", () => {
23
+ let client: MockClient;
24
+
25
+ beforeEach(() => {
26
+ client = {
27
+ set: jest.fn().mockResolvedValue("OK"),
28
+ expire: jest.fn().mockResolvedValue(1),
29
+ get: jest.fn(),
30
+ };
31
+ (Redis.getClient as jest.Mock).mockReturnValue(client);
32
+ (Redis.isConnected as jest.Mock).mockReturnValue(true);
33
+ });
34
+
35
+ afterEach(() => {
36
+ jest.clearAllMocks();
37
+ });
38
+
39
+ /*
40
+ * The TTL must be applied atomically with the SET. A separate
41
+ * SET + EXPIRE pair can crash in between and leave a key that
42
+ * never expires — for fence/throttle keys (e.g. the OTel ingest
43
+ * maintenance fence) that permanently suppresses the work the
44
+ * key gates.
45
+ */
46
+ test("sets the value and TTL in one atomic SET ... EX call", async () => {
47
+ await GlobalCache.setString("ns", "key", "value", {
48
+ expiresInSeconds: 60,
49
+ });
50
+
51
+ expect(client.set).toHaveBeenCalledTimes(1);
52
+ expect(client.set).toHaveBeenCalledWith("ns-key", "value", "EX", 60);
53
+ expect(client.expire).not.toHaveBeenCalled();
54
+ });
55
+
56
+ test("defaults the TTL to 30 days when no option is passed", async () => {
57
+ await GlobalCache.setString("ns", "key", "value");
58
+
59
+ expect(client.set).toHaveBeenCalledTimes(1);
60
+ expect(client.set).toHaveBeenCalledWith(
61
+ "ns-key",
62
+ "value",
63
+ "EX",
64
+ OneUptimeDate.getSecondsInDays(30),
65
+ );
66
+ expect(client.expire).not.toHaveBeenCalled();
67
+ });
68
+
69
+ test("throws when the cache is not connected", async () => {
70
+ (Redis.isConnected as jest.Mock).mockReturnValue(false);
71
+
72
+ await expect(GlobalCache.setString("ns", "key", "value")).rejects.toThrow(
73
+ DatabaseNotConnectedException,
74
+ );
75
+ expect(client.set).not.toHaveBeenCalled();
76
+ });
77
+
78
+ test("setStringArray and setJSON funnel through the atomic setString", async () => {
79
+ await GlobalCache.setStringArray("ns", "arr", ["a", "b"], {
80
+ expiresInSeconds: 120,
81
+ });
82
+ await GlobalCache.setJSON("ns", "obj", { a: 1 }, { expiresInSeconds: 180 });
83
+
84
+ expect(client.set).toHaveBeenNthCalledWith(
85
+ 1,
86
+ "ns-arr",
87
+ JSON.stringify(["a", "b"]),
88
+ "EX",
89
+ 120,
90
+ );
91
+ expect(client.set).toHaveBeenNthCalledWith(
92
+ 2,
93
+ "ns-obj",
94
+ expect.any(String),
95
+ "EX",
96
+ 180,
97
+ );
98
+ expect(client.expire).not.toHaveBeenCalled();
99
+ });
100
+ });
@@ -1057,6 +1057,111 @@ describe("BillingService", () => {
1057
1057
  });
1058
1058
  });
1059
1059
 
1060
+ it("should mark the customer's default payment method and order it first", async () => {
1061
+ const mockPaymentMethodsResponse: {
1062
+ data: Array<Stripe.PaymentMethod>;
1063
+ } = {
1064
+ data: [
1065
+ {
1066
+ id: "pm_123",
1067
+ type: "card",
1068
+ // @ts-expect-error - Simplified mock card object for testing without all required Stripe card properties
1069
+ card: { last4: "4242", brand: "mastercard" },
1070
+ },
1071
+ {
1072
+ id: "pm_456",
1073
+ type: "card",
1074
+ // @ts-expect-error - Simplified mock card object for testing without all required Stripe card properties
1075
+ card: { last4: "4343", brand: "mastercard" },
1076
+ },
1077
+ ],
1078
+ };
1079
+ mockStripe.paymentMethods.list = getJestMockFunction()
1080
+ .mockResolvedValueOnce(mockPaymentMethodsResponse)
1081
+ .mockResolvedValue({ data: [] });
1082
+
1083
+ const customerWithDefault: Stripe.Customer = getStripeCustomer(
1084
+ customer.id.toString(),
1085
+ );
1086
+ customerWithDefault.invoice_settings.default_payment_method = "pm_456";
1087
+ mockStripe.customers.retrieve =
1088
+ getJestMockFunction().mockResolvedValue(customerWithDefault);
1089
+
1090
+ const paymentMethods: PaymentMethod[] =
1091
+ await billingService.getPaymentMethods(customerId);
1092
+
1093
+ expect(paymentMethods).toHaveLength(2);
1094
+ expect(paymentMethods[0]?.id).toBe("pm_456");
1095
+ expect(paymentMethods[0]?.isDefault).toBe(true);
1096
+ expect(paymentMethods[1]?.id).toBe("pm_123");
1097
+ expect(paymentMethods[1]?.isDefault).toBe(false);
1098
+ expect(mockStripe.customers.update).not.toHaveBeenCalled();
1099
+ });
1100
+
1101
+ it("should not mark any payment method as default when the default is not in the list", async () => {
1102
+ const mockPaymentMethodsResponse: {
1103
+ data: Array<Stripe.PaymentMethod>;
1104
+ } = {
1105
+ data: [
1106
+ {
1107
+ id: "pm_123",
1108
+ type: "card",
1109
+ // @ts-expect-error - Simplified mock card object for testing without all required Stripe card properties
1110
+ card: { last4: "4242", brand: "mastercard" },
1111
+ },
1112
+ ],
1113
+ };
1114
+ mockStripe.paymentMethods.list = getJestMockFunction()
1115
+ .mockResolvedValueOnce(mockPaymentMethodsResponse)
1116
+ .mockResolvedValue({ data: [] });
1117
+
1118
+ const customerWithDetachedDefault: Stripe.Customer = getStripeCustomer(
1119
+ customer.id.toString(),
1120
+ );
1121
+ customerWithDetachedDefault.invoice_settings.default_payment_method =
1122
+ "pm_detached";
1123
+ mockStripe.customers.retrieve = getJestMockFunction().mockResolvedValue(
1124
+ customerWithDetachedDefault,
1125
+ );
1126
+
1127
+ const paymentMethods: PaymentMethod[] =
1128
+ await billingService.getPaymentMethods(customerId);
1129
+
1130
+ expect(paymentMethods).toHaveLength(1);
1131
+ expect(paymentMethods[0]?.isDefault).toBe(false);
1132
+ expect(mockStripe.customers.update).not.toHaveBeenCalled();
1133
+ });
1134
+
1135
+ it("should set the first payment method as default when none is set", async () => {
1136
+ const mockPaymentMethodsResponse: {
1137
+ data: Array<Stripe.PaymentMethod>;
1138
+ } = {
1139
+ data: [
1140
+ {
1141
+ id: "pm_123",
1142
+ type: "card",
1143
+ // @ts-expect-error - Simplified mock card object for testing without all required Stripe card properties
1144
+ card: { last4: "4242", brand: "mastercard" },
1145
+ },
1146
+ ],
1147
+ };
1148
+ mockStripe.paymentMethods.list = getJestMockFunction()
1149
+ .mockResolvedValueOnce(mockPaymentMethodsResponse)
1150
+ .mockResolvedValue({ data: [] });
1151
+ mockStripe.customers.retrieve =
1152
+ getJestMockFunction().mockResolvedValue(mockCustomer);
1153
+
1154
+ const paymentMethods: PaymentMethod[] =
1155
+ await billingService.getPaymentMethods(customerId);
1156
+
1157
+ expect(paymentMethods[0]?.isDefault).toBe(true);
1158
+ expect(mockStripe.customers.update).toHaveBeenCalledWith(customerId, {
1159
+ invoice_settings: {
1160
+ default_payment_method: "pm_123",
1161
+ },
1162
+ });
1163
+ });
1164
+
1060
1165
  it("should return an empty array if no payment methods are present", async () => {
1061
1166
  const mockEmptyPaymentMethodsResponse: {
1062
1167
  data: Array<PaymentMethod>;
@@ -1440,6 +1545,224 @@ describe("BillingService", () => {
1440
1545
  },
1441
1546
  );
1442
1547
  });
1548
+
1549
+ const mockTwoPaymentMethodsResponse: PaymentMethodsResponse = {
1550
+ data: [
1551
+ {
1552
+ id: "pm_123",
1553
+ type: "card",
1554
+ last4Digits: "4242",
1555
+ isDefault: false,
1556
+ },
1557
+ {
1558
+ id: "pm_456",
1559
+ type: "card",
1560
+ last4Digits: "4343",
1561
+ isDefault: false,
1562
+ },
1563
+ ],
1564
+ };
1565
+
1566
+ type GetCardDeclinedErrorFunction = () => Error;
1567
+
1568
+ const getCardDeclinedError: GetCardDeclinedErrorFunction = (): Error => {
1569
+ return Object.assign(new Error("Your card was declined."), {
1570
+ type: "StripeCardError",
1571
+ code: "card_declined",
1572
+ });
1573
+ };
1574
+
1575
+ it("should fall back to the next payment method when the first is declined", async () => {
1576
+ mockStripe.paymentMethods.list = getJestMockFunction()
1577
+ .mockResolvedValueOnce(mockTwoPaymentMethodsResponse)
1578
+ .mockResolvedValue({ data: [] });
1579
+ mockStripe.customers.retrieve =
1580
+ getJestMockFunction().mockResolvedValue(mockCustomer);
1581
+
1582
+ const mockPaidInvoice: Stripe.Invoice = getStripeInvoice();
1583
+ mockStripe.invoices.pay = getJestMockFunction()
1584
+ .mockRejectedValueOnce(getCardDeclinedError())
1585
+ .mockResolvedValue(mockPaidInvoice);
1586
+
1587
+ const paidInvoice: Invoice = await billingService.payInvoice(
1588
+ customerId,
1589
+ mockPaidInvoice.id || "",
1590
+ );
1591
+
1592
+ expect(paidInvoice.id).toBe(mockPaidInvoice.id);
1593
+ expect(mockStripe.invoices.pay).toHaveBeenCalledTimes(2);
1594
+ expect(mockStripe.invoices.pay).toHaveBeenNthCalledWith(
1595
+ 1,
1596
+ mockPaidInvoice.id,
1597
+ {
1598
+ payment_method: "pm_123",
1599
+ },
1600
+ );
1601
+ expect(mockStripe.invoices.pay).toHaveBeenNthCalledWith(
1602
+ 2,
1603
+ mockPaidInvoice.id,
1604
+ {
1605
+ payment_method: "pm_456",
1606
+ },
1607
+ );
1608
+ });
1609
+
1610
+ it("should charge the customer's default payment method first", async () => {
1611
+ mockStripe.paymentMethods.list = getJestMockFunction()
1612
+ .mockResolvedValueOnce(mockTwoPaymentMethodsResponse)
1613
+ .mockResolvedValue({ data: [] });
1614
+
1615
+ const customerWithDefault: Stripe.Customer = getStripeCustomer(
1616
+ customer.id.toString(),
1617
+ );
1618
+ customerWithDefault.invoice_settings.default_payment_method = "pm_456";
1619
+ mockStripe.customers.retrieve =
1620
+ getJestMockFunction().mockResolvedValue(customerWithDefault);
1621
+
1622
+ const mockPaidInvoice: Stripe.Invoice = getStripeInvoice();
1623
+ mockStripe.invoices.pay =
1624
+ getJestMockFunction().mockResolvedValue(mockPaidInvoice);
1625
+
1626
+ await billingService.payInvoice(customerId, mockPaidInvoice.id || "");
1627
+
1628
+ expect(mockStripe.invoices.pay).toHaveBeenCalledTimes(1);
1629
+ expect(mockStripe.invoices.pay).toHaveBeenCalledWith(
1630
+ mockPaidInvoice.id,
1631
+ {
1632
+ payment_method: "pm_456",
1633
+ },
1634
+ );
1635
+ });
1636
+
1637
+ it("should throw the last error when all payment methods are declined", async () => {
1638
+ mockStripe.paymentMethods.list = getJestMockFunction()
1639
+ .mockResolvedValueOnce(mockTwoPaymentMethodsResponse)
1640
+ .mockResolvedValue({ data: [] });
1641
+ mockStripe.customers.retrieve =
1642
+ getJestMockFunction().mockResolvedValue(mockCustomer);
1643
+
1644
+ const lastError: Error = Object.assign(
1645
+ new Error("Insufficient funds."),
1646
+ {
1647
+ type: "StripeCardError",
1648
+ code: "card_declined",
1649
+ },
1650
+ );
1651
+ mockStripe.invoices.pay = getJestMockFunction()
1652
+ .mockRejectedValueOnce(getCardDeclinedError())
1653
+ .mockRejectedValueOnce(lastError);
1654
+
1655
+ await expect(
1656
+ billingService.payInvoice(customerId, invoiceId),
1657
+ ).rejects.toThrow(lastError);
1658
+ expect(mockStripe.invoices.pay).toHaveBeenCalledTimes(2);
1659
+ });
1660
+
1661
+ it("should not try other payment methods on errors unrelated to the payment method", async () => {
1662
+ mockStripe.paymentMethods.list = getJestMockFunction()
1663
+ .mockResolvedValueOnce(mockTwoPaymentMethodsResponse)
1664
+ .mockResolvedValue({ data: [] });
1665
+ mockStripe.customers.retrieve =
1666
+ getJestMockFunction().mockResolvedValue(mockCustomer);
1667
+
1668
+ const invoiceStateError: Error = Object.assign(
1669
+ new Error("Invoice is already paid."),
1670
+ {
1671
+ type: "StripeInvalidRequestError",
1672
+ code: "invoice_already_paid",
1673
+ },
1674
+ );
1675
+ mockStripe.invoices.pay =
1676
+ getJestMockFunction().mockRejectedValue(invoiceStateError);
1677
+
1678
+ await expect(
1679
+ billingService.payInvoice(customerId, invoiceId),
1680
+ ).rejects.toThrow(invoiceStateError);
1681
+ expect(mockStripe.invoices.pay).toHaveBeenCalledTimes(1);
1682
+ });
1683
+
1684
+ it("should fall back to the next payment method on payment method and bank account errors", async () => {
1685
+ mockStripe.paymentMethods.list = getJestMockFunction()
1686
+ .mockResolvedValueOnce(mockTwoPaymentMethodsResponse)
1687
+ .mockResolvedValue({ data: [] });
1688
+ mockStripe.customers.retrieve =
1689
+ getJestMockFunction().mockResolvedValue(mockCustomer);
1690
+
1691
+ const bankAccountError: Error = Object.assign(
1692
+ new Error("This bank account cannot be used."),
1693
+ {
1694
+ type: "StripeInvalidRequestError",
1695
+ code: "bank_account_unusable",
1696
+ },
1697
+ );
1698
+
1699
+ const mockPaidInvoice: Stripe.Invoice = getStripeInvoice();
1700
+ mockStripe.invoices.pay = getJestMockFunction()
1701
+ .mockRejectedValueOnce(bankAccountError)
1702
+ .mockResolvedValue(mockPaidInvoice);
1703
+
1704
+ const paidInvoice: Invoice = await billingService.payInvoice(
1705
+ customerId,
1706
+ mockPaidInvoice.id || "",
1707
+ );
1708
+
1709
+ expect(paidInvoice.id).toBe(mockPaidInvoice.id);
1710
+ expect(mockStripe.invoices.pay).toHaveBeenCalledTimes(2);
1711
+ });
1712
+
1713
+ it("should not try other payment methods when authentication is required", async () => {
1714
+ /*
1715
+ * the interactive 3DS flow in BillingInvoiceAPI must surface
1716
+ * authentication for the default payment method instead.
1717
+ */
1718
+ mockStripe.paymentMethods.list = getJestMockFunction()
1719
+ .mockResolvedValueOnce(mockTwoPaymentMethodsResponse)
1720
+ .mockResolvedValue({ data: [] });
1721
+ mockStripe.customers.retrieve =
1722
+ getJestMockFunction().mockResolvedValue(mockCustomer);
1723
+
1724
+ const requiresActionError: Error = Object.assign(
1725
+ new Error("This payment requires additional authentication."),
1726
+ {
1727
+ type: "StripeInvalidRequestError",
1728
+ code: "invoice_payment_intent_requires_action",
1729
+ },
1730
+ );
1731
+ mockStripe.invoices.pay =
1732
+ getJestMockFunction().mockRejectedValue(requiresActionError);
1733
+
1734
+ await expect(
1735
+ billingService.payInvoice(customerId, invoiceId),
1736
+ ).rejects.toThrow(requiresActionError);
1737
+ expect(mockStripe.invoices.pay).toHaveBeenCalledTimes(1);
1738
+ });
1739
+
1740
+ it("should try at most three payment methods", async () => {
1741
+ const mockFourPaymentMethodsResponse: PaymentMethodsResponse = {
1742
+ data: ["pm_1", "pm_2", "pm_3", "pm_4"].map((id: string) => {
1743
+ return {
1744
+ id,
1745
+ type: "card",
1746
+ last4Digits: "4242",
1747
+ isDefault: false,
1748
+ };
1749
+ }),
1750
+ };
1751
+ mockStripe.paymentMethods.list = getJestMockFunction()
1752
+ .mockResolvedValueOnce(mockFourPaymentMethodsResponse)
1753
+ .mockResolvedValue({ data: [] });
1754
+ mockStripe.customers.retrieve =
1755
+ getJestMockFunction().mockResolvedValue(mockCustomer);
1756
+
1757
+ mockStripe.invoices.pay = getJestMockFunction().mockRejectedValue(
1758
+ getCardDeclinedError(),
1759
+ );
1760
+
1761
+ await expect(
1762
+ billingService.payInvoice(customerId, invoiceId),
1763
+ ).rejects.toThrow("Your card was declined.");
1764
+ expect(mockStripe.invoices.pay).toHaveBeenCalledTimes(3);
1765
+ });
1443
1766
  });
1444
1767
  });
1445
1768
  });