@oneuptime/common 10.8.2 → 11.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (740) hide show
  1. package/Models/AnalyticsModels/AnalyticsBaseModel/AnalyticsBaseModel.ts +16 -18
  2. package/Models/AnalyticsModels/AuditLog.ts +3 -1
  3. package/Models/AnalyticsModels/ExceptionInstance.ts +200 -82
  4. package/Models/AnalyticsModels/Index.ts +7 -2
  5. package/Models/AnalyticsModels/Log.ts +197 -81
  6. package/Models/AnalyticsModels/Metric.ts +199 -86
  7. package/Models/AnalyticsModels/MetricBaselineHourly.ts +44 -25
  8. package/Models/AnalyticsModels/MetricItemAggMV1m.ts +23 -20
  9. package/Models/AnalyticsModels/{MetricItemAggMV1mByHost.ts → MetricItemAggMV1mByHostV2.ts} +58 -47
  10. package/Models/AnalyticsModels/MonitorLog.ts +5 -1
  11. package/Models/AnalyticsModels/Profile.ts +206 -85
  12. package/Models/AnalyticsModels/ProfileSample.ts +196 -83
  13. package/Models/AnalyticsModels/Span.ts +218 -85
  14. package/Models/DatabaseModels/Index.ts +4 -0
  15. package/Models/DatabaseModels/Service.ts +29 -0
  16. package/Models/DatabaseModels/TelemetryEntity.ts +393 -0
  17. package/Models/DatabaseModels/TelemetryEntityRelationship.ts +294 -0
  18. package/Models/DatabaseModels/TelemetryException.ts +10 -10
  19. package/Models/DatabaseModels/TelemetryUsageBilling.ts +5 -5
  20. package/Server/API/AIAgentDataAPI.ts +13 -12
  21. package/Server/API/DashboardAPI.ts +2 -2
  22. package/Server/API/TelemetryAPI.ts +656 -141
  23. package/Server/API/TelemetryExceptionAPI.ts +2 -2
  24. package/Server/Infrastructure/ClickhouseConfig.ts +12 -0
  25. package/Server/Infrastructure/Postgres/SchemaMigrations/1781100000001-RenameTelemetryServiceIdToPrimaryEntityId.ts +48 -0
  26. package/Server/Infrastructure/Postgres/SchemaMigrations/1781200000000-AddTelemetryEntityTable.ts +70 -0
  27. package/Server/Infrastructure/Postgres/SchemaMigrations/1781200000001-AddTelemetryEntityRelationshipTable.ts +57 -0
  28. package/Server/Infrastructure/Postgres/SchemaMigrations/1781250074195-MigrationName.ts +207 -0
  29. package/Server/Infrastructure/Postgres/SchemaMigrations/1781300000000-AddTelemetryEntityLabels.ts +24 -0
  30. package/Server/Infrastructure/Postgres/SchemaMigrations/1781400000000-AddServiceTelemetrySdkLanguage.ts +25 -0
  31. package/Server/Infrastructure/Postgres/SchemaMigrations/Index.ts +12 -0
  32. package/Server/Infrastructure/Queue.ts +36 -3
  33. package/Server/Middleware/TelemetryIngest.ts +27 -22
  34. package/Server/Services/AlertService.ts +9 -9
  35. package/Server/Services/AnalyticsDatabaseService.ts +204 -35
  36. package/Server/Services/ExceptionAggregationService.ts +41 -18
  37. package/Server/Services/HostService.ts +2 -1
  38. package/Server/Services/IncidentService.ts +19 -19
  39. package/Server/Services/Index.ts +6 -2
  40. package/Server/Services/LogAggregationService.ts +116 -43
  41. package/Server/Services/MetricAggregationService.ts +29 -14
  42. package/Server/Services/MetricBaselineService.ts +34 -34
  43. package/Server/Services/MetricItemAggMV1mByHostV2Service.ts +30 -0
  44. package/Server/Services/MetricService.ts +119 -31
  45. package/Server/Services/OpenTelemetryIngestService.ts +186 -50
  46. package/Server/Services/ProfileAggregationService.ts +904 -126
  47. package/Server/Services/ServiceService.ts +6 -0
  48. package/Server/Services/SpanService.ts +274 -14
  49. package/Server/Services/TelemetryEntityRelationshipService.ts +71 -0
  50. package/Server/Services/TelemetryEntityService.ts +246 -0
  51. package/Server/Services/TelemetryExceptionService.ts +27 -23
  52. package/Server/Services/TelemetryUsageBillingService.ts +38 -31
  53. package/Server/Services/TraceAggregationService.ts +875 -43
  54. package/Server/Types/AnalyticsDatabase/ModelPermission.ts +43 -2
  55. package/Server/Types/Database/Permissions/AccessControlPermission.ts +47 -2
  56. package/Server/Types/Database/Permissions/BasePermission.ts +37 -1
  57. package/Server/Types/Database/Permissions/OwnedScopePermission.ts +21 -3
  58. package/Server/Types/Database/Permissions/OwnerTableRegistry.ts +1 -0
  59. package/Server/Types/Database/QueryHelper.ts +41 -0
  60. package/Server/Utils/Alert/AlertPrivacyFilter.ts +9 -2
  61. package/Server/Utils/AlertEpisode/AlertEpisodePrivacyFilter.ts +9 -2
  62. package/Server/Utils/AnalyticsDatabase/QuerySettingsHelper.ts +95 -0
  63. package/Server/Utils/AnalyticsDatabase/StatementGenerator.ts +133 -0
  64. package/Server/Utils/Incident/IncidentPrivacyFilter.ts +9 -2
  65. package/Server/Utils/IncidentEpisode/IncidentEpisodePrivacyFilter.ts +9 -2
  66. package/Server/Utils/Monitor/Criteria/EvaluateOverTime.ts +1 -1
  67. package/Server/Utils/Monitor/MonitorLogUtil.ts +1 -2
  68. package/Server/Utils/Monitor/MonitorMetricUtil.ts +3 -4
  69. package/Server/Utils/PrivacyFilterUtil.ts +72 -0
  70. package/Server/Utils/Profile/PprofEncoder.ts +135 -11
  71. package/Server/Utils/Telemetry/EntityRegistry.ts +316 -0
  72. package/Server/Utils/Telemetry/ResourceFacetResolver.ts +5 -0
  73. package/Server/Utils/Telemetry/TelemetryEntity.ts +783 -0
  74. package/Tests/Server/Services/AnalyticsDatabaseService.test.ts +79 -4
  75. package/Tests/Server/Services/LogAggregationService.test.ts +7 -2
  76. package/Tests/Server/Services/ProfileAggregationService.test.ts +280 -0
  77. package/Tests/Server/Services/ProfileBreakdown.test.ts +161 -0
  78. package/Tests/Server/Services/ProfileFunctionFocus.test.ts +349 -0
  79. package/Tests/Server/Services/TelemetryAttributeService.test.ts +1 -1
  80. package/Tests/Server/Services/TraceAggregationService.test.ts +403 -0
  81. package/Tests/Server/Types/AnalyticsDatabase/ModelPermissionOwnedScope.test.ts +114 -0
  82. package/Tests/Server/Types/Database/Permissions/AccessControlPermission.test.ts +189 -0
  83. package/Tests/Server/Types/Database/Permissions/BasePermission.test.ts +118 -0
  84. package/Tests/Server/Types/Database/Permissions/OwnedScopePermission.test.ts +159 -0
  85. package/Tests/Server/Utils/AnalyticsDatabase/StatementGenerator.test.ts +275 -8
  86. package/Tests/Server/Utils/PrivacyFilterUtil.test.ts +177 -0
  87. package/Tests/Server/Utils/Profile/PprofEncoder.test.ts +276 -0
  88. package/Tests/Server/Utils/Telemetry/TelemetryEntity.test.ts +761 -0
  89. package/Tests/Types/Monitor/MonitorStepEntityScope.test.ts +275 -0
  90. package/Tests/Types/Text.test.ts +52 -0
  91. package/Tests/Utils/ModelImportExport.test.ts +366 -0
  92. package/Tests/Utils/Telemetry/EntityKey.test.ts +150 -0
  93. package/Tests/Utils/Telemetry/EntityKeySqlParity.test.ts +40 -0
  94. package/Tests/Utils/Telemetry/EntityRelationship.test.ts +150 -0
  95. package/Tests/Utils/UUID.test.ts +47 -0
  96. package/Types/AnalyticsDatabase/AnalyticsTableName.ts +14 -9
  97. package/Types/AnalyticsDatabase/TableColumnType.ts +1 -0
  98. package/Types/Dashboard/DashboardComponentType.ts +1 -0
  99. package/Types/Dashboard/DashboardComponents/DashboardTraceChartComponent.ts +37 -0
  100. package/Types/Dashboard/DashboardTemplates.ts +4 -5
  101. package/Types/Log/LogQueryParser.ts +2 -2
  102. package/Types/Log/LogQueryToFilter.ts +2 -2
  103. package/Types/Monitor/MonitorStepExceptionMonitor.ts +19 -1
  104. package/Types/Monitor/MonitorStepLogMonitor.ts +20 -1
  105. package/Types/Monitor/MonitorStepMetricMonitor.ts +27 -0
  106. package/Types/Monitor/MonitorStepProfileMonitor.ts +19 -1
  107. package/Types/Monitor/MonitorStepTraceMonitor.ts +18 -1
  108. package/Types/Monitor/MonitorType.ts +8 -1
  109. package/Types/ObjectID.ts +10 -0
  110. package/Types/Telemetry/EntityRelationshipType.ts +31 -0
  111. package/Types/Telemetry/EntityType.ts +33 -0
  112. package/Types/Telemetry/TelemetrySavedViewState.ts +2 -0
  113. package/Types/Text.ts +34 -0
  114. package/Types/Trace/TraceAggregationType.ts +1 -0
  115. package/Types/Trace/TraceRecordingRuleDefinition.ts +74 -0
  116. package/UI/Components/ImportExport/ExportModelCard.tsx +90 -0
  117. package/UI/Components/ImportExport/ImportModelsModal.tsx +239 -0
  118. package/UI/Components/LogsViewer/LogsViewer.tsx +12 -9
  119. package/UI/Components/LogsViewer/components/LogDetailsPanel.tsx +10 -9
  120. package/UI/Components/LogsViewer/components/LogSearchBar.tsx +1 -1
  121. package/UI/Components/LogsViewer/components/LogsAnalyticsView.tsx +2 -2
  122. package/UI/Components/LogsViewer/components/LogsFacetSidebar.tsx +4 -4
  123. package/UI/Components/LogsViewer/components/LogsTable.tsx +5 -3
  124. package/UI/Components/ModelTable/ModelTable.tsx +294 -143
  125. package/UI/Components/Navbar/NavBarMenuModal.tsx +81 -44
  126. package/UI/Components/TelemetryViewer/TelemetryViewer.tsx +33 -10
  127. package/UI/Components/TelemetryViewer/components/TelemetryFacetSidebar.tsx +18 -3
  128. package/UI/Components/TelemetryViewer/components/TelemetryHistogram.tsx +91 -68
  129. package/UI/Components/TelemetryViewer/components/TelemetryHistogramTooltip.tsx +9 -2
  130. package/UI/Utils/LogExport.ts +2 -2
  131. package/UI/Utils/ModelImportExport.ts +207 -0
  132. package/UI/Utils/TelemetryService.ts +20 -20
  133. package/Utils/Dashboard/Components/DashboardTraceChartComponent.ts +134 -0
  134. package/Utils/Dashboard/Components/Index.ts +7 -0
  135. package/Utils/ModelImportExport.ts +369 -0
  136. package/Utils/Telemetry/EntityKey.ts +151 -0
  137. package/Utils/Telemetry/EntityRelationship.ts +113 -0
  138. package/Utils/Traces/CriticalPath.ts +7 -7
  139. package/Utils/UUID.ts +57 -0
  140. package/build/dist/Models/AnalyticsModels/AnalyticsBaseModel/AnalyticsBaseModel.js +14 -13
  141. package/build/dist/Models/AnalyticsModels/AnalyticsBaseModel/AnalyticsBaseModel.js.map +1 -1
  142. package/build/dist/Models/AnalyticsModels/AuditLog.js +2 -1
  143. package/build/dist/Models/AnalyticsModels/AuditLog.js.map +1 -1
  144. package/build/dist/Models/AnalyticsModels/ExceptionInstance.js +125 -22
  145. package/build/dist/Models/AnalyticsModels/ExceptionInstance.js.map +1 -1
  146. package/build/dist/Models/AnalyticsModels/Index.js +7 -2
  147. package/build/dist/Models/AnalyticsModels/Index.js.map +1 -1
  148. package/build/dist/Models/AnalyticsModels/Log.js +123 -22
  149. package/build/dist/Models/AnalyticsModels/Log.js.map +1 -1
  150. package/build/dist/Models/AnalyticsModels/Metric.js +125 -27
  151. package/build/dist/Models/AnalyticsModels/Metric.js.map +1 -1
  152. package/build/dist/Models/AnalyticsModels/MetricBaselineHourly.js +38 -21
  153. package/build/dist/Models/AnalyticsModels/MetricBaselineHourly.js.map +1 -1
  154. package/build/dist/Models/AnalyticsModels/MetricItemAggMV1m.js +17 -16
  155. package/build/dist/Models/AnalyticsModels/MetricItemAggMV1m.js.map +1 -1
  156. package/build/dist/Models/AnalyticsModels/{MetricItemAggMV1mByHost.js → MetricItemAggMV1mByHostV2.js} +54 -42
  157. package/build/dist/Models/AnalyticsModels/MetricItemAggMV1mByHostV2.js.map +1 -0
  158. package/build/dist/Models/AnalyticsModels/MonitorLog.js +4 -1
  159. package/build/dist/Models/AnalyticsModels/MonitorLog.js.map +1 -1
  160. package/build/dist/Models/AnalyticsModels/Profile.js +132 -26
  161. package/build/dist/Models/AnalyticsModels/Profile.js.map +1 -1
  162. package/build/dist/Models/AnalyticsModels/ProfileSample.js +121 -23
  163. package/build/dist/Models/AnalyticsModels/ProfileSample.js.map +1 -1
  164. package/build/dist/Models/AnalyticsModels/Span.js +144 -26
  165. package/build/dist/Models/AnalyticsModels/Span.js.map +1 -1
  166. package/build/dist/Models/DatabaseModels/Index.js +4 -0
  167. package/build/dist/Models/DatabaseModels/Index.js.map +1 -1
  168. package/build/dist/Models/DatabaseModels/Service.js +30 -0
  169. package/build/dist/Models/DatabaseModels/Service.js.map +1 -1
  170. package/build/dist/Models/DatabaseModels/TelemetryEntity.js +419 -0
  171. package/build/dist/Models/DatabaseModels/TelemetryEntity.js.map +1 -0
  172. package/build/dist/Models/DatabaseModels/TelemetryEntityRelationship.js +317 -0
  173. package/build/dist/Models/DatabaseModels/TelemetryEntityRelationship.js.map +1 -0
  174. package/build/dist/Models/DatabaseModels/TelemetryException.js +12 -12
  175. package/build/dist/Models/DatabaseModels/TelemetryException.js.map +1 -1
  176. package/build/dist/Models/DatabaseModels/TelemetryUsageBilling.js +7 -7
  177. package/build/dist/Models/DatabaseModels/TelemetryUsageBilling.js.map +1 -1
  178. package/build/dist/Server/API/AIAgentDataAPI.js +14 -13
  179. package/build/dist/Server/API/AIAgentDataAPI.js.map +1 -1
  180. package/build/dist/Server/API/DashboardAPI.js +2 -2
  181. package/build/dist/Server/API/DashboardAPI.js.map +1 -1
  182. package/build/dist/Server/API/TelemetryAPI.js +425 -129
  183. package/build/dist/Server/API/TelemetryAPI.js.map +1 -1
  184. package/build/dist/Server/API/TelemetryExceptionAPI.js +2 -2
  185. package/build/dist/Server/API/TelemetryExceptionAPI.js.map +1 -1
  186. package/build/dist/Server/Infrastructure/ClickhouseConfig.js +12 -0
  187. package/build/dist/Server/Infrastructure/ClickhouseConfig.js.map +1 -1
  188. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781100000001-RenameTelemetryServiceIdToPrimaryEntityId.js +29 -0
  189. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781100000001-RenameTelemetryServiceIdToPrimaryEntityId.js.map +1 -0
  190. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781200000000-AddTelemetryEntityTable.js +38 -0
  191. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781200000000-AddTelemetryEntityTable.js.map +1 -0
  192. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781200000001-AddTelemetryEntityRelationshipTable.js +33 -0
  193. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781200000001-AddTelemetryEntityRelationshipTable.js.map +1 -0
  194. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781250074195-MigrationName.js +78 -0
  195. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781250074195-MigrationName.js.map +1 -0
  196. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781300000000-AddTelemetryEntityLabels.js +19 -0
  197. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781300000000-AddTelemetryEntityLabels.js.map +1 -0
  198. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781400000000-AddServiceTelemetrySdkLanguage.js +18 -0
  199. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781400000000-AddServiceTelemetrySdkLanguage.js.map +1 -0
  200. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js +12 -0
  201. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js.map +1 -1
  202. package/build/dist/Server/Infrastructure/Queue.js +14 -3
  203. package/build/dist/Server/Infrastructure/Queue.js.map +1 -1
  204. package/build/dist/Server/Middleware/TelemetryIngest.js +16 -18
  205. package/build/dist/Server/Middleware/TelemetryIngest.js.map +1 -1
  206. package/build/dist/Server/Services/AlertService.js +9 -9
  207. package/build/dist/Server/Services/AlertService.js.map +1 -1
  208. package/build/dist/Server/Services/AnalyticsDatabaseService.js +115 -40
  209. package/build/dist/Server/Services/AnalyticsDatabaseService.js.map +1 -1
  210. package/build/dist/Server/Services/ExceptionAggregationService.js +38 -18
  211. package/build/dist/Server/Services/ExceptionAggregationService.js.map +1 -1
  212. package/build/dist/Server/Services/HostService.js +2 -1
  213. package/build/dist/Server/Services/HostService.js.map +1 -1
  214. package/build/dist/Server/Services/IncidentService.js +19 -19
  215. package/build/dist/Server/Services/IncidentService.js.map +1 -1
  216. package/build/dist/Server/Services/Index.js +6 -2
  217. package/build/dist/Server/Services/Index.js.map +1 -1
  218. package/build/dist/Server/Services/LogAggregationService.js +100 -42
  219. package/build/dist/Server/Services/LogAggregationService.js.map +1 -1
  220. package/build/dist/Server/Services/MetricAggregationService.js +27 -14
  221. package/build/dist/Server/Services/MetricAggregationService.js.map +1 -1
  222. package/build/dist/Server/Services/MetricBaselineService.js +28 -28
  223. package/build/dist/Server/Services/MetricBaselineService.js.map +1 -1
  224. package/build/dist/Server/Services/MetricItemAggMV1mByHostV2Service.js +28 -0
  225. package/build/dist/Server/Services/MetricItemAggMV1mByHostV2Service.js.map +1 -0
  226. package/build/dist/Server/Services/MetricService.js +116 -31
  227. package/build/dist/Server/Services/MetricService.js.map +1 -1
  228. package/build/dist/Server/Services/OpenTelemetryIngestService.js +103 -36
  229. package/build/dist/Server/Services/OpenTelemetryIngestService.js.map +1 -1
  230. package/build/dist/Server/Services/ProfileAggregationService.js +613 -105
  231. package/build/dist/Server/Services/ProfileAggregationService.js.map +1 -1
  232. package/build/dist/Server/Services/ServiceService.js +9 -5
  233. package/build/dist/Server/Services/ServiceService.js.map +1 -1
  234. package/build/dist/Server/Services/SpanService.js +217 -15
  235. package/build/dist/Server/Services/SpanService.js.map +1 -1
  236. package/build/dist/Server/Services/TelemetryEntityRelationshipService.js +72 -0
  237. package/build/dist/Server/Services/TelemetryEntityRelationshipService.js.map +1 -0
  238. package/build/dist/Server/Services/TelemetryEntityService.js +201 -0
  239. package/build/dist/Server/Services/TelemetryEntityService.js.map +1 -0
  240. package/build/dist/Server/Services/TelemetryExceptionService.js +18 -18
  241. package/build/dist/Server/Services/TelemetryExceptionService.js.map +1 -1
  242. package/build/dist/Server/Services/TelemetryUsageBillingService.js +27 -21
  243. package/build/dist/Server/Services/TelemetryUsageBillingService.js.map +1 -1
  244. package/build/dist/Server/Services/TraceAggregationService.js +568 -43
  245. package/build/dist/Server/Services/TraceAggregationService.js.map +1 -1
  246. package/build/dist/Server/Types/AnalyticsDatabase/ModelPermission.js +38 -2
  247. package/build/dist/Server/Types/AnalyticsDatabase/ModelPermission.js.map +1 -1
  248. package/build/dist/Server/Types/Database/Permissions/AccessControlPermission.js +36 -2
  249. package/build/dist/Server/Types/Database/Permissions/AccessControlPermission.js.map +1 -1
  250. package/build/dist/Server/Types/Database/Permissions/BasePermission.js +25 -1
  251. package/build/dist/Server/Types/Database/Permissions/BasePermission.js.map +1 -1
  252. package/build/dist/Server/Types/Database/Permissions/OwnedScopePermission.js +17 -3
  253. package/build/dist/Server/Types/Database/Permissions/OwnedScopePermission.js.map +1 -1
  254. package/build/dist/Server/Types/Database/Permissions/OwnerTableRegistry.js +1 -0
  255. package/build/dist/Server/Types/Database/Permissions/OwnerTableRegistry.js.map +1 -1
  256. package/build/dist/Server/Types/Database/QueryHelper.js +31 -0
  257. package/build/dist/Server/Types/Database/QueryHelper.js.map +1 -1
  258. package/build/dist/Server/Utils/Alert/AlertPrivacyFilter.js +3 -2
  259. package/build/dist/Server/Utils/Alert/AlertPrivacyFilter.js.map +1 -1
  260. package/build/dist/Server/Utils/AlertEpisode/AlertEpisodePrivacyFilter.js +3 -2
  261. package/build/dist/Server/Utils/AlertEpisode/AlertEpisodePrivacyFilter.js.map +1 -1
  262. package/build/dist/Server/Utils/AnalyticsDatabase/QuerySettingsHelper.js +46 -0
  263. package/build/dist/Server/Utils/AnalyticsDatabase/QuerySettingsHelper.js.map +1 -0
  264. package/build/dist/Server/Utils/AnalyticsDatabase/StatementGenerator.js +97 -3
  265. package/build/dist/Server/Utils/AnalyticsDatabase/StatementGenerator.js.map +1 -1
  266. package/build/dist/Server/Utils/Incident/IncidentPrivacyFilter.js +3 -2
  267. package/build/dist/Server/Utils/Incident/IncidentPrivacyFilter.js.map +1 -1
  268. package/build/dist/Server/Utils/IncidentEpisode/IncidentEpisodePrivacyFilter.js +3 -2
  269. package/build/dist/Server/Utils/IncidentEpisode/IncidentEpisodePrivacyFilter.js.map +1 -1
  270. package/build/dist/Server/Utils/Monitor/Criteria/EvaluateOverTime.js +1 -1
  271. package/build/dist/Server/Utils/Monitor/Criteria/EvaluateOverTime.js.map +1 -1
  272. package/build/dist/Server/Utils/Monitor/MonitorLogUtil.js +1 -2
  273. package/build/dist/Server/Utils/Monitor/MonitorLogUtil.js.map +1 -1
  274. package/build/dist/Server/Utils/Monitor/MonitorMetricUtil.js +3 -4
  275. package/build/dist/Server/Utils/Monitor/MonitorMetricUtil.js.map +1 -1
  276. package/build/dist/Server/Utils/PrivacyFilterUtil.js +47 -0
  277. package/build/dist/Server/Utils/PrivacyFilterUtil.js.map +1 -0
  278. package/build/dist/Server/Utils/Profile/PprofEncoder.js +132 -4
  279. package/build/dist/Server/Utils/Profile/PprofEncoder.js.map +1 -1
  280. package/build/dist/Server/Utils/Telemetry/EntityRegistry.js +228 -0
  281. package/build/dist/Server/Utils/Telemetry/EntityRegistry.js.map +1 -0
  282. package/build/dist/Server/Utils/Telemetry/ResourceFacetResolver.js +5 -0
  283. package/build/dist/Server/Utils/Telemetry/ResourceFacetResolver.js.map +1 -1
  284. package/build/dist/Server/Utils/Telemetry/TelemetryEntity.js +569 -0
  285. package/build/dist/Server/Utils/Telemetry/TelemetryEntity.js.map +1 -0
  286. package/build/dist/Types/AnalyticsDatabase/AnalyticsTableName.js +14 -9
  287. package/build/dist/Types/AnalyticsDatabase/AnalyticsTableName.js.map +1 -1
  288. package/build/dist/Types/AnalyticsDatabase/TableColumnType.js +1 -0
  289. package/build/dist/Types/AnalyticsDatabase/TableColumnType.js.map +1 -1
  290. package/build/dist/Types/Dashboard/DashboardComponentType.js +1 -0
  291. package/build/dist/Types/Dashboard/DashboardComponentType.js.map +1 -1
  292. package/build/dist/Types/Dashboard/DashboardComponents/DashboardTraceChartComponent.js +2 -0
  293. package/build/dist/Types/Dashboard/DashboardComponents/DashboardTraceChartComponent.js.map +1 -0
  294. package/build/dist/Types/Dashboard/DashboardTemplates.js +4 -5
  295. package/build/dist/Types/Dashboard/DashboardTemplates.js.map +1 -1
  296. package/build/dist/Types/Log/LogQueryParser.js +2 -2
  297. package/build/dist/Types/Log/LogQueryParser.js.map +1 -1
  298. package/build/dist/Types/Log/LogQueryToFilter.js +1 -1
  299. package/build/dist/Types/Log/LogQueryToFilter.js.map +1 -1
  300. package/build/dist/Types/Monitor/MonitorStepExceptionMonitor.js +9 -1
  301. package/build/dist/Types/Monitor/MonitorStepExceptionMonitor.js.map +1 -1
  302. package/build/dist/Types/Monitor/MonitorStepLogMonitor.js +9 -1
  303. package/build/dist/Types/Monitor/MonitorStepLogMonitor.js.map +1 -1
  304. package/build/dist/Types/Monitor/MonitorStepMetricMonitor.js +13 -0
  305. package/build/dist/Types/Monitor/MonitorStepMetricMonitor.js.map +1 -1
  306. package/build/dist/Types/Monitor/MonitorStepProfileMonitor.js +9 -1
  307. package/build/dist/Types/Monitor/MonitorStepProfileMonitor.js.map +1 -1
  308. package/build/dist/Types/Monitor/MonitorStepTraceMonitor.js +9 -1
  309. package/build/dist/Types/Monitor/MonitorStepTraceMonitor.js.map +1 -1
  310. package/build/dist/Types/Monitor/MonitorType.js +8 -1
  311. package/build/dist/Types/Monitor/MonitorType.js.map +1 -1
  312. package/build/dist/Types/ObjectID.js +9 -0
  313. package/build/dist/Types/ObjectID.js.map +1 -1
  314. package/build/dist/Types/Telemetry/EntityRelationshipType.js +32 -0
  315. package/build/dist/Types/Telemetry/EntityRelationshipType.js.map +1 -0
  316. package/build/dist/Types/Telemetry/EntityType.js +34 -0
  317. package/build/dist/Types/Telemetry/EntityType.js.map +1 -0
  318. package/build/dist/Types/Text.js +32 -1
  319. package/build/dist/Types/Text.js.map +1 -1
  320. package/build/dist/Types/Trace/TraceAggregationType.js +1 -0
  321. package/build/dist/Types/Trace/TraceAggregationType.js.map +1 -1
  322. package/build/dist/Types/Trace/TraceRecordingRuleDefinition.js +50 -1
  323. package/build/dist/Types/Trace/TraceRecordingRuleDefinition.js.map +1 -1
  324. package/build/dist/UI/Components/ImportExport/ExportModelCard.js +50 -0
  325. package/build/dist/UI/Components/ImportExport/ExportModelCard.js.map +1 -0
  326. package/build/dist/UI/Components/ImportExport/ImportModelsModal.js +115 -0
  327. package/build/dist/UI/Components/ImportExport/ImportModelsModal.js.map +1 -0
  328. package/build/dist/UI/Components/LogsViewer/LogsViewer.js +10 -9
  329. package/build/dist/UI/Components/LogsViewer/LogsViewer.js.map +1 -1
  330. package/build/dist/UI/Components/LogsViewer/components/LogDetailsPanel.js +8 -8
  331. package/build/dist/UI/Components/LogsViewer/components/LogDetailsPanel.js.map +1 -1
  332. package/build/dist/UI/Components/LogsViewer/components/LogSearchBar.js +1 -1
  333. package/build/dist/UI/Components/LogsViewer/components/LogSearchBar.js.map +1 -1
  334. package/build/dist/UI/Components/LogsViewer/components/LogsAnalyticsView.js +2 -2
  335. package/build/dist/UI/Components/LogsViewer/components/LogsAnalyticsView.js.map +1 -1
  336. package/build/dist/UI/Components/LogsViewer/components/LogsFacetSidebar.js +4 -4
  337. package/build/dist/UI/Components/LogsViewer/components/LogsFacetSidebar.js.map +1 -1
  338. package/build/dist/UI/Components/LogsViewer/components/LogsTable.js +3 -3
  339. package/build/dist/UI/Components/LogsViewer/components/LogsTable.js.map +1 -1
  340. package/build/dist/UI/Components/ModelTable/ModelTable.js +166 -74
  341. package/build/dist/UI/Components/ModelTable/ModelTable.js.map +1 -1
  342. package/build/dist/UI/Components/Navbar/NavBarMenuModal.js +43 -30
  343. package/build/dist/UI/Components/Navbar/NavBarMenuModal.js.map +1 -1
  344. package/build/dist/UI/Components/TelemetryViewer/TelemetryViewer.js +6 -2
  345. package/build/dist/UI/Components/TelemetryViewer/TelemetryViewer.js.map +1 -1
  346. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryFacetSidebar.js +14 -3
  347. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryFacetSidebar.js.map +1 -1
  348. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryHistogram.js +18 -10
  349. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryHistogram.js.map +1 -1
  350. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryHistogramTooltip.js +4 -2
  351. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryHistogramTooltip.js.map +1 -1
  352. package/build/dist/UI/Utils/LogExport.js +2 -2
  353. package/build/dist/UI/Utils/LogExport.js.map +1 -1
  354. package/build/dist/UI/Utils/ModelImportExport.js +142 -0
  355. package/build/dist/UI/Utils/ModelImportExport.js.map +1 -0
  356. package/build/dist/UI/Utils/TelemetryService.js +16 -16
  357. package/build/dist/UI/Utils/TelemetryService.js.map +1 -1
  358. package/build/dist/Utils/Dashboard/Components/DashboardTraceChartComponent.js +110 -0
  359. package/build/dist/Utils/Dashboard/Components/DashboardTraceChartComponent.js.map +1 -0
  360. package/build/dist/Utils/Dashboard/Components/Index.js +4 -0
  361. package/build/dist/Utils/Dashboard/Components/Index.js.map +1 -1
  362. package/build/dist/Utils/ModelImportExport.js +257 -0
  363. package/build/dist/Utils/ModelImportExport.js.map +1 -0
  364. package/build/dist/Utils/Telemetry/EntityKey.js +115 -0
  365. package/build/dist/Utils/Telemetry/EntityKey.js.map +1 -0
  366. package/build/dist/Utils/Telemetry/EntityRelationship.js +71 -0
  367. package/build/dist/Utils/Telemetry/EntityRelationship.js.map +1 -0
  368. package/build/dist/Utils/Traces/CriticalPath.js +5 -5
  369. package/build/dist/Utils/Traces/CriticalPath.js.map +1 -1
  370. package/build/dist/Utils/UUID.js +50 -0
  371. package/build/dist/Utils/UUID.js.map +1 -1
  372. package/package.json +2 -1
  373. package/tsconfig.json +10 -1
  374. package/Server/Services/MetricItemAggMV1mByHostService.ts +0 -30
  375. package/Types/Profile/ProfileMetricType.ts +0 -16
  376. package/build/dist/Models/AnalyticsModels/MetricItemAggMV1mByHost.js.map +0 -1
  377. package/build/dist/Server/Services/MetricItemAggMV1mByHostService.js +0 -28
  378. package/build/dist/Server/Services/MetricItemAggMV1mByHostService.js.map +0 -1
  379. package/build/dist/Tests/MockType.js +0 -5
  380. package/build/dist/Tests/MockType.js.map +0 -1
  381. package/build/dist/Tests/Models/AnalyticsModels/Log.test.js +0 -12
  382. package/build/dist/Tests/Models/AnalyticsModels/Log.test.js.map +0 -1
  383. package/build/dist/Tests/Models/File.test.js +0 -10
  384. package/build/dist/Tests/Models/File.test.js.map +0 -1
  385. package/build/dist/Tests/Server/API/BaseAPI.test.js +0 -590
  386. package/build/dist/Tests/Server/API/BaseAPI.test.js.map +0 -1
  387. package/build/dist/Tests/Server/API/Helpers.js +0 -27
  388. package/build/dist/Tests/Server/API/Helpers.js.map +0 -1
  389. package/build/dist/Tests/Server/API/ProbeAPI.test.js +0 -84
  390. package/build/dist/Tests/Server/API/ProbeAPI.test.js.map +0 -1
  391. package/build/dist/Tests/Server/API/ProjectAPI.test.js +0 -170
  392. package/build/dist/Tests/Server/API/ProjectAPI.test.js.map +0 -1
  393. package/build/dist/Tests/Server/API/UserSmsApi.test.js +0 -177
  394. package/build/dist/Tests/Server/API/UserSmsApi.test.js.map +0 -1
  395. package/build/dist/Tests/Server/Middleware/BearerTokenAuthorization.test.js +0 -63
  396. package/build/dist/Tests/Server/Middleware/BearerTokenAuthorization.test.js.map +0 -1
  397. package/build/dist/Tests/Server/Middleware/ClusterKeyAuthorization.test.js +0 -58
  398. package/build/dist/Tests/Server/Middleware/ClusterKeyAuthorization.test.js.map +0 -1
  399. package/build/dist/Tests/Server/Middleware/NotificationMiddleware.test.js +0 -101
  400. package/build/dist/Tests/Server/Middleware/NotificationMiddleware.test.js.map +0 -1
  401. package/build/dist/Tests/Server/Middleware/ProjectAuthorization.test.js +0 -160
  402. package/build/dist/Tests/Server/Middleware/ProjectAuthorization.test.js.map +0 -1
  403. package/build/dist/Tests/Server/Middleware/UserAuthorization.test.js +0 -410
  404. package/build/dist/Tests/Server/Middleware/UserAuthorization.test.js.map +0 -1
  405. package/build/dist/Tests/Server/Services/AlertEpisodeMemberService.test.js +0 -165
  406. package/build/dist/Tests/Server/Services/AlertEpisodeMemberService.test.js.map +0 -1
  407. package/build/dist/Tests/Server/Services/AlertEpisodeService.test.js +0 -193
  408. package/build/dist/Tests/Server/Services/AlertEpisodeService.test.js.map +0 -1
  409. package/build/dist/Tests/Server/Services/AlertGroupingEngineService.test.js +0 -435
  410. package/build/dist/Tests/Server/Services/AlertGroupingEngineService.test.js.map +0 -1
  411. package/build/dist/Tests/Server/Services/AlertGroupingRuleService.test.js +0 -320
  412. package/build/dist/Tests/Server/Services/AlertGroupingRuleService.test.js.map +0 -1
  413. package/build/dist/Tests/Server/Services/AnalyticsDatabaseService.test.js +0 -266
  414. package/build/dist/Tests/Server/Services/AnalyticsDatabaseService.test.js.map +0 -1
  415. package/build/dist/Tests/Server/Services/BillingService.test.js +0 -910
  416. package/build/dist/Tests/Server/Services/BillingService.test.js.map +0 -1
  417. package/build/dist/Tests/Server/Services/LogAggregationService.test.js +0 -75
  418. package/build/dist/Tests/Server/Services/LogAggregationService.test.js.map +0 -1
  419. package/build/dist/Tests/Server/Services/ProbeService.test.js +0 -127
  420. package/build/dist/Tests/Server/Services/ProbeService.test.js.map +0 -1
  421. package/build/dist/Tests/Server/Services/ScheduledMaintenanceService.test.js +0 -114
  422. package/build/dist/Tests/Server/Services/ScheduledMaintenanceService.test.js.map +0 -1
  423. package/build/dist/Tests/Server/Services/TeamMemberService.test.js +0 -106
  424. package/build/dist/Tests/Server/Services/TeamMemberService.test.js.map +0 -1
  425. package/build/dist/Tests/Server/Services/TelemetryAttributeService.test.js +0 -50
  426. package/build/dist/Tests/Server/Services/TelemetryAttributeService.test.js.map +0 -1
  427. package/build/dist/Tests/Server/TestingUtils/Init.js +0 -4
  428. package/build/dist/Tests/Server/TestingUtils/Init.js.map +0 -1
  429. package/build/dist/Tests/Server/TestingUtils/Postgres/TestDataSourceOptions.js +0 -9
  430. package/build/dist/Tests/Server/TestingUtils/Postgres/TestDataSourceOptions.js.map +0 -1
  431. package/build/dist/Tests/Server/TestingUtils/Redis/TestRedisOptions.js +0 -16
  432. package/build/dist/Tests/Server/TestingUtils/Redis/TestRedisOptions.js.map +0 -1
  433. package/build/dist/Tests/Server/TestingUtils/Services/BillingServiceHelper.js +0 -125
  434. package/build/dist/Tests/Server/TestingUtils/Services/BillingServiceHelper.js.map +0 -1
  435. package/build/dist/Tests/Server/TestingUtils/Services/ProjectServiceHelper.js +0 -39
  436. package/build/dist/Tests/Server/TestingUtils/Services/ProjectServiceHelper.js.map +0 -1
  437. package/build/dist/Tests/Server/TestingUtils/Services/ScheduledMaintenanceServiceHelper.js +0 -20
  438. package/build/dist/Tests/Server/TestingUtils/Services/ScheduledMaintenanceServiceHelper.js.map +0 -1
  439. package/build/dist/Tests/Server/TestingUtils/Services/ScheduledMaintenanceStateServiceHelper.js +0 -31
  440. package/build/dist/Tests/Server/TestingUtils/Services/ScheduledMaintenanceStateServiceHelper.js.map +0 -1
  441. package/build/dist/Tests/Server/TestingUtils/Services/TeamMemberServiceHelper.js +0 -14
  442. package/build/dist/Tests/Server/TestingUtils/Services/TeamMemberServiceHelper.js.map +0 -1
  443. package/build/dist/Tests/Server/TestingUtils/Services/TeamServiceHelper.js +0 -21
  444. package/build/dist/Tests/Server/TestingUtils/Services/TeamServiceHelper.js.map +0 -1
  445. package/build/dist/Tests/Server/TestingUtils/Services/Types.js +0 -2
  446. package/build/dist/Tests/Server/TestingUtils/Services/Types.js.map +0 -1
  447. package/build/dist/Tests/Server/TestingUtils/Services/UserServiceHelper.js +0 -37
  448. package/build/dist/Tests/Server/TestingUtils/Services/UserServiceHelper.js.map +0 -1
  449. package/build/dist/Tests/Server/TestingUtils/__mocks__/Stripe.mock.js +0 -13
  450. package/build/dist/Tests/Server/TestingUtils/__mocks__/Stripe.mock.js.map +0 -1
  451. package/build/dist/Tests/Server/TestingUtils/__mocks__/TestDatabase.mock.js +0 -22
  452. package/build/dist/Tests/Server/TestingUtils/__mocks__/TestDatabase.mock.js.map +0 -1
  453. package/build/dist/Tests/Server/Types/Domain.test.js +0 -78
  454. package/build/dist/Tests/Server/Types/Domain.test.js.map +0 -1
  455. package/build/dist/Tests/Server/Utils/AnalyticsDatabase/Statement.test.js +0 -94
  456. package/build/dist/Tests/Server/Utils/AnalyticsDatabase/Statement.test.js.map +0 -1
  457. package/build/dist/Tests/Server/Utils/AnalyticsDatabase/StatementGenerator.test.js +0 -459
  458. package/build/dist/Tests/Server/Utils/AnalyticsDatabase/StatementGenerator.test.js.map +0 -1
  459. package/build/dist/Tests/Server/Utils/Cookie.test.js +0 -83
  460. package/build/dist/Tests/Server/Utils/Cookie.test.js.map +0 -1
  461. package/build/dist/Tests/Server/Utils/CronTab.test.js +0 -29
  462. package/build/dist/Tests/Server/Utils/CronTab.test.js.map +0 -1
  463. package/build/dist/Tests/Server/Utils/JsonToCsv.test.js +0 -114
  464. package/build/dist/Tests/Server/Utils/JsonToCsv.test.js.map +0 -1
  465. package/build/dist/Tests/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.test.js +0 -606
  466. package/build/dist/Tests/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.test.js.map +0 -1
  467. package/build/dist/Tests/Server/Utils/Monitor/Criteria/SnmpMonitorCriteria.test.js +0 -255
  468. package/build/dist/Tests/Server/Utils/Monitor/Criteria/SnmpMonitorCriteria.test.js.map +0 -1
  469. package/build/dist/Tests/Server/Utils/Monitor/MonitorMaintenanceSuppression.test.js +0 -142
  470. package/build/dist/Tests/Server/Utils/Monitor/MonitorMaintenanceSuppression.test.js.map +0 -1
  471. package/build/dist/Tests/Server/Utils/StatusPageResource.test.js +0 -122
  472. package/build/dist/Tests/Server/Utils/StatusPageResource.test.js.map +0 -1
  473. package/build/dist/Tests/Server/Utils/Telemetry/LogExceptionExtractor.test.js +0 -0
  474. package/build/dist/Tests/Server/Utils/Telemetry/LogExceptionExtractor.test.js.map +0 -1
  475. package/build/dist/Tests/Server/Utils/VM/VMAPI.test.js +0 -205
  476. package/build/dist/Tests/Server/Utils/VM/VMAPI.test.js.map +0 -1
  477. package/build/dist/Tests/Spy.js +0 -4
  478. package/build/dist/Tests/Spy.js.map +0 -1
  479. package/build/dist/Tests/Types/API/ErrorResponse.test.js +0 -13
  480. package/build/dist/Tests/Types/API/ErrorResponse.test.js.map +0 -1
  481. package/build/dist/Tests/Types/API/HTTPErrorResponse.test.js +0 -33
  482. package/build/dist/Tests/Types/API/HTTPErrorResponse.test.js.map +0 -1
  483. package/build/dist/Tests/Types/API/HTTPMethod.test.js +0 -16
  484. package/build/dist/Tests/Types/API/HTTPMethod.test.js.map +0 -1
  485. package/build/dist/Tests/Types/API/Headers.test.js +0 -14
  486. package/build/dist/Tests/Types/API/Headers.test.js.map +0 -1
  487. package/build/dist/Tests/Types/API/Hostname.test.js +0 -22
  488. package/build/dist/Tests/Types/API/Hostname.test.js.map +0 -1
  489. package/build/dist/Tests/Types/API/Protocal.test.js +0 -19
  490. package/build/dist/Tests/Types/API/Protocal.test.js.map +0 -1
  491. package/build/dist/Tests/Types/API/Response.test.js +0 -14
  492. package/build/dist/Tests/Types/API/Response.test.js.map +0 -1
  493. package/build/dist/Tests/Types/API/ResponseType.test.js +0 -13
  494. package/build/dist/Tests/Types/API/ResponseType.test.js.map +0 -1
  495. package/build/dist/Tests/Types/API/Route.test.js +0 -30
  496. package/build/dist/Tests/Types/API/Route.test.js.map +0 -1
  497. package/build/dist/Tests/Types/API/StatusCode.test.js +0 -26
  498. package/build/dist/Tests/Types/API/StatusCode.test.js.map +0 -1
  499. package/build/dist/Tests/Types/API/URL.test.js +0 -33
  500. package/build/dist/Tests/Types/API/URL.test.js.map +0 -1
  501. package/build/dist/Tests/Types/Alerts/AlertEventType.test.js +0 -34
  502. package/build/dist/Tests/Types/Alerts/AlertEventType.test.js.map +0 -1
  503. package/build/dist/Tests/Types/Alerts/AlertType.test.js +0 -19
  504. package/build/dist/Tests/Types/Alerts/AlertType.test.js.map +0 -1
  505. package/build/dist/Tests/Types/AppEnvironment.test.js +0 -13
  506. package/build/dist/Tests/Types/AppEnvironment.test.js.map +0 -1
  507. package/build/dist/Tests/Types/ApplicationLog/ApplicationLogType.test.js +0 -13
  508. package/build/dist/Tests/Types/ApplicationLog/ApplicationLogType.test.js.map +0 -1
  509. package/build/dist/Tests/Types/ArrayUtil.test.js +0 -71
  510. package/build/dist/Tests/Types/ArrayUtil.test.js.map +0 -1
  511. package/build/dist/Tests/Types/Billing/SubscriptionPlan.test.js +0 -181
  512. package/build/dist/Tests/Types/Billing/SubscriptionPlan.test.js.map +0 -1
  513. package/build/dist/Tests/Types/BrandColors.test.js +0 -124
  514. package/build/dist/Tests/Types/BrandColors.test.js.map +0 -1
  515. package/build/dist/Tests/Types/Char.test.js +0 -82
  516. package/build/dist/Tests/Types/Char.test.js.map +0 -1
  517. package/build/dist/Tests/Types/Code/CodeType.test.js +0 -13
  518. package/build/dist/Tests/Types/Code/CodeType.test.js.map +0 -1
  519. package/build/dist/Tests/Types/Color.test.js +0 -44
  520. package/build/dist/Tests/Types/Color.test.js.map +0 -1
  521. package/build/dist/Tests/Types/Company/CompanySize.test.js +0 -20
  522. package/build/dist/Tests/Types/Company/CompanySize.test.js.map +0 -1
  523. package/build/dist/Tests/Types/Company/JobRole.test.js +0 -22
  524. package/build/dist/Tests/Types/Company/JobRole.test.js.map +0 -1
  525. package/build/dist/Tests/Types/Countries.test.js +0 -249
  526. package/build/dist/Tests/Types/Countries.test.js.map +0 -1
  527. package/build/dist/Tests/Types/Database/ColumnLength.test.js +0 -43
  528. package/build/dist/Tests/Types/Database/ColumnLength.test.js.map +0 -1
  529. package/build/dist/Tests/Types/Database/ColumnType.test.js +0 -79
  530. package/build/dist/Tests/Types/Database/ColumnType.test.js.map +0 -1
  531. package/build/dist/Tests/Types/Database/Columns.test.js +0 -20
  532. package/build/dist/Tests/Types/Database/Columns.test.js.map +0 -1
  533. package/build/dist/Tests/Types/Database/CompareBase.test.js +0 -37
  534. package/build/dist/Tests/Types/Database/CompareBase.test.js.map +0 -1
  535. package/build/dist/Tests/Types/Database/Date.test.js +0 -62
  536. package/build/dist/Tests/Types/Database/Date.test.js.map +0 -1
  537. package/build/dist/Tests/Types/Database/EqualTo.test.js +0 -65
  538. package/build/dist/Tests/Types/Database/EqualTo.test.js.map +0 -1
  539. package/build/dist/Tests/Types/Database/EqualToOrNull.test.js +0 -62
  540. package/build/dist/Tests/Types/Database/EqualToOrNull.test.js.map +0 -1
  541. package/build/dist/Tests/Types/Database/InBetween.test.js +0 -72
  542. package/build/dist/Tests/Types/Database/InBetween.test.js.map +0 -1
  543. package/build/dist/Tests/Types/Database/LimitMax.test.js +0 -18
  544. package/build/dist/Tests/Types/Database/LimitMax.test.js.map +0 -1
  545. package/build/dist/Tests/Types/Database/NotEqual.test.js +0 -19
  546. package/build/dist/Tests/Types/Database/NotEqual.test.js.map +0 -1
  547. package/build/dist/Tests/Types/Database/Search.test.js +0 -10
  548. package/build/dist/Tests/Types/Database/Search.test.js.map +0 -1
  549. package/build/dist/Tests/Types/DatabaseType.test.js +0 -7
  550. package/build/dist/Tests/Types/DatabaseType.test.js.map +0 -1
  551. package/build/dist/Tests/Types/Date.test.js +0 -194
  552. package/build/dist/Tests/Types/Date.test.js.map +0 -1
  553. package/build/dist/Tests/Types/Dictionary.test.js +0 -25
  554. package/build/dist/Tests/Types/Dictionary.test.js.map +0 -1
  555. package/build/dist/Tests/Types/Domain.test.js +0 -54
  556. package/build/dist/Tests/Types/Domain.test.js.map +0 -1
  557. package/build/dist/Tests/Types/Email/Email.test.js +0 -51
  558. package/build/dist/Tests/Types/Email/Email.test.js.map +0 -1
  559. package/build/dist/Tests/Types/EmailWithName.test.js +0 -36
  560. package/build/dist/Tests/Types/EmailWithName.test.js.map +0 -1
  561. package/build/dist/Tests/Types/EncryptionAlgorithm.test.js +0 -7
  562. package/build/dist/Tests/Types/EncryptionAlgorithm.test.js.map +0 -1
  563. package/build/dist/Tests/Types/Exception/ApiException.test.js +0 -10
  564. package/build/dist/Tests/Types/Exception/ApiException.test.js.map +0 -1
  565. package/build/dist/Tests/Types/Exception/BadDataException.test.js +0 -12
  566. package/build/dist/Tests/Types/Exception/BadDataException.test.js.map +0 -1
  567. package/build/dist/Tests/Types/Exception/BadOperationException.test.js +0 -10
  568. package/build/dist/Tests/Types/Exception/BadOperationException.test.js.map +0 -1
  569. package/build/dist/Tests/Types/Exception/BadRequestException.test.js +0 -12
  570. package/build/dist/Tests/Types/Exception/BadRequestException.test.js.map +0 -1
  571. package/build/dist/Tests/Types/Exception/DatabaseNotConnectedException.test.js +0 -10
  572. package/build/dist/Tests/Types/Exception/DatabaseNotConnectedException.test.js.map +0 -1
  573. package/build/dist/Tests/Types/Exception/Exception.test.js +0 -15
  574. package/build/dist/Tests/Types/Exception/Exception.test.js.map +0 -1
  575. package/build/dist/Tests/Types/Exception/NotImplementedException.test.js +0 -12
  576. package/build/dist/Tests/Types/Exception/NotImplementedException.test.js.map +0 -1
  577. package/build/dist/Tests/Types/File.test.js +0 -22
  578. package/build/dist/Tests/Types/File.test.js.map +0 -1
  579. package/build/dist/Tests/Types/HashedString.test.js +0 -51
  580. package/build/dist/Tests/Types/HashedString.test.js.map +0 -1
  581. package/build/dist/Tests/Types/Html.test.js +0 -8
  582. package/build/dist/Tests/Types/Html.test.js.map +0 -1
  583. package/build/dist/Tests/Types/IP/IP.test.js +0 -65
  584. package/build/dist/Tests/Types/IP/IP.test.js.map +0 -1
  585. package/build/dist/Tests/Types/IP/IPType.test.js +0 -10
  586. package/build/dist/Tests/Types/IP/IPType.test.js.map +0 -1
  587. package/build/dist/Tests/Types/IP/IPv4.test.js +0 -17
  588. package/build/dist/Tests/Types/IP/IPv4.test.js.map +0 -1
  589. package/build/dist/Tests/Types/IP/IPv6.test.js +0 -17
  590. package/build/dist/Tests/Types/IP/IPv6.test.js.map +0 -1
  591. package/build/dist/Tests/Types/JSON.test.js +0 -37
  592. package/build/dist/Tests/Types/JSON.test.js.map +0 -1
  593. package/build/dist/Tests/Types/JSONFunctions.test.js +0 -38
  594. package/build/dist/Tests/Types/JSONFunctions.test.js.map +0 -1
  595. package/build/dist/Tests/Types/ListData.test.js +0 -34
  596. package/build/dist/Tests/Types/ListData.test.js.map +0 -1
  597. package/build/dist/Tests/Types/Monitor/KubernetesAlertTemplates.test.js +0 -121
  598. package/build/dist/Tests/Types/Monitor/KubernetesAlertTemplates.test.js.map +0 -1
  599. package/build/dist/Tests/Types/Name.test.js +0 -26
  600. package/build/dist/Tests/Types/Name.test.js.map +0 -1
  601. package/build/dist/Tests/Types/ObjectID.test.js +0 -12
  602. package/build/dist/Tests/Types/ObjectID.test.js.map +0 -1
  603. package/build/dist/Tests/Types/OnCallDutyPolicy/LayerUtil.test.js +0 -530
  604. package/build/dist/Tests/Types/OnCallDutyPolicy/LayerUtil.test.js.map +0 -1
  605. package/build/dist/Tests/Types/Permission.test.js +0 -99
  606. package/build/dist/Tests/Types/Permission.test.js.map +0 -1
  607. package/build/dist/Tests/Types/Phone.test.js +0 -37
  608. package/build/dist/Tests/Types/Phone.test.js.map +0 -1
  609. package/build/dist/Tests/Types/Port.test.js +0 -35
  610. package/build/dist/Tests/Types/Port.test.js.map +0 -1
  611. package/build/dist/Tests/Types/PositiveNumber.test.js +0 -101
  612. package/build/dist/Tests/Types/PositiveNumber.test.js.map +0 -1
  613. package/build/dist/Tests/Types/SecuritySeverity.test.js +0 -16
  614. package/build/dist/Tests/Types/SecuritySeverity.test.js.map +0 -1
  615. package/build/dist/Tests/Types/SerializableObject.test.js +0 -37
  616. package/build/dist/Tests/Types/SerializableObject.test.js.map +0 -1
  617. package/build/dist/Tests/Types/Sleep.test.js +0 -14
  618. package/build/dist/Tests/Types/Sleep.test.js.map +0 -1
  619. package/build/dist/Tests/Types/Text.test.js +0 -8
  620. package/build/dist/Tests/Types/Text.test.js.map +0 -1
  621. package/build/dist/Tests/Types/Timezone.test.js +0 -596
  622. package/build/dist/Tests/Types/Timezone.test.js.map +0 -1
  623. package/build/dist/Tests/Types/Typeof.test.js +0 -16
  624. package/build/dist/Tests/Types/Typeof.test.js.map +0 -1
  625. package/build/dist/Tests/Types/UserType.test.js +0 -16
  626. package/build/dist/Tests/Types/UserType.test.js.map +0 -1
  627. package/build/dist/Tests/Types/Version.test.js +0 -35
  628. package/build/dist/Tests/Types/Version.test.js.map +0 -1
  629. package/build/dist/Tests/Types/XML.test.js +0 -35
  630. package/build/dist/Tests/Types/XML.test.js.map +0 -1
  631. package/build/dist/Tests/UI/Components/404.test.js +0 -59
  632. package/build/dist/Tests/UI/Components/404.test.js.map +0 -1
  633. package/build/dist/Tests/UI/Components/Alert.test.js +0 -83
  634. package/build/dist/Tests/UI/Components/Alert.test.js.map +0 -1
  635. package/build/dist/Tests/UI/Components/Badge.test.js +0 -59
  636. package/build/dist/Tests/UI/Components/Badge.test.js.map +0 -1
  637. package/build/dist/Tests/UI/Components/BasicForm.test.js +0 -92
  638. package/build/dist/Tests/UI/Components/BasicForm.test.js.map +0 -1
  639. package/build/dist/Tests/UI/Components/Breadcrumbs.test.js +0 -69
  640. package/build/dist/Tests/UI/Components/Breadcrumbs.test.js.map +0 -1
  641. package/build/dist/Tests/UI/Components/Button.test.js +0 -104
  642. package/build/dist/Tests/UI/Components/Button.test.js.map +0 -1
  643. package/build/dist/Tests/UI/Components/Card.test.js +0 -81
  644. package/build/dist/Tests/UI/Components/Card.test.js.map +0 -1
  645. package/build/dist/Tests/UI/Components/ColorViewer.test.js +0 -42
  646. package/build/dist/Tests/UI/Components/ColorViewer.test.js.map +0 -1
  647. package/build/dist/Tests/UI/Components/ComponentsModal.test.js +0 -233
  648. package/build/dist/Tests/UI/Components/ComponentsModal.test.js.map +0 -1
  649. package/build/dist/Tests/UI/Components/ConfirmModal.test.js +0 -57
  650. package/build/dist/Tests/UI/Components/ConfirmModal.test.js.map +0 -1
  651. package/build/dist/Tests/UI/Components/DictionaryOfStrings.test.js +0 -84
  652. package/build/dist/Tests/UI/Components/DictionaryOfStrings.test.js.map +0 -1
  653. package/build/dist/Tests/UI/Components/Dropdown.test.js +0 -146
  654. package/build/dist/Tests/UI/Components/Dropdown.test.js.map +0 -1
  655. package/build/dist/Tests/UI/Components/DuplicateModel.test.js +0 -229
  656. package/build/dist/Tests/UI/Components/DuplicateModel.test.js.map +0 -1
  657. package/build/dist/Tests/UI/Components/EmptyState/EmptyState.test.js +0 -26
  658. package/build/dist/Tests/UI/Components/EmptyState/EmptyState.test.js.map +0 -1
  659. package/build/dist/Tests/UI/Components/ErrorBoundary.test.js +0 -32
  660. package/build/dist/Tests/UI/Components/ErrorBoundary.test.js.map +0 -1
  661. package/build/dist/Tests/UI/Components/FilePicker.test.js +0 -342
  662. package/build/dist/Tests/UI/Components/FilePicker.test.js.map +0 -1
  663. package/build/dist/Tests/UI/Components/HiddenText.test.js +0 -50
  664. package/build/dist/Tests/UI/Components/HiddenText.test.js.map +0 -1
  665. package/build/dist/Tests/UI/Components/Input.test.js +0 -223
  666. package/build/dist/Tests/UI/Components/Input.test.js.map +0 -1
  667. package/build/dist/Tests/UI/Components/Item.test.js +0 -58
  668. package/build/dist/Tests/UI/Components/Item.test.js.map +0 -1
  669. package/build/dist/Tests/UI/Components/List.test.js +0 -83
  670. package/build/dist/Tests/UI/Components/List.test.js.map +0 -1
  671. package/build/dist/Tests/UI/Components/Loader.test.js +0 -19
  672. package/build/dist/Tests/UI/Components/Loader.test.js.map +0 -1
  673. package/build/dist/Tests/UI/Components/MarkdownEditor.test.js +0 -85
  674. package/build/dist/Tests/UI/Components/MarkdownEditor.test.js.map +0 -1
  675. package/build/dist/Tests/UI/Components/MasterPage.test.js +0 -46
  676. package/build/dist/Tests/UI/Components/MasterPage.test.js.map +0 -1
  677. package/build/dist/Tests/UI/Components/Modal.test.js +0 -127
  678. package/build/dist/Tests/UI/Components/Modal.test.js.map +0 -1
  679. package/build/dist/Tests/UI/Components/NavBar.test.js +0 -52
  680. package/build/dist/Tests/UI/Components/NavBar.test.js.map +0 -1
  681. package/build/dist/Tests/UI/Components/OrderedStatesList.test.js +0 -86
  682. package/build/dist/Tests/UI/Components/OrderedStatesList.test.js.map +0 -1
  683. package/build/dist/Tests/UI/Components/Pagination.test.js +0 -137
  684. package/build/dist/Tests/UI/Components/Pagination.test.js.map +0 -1
  685. package/build/dist/Tests/UI/Components/Pill.test.js +0 -55
  686. package/build/dist/Tests/UI/Components/Pill.test.js.map +0 -1
  687. package/build/dist/Tests/UI/Components/Probe.test.js +0 -52
  688. package/build/dist/Tests/UI/Components/Probe.test.js.map +0 -1
  689. package/build/dist/Tests/UI/Components/ProgressBar.test.js +0 -41
  690. package/build/dist/Tests/UI/Components/ProgressBar.test.js.map +0 -1
  691. package/build/dist/Tests/UI/Components/RadioButtons.test.js +0 -66
  692. package/build/dist/Tests/UI/Components/RadioButtons.test.js.map +0 -1
  693. package/build/dist/Tests/UI/Components/SideMenuItem.test.js +0 -99
  694. package/build/dist/Tests/UI/Components/SideMenuItem.test.js.map +0 -1
  695. package/build/dist/Tests/UI/Components/SideOver.test.js +0 -77
  696. package/build/dist/Tests/UI/Components/SideOver.test.js.map +0 -1
  697. package/build/dist/Tests/UI/Components/Tabs.test.js +0 -56
  698. package/build/dist/Tests/UI/Components/Tabs.test.js.map +0 -1
  699. package/build/dist/Tests/UI/Components/Template/Template.test.js +0 -15
  700. package/build/dist/Tests/UI/Components/Template/Template.test.js.map +0 -1
  701. package/build/dist/Tests/UI/Components/TextArea.test.js +0 -112
  702. package/build/dist/Tests/UI/Components/TextArea.test.js.map +0 -1
  703. package/build/dist/Tests/UI/Components/TimePicker/TimePicker.test.js +0 -352
  704. package/build/dist/Tests/UI/Components/TimePicker/TimePicker.test.js.map +0 -1
  705. package/build/dist/Tests/UI/Components/Toast.test.js +0 -48
  706. package/build/dist/Tests/UI/Components/Toast.test.js.map +0 -1
  707. package/build/dist/Tests/UI/Components/Toggle.test.js +0 -95
  708. package/build/dist/Tests/UI/Components/Toggle.test.js.map +0 -1
  709. package/build/dist/Tests/UI/Components/TopSection.test.js +0 -33
  710. package/build/dist/Tests/UI/Components/TopSection.test.js.map +0 -1
  711. package/build/dist/Tests/UI/Components/XAxis.test.js +0 -21
  712. package/build/dist/Tests/UI/Components/XAxis.test.js.map +0 -1
  713. package/build/dist/Tests/UI/Index.js +0 -2
  714. package/build/dist/Tests/UI/Index.js.map +0 -1
  715. package/build/dist/Tests/UI/Mocks/FileMock.js +0 -3
  716. package/build/dist/Tests/UI/Mocks/FileMock.js.map +0 -1
  717. package/build/dist/Tests/Utils/API.test.js +0 -399
  718. package/build/dist/Tests/Utils/API.test.js.map +0 -1
  719. package/build/dist/Tests/Utils/Analytics.test.js +0 -67
  720. package/build/dist/Tests/Utils/Analytics.test.js.map +0 -1
  721. package/build/dist/Tests/Utils/CronTime.test.js +0 -22
  722. package/build/dist/Tests/Utils/CronTime.test.js.map +0 -1
  723. package/build/dist/Tests/Utils/Faker.test.js +0 -27
  724. package/build/dist/Tests/Utils/Faker.test.js.map +0 -1
  725. package/build/dist/Tests/Utils/MetricUnitUtil.test.js +0 -187
  726. package/build/dist/Tests/Utils/MetricUnitUtil.test.js.map +0 -1
  727. package/build/dist/Tests/Utils/Metrics/MetricFormulaEvaluator.test.js +0 -224
  728. package/build/dist/Tests/Utils/Metrics/MetricFormulaEvaluator.test.js.map +0 -1
  729. package/build/dist/Tests/Utils/Metrics/MetricResultUnitConverter.test.js +0 -180
  730. package/build/dist/Tests/Utils/Metrics/MetricResultUnitConverter.test.js.map +0 -1
  731. package/build/dist/Tests/Utils/RecordingRuleExpression.test.js +0 -142
  732. package/build/dist/Tests/Utils/RecordingRuleExpression.test.js.map +0 -1
  733. package/build/dist/Tests/Utils/Slug.test.js +0 -20
  734. package/build/dist/Tests/Utils/Slug.test.js.map +0 -1
  735. package/build/dist/Tests/Utils/UUID.test.js +0 -48
  736. package/build/dist/Tests/Utils/UUID.test.js.map +0 -1
  737. package/build/dist/Tests/jest.setup.js +0 -30
  738. package/build/dist/Tests/jest.setup.js.map +0 -1
  739. package/build/dist/Types/Profile/ProfileMetricType.js +0 -17
  740. package/build/dist/Types/Profile/ProfileMetricType.js.map +0 -1
@@ -0,0 +1,275 @@
1
+ import Includes from "../../../Types/BaseDatabase/Includes";
2
+ import Query from "../../../Types/BaseDatabase/Query";
3
+ import Log from "../../../Models/AnalyticsModels/Log";
4
+ import Span from "../../../Models/AnalyticsModels/Span";
5
+ import ExceptionInstance from "../../../Models/AnalyticsModels/ExceptionInstance";
6
+ import Profile from "../../../Models/AnalyticsModels/Profile";
7
+ import Metric from "../../../Models/AnalyticsModels/Metric";
8
+ import MonitorStepLogMonitor, {
9
+ MonitorStepLogMonitorUtil,
10
+ } from "../../../Types/Monitor/MonitorStepLogMonitor";
11
+ import MonitorStepTraceMonitor, {
12
+ MonitorStepTraceMonitorUtil,
13
+ } from "../../../Types/Monitor/MonitorStepTraceMonitor";
14
+ import MonitorStepExceptionMonitor, {
15
+ MonitorStepExceptionMonitorUtil,
16
+ } from "../../../Types/Monitor/MonitorStepExceptionMonitor";
17
+ import MonitorStepProfileMonitor, {
18
+ MonitorStepProfileMonitorUtil,
19
+ } from "../../../Types/Monitor/MonitorStepProfileMonitor";
20
+ import MonitorStepMetricMonitor, {
21
+ MonitorStepMetricMonitorUtil,
22
+ } from "../../../Types/Monitor/MonitorStepMetricMonitor";
23
+ import { JSONObject } from "../../../Types/JSON";
24
+
25
+ /*
26
+ * Entity scoping on telemetry monitor steps (entityKeys -> hasAny membership
27
+ * predicate). The contract these tests lock in:
28
+ *
29
+ * 1. Backward compatibility — monitors saved before the field existed
30
+ * deserialize with no entityKeys (or an empty array), and the query
31
+ * compile treats undefined/empty as a strict no-op (no `entityKeys`
32
+ * predicate in the generated Query<Model>).
33
+ * 2. When 1+ keys are present, the compile emits an Includes on the
34
+ * `entityKeys` column, which StatementGenerator turns into
35
+ * hasAny(entityKeys, [...]) for Array(String) columns.
36
+ */
37
+
38
+ const TWO_KEYS: Array<string> = ["a1b2c3d4e5f60708", "1122334455667788"];
39
+
40
+ type ExpectIncludesFunction = (
41
+ value: unknown,
42
+ expectedKeys: Array<string>,
43
+ ) => void;
44
+
45
+ const expectIncludes: ExpectIncludesFunction = (
46
+ value: unknown,
47
+ expectedKeys: Array<string>,
48
+ ): void => {
49
+ expect(value).toBeInstanceOf(Includes);
50
+ expect((value as Includes).values).toEqual(expectedKeys);
51
+ };
52
+
53
+ describe("MonitorStepLogMonitorUtil.toQuery entity scoping", () => {
54
+ test("omits entityKeys predicate when field is undefined (pre-existing saved monitors)", () => {
55
+ const step: MonitorStepLogMonitor = MonitorStepLogMonitorUtil.getDefault();
56
+ delete step.entityKeys;
57
+
58
+ const query: Query<Log> = MonitorStepLogMonitorUtil.toQuery(step);
59
+
60
+ expect(query.entityKeys).toBeUndefined();
61
+ expect(Object.keys(query)).not.toContain("entityKeys");
62
+ });
63
+
64
+ test("omits entityKeys predicate when field is an empty array", () => {
65
+ const step: MonitorStepLogMonitor = MonitorStepLogMonitorUtil.getDefault();
66
+ step.entityKeys = [];
67
+
68
+ const query: Query<Log> = MonitorStepLogMonitorUtil.toQuery(step);
69
+
70
+ expect(query.entityKeys).toBeUndefined();
71
+ });
72
+
73
+ test("compiles two entity keys to an Includes on entityKeys", () => {
74
+ const step: MonitorStepLogMonitor = MonitorStepLogMonitorUtil.getDefault();
75
+ step.entityKeys = TWO_KEYS;
76
+
77
+ const query: Query<Log> = MonitorStepLogMonitorUtil.toQuery(step);
78
+
79
+ expectIncludes(query.entityKeys, TWO_KEYS);
80
+ });
81
+
82
+ test("fromJSON tolerates legacy JSON without entityKeys and round-trips keys", () => {
83
+ const legacyJson: JSONObject = MonitorStepLogMonitorUtil.toJSON(
84
+ MonitorStepLogMonitorUtil.getDefault(),
85
+ );
86
+ delete legacyJson["entityKeys"];
87
+
88
+ const legacyStep: MonitorStepLogMonitor =
89
+ MonitorStepLogMonitorUtil.fromJSON(legacyJson);
90
+ expect(legacyStep.entityKeys).toEqual([]);
91
+
92
+ const stepWithKeys: MonitorStepLogMonitor =
93
+ MonitorStepLogMonitorUtil.getDefault();
94
+ stepWithKeys.entityKeys = TWO_KEYS;
95
+
96
+ const roundTripped: MonitorStepLogMonitor =
97
+ MonitorStepLogMonitorUtil.fromJSON(
98
+ MonitorStepLogMonitorUtil.toJSON(stepWithKeys),
99
+ );
100
+ expect(roundTripped.entityKeys).toEqual(TWO_KEYS);
101
+ });
102
+ });
103
+
104
+ describe("MonitorStepTraceMonitorUtil.toQuery entity scoping", () => {
105
+ test("omits entityKeys predicate when field is undefined", () => {
106
+ const step: MonitorStepTraceMonitor =
107
+ MonitorStepTraceMonitorUtil.getDefault();
108
+ delete step.entityKeys;
109
+
110
+ const query: Query<Span> = MonitorStepTraceMonitorUtil.toQuery(step);
111
+
112
+ expect(query.entityKeys).toBeUndefined();
113
+ });
114
+
115
+ test("omits entityKeys predicate when field is an empty array", () => {
116
+ const step: MonitorStepTraceMonitor =
117
+ MonitorStepTraceMonitorUtil.getDefault();
118
+ step.entityKeys = [];
119
+
120
+ const query: Query<Span> = MonitorStepTraceMonitorUtil.toQuery(step);
121
+
122
+ expect(query.entityKeys).toBeUndefined();
123
+ });
124
+
125
+ test("compiles two entity keys to an Includes on entityKeys", () => {
126
+ const step: MonitorStepTraceMonitor =
127
+ MonitorStepTraceMonitorUtil.getDefault();
128
+ step.entityKeys = TWO_KEYS;
129
+
130
+ const query: Query<Span> = MonitorStepTraceMonitorUtil.toQuery(step);
131
+
132
+ expectIncludes(query.entityKeys, TWO_KEYS);
133
+ });
134
+
135
+ test("fromJSON tolerates legacy JSON without entityKeys", () => {
136
+ const legacyJson: JSONObject = MonitorStepTraceMonitorUtil.toJSON(
137
+ MonitorStepTraceMonitorUtil.getDefault(),
138
+ );
139
+ delete legacyJson["entityKeys"];
140
+
141
+ const legacyStep: MonitorStepTraceMonitor =
142
+ MonitorStepTraceMonitorUtil.fromJSON(legacyJson);
143
+ expect(legacyStep.entityKeys).toEqual([]);
144
+ });
145
+ });
146
+
147
+ describe("MonitorStepExceptionMonitorUtil.toAnalyticsQuery entity scoping", () => {
148
+ test("omits entityKeys predicate when field is undefined", () => {
149
+ const step: MonitorStepExceptionMonitor =
150
+ MonitorStepExceptionMonitorUtil.getDefault();
151
+ delete step.entityKeys;
152
+
153
+ const query: Query<ExceptionInstance> =
154
+ MonitorStepExceptionMonitorUtil.toAnalyticsQuery(step);
155
+
156
+ expect(query.entityKeys).toBeUndefined();
157
+ });
158
+
159
+ test("omits entityKeys predicate when field is an empty array", () => {
160
+ const step: MonitorStepExceptionMonitor =
161
+ MonitorStepExceptionMonitorUtil.getDefault();
162
+ step.entityKeys = [];
163
+
164
+ const query: Query<ExceptionInstance> =
165
+ MonitorStepExceptionMonitorUtil.toAnalyticsQuery(step);
166
+
167
+ expect(query.entityKeys).toBeUndefined();
168
+ });
169
+
170
+ test("compiles two entity keys to an Includes on entityKeys", () => {
171
+ const step: MonitorStepExceptionMonitor =
172
+ MonitorStepExceptionMonitorUtil.getDefault();
173
+ step.entityKeys = TWO_KEYS;
174
+
175
+ const query: Query<ExceptionInstance> =
176
+ MonitorStepExceptionMonitorUtil.toAnalyticsQuery(step);
177
+
178
+ expectIncludes(query.entityKeys, TWO_KEYS);
179
+ });
180
+
181
+ test("fromJSON tolerates legacy JSON without entityKeys", () => {
182
+ const legacyJson: JSONObject = MonitorStepExceptionMonitorUtil.toJSON(
183
+ MonitorStepExceptionMonitorUtil.getDefault(),
184
+ );
185
+ delete legacyJson["entityKeys"];
186
+
187
+ const legacyStep: MonitorStepExceptionMonitor =
188
+ MonitorStepExceptionMonitorUtil.fromJSON(legacyJson);
189
+ expect(legacyStep.entityKeys).toEqual([]);
190
+ });
191
+ });
192
+
193
+ describe("MonitorStepProfileMonitorUtil.toQuery entity scoping", () => {
194
+ test("omits entityKeys predicate when field is undefined", () => {
195
+ const step: MonitorStepProfileMonitor =
196
+ MonitorStepProfileMonitorUtil.getDefault();
197
+ delete step.entityKeys;
198
+
199
+ const query: Query<Profile> = MonitorStepProfileMonitorUtil.toQuery(step);
200
+
201
+ expect(query.entityKeys).toBeUndefined();
202
+ });
203
+
204
+ test("omits entityKeys predicate when field is an empty array", () => {
205
+ const step: MonitorStepProfileMonitor =
206
+ MonitorStepProfileMonitorUtil.getDefault();
207
+ step.entityKeys = [];
208
+
209
+ const query: Query<Profile> = MonitorStepProfileMonitorUtil.toQuery(step);
210
+
211
+ expect(query.entityKeys).toBeUndefined();
212
+ });
213
+
214
+ test("compiles two entity keys to an Includes on entityKeys", () => {
215
+ const step: MonitorStepProfileMonitor =
216
+ MonitorStepProfileMonitorUtil.getDefault();
217
+ step.entityKeys = TWO_KEYS;
218
+
219
+ const query: Query<Profile> = MonitorStepProfileMonitorUtil.toQuery(step);
220
+
221
+ expectIncludes(query.entityKeys, TWO_KEYS);
222
+ });
223
+ });
224
+
225
+ describe("MonitorStepMetricMonitorUtil.applyEntityScopeToQuery", () => {
226
+ test("is a no-op when entityKeys is undefined (pre-existing saved monitors)", () => {
227
+ const step: MonitorStepMetricMonitor =
228
+ MonitorStepMetricMonitorUtil.getDefault();
229
+ delete step.entityKeys;
230
+
231
+ const query: Query<Metric> = {};
232
+ MonitorStepMetricMonitorUtil.applyEntityScopeToQuery(query, step);
233
+
234
+ expect(query.entityKeys).toBeUndefined();
235
+ expect(Object.keys(query)).toHaveLength(0);
236
+ });
237
+
238
+ test("is a no-op when entityKeys is an empty array", () => {
239
+ const step: MonitorStepMetricMonitor =
240
+ MonitorStepMetricMonitorUtil.getDefault();
241
+ step.entityKeys = [];
242
+
243
+ const query: Query<Metric> = {};
244
+ MonitorStepMetricMonitorUtil.applyEntityScopeToQuery(query, step);
245
+
246
+ expect(query.entityKeys).toBeUndefined();
247
+ });
248
+
249
+ test("stamps an Includes on entityKeys for two keys and preserves other predicates", () => {
250
+ const step: MonitorStepMetricMonitor =
251
+ MonitorStepMetricMonitorUtil.getDefault();
252
+ step.entityKeys = TWO_KEYS;
253
+
254
+ const query: Query<Metric> = { name: "cpu.usage" };
255
+ const returned: Query<Metric> =
256
+ MonitorStepMetricMonitorUtil.applyEntityScopeToQuery(query, step);
257
+
258
+ expect(returned).toBe(query);
259
+ expect(query.name).toBe("cpu.usage");
260
+ expectIncludes(query.entityKeys, TWO_KEYS);
261
+ });
262
+
263
+ test("fromJSON preserves entityKeys (pass-through serialization)", () => {
264
+ const step: MonitorStepMetricMonitor =
265
+ MonitorStepMetricMonitorUtil.getDefault();
266
+ step.entityKeys = TWO_KEYS;
267
+
268
+ const roundTripped: MonitorStepMetricMonitor =
269
+ MonitorStepMetricMonitorUtil.fromJSON(
270
+ MonitorStepMetricMonitorUtil.toJSON(step),
271
+ );
272
+
273
+ expect(roundTripped.entityKeys).toEqual(TWO_KEYS);
274
+ });
275
+ });
@@ -5,4 +5,56 @@ describe("class Text", () => {
5
5
  expect(Text.uppercaseFirstLetter("text")).toEqual("Text");
6
6
  expect(Text.uppercaseFirstLetter("another test")).toEqual("Another test");
7
7
  });
8
+
9
+ describe("Text.convertOtlpIdToHex", () => {
10
+ test("passes 32-char hex trace ids through, normalised to lowercase", () => {
11
+ const hexTraceId: string = "4BF92F3577B34DA6A3CE929D0E0E4736";
12
+ expect(Text.convertOtlpIdToHex(hexTraceId)).toEqual(
13
+ "4bf92f3577b34da6a3ce929d0e0e4736",
14
+ );
15
+ expect(
16
+ Text.convertOtlpIdToHex("4bf92f3577b34da6a3ce929d0e0e4736"),
17
+ ).toEqual("4bf92f3577b34da6a3ce929d0e0e4736");
18
+ });
19
+
20
+ test("passes 16-char hex span ids through, normalised to lowercase", () => {
21
+ expect(Text.convertOtlpIdToHex("00F067AA0BA902B7")).toEqual(
22
+ "00f067aa0ba902b7",
23
+ );
24
+ });
25
+
26
+ test("decodes base64 ids (the OTLP/protobuf wire form) to hex", () => {
27
+ // 16-byte trace id -> 24-char base64 -> 32-char hex
28
+ const traceIdBytes: Buffer = Buffer.from(
29
+ "4bf92f3577b34da6a3ce929d0e0e4736",
30
+ "hex",
31
+ );
32
+ expect(Text.convertOtlpIdToHex(traceIdBytes.toString("base64"))).toEqual(
33
+ "4bf92f3577b34da6a3ce929d0e0e4736",
34
+ );
35
+
36
+ // 8-byte span id -> 12-char base64 -> 16-char hex
37
+ const spanIdBytes: Buffer = Buffer.from("00f067aa0ba902b7", "hex");
38
+ expect(Text.convertOtlpIdToHex(spanIdBytes.toString("base64"))).toEqual(
39
+ "00f067aa0ba902b7",
40
+ );
41
+ });
42
+
43
+ test("returns empty string for missing ids", () => {
44
+ expect(Text.convertOtlpIdToHex(undefined)).toEqual("");
45
+ expect(Text.convertOtlpIdToHex("")).toEqual("");
46
+ });
47
+
48
+ test("hex detection requires the exact id lengths — other hex-looking strings still take the base64 path", () => {
49
+ /*
50
+ * A 24-char hex-only string is a valid base64 payload and is NOT
51
+ * an OTLP hex id (ids are exactly 16 or 32 chars), so it must be
52
+ * treated as base64 — same behaviour as convertBase64ToHex.
53
+ */
54
+ const ambiguous: string = "abcdefabcdefabcdefabcdef";
55
+ expect(Text.convertOtlpIdToHex(ambiguous)).toEqual(
56
+ Text.convertBase64ToHex(ambiguous),
57
+ );
58
+ });
59
+ });
8
60
  });
@@ -0,0 +1,366 @@
1
+ import Dashboard from "../../Models/DatabaseModels/Dashboard";
2
+ import Monitor from "../../Models/DatabaseModels/Monitor";
3
+ import ScheduledMaintenanceTemplate from "../../Models/DatabaseModels/ScheduledMaintenanceTemplate";
4
+ import StatusPage from "../../Models/DatabaseModels/StatusPage";
5
+ import EventInterval from "../../Types/Events/EventInterval";
6
+ import Recurring from "../../Types/Events/Recurring";
7
+ import BadDataException from "../../Types/Exception/BadDataException";
8
+ import { JSONObject } from "../../Types/JSON";
9
+ import ObjectID from "../../Types/ObjectID";
10
+ import PositiveNumber from "../../Types/PositiveNumber";
11
+ import ModelImportExport, {
12
+ MODEL_EXPORT_FILE_TYPE,
13
+ MODEL_EXPORT_SCHEMA_VERSION,
14
+ } from "../../Utils/ModelImportExport";
15
+ import { describe, expect, test } from "@jest/globals";
16
+
17
+ describe("ModelImportExport", () => {
18
+ describe("getImportExportableColumnNames", () => {
19
+ test("should include user-editable configuration columns for Dashboard", () => {
20
+ const columns: Array<string> =
21
+ ModelImportExport.getImportExportableColumnNames(Dashboard);
22
+
23
+ expect(columns).toContain("name");
24
+ expect(columns).toContain("description");
25
+ expect(columns).toContain("dashboardViewConfig");
26
+ });
27
+
28
+ test("should exclude server-controlled and system columns", () => {
29
+ const columns: Array<string> =
30
+ ModelImportExport.getImportExportableColumnNames(Dashboard);
31
+
32
+ expect(columns).not.toContain("_id");
33
+ expect(columns).not.toContain("createdAt");
34
+ expect(columns).not.toContain("updatedAt");
35
+ expect(columns).not.toContain("deletedAt");
36
+ expect(columns).not.toContain("version");
37
+ expect(columns).not.toContain("slug");
38
+ });
39
+
40
+ test("should exclude the tenant column", () => {
41
+ const columns: Array<string> =
42
+ ModelImportExport.getImportExportableColumnNames(Dashboard);
43
+
44
+ expect(columns).not.toContain("projectId");
45
+ });
46
+
47
+ test("should exclude entity relations and their foreign key columns", () => {
48
+ const columns: Array<string> =
49
+ ModelImportExport.getImportExportableColumnNames(Dashboard);
50
+
51
+ expect(columns).not.toContain("labels");
52
+ expect(columns).not.toContain("createdByUser");
53
+ expect(columns).not.toContain("createdByUserId");
54
+ expect(columns).not.toContain("deletedByUser");
55
+ expect(columns).not.toContain("deletedByUserId");
56
+ expect(columns).not.toContain("logoFile");
57
+ expect(columns).not.toContain("logoFileId");
58
+ });
59
+
60
+ test("should include monitor configuration columns", () => {
61
+ const columns: Array<string> =
62
+ ModelImportExport.getImportExportableColumnNames(Monitor);
63
+
64
+ expect(columns).toContain("name");
65
+ expect(columns).toContain("monitorType");
66
+ expect(columns).toContain("monitorSteps");
67
+ expect(columns).not.toContain("currentMonitorStatusId");
68
+ expect(columns).not.toContain("projectId");
69
+ expect(columns).not.toContain("slug");
70
+ });
71
+
72
+ test("should exclude status page foreign keys and relations", () => {
73
+ const columns: Array<string> =
74
+ ModelImportExport.getImportExportableColumnNames(StatusPage);
75
+
76
+ expect(columns).toContain("name");
77
+ expect(columns).not.toContain("projectId");
78
+ expect(columns).not.toContain("labels");
79
+ expect(columns).not.toContain("faviconFileId");
80
+ });
81
+
82
+ test("should exclude plain-text credentials via the per-table exclusion list", () => {
83
+ const columns: Array<string> =
84
+ ModelImportExport.getImportExportableColumnNames(StatusPage);
85
+
86
+ expect(columns).not.toContain("embeddedOverallStatusToken");
87
+ });
88
+
89
+ test("should exclude monitor runtime-state columns", () => {
90
+ const columns: Array<string> =
91
+ ModelImportExport.getImportExportableColumnNames(Monitor);
92
+
93
+ expect(columns).not.toContain("incomingMonitorRequest");
94
+ expect(columns).not.toContain("serverMonitorResponse");
95
+ expect(columns).not.toContain("incomingRequestMonitorHeartbeatCheckedAt");
96
+ expect(columns).not.toContain("serverMonitorRequestReceivedAt");
97
+ expect(columns).not.toContain("telemetryMonitorNextMonitorAt");
98
+ expect(columns).not.toContain("telemetryMonitorLastMonitorAt");
99
+ });
100
+ });
101
+
102
+ describe("getImportExportSelect", () => {
103
+ test("should build a select object from exportable columns", () => {
104
+ const select: JSONObject = ModelImportExport.getImportExportSelect(
105
+ Dashboard,
106
+ ) as JSONObject;
107
+
108
+ expect(select["name"]).toBe(true);
109
+ expect(select["dashboardViewConfig"]).toBe(true);
110
+ expect(select["_id"]).toBeUndefined();
111
+ expect(select["projectId"]).toBeUndefined();
112
+ });
113
+ });
114
+
115
+ describe("buildExportEnvelope and toExportJSON", () => {
116
+ test("should build a valid envelope and strip non-exportable columns", () => {
117
+ const dashboard: Dashboard = new Dashboard();
118
+ dashboard.name = "My Dashboard";
119
+ dashboard.description = "My Description";
120
+ dashboard._id = "aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa";
121
+ dashboard.projectId = new ObjectID(
122
+ "bbbbbbbb-bbbb-bbbb-bbbb-bbbbbbbbbbbb",
123
+ );
124
+
125
+ const envelope: JSONObject = ModelImportExport.buildExportEnvelope({
126
+ modelType: Dashboard,
127
+ items: [dashboard],
128
+ exportedAt: new Date("2026-06-11T00:00:00.000Z"),
129
+ });
130
+
131
+ expect(envelope["fileType"]).toBe(MODEL_EXPORT_FILE_TYPE);
132
+ expect(envelope["schemaVersion"]).toBe(MODEL_EXPORT_SCHEMA_VERSION);
133
+ expect(envelope["resourceType"]).toBe(new Dashboard().tableName);
134
+ expect(envelope["exportedAt"]).toBe("2026-06-11T00:00:00.000Z");
135
+
136
+ const items: Array<JSONObject> = envelope["items"] as Array<JSONObject>;
137
+ expect(items).toHaveLength(1);
138
+ expect(items[0]!["name"]).toBe("My Dashboard");
139
+ expect(items[0]!["description"]).toBe("My Description");
140
+ expect(items[0]!["_id"]).toBeUndefined();
141
+ expect(items[0]!["projectId"]).toBeUndefined();
142
+ });
143
+ });
144
+
145
+ describe("parseImportPayload", () => {
146
+ test("should accept a valid envelope", () => {
147
+ const items: Array<JSONObject> = ModelImportExport.parseImportPayload({
148
+ modelType: Dashboard,
149
+ payload: {
150
+ fileType: MODEL_EXPORT_FILE_TYPE,
151
+ schemaVersion: MODEL_EXPORT_SCHEMA_VERSION,
152
+ resourceType: new Dashboard().tableName!,
153
+ items: [{ name: "Imported Dashboard" }],
154
+ },
155
+ });
156
+
157
+ expect(items).toHaveLength(1);
158
+ expect(items[0]!["name"]).toBe("Imported Dashboard");
159
+ });
160
+
161
+ test("should accept a plain array of items", () => {
162
+ const items: Array<JSONObject> = ModelImportExport.parseImportPayload({
163
+ modelType: Dashboard,
164
+ payload: [{ name: "One" }, { name: "Two" }],
165
+ });
166
+
167
+ expect(items).toHaveLength(2);
168
+ });
169
+
170
+ test("should accept a single bare item object", () => {
171
+ const items: Array<JSONObject> = ModelImportExport.parseImportPayload({
172
+ modelType: Dashboard,
173
+ payload: { name: "Only One" },
174
+ });
175
+
176
+ expect(items).toHaveLength(1);
177
+ });
178
+
179
+ test("should reject an envelope for a different resource type", () => {
180
+ expect(() => {
181
+ ModelImportExport.parseImportPayload({
182
+ modelType: Dashboard,
183
+ payload: {
184
+ fileType: MODEL_EXPORT_FILE_TYPE,
185
+ resourceType: new Monitor().tableName!,
186
+ items: [{ name: "A Monitor" }],
187
+ },
188
+ });
189
+ }).toThrow(BadDataException);
190
+ });
191
+
192
+ test("should reject an envelope with no items", () => {
193
+ expect(() => {
194
+ ModelImportExport.parseImportPayload({
195
+ modelType: Dashboard,
196
+ payload: {
197
+ fileType: MODEL_EXPORT_FILE_TYPE,
198
+ resourceType: new Dashboard().tableName!,
199
+ items: [],
200
+ },
201
+ });
202
+ }).toThrow(BadDataException);
203
+ });
204
+
205
+ test("should reject items that are not objects", () => {
206
+ expect(() => {
207
+ ModelImportExport.parseImportPayload({
208
+ modelType: Dashboard,
209
+ payload: ["not-an-object"] as any,
210
+ });
211
+ }).toThrow(BadDataException);
212
+ });
213
+ });
214
+
215
+ describe("fromImportJSON", () => {
216
+ test("should build a model with only importable columns", () => {
217
+ const item: Dashboard = ModelImportExport.fromImportJSON({
218
+ json: {
219
+ _id: "aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa",
220
+ id: "aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa",
221
+ slug: "my-dashboard",
222
+ projectId: "bbbbbbbb-bbbb-bbbb-bbbb-bbbbbbbbbbbb",
223
+ createdAt: "2026-01-01T00:00:00.000Z",
224
+ name: "My Dashboard",
225
+ description: "My Description",
226
+ dashboardViewConfig: { components: [], heightInDashboardUnits: 60 },
227
+ unknownColumn: "should be dropped",
228
+ },
229
+ modelType: Dashboard,
230
+ });
231
+
232
+ expect(item.name).toBe("My Dashboard");
233
+ expect(item.description).toBe("My Description");
234
+ expect(item.dashboardViewConfig).toBeDefined();
235
+ expect(item._id).toBeUndefined();
236
+ expect(item.projectId).toBeUndefined();
237
+ expect(item.slug).toBeUndefined();
238
+ expect(item.createdAt).toBeUndefined();
239
+ expect((item as any)["unknownColumn"]).toBeUndefined();
240
+ });
241
+
242
+ test("should round-trip an exported dashboard back into a creatable model", () => {
243
+ const original: Dashboard = new Dashboard();
244
+ original.name = "Round Trip";
245
+ original.description = "Round trip description";
246
+
247
+ const envelope: JSONObject = ModelImportExport.buildExportEnvelope({
248
+ modelType: Dashboard,
249
+ items: [original],
250
+ exportedAt: new Date(),
251
+ });
252
+
253
+ const itemJsons: Array<JSONObject> = ModelImportExport.parseImportPayload(
254
+ {
255
+ modelType: Dashboard,
256
+ payload: envelope,
257
+ },
258
+ );
259
+
260
+ const imported: Dashboard = ModelImportExport.fromImportJSON({
261
+ json: itemJsons[0]!,
262
+ modelType: Dashboard,
263
+ });
264
+
265
+ expect(imported.name).toBe("Round Trip");
266
+ expect(imported.description).toBe("Round trip description");
267
+ expect(imported._id).toBeUndefined();
268
+ });
269
+
270
+ test("should advance past recurring dates for scheduled maintenance templates", () => {
271
+ const dayInMs: number = 24 * 60 * 60 * 1000;
272
+
273
+ const template: ScheduledMaintenanceTemplate =
274
+ new ScheduledMaintenanceTemplate();
275
+ template.templateName = "Weekly Maintenance";
276
+ template.isRecurringEvent = true;
277
+
278
+ const recurring: Recurring = new Recurring();
279
+ recurring.intervalType = EventInterval.Week;
280
+ recurring.intervalCount = new PositiveNumber(1);
281
+ template.recurringInterval = recurring;
282
+
283
+ const pastScheduledAt: Date = new Date(Date.now() - 30 * dayInMs);
284
+ const pastStartsAt: Date = new Date(Date.now() - 29 * dayInMs);
285
+ const pastEndsAt: Date = new Date(
286
+ pastStartsAt.getTime() + 2 * 60 * 60 * 1000,
287
+ );
288
+
289
+ template.firstEventScheduledAt = pastScheduledAt;
290
+ template.firstEventStartsAt = pastStartsAt;
291
+ template.firstEventEndsAt = pastEndsAt;
292
+
293
+ const envelope: JSONObject = ModelImportExport.buildExportEnvelope({
294
+ modelType: ScheduledMaintenanceTemplate,
295
+ items: [template],
296
+ exportedAt: new Date(),
297
+ });
298
+
299
+ const itemJsons: Array<JSONObject> = ModelImportExport.parseImportPayload(
300
+ {
301
+ modelType: ScheduledMaintenanceTemplate,
302
+ payload: envelope,
303
+ },
304
+ );
305
+
306
+ const imported: ScheduledMaintenanceTemplate =
307
+ ModelImportExport.fromImportJSON({
308
+ json: itemJsons[0]!,
309
+ modelType: ScheduledMaintenanceTemplate,
310
+ });
311
+
312
+ expect(imported.firstEventScheduledAt!.getTime()).toBeGreaterThan(
313
+ Date.now(),
314
+ );
315
+ expect(imported.firstEventStartsAt!.getTime()).toBeGreaterThan(
316
+ Date.now(),
317
+ );
318
+ expect(imported.firstEventEndsAt!.getTime()).toBeGreaterThan(Date.now());
319
+
320
+ // offsets between the dates are preserved.
321
+ expect(
322
+ imported.firstEventStartsAt!.getTime() -
323
+ imported.firstEventScheduledAt!.getTime(),
324
+ ).toBe(pastStartsAt.getTime() - pastScheduledAt.getTime());
325
+ expect(
326
+ imported.firstEventEndsAt!.getTime() -
327
+ imported.firstEventStartsAt!.getTime(),
328
+ ).toBe(pastEndsAt.getTime() - pastStartsAt.getTime());
329
+ });
330
+
331
+ test("should leave future recurring dates unchanged", () => {
332
+ const dayInMs: number = 24 * 60 * 60 * 1000;
333
+
334
+ const template: ScheduledMaintenanceTemplate =
335
+ new ScheduledMaintenanceTemplate();
336
+ template.templateName = "Future Maintenance";
337
+ template.isRecurringEvent = true;
338
+
339
+ const recurring: Recurring = new Recurring();
340
+ recurring.intervalType = EventInterval.Day;
341
+ recurring.intervalCount = new PositiveNumber(1);
342
+ template.recurringInterval = recurring;
343
+
344
+ const futureScheduledAt: Date = new Date(Date.now() + 10 * dayInMs);
345
+ template.firstEventScheduledAt = futureScheduledAt;
346
+ template.firstEventStartsAt = new Date(Date.now() + 11 * dayInMs);
347
+ template.firstEventEndsAt = new Date(Date.now() + 12 * dayInMs);
348
+
349
+ const envelope: JSONObject = ModelImportExport.buildExportEnvelope({
350
+ modelType: ScheduledMaintenanceTemplate,
351
+ items: [template],
352
+ exportedAt: new Date(),
353
+ });
354
+
355
+ const imported: ScheduledMaintenanceTemplate =
356
+ ModelImportExport.fromImportJSON({
357
+ json: (envelope["items"] as Array<JSONObject>)[0]!,
358
+ modelType: ScheduledMaintenanceTemplate,
359
+ });
360
+
361
+ expect(imported.firstEventScheduledAt!.getTime()).toBe(
362
+ futureScheduledAt.getTime(),
363
+ );
364
+ });
365
+ });
366
+ });