@oneuptime/common 10.8.2 → 11.0.0

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 (724) 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/Telemetry/EntityKey.test.ts +150 -0
  92. package/Tests/Utils/Telemetry/EntityKeySqlParity.test.ts +40 -0
  93. package/Tests/Utils/Telemetry/EntityRelationship.test.ts +150 -0
  94. package/Tests/Utils/UUID.test.ts +47 -0
  95. package/Types/AnalyticsDatabase/AnalyticsTableName.ts +14 -9
  96. package/Types/AnalyticsDatabase/TableColumnType.ts +1 -0
  97. package/Types/Dashboard/DashboardComponentType.ts +1 -0
  98. package/Types/Dashboard/DashboardComponents/DashboardTraceChartComponent.ts +37 -0
  99. package/Types/Dashboard/DashboardTemplates.ts +4 -5
  100. package/Types/Log/LogQueryParser.ts +2 -2
  101. package/Types/Log/LogQueryToFilter.ts +2 -2
  102. package/Types/Monitor/MonitorStepExceptionMonitor.ts +19 -1
  103. package/Types/Monitor/MonitorStepLogMonitor.ts +20 -1
  104. package/Types/Monitor/MonitorStepMetricMonitor.ts +27 -0
  105. package/Types/Monitor/MonitorStepProfileMonitor.ts +19 -1
  106. package/Types/Monitor/MonitorStepTraceMonitor.ts +18 -1
  107. package/Types/Monitor/MonitorType.ts +8 -1
  108. package/Types/ObjectID.ts +10 -0
  109. package/Types/Telemetry/EntityRelationshipType.ts +31 -0
  110. package/Types/Telemetry/EntityType.ts +33 -0
  111. package/Types/Telemetry/TelemetrySavedViewState.ts +2 -0
  112. package/Types/Text.ts +34 -0
  113. package/Types/Trace/TraceAggregationType.ts +1 -0
  114. package/Types/Trace/TraceRecordingRuleDefinition.ts +74 -0
  115. package/UI/Components/LogsViewer/LogsViewer.tsx +12 -9
  116. package/UI/Components/LogsViewer/components/LogDetailsPanel.tsx +10 -9
  117. package/UI/Components/LogsViewer/components/LogSearchBar.tsx +1 -1
  118. package/UI/Components/LogsViewer/components/LogsAnalyticsView.tsx +2 -2
  119. package/UI/Components/LogsViewer/components/LogsFacetSidebar.tsx +4 -4
  120. package/UI/Components/LogsViewer/components/LogsTable.tsx +5 -3
  121. package/UI/Components/Navbar/NavBarMenuModal.tsx +81 -44
  122. package/UI/Components/TelemetryViewer/TelemetryViewer.tsx +33 -10
  123. package/UI/Components/TelemetryViewer/components/TelemetryFacetSidebar.tsx +18 -3
  124. package/UI/Components/TelemetryViewer/components/TelemetryHistogram.tsx +91 -68
  125. package/UI/Components/TelemetryViewer/components/TelemetryHistogramTooltip.tsx +9 -2
  126. package/UI/Utils/LogExport.ts +2 -2
  127. package/UI/Utils/TelemetryService.ts +20 -20
  128. package/Utils/Dashboard/Components/DashboardTraceChartComponent.ts +134 -0
  129. package/Utils/Dashboard/Components/Index.ts +7 -0
  130. package/Utils/Telemetry/EntityKey.ts +151 -0
  131. package/Utils/Telemetry/EntityRelationship.ts +113 -0
  132. package/Utils/Traces/CriticalPath.ts +7 -7
  133. package/Utils/UUID.ts +57 -0
  134. package/build/dist/Models/AnalyticsModels/AnalyticsBaseModel/AnalyticsBaseModel.js +14 -13
  135. package/build/dist/Models/AnalyticsModels/AnalyticsBaseModel/AnalyticsBaseModel.js.map +1 -1
  136. package/build/dist/Models/AnalyticsModels/AuditLog.js +2 -1
  137. package/build/dist/Models/AnalyticsModels/AuditLog.js.map +1 -1
  138. package/build/dist/Models/AnalyticsModels/ExceptionInstance.js +125 -22
  139. package/build/dist/Models/AnalyticsModels/ExceptionInstance.js.map +1 -1
  140. package/build/dist/Models/AnalyticsModels/Index.js +7 -2
  141. package/build/dist/Models/AnalyticsModels/Index.js.map +1 -1
  142. package/build/dist/Models/AnalyticsModels/Log.js +123 -22
  143. package/build/dist/Models/AnalyticsModels/Log.js.map +1 -1
  144. package/build/dist/Models/AnalyticsModels/Metric.js +125 -27
  145. package/build/dist/Models/AnalyticsModels/Metric.js.map +1 -1
  146. package/build/dist/Models/AnalyticsModels/MetricBaselineHourly.js +38 -21
  147. package/build/dist/Models/AnalyticsModels/MetricBaselineHourly.js.map +1 -1
  148. package/build/dist/Models/AnalyticsModels/MetricItemAggMV1m.js +17 -16
  149. package/build/dist/Models/AnalyticsModels/MetricItemAggMV1m.js.map +1 -1
  150. package/build/dist/Models/AnalyticsModels/{MetricItemAggMV1mByHost.js → MetricItemAggMV1mByHostV2.js} +54 -42
  151. package/build/dist/Models/AnalyticsModels/MetricItemAggMV1mByHostV2.js.map +1 -0
  152. package/build/dist/Models/AnalyticsModels/MonitorLog.js +4 -1
  153. package/build/dist/Models/AnalyticsModels/MonitorLog.js.map +1 -1
  154. package/build/dist/Models/AnalyticsModels/Profile.js +132 -26
  155. package/build/dist/Models/AnalyticsModels/Profile.js.map +1 -1
  156. package/build/dist/Models/AnalyticsModels/ProfileSample.js +121 -23
  157. package/build/dist/Models/AnalyticsModels/ProfileSample.js.map +1 -1
  158. package/build/dist/Models/AnalyticsModels/Span.js +144 -26
  159. package/build/dist/Models/AnalyticsModels/Span.js.map +1 -1
  160. package/build/dist/Models/DatabaseModels/Index.js +4 -0
  161. package/build/dist/Models/DatabaseModels/Index.js.map +1 -1
  162. package/build/dist/Models/DatabaseModels/Service.js +30 -0
  163. package/build/dist/Models/DatabaseModels/Service.js.map +1 -1
  164. package/build/dist/Models/DatabaseModels/TelemetryEntity.js +419 -0
  165. package/build/dist/Models/DatabaseModels/TelemetryEntity.js.map +1 -0
  166. package/build/dist/Models/DatabaseModels/TelemetryEntityRelationship.js +317 -0
  167. package/build/dist/Models/DatabaseModels/TelemetryEntityRelationship.js.map +1 -0
  168. package/build/dist/Models/DatabaseModels/TelemetryException.js +12 -12
  169. package/build/dist/Models/DatabaseModels/TelemetryException.js.map +1 -1
  170. package/build/dist/Models/DatabaseModels/TelemetryUsageBilling.js +7 -7
  171. package/build/dist/Models/DatabaseModels/TelemetryUsageBilling.js.map +1 -1
  172. package/build/dist/Server/API/AIAgentDataAPI.js +14 -13
  173. package/build/dist/Server/API/AIAgentDataAPI.js.map +1 -1
  174. package/build/dist/Server/API/DashboardAPI.js +2 -2
  175. package/build/dist/Server/API/DashboardAPI.js.map +1 -1
  176. package/build/dist/Server/API/TelemetryAPI.js +425 -129
  177. package/build/dist/Server/API/TelemetryAPI.js.map +1 -1
  178. package/build/dist/Server/API/TelemetryExceptionAPI.js +2 -2
  179. package/build/dist/Server/API/TelemetryExceptionAPI.js.map +1 -1
  180. package/build/dist/Server/Infrastructure/ClickhouseConfig.js +12 -0
  181. package/build/dist/Server/Infrastructure/ClickhouseConfig.js.map +1 -1
  182. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781100000001-RenameTelemetryServiceIdToPrimaryEntityId.js +29 -0
  183. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781100000001-RenameTelemetryServiceIdToPrimaryEntityId.js.map +1 -0
  184. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781200000000-AddTelemetryEntityTable.js +38 -0
  185. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781200000000-AddTelemetryEntityTable.js.map +1 -0
  186. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781200000001-AddTelemetryEntityRelationshipTable.js +33 -0
  187. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781200000001-AddTelemetryEntityRelationshipTable.js.map +1 -0
  188. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781250074195-MigrationName.js +78 -0
  189. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781250074195-MigrationName.js.map +1 -0
  190. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781300000000-AddTelemetryEntityLabels.js +19 -0
  191. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781300000000-AddTelemetryEntityLabels.js.map +1 -0
  192. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781400000000-AddServiceTelemetrySdkLanguage.js +18 -0
  193. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1781400000000-AddServiceTelemetrySdkLanguage.js.map +1 -0
  194. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js +12 -0
  195. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js.map +1 -1
  196. package/build/dist/Server/Infrastructure/Queue.js +14 -3
  197. package/build/dist/Server/Infrastructure/Queue.js.map +1 -1
  198. package/build/dist/Server/Middleware/TelemetryIngest.js +16 -18
  199. package/build/dist/Server/Middleware/TelemetryIngest.js.map +1 -1
  200. package/build/dist/Server/Services/AlertService.js +9 -9
  201. package/build/dist/Server/Services/AlertService.js.map +1 -1
  202. package/build/dist/Server/Services/AnalyticsDatabaseService.js +115 -40
  203. package/build/dist/Server/Services/AnalyticsDatabaseService.js.map +1 -1
  204. package/build/dist/Server/Services/ExceptionAggregationService.js +38 -18
  205. package/build/dist/Server/Services/ExceptionAggregationService.js.map +1 -1
  206. package/build/dist/Server/Services/HostService.js +2 -1
  207. package/build/dist/Server/Services/HostService.js.map +1 -1
  208. package/build/dist/Server/Services/IncidentService.js +19 -19
  209. package/build/dist/Server/Services/IncidentService.js.map +1 -1
  210. package/build/dist/Server/Services/Index.js +6 -2
  211. package/build/dist/Server/Services/Index.js.map +1 -1
  212. package/build/dist/Server/Services/LogAggregationService.js +100 -42
  213. package/build/dist/Server/Services/LogAggregationService.js.map +1 -1
  214. package/build/dist/Server/Services/MetricAggregationService.js +27 -14
  215. package/build/dist/Server/Services/MetricAggregationService.js.map +1 -1
  216. package/build/dist/Server/Services/MetricBaselineService.js +28 -28
  217. package/build/dist/Server/Services/MetricBaselineService.js.map +1 -1
  218. package/build/dist/Server/Services/MetricItemAggMV1mByHostV2Service.js +28 -0
  219. package/build/dist/Server/Services/MetricItemAggMV1mByHostV2Service.js.map +1 -0
  220. package/build/dist/Server/Services/MetricService.js +116 -31
  221. package/build/dist/Server/Services/MetricService.js.map +1 -1
  222. package/build/dist/Server/Services/OpenTelemetryIngestService.js +103 -36
  223. package/build/dist/Server/Services/OpenTelemetryIngestService.js.map +1 -1
  224. package/build/dist/Server/Services/ProfileAggregationService.js +613 -105
  225. package/build/dist/Server/Services/ProfileAggregationService.js.map +1 -1
  226. package/build/dist/Server/Services/ServiceService.js +9 -5
  227. package/build/dist/Server/Services/ServiceService.js.map +1 -1
  228. package/build/dist/Server/Services/SpanService.js +217 -15
  229. package/build/dist/Server/Services/SpanService.js.map +1 -1
  230. package/build/dist/Server/Services/TelemetryEntityRelationshipService.js +72 -0
  231. package/build/dist/Server/Services/TelemetryEntityRelationshipService.js.map +1 -0
  232. package/build/dist/Server/Services/TelemetryEntityService.js +201 -0
  233. package/build/dist/Server/Services/TelemetryEntityService.js.map +1 -0
  234. package/build/dist/Server/Services/TelemetryExceptionService.js +18 -18
  235. package/build/dist/Server/Services/TelemetryExceptionService.js.map +1 -1
  236. package/build/dist/Server/Services/TelemetryUsageBillingService.js +27 -21
  237. package/build/dist/Server/Services/TelemetryUsageBillingService.js.map +1 -1
  238. package/build/dist/Server/Services/TraceAggregationService.js +568 -43
  239. package/build/dist/Server/Services/TraceAggregationService.js.map +1 -1
  240. package/build/dist/Server/Types/AnalyticsDatabase/ModelPermission.js +38 -2
  241. package/build/dist/Server/Types/AnalyticsDatabase/ModelPermission.js.map +1 -1
  242. package/build/dist/Server/Types/Database/Permissions/AccessControlPermission.js +36 -2
  243. package/build/dist/Server/Types/Database/Permissions/AccessControlPermission.js.map +1 -1
  244. package/build/dist/Server/Types/Database/Permissions/BasePermission.js +25 -1
  245. package/build/dist/Server/Types/Database/Permissions/BasePermission.js.map +1 -1
  246. package/build/dist/Server/Types/Database/Permissions/OwnedScopePermission.js +17 -3
  247. package/build/dist/Server/Types/Database/Permissions/OwnedScopePermission.js.map +1 -1
  248. package/build/dist/Server/Types/Database/Permissions/OwnerTableRegistry.js +1 -0
  249. package/build/dist/Server/Types/Database/Permissions/OwnerTableRegistry.js.map +1 -1
  250. package/build/dist/Server/Types/Database/QueryHelper.js +31 -0
  251. package/build/dist/Server/Types/Database/QueryHelper.js.map +1 -1
  252. package/build/dist/Server/Utils/Alert/AlertPrivacyFilter.js +3 -2
  253. package/build/dist/Server/Utils/Alert/AlertPrivacyFilter.js.map +1 -1
  254. package/build/dist/Server/Utils/AlertEpisode/AlertEpisodePrivacyFilter.js +3 -2
  255. package/build/dist/Server/Utils/AlertEpisode/AlertEpisodePrivacyFilter.js.map +1 -1
  256. package/build/dist/Server/Utils/AnalyticsDatabase/QuerySettingsHelper.js +46 -0
  257. package/build/dist/Server/Utils/AnalyticsDatabase/QuerySettingsHelper.js.map +1 -0
  258. package/build/dist/Server/Utils/AnalyticsDatabase/StatementGenerator.js +97 -3
  259. package/build/dist/Server/Utils/AnalyticsDatabase/StatementGenerator.js.map +1 -1
  260. package/build/dist/Server/Utils/Incident/IncidentPrivacyFilter.js +3 -2
  261. package/build/dist/Server/Utils/Incident/IncidentPrivacyFilter.js.map +1 -1
  262. package/build/dist/Server/Utils/IncidentEpisode/IncidentEpisodePrivacyFilter.js +3 -2
  263. package/build/dist/Server/Utils/IncidentEpisode/IncidentEpisodePrivacyFilter.js.map +1 -1
  264. package/build/dist/Server/Utils/Monitor/Criteria/EvaluateOverTime.js +1 -1
  265. package/build/dist/Server/Utils/Monitor/Criteria/EvaluateOverTime.js.map +1 -1
  266. package/build/dist/Server/Utils/Monitor/MonitorLogUtil.js +1 -2
  267. package/build/dist/Server/Utils/Monitor/MonitorLogUtil.js.map +1 -1
  268. package/build/dist/Server/Utils/Monitor/MonitorMetricUtil.js +3 -4
  269. package/build/dist/Server/Utils/Monitor/MonitorMetricUtil.js.map +1 -1
  270. package/build/dist/Server/Utils/PrivacyFilterUtil.js +47 -0
  271. package/build/dist/Server/Utils/PrivacyFilterUtil.js.map +1 -0
  272. package/build/dist/Server/Utils/Profile/PprofEncoder.js +132 -4
  273. package/build/dist/Server/Utils/Profile/PprofEncoder.js.map +1 -1
  274. package/build/dist/Server/Utils/Telemetry/EntityRegistry.js +228 -0
  275. package/build/dist/Server/Utils/Telemetry/EntityRegistry.js.map +1 -0
  276. package/build/dist/Server/Utils/Telemetry/ResourceFacetResolver.js +5 -0
  277. package/build/dist/Server/Utils/Telemetry/ResourceFacetResolver.js.map +1 -1
  278. package/build/dist/Server/Utils/Telemetry/TelemetryEntity.js +569 -0
  279. package/build/dist/Server/Utils/Telemetry/TelemetryEntity.js.map +1 -0
  280. package/build/dist/Types/AnalyticsDatabase/AnalyticsTableName.js +14 -9
  281. package/build/dist/Types/AnalyticsDatabase/AnalyticsTableName.js.map +1 -1
  282. package/build/dist/Types/AnalyticsDatabase/TableColumnType.js +1 -0
  283. package/build/dist/Types/AnalyticsDatabase/TableColumnType.js.map +1 -1
  284. package/build/dist/Types/Dashboard/DashboardComponentType.js +1 -0
  285. package/build/dist/Types/Dashboard/DashboardComponentType.js.map +1 -1
  286. package/build/dist/Types/Dashboard/DashboardComponents/DashboardTraceChartComponent.js +2 -0
  287. package/build/dist/Types/Dashboard/DashboardComponents/DashboardTraceChartComponent.js.map +1 -0
  288. package/build/dist/Types/Dashboard/DashboardTemplates.js +4 -5
  289. package/build/dist/Types/Dashboard/DashboardTemplates.js.map +1 -1
  290. package/build/dist/Types/Log/LogQueryParser.js +2 -2
  291. package/build/dist/Types/Log/LogQueryParser.js.map +1 -1
  292. package/build/dist/Types/Log/LogQueryToFilter.js +1 -1
  293. package/build/dist/Types/Log/LogQueryToFilter.js.map +1 -1
  294. package/build/dist/Types/Monitor/MonitorStepExceptionMonitor.js +9 -1
  295. package/build/dist/Types/Monitor/MonitorStepExceptionMonitor.js.map +1 -1
  296. package/build/dist/Types/Monitor/MonitorStepLogMonitor.js +9 -1
  297. package/build/dist/Types/Monitor/MonitorStepLogMonitor.js.map +1 -1
  298. package/build/dist/Types/Monitor/MonitorStepMetricMonitor.js +13 -0
  299. package/build/dist/Types/Monitor/MonitorStepMetricMonitor.js.map +1 -1
  300. package/build/dist/Types/Monitor/MonitorStepProfileMonitor.js +9 -1
  301. package/build/dist/Types/Monitor/MonitorStepProfileMonitor.js.map +1 -1
  302. package/build/dist/Types/Monitor/MonitorStepTraceMonitor.js +9 -1
  303. package/build/dist/Types/Monitor/MonitorStepTraceMonitor.js.map +1 -1
  304. package/build/dist/Types/Monitor/MonitorType.js +8 -1
  305. package/build/dist/Types/Monitor/MonitorType.js.map +1 -1
  306. package/build/dist/Types/ObjectID.js +9 -0
  307. package/build/dist/Types/ObjectID.js.map +1 -1
  308. package/build/dist/Types/Telemetry/EntityRelationshipType.js +32 -0
  309. package/build/dist/Types/Telemetry/EntityRelationshipType.js.map +1 -0
  310. package/build/dist/Types/Telemetry/EntityType.js +34 -0
  311. package/build/dist/Types/Telemetry/EntityType.js.map +1 -0
  312. package/build/dist/Types/Text.js +32 -1
  313. package/build/dist/Types/Text.js.map +1 -1
  314. package/build/dist/Types/Trace/TraceAggregationType.js +1 -0
  315. package/build/dist/Types/Trace/TraceAggregationType.js.map +1 -1
  316. package/build/dist/Types/Trace/TraceRecordingRuleDefinition.js +50 -1
  317. package/build/dist/Types/Trace/TraceRecordingRuleDefinition.js.map +1 -1
  318. package/build/dist/UI/Components/LogsViewer/LogsViewer.js +10 -9
  319. package/build/dist/UI/Components/LogsViewer/LogsViewer.js.map +1 -1
  320. package/build/dist/UI/Components/LogsViewer/components/LogDetailsPanel.js +8 -8
  321. package/build/dist/UI/Components/LogsViewer/components/LogDetailsPanel.js.map +1 -1
  322. package/build/dist/UI/Components/LogsViewer/components/LogSearchBar.js +1 -1
  323. package/build/dist/UI/Components/LogsViewer/components/LogSearchBar.js.map +1 -1
  324. package/build/dist/UI/Components/LogsViewer/components/LogsAnalyticsView.js +2 -2
  325. package/build/dist/UI/Components/LogsViewer/components/LogsAnalyticsView.js.map +1 -1
  326. package/build/dist/UI/Components/LogsViewer/components/LogsFacetSidebar.js +4 -4
  327. package/build/dist/UI/Components/LogsViewer/components/LogsFacetSidebar.js.map +1 -1
  328. package/build/dist/UI/Components/LogsViewer/components/LogsTable.js +3 -3
  329. package/build/dist/UI/Components/LogsViewer/components/LogsTable.js.map +1 -1
  330. package/build/dist/UI/Components/Navbar/NavBarMenuModal.js +43 -30
  331. package/build/dist/UI/Components/Navbar/NavBarMenuModal.js.map +1 -1
  332. package/build/dist/UI/Components/TelemetryViewer/TelemetryViewer.js +6 -2
  333. package/build/dist/UI/Components/TelemetryViewer/TelemetryViewer.js.map +1 -1
  334. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryFacetSidebar.js +14 -3
  335. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryFacetSidebar.js.map +1 -1
  336. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryHistogram.js +18 -10
  337. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryHistogram.js.map +1 -1
  338. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryHistogramTooltip.js +4 -2
  339. package/build/dist/UI/Components/TelemetryViewer/components/TelemetryHistogramTooltip.js.map +1 -1
  340. package/build/dist/UI/Utils/LogExport.js +2 -2
  341. package/build/dist/UI/Utils/LogExport.js.map +1 -1
  342. package/build/dist/UI/Utils/TelemetryService.js +16 -16
  343. package/build/dist/UI/Utils/TelemetryService.js.map +1 -1
  344. package/build/dist/Utils/Dashboard/Components/DashboardTraceChartComponent.js +110 -0
  345. package/build/dist/Utils/Dashboard/Components/DashboardTraceChartComponent.js.map +1 -0
  346. package/build/dist/Utils/Dashboard/Components/Index.js +4 -0
  347. package/build/dist/Utils/Dashboard/Components/Index.js.map +1 -1
  348. package/build/dist/Utils/Telemetry/EntityKey.js +115 -0
  349. package/build/dist/Utils/Telemetry/EntityKey.js.map +1 -0
  350. package/build/dist/Utils/Telemetry/EntityRelationship.js +71 -0
  351. package/build/dist/Utils/Telemetry/EntityRelationship.js.map +1 -0
  352. package/build/dist/Utils/Traces/CriticalPath.js +5 -5
  353. package/build/dist/Utils/Traces/CriticalPath.js.map +1 -1
  354. package/build/dist/Utils/UUID.js +50 -0
  355. package/build/dist/Utils/UUID.js.map +1 -1
  356. package/package.json +2 -1
  357. package/tsconfig.json +10 -1
  358. package/Server/Services/MetricItemAggMV1mByHostService.ts +0 -30
  359. package/Types/Profile/ProfileMetricType.ts +0 -16
  360. package/build/dist/Models/AnalyticsModels/MetricItemAggMV1mByHost.js.map +0 -1
  361. package/build/dist/Server/Services/MetricItemAggMV1mByHostService.js +0 -28
  362. package/build/dist/Server/Services/MetricItemAggMV1mByHostService.js.map +0 -1
  363. package/build/dist/Tests/MockType.js +0 -5
  364. package/build/dist/Tests/MockType.js.map +0 -1
  365. package/build/dist/Tests/Models/AnalyticsModels/Log.test.js +0 -12
  366. package/build/dist/Tests/Models/AnalyticsModels/Log.test.js.map +0 -1
  367. package/build/dist/Tests/Models/File.test.js +0 -10
  368. package/build/dist/Tests/Models/File.test.js.map +0 -1
  369. package/build/dist/Tests/Server/API/BaseAPI.test.js +0 -590
  370. package/build/dist/Tests/Server/API/BaseAPI.test.js.map +0 -1
  371. package/build/dist/Tests/Server/API/Helpers.js +0 -27
  372. package/build/dist/Tests/Server/API/Helpers.js.map +0 -1
  373. package/build/dist/Tests/Server/API/ProbeAPI.test.js +0 -84
  374. package/build/dist/Tests/Server/API/ProbeAPI.test.js.map +0 -1
  375. package/build/dist/Tests/Server/API/ProjectAPI.test.js +0 -170
  376. package/build/dist/Tests/Server/API/ProjectAPI.test.js.map +0 -1
  377. package/build/dist/Tests/Server/API/UserSmsApi.test.js +0 -177
  378. package/build/dist/Tests/Server/API/UserSmsApi.test.js.map +0 -1
  379. package/build/dist/Tests/Server/Middleware/BearerTokenAuthorization.test.js +0 -63
  380. package/build/dist/Tests/Server/Middleware/BearerTokenAuthorization.test.js.map +0 -1
  381. package/build/dist/Tests/Server/Middleware/ClusterKeyAuthorization.test.js +0 -58
  382. package/build/dist/Tests/Server/Middleware/ClusterKeyAuthorization.test.js.map +0 -1
  383. package/build/dist/Tests/Server/Middleware/NotificationMiddleware.test.js +0 -101
  384. package/build/dist/Tests/Server/Middleware/NotificationMiddleware.test.js.map +0 -1
  385. package/build/dist/Tests/Server/Middleware/ProjectAuthorization.test.js +0 -160
  386. package/build/dist/Tests/Server/Middleware/ProjectAuthorization.test.js.map +0 -1
  387. package/build/dist/Tests/Server/Middleware/UserAuthorization.test.js +0 -410
  388. package/build/dist/Tests/Server/Middleware/UserAuthorization.test.js.map +0 -1
  389. package/build/dist/Tests/Server/Services/AlertEpisodeMemberService.test.js +0 -165
  390. package/build/dist/Tests/Server/Services/AlertEpisodeMemberService.test.js.map +0 -1
  391. package/build/dist/Tests/Server/Services/AlertEpisodeService.test.js +0 -193
  392. package/build/dist/Tests/Server/Services/AlertEpisodeService.test.js.map +0 -1
  393. package/build/dist/Tests/Server/Services/AlertGroupingEngineService.test.js +0 -435
  394. package/build/dist/Tests/Server/Services/AlertGroupingEngineService.test.js.map +0 -1
  395. package/build/dist/Tests/Server/Services/AlertGroupingRuleService.test.js +0 -320
  396. package/build/dist/Tests/Server/Services/AlertGroupingRuleService.test.js.map +0 -1
  397. package/build/dist/Tests/Server/Services/AnalyticsDatabaseService.test.js +0 -266
  398. package/build/dist/Tests/Server/Services/AnalyticsDatabaseService.test.js.map +0 -1
  399. package/build/dist/Tests/Server/Services/BillingService.test.js +0 -910
  400. package/build/dist/Tests/Server/Services/BillingService.test.js.map +0 -1
  401. package/build/dist/Tests/Server/Services/LogAggregationService.test.js +0 -75
  402. package/build/dist/Tests/Server/Services/LogAggregationService.test.js.map +0 -1
  403. package/build/dist/Tests/Server/Services/ProbeService.test.js +0 -127
  404. package/build/dist/Tests/Server/Services/ProbeService.test.js.map +0 -1
  405. package/build/dist/Tests/Server/Services/ScheduledMaintenanceService.test.js +0 -114
  406. package/build/dist/Tests/Server/Services/ScheduledMaintenanceService.test.js.map +0 -1
  407. package/build/dist/Tests/Server/Services/TeamMemberService.test.js +0 -106
  408. package/build/dist/Tests/Server/Services/TeamMemberService.test.js.map +0 -1
  409. package/build/dist/Tests/Server/Services/TelemetryAttributeService.test.js +0 -50
  410. package/build/dist/Tests/Server/Services/TelemetryAttributeService.test.js.map +0 -1
  411. package/build/dist/Tests/Server/TestingUtils/Init.js +0 -4
  412. package/build/dist/Tests/Server/TestingUtils/Init.js.map +0 -1
  413. package/build/dist/Tests/Server/TestingUtils/Postgres/TestDataSourceOptions.js +0 -9
  414. package/build/dist/Tests/Server/TestingUtils/Postgres/TestDataSourceOptions.js.map +0 -1
  415. package/build/dist/Tests/Server/TestingUtils/Redis/TestRedisOptions.js +0 -16
  416. package/build/dist/Tests/Server/TestingUtils/Redis/TestRedisOptions.js.map +0 -1
  417. package/build/dist/Tests/Server/TestingUtils/Services/BillingServiceHelper.js +0 -125
  418. package/build/dist/Tests/Server/TestingUtils/Services/BillingServiceHelper.js.map +0 -1
  419. package/build/dist/Tests/Server/TestingUtils/Services/ProjectServiceHelper.js +0 -39
  420. package/build/dist/Tests/Server/TestingUtils/Services/ProjectServiceHelper.js.map +0 -1
  421. package/build/dist/Tests/Server/TestingUtils/Services/ScheduledMaintenanceServiceHelper.js +0 -20
  422. package/build/dist/Tests/Server/TestingUtils/Services/ScheduledMaintenanceServiceHelper.js.map +0 -1
  423. package/build/dist/Tests/Server/TestingUtils/Services/ScheduledMaintenanceStateServiceHelper.js +0 -31
  424. package/build/dist/Tests/Server/TestingUtils/Services/ScheduledMaintenanceStateServiceHelper.js.map +0 -1
  425. package/build/dist/Tests/Server/TestingUtils/Services/TeamMemberServiceHelper.js +0 -14
  426. package/build/dist/Tests/Server/TestingUtils/Services/TeamMemberServiceHelper.js.map +0 -1
  427. package/build/dist/Tests/Server/TestingUtils/Services/TeamServiceHelper.js +0 -21
  428. package/build/dist/Tests/Server/TestingUtils/Services/TeamServiceHelper.js.map +0 -1
  429. package/build/dist/Tests/Server/TestingUtils/Services/Types.js +0 -2
  430. package/build/dist/Tests/Server/TestingUtils/Services/Types.js.map +0 -1
  431. package/build/dist/Tests/Server/TestingUtils/Services/UserServiceHelper.js +0 -37
  432. package/build/dist/Tests/Server/TestingUtils/Services/UserServiceHelper.js.map +0 -1
  433. package/build/dist/Tests/Server/TestingUtils/__mocks__/Stripe.mock.js +0 -13
  434. package/build/dist/Tests/Server/TestingUtils/__mocks__/Stripe.mock.js.map +0 -1
  435. package/build/dist/Tests/Server/TestingUtils/__mocks__/TestDatabase.mock.js +0 -22
  436. package/build/dist/Tests/Server/TestingUtils/__mocks__/TestDatabase.mock.js.map +0 -1
  437. package/build/dist/Tests/Server/Types/Domain.test.js +0 -78
  438. package/build/dist/Tests/Server/Types/Domain.test.js.map +0 -1
  439. package/build/dist/Tests/Server/Utils/AnalyticsDatabase/Statement.test.js +0 -94
  440. package/build/dist/Tests/Server/Utils/AnalyticsDatabase/Statement.test.js.map +0 -1
  441. package/build/dist/Tests/Server/Utils/AnalyticsDatabase/StatementGenerator.test.js +0 -459
  442. package/build/dist/Tests/Server/Utils/AnalyticsDatabase/StatementGenerator.test.js.map +0 -1
  443. package/build/dist/Tests/Server/Utils/Cookie.test.js +0 -83
  444. package/build/dist/Tests/Server/Utils/Cookie.test.js.map +0 -1
  445. package/build/dist/Tests/Server/Utils/CronTab.test.js +0 -29
  446. package/build/dist/Tests/Server/Utils/CronTab.test.js.map +0 -1
  447. package/build/dist/Tests/Server/Utils/JsonToCsv.test.js +0 -114
  448. package/build/dist/Tests/Server/Utils/JsonToCsv.test.js.map +0 -1
  449. package/build/dist/Tests/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.test.js +0 -606
  450. package/build/dist/Tests/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.test.js.map +0 -1
  451. package/build/dist/Tests/Server/Utils/Monitor/Criteria/SnmpMonitorCriteria.test.js +0 -255
  452. package/build/dist/Tests/Server/Utils/Monitor/Criteria/SnmpMonitorCriteria.test.js.map +0 -1
  453. package/build/dist/Tests/Server/Utils/Monitor/MonitorMaintenanceSuppression.test.js +0 -142
  454. package/build/dist/Tests/Server/Utils/Monitor/MonitorMaintenanceSuppression.test.js.map +0 -1
  455. package/build/dist/Tests/Server/Utils/StatusPageResource.test.js +0 -122
  456. package/build/dist/Tests/Server/Utils/StatusPageResource.test.js.map +0 -1
  457. package/build/dist/Tests/Server/Utils/Telemetry/LogExceptionExtractor.test.js +0 -0
  458. package/build/dist/Tests/Server/Utils/Telemetry/LogExceptionExtractor.test.js.map +0 -1
  459. package/build/dist/Tests/Server/Utils/VM/VMAPI.test.js +0 -205
  460. package/build/dist/Tests/Server/Utils/VM/VMAPI.test.js.map +0 -1
  461. package/build/dist/Tests/Spy.js +0 -4
  462. package/build/dist/Tests/Spy.js.map +0 -1
  463. package/build/dist/Tests/Types/API/ErrorResponse.test.js +0 -13
  464. package/build/dist/Tests/Types/API/ErrorResponse.test.js.map +0 -1
  465. package/build/dist/Tests/Types/API/HTTPErrorResponse.test.js +0 -33
  466. package/build/dist/Tests/Types/API/HTTPErrorResponse.test.js.map +0 -1
  467. package/build/dist/Tests/Types/API/HTTPMethod.test.js +0 -16
  468. package/build/dist/Tests/Types/API/HTTPMethod.test.js.map +0 -1
  469. package/build/dist/Tests/Types/API/Headers.test.js +0 -14
  470. package/build/dist/Tests/Types/API/Headers.test.js.map +0 -1
  471. package/build/dist/Tests/Types/API/Hostname.test.js +0 -22
  472. package/build/dist/Tests/Types/API/Hostname.test.js.map +0 -1
  473. package/build/dist/Tests/Types/API/Protocal.test.js +0 -19
  474. package/build/dist/Tests/Types/API/Protocal.test.js.map +0 -1
  475. package/build/dist/Tests/Types/API/Response.test.js +0 -14
  476. package/build/dist/Tests/Types/API/Response.test.js.map +0 -1
  477. package/build/dist/Tests/Types/API/ResponseType.test.js +0 -13
  478. package/build/dist/Tests/Types/API/ResponseType.test.js.map +0 -1
  479. package/build/dist/Tests/Types/API/Route.test.js +0 -30
  480. package/build/dist/Tests/Types/API/Route.test.js.map +0 -1
  481. package/build/dist/Tests/Types/API/StatusCode.test.js +0 -26
  482. package/build/dist/Tests/Types/API/StatusCode.test.js.map +0 -1
  483. package/build/dist/Tests/Types/API/URL.test.js +0 -33
  484. package/build/dist/Tests/Types/API/URL.test.js.map +0 -1
  485. package/build/dist/Tests/Types/Alerts/AlertEventType.test.js +0 -34
  486. package/build/dist/Tests/Types/Alerts/AlertEventType.test.js.map +0 -1
  487. package/build/dist/Tests/Types/Alerts/AlertType.test.js +0 -19
  488. package/build/dist/Tests/Types/Alerts/AlertType.test.js.map +0 -1
  489. package/build/dist/Tests/Types/AppEnvironment.test.js +0 -13
  490. package/build/dist/Tests/Types/AppEnvironment.test.js.map +0 -1
  491. package/build/dist/Tests/Types/ApplicationLog/ApplicationLogType.test.js +0 -13
  492. package/build/dist/Tests/Types/ApplicationLog/ApplicationLogType.test.js.map +0 -1
  493. package/build/dist/Tests/Types/ArrayUtil.test.js +0 -71
  494. package/build/dist/Tests/Types/ArrayUtil.test.js.map +0 -1
  495. package/build/dist/Tests/Types/Billing/SubscriptionPlan.test.js +0 -181
  496. package/build/dist/Tests/Types/Billing/SubscriptionPlan.test.js.map +0 -1
  497. package/build/dist/Tests/Types/BrandColors.test.js +0 -124
  498. package/build/dist/Tests/Types/BrandColors.test.js.map +0 -1
  499. package/build/dist/Tests/Types/Char.test.js +0 -82
  500. package/build/dist/Tests/Types/Char.test.js.map +0 -1
  501. package/build/dist/Tests/Types/Code/CodeType.test.js +0 -13
  502. package/build/dist/Tests/Types/Code/CodeType.test.js.map +0 -1
  503. package/build/dist/Tests/Types/Color.test.js +0 -44
  504. package/build/dist/Tests/Types/Color.test.js.map +0 -1
  505. package/build/dist/Tests/Types/Company/CompanySize.test.js +0 -20
  506. package/build/dist/Tests/Types/Company/CompanySize.test.js.map +0 -1
  507. package/build/dist/Tests/Types/Company/JobRole.test.js +0 -22
  508. package/build/dist/Tests/Types/Company/JobRole.test.js.map +0 -1
  509. package/build/dist/Tests/Types/Countries.test.js +0 -249
  510. package/build/dist/Tests/Types/Countries.test.js.map +0 -1
  511. package/build/dist/Tests/Types/Database/ColumnLength.test.js +0 -43
  512. package/build/dist/Tests/Types/Database/ColumnLength.test.js.map +0 -1
  513. package/build/dist/Tests/Types/Database/ColumnType.test.js +0 -79
  514. package/build/dist/Tests/Types/Database/ColumnType.test.js.map +0 -1
  515. package/build/dist/Tests/Types/Database/Columns.test.js +0 -20
  516. package/build/dist/Tests/Types/Database/Columns.test.js.map +0 -1
  517. package/build/dist/Tests/Types/Database/CompareBase.test.js +0 -37
  518. package/build/dist/Tests/Types/Database/CompareBase.test.js.map +0 -1
  519. package/build/dist/Tests/Types/Database/Date.test.js +0 -62
  520. package/build/dist/Tests/Types/Database/Date.test.js.map +0 -1
  521. package/build/dist/Tests/Types/Database/EqualTo.test.js +0 -65
  522. package/build/dist/Tests/Types/Database/EqualTo.test.js.map +0 -1
  523. package/build/dist/Tests/Types/Database/EqualToOrNull.test.js +0 -62
  524. package/build/dist/Tests/Types/Database/EqualToOrNull.test.js.map +0 -1
  525. package/build/dist/Tests/Types/Database/InBetween.test.js +0 -72
  526. package/build/dist/Tests/Types/Database/InBetween.test.js.map +0 -1
  527. package/build/dist/Tests/Types/Database/LimitMax.test.js +0 -18
  528. package/build/dist/Tests/Types/Database/LimitMax.test.js.map +0 -1
  529. package/build/dist/Tests/Types/Database/NotEqual.test.js +0 -19
  530. package/build/dist/Tests/Types/Database/NotEqual.test.js.map +0 -1
  531. package/build/dist/Tests/Types/Database/Search.test.js +0 -10
  532. package/build/dist/Tests/Types/Database/Search.test.js.map +0 -1
  533. package/build/dist/Tests/Types/DatabaseType.test.js +0 -7
  534. package/build/dist/Tests/Types/DatabaseType.test.js.map +0 -1
  535. package/build/dist/Tests/Types/Date.test.js +0 -194
  536. package/build/dist/Tests/Types/Date.test.js.map +0 -1
  537. package/build/dist/Tests/Types/Dictionary.test.js +0 -25
  538. package/build/dist/Tests/Types/Dictionary.test.js.map +0 -1
  539. package/build/dist/Tests/Types/Domain.test.js +0 -54
  540. package/build/dist/Tests/Types/Domain.test.js.map +0 -1
  541. package/build/dist/Tests/Types/Email/Email.test.js +0 -51
  542. package/build/dist/Tests/Types/Email/Email.test.js.map +0 -1
  543. package/build/dist/Tests/Types/EmailWithName.test.js +0 -36
  544. package/build/dist/Tests/Types/EmailWithName.test.js.map +0 -1
  545. package/build/dist/Tests/Types/EncryptionAlgorithm.test.js +0 -7
  546. package/build/dist/Tests/Types/EncryptionAlgorithm.test.js.map +0 -1
  547. package/build/dist/Tests/Types/Exception/ApiException.test.js +0 -10
  548. package/build/dist/Tests/Types/Exception/ApiException.test.js.map +0 -1
  549. package/build/dist/Tests/Types/Exception/BadDataException.test.js +0 -12
  550. package/build/dist/Tests/Types/Exception/BadDataException.test.js.map +0 -1
  551. package/build/dist/Tests/Types/Exception/BadOperationException.test.js +0 -10
  552. package/build/dist/Tests/Types/Exception/BadOperationException.test.js.map +0 -1
  553. package/build/dist/Tests/Types/Exception/BadRequestException.test.js +0 -12
  554. package/build/dist/Tests/Types/Exception/BadRequestException.test.js.map +0 -1
  555. package/build/dist/Tests/Types/Exception/DatabaseNotConnectedException.test.js +0 -10
  556. package/build/dist/Tests/Types/Exception/DatabaseNotConnectedException.test.js.map +0 -1
  557. package/build/dist/Tests/Types/Exception/Exception.test.js +0 -15
  558. package/build/dist/Tests/Types/Exception/Exception.test.js.map +0 -1
  559. package/build/dist/Tests/Types/Exception/NotImplementedException.test.js +0 -12
  560. package/build/dist/Tests/Types/Exception/NotImplementedException.test.js.map +0 -1
  561. package/build/dist/Tests/Types/File.test.js +0 -22
  562. package/build/dist/Tests/Types/File.test.js.map +0 -1
  563. package/build/dist/Tests/Types/HashedString.test.js +0 -51
  564. package/build/dist/Tests/Types/HashedString.test.js.map +0 -1
  565. package/build/dist/Tests/Types/Html.test.js +0 -8
  566. package/build/dist/Tests/Types/Html.test.js.map +0 -1
  567. package/build/dist/Tests/Types/IP/IP.test.js +0 -65
  568. package/build/dist/Tests/Types/IP/IP.test.js.map +0 -1
  569. package/build/dist/Tests/Types/IP/IPType.test.js +0 -10
  570. package/build/dist/Tests/Types/IP/IPType.test.js.map +0 -1
  571. package/build/dist/Tests/Types/IP/IPv4.test.js +0 -17
  572. package/build/dist/Tests/Types/IP/IPv4.test.js.map +0 -1
  573. package/build/dist/Tests/Types/IP/IPv6.test.js +0 -17
  574. package/build/dist/Tests/Types/IP/IPv6.test.js.map +0 -1
  575. package/build/dist/Tests/Types/JSON.test.js +0 -37
  576. package/build/dist/Tests/Types/JSON.test.js.map +0 -1
  577. package/build/dist/Tests/Types/JSONFunctions.test.js +0 -38
  578. package/build/dist/Tests/Types/JSONFunctions.test.js.map +0 -1
  579. package/build/dist/Tests/Types/ListData.test.js +0 -34
  580. package/build/dist/Tests/Types/ListData.test.js.map +0 -1
  581. package/build/dist/Tests/Types/Monitor/KubernetesAlertTemplates.test.js +0 -121
  582. package/build/dist/Tests/Types/Monitor/KubernetesAlertTemplates.test.js.map +0 -1
  583. package/build/dist/Tests/Types/Name.test.js +0 -26
  584. package/build/dist/Tests/Types/Name.test.js.map +0 -1
  585. package/build/dist/Tests/Types/ObjectID.test.js +0 -12
  586. package/build/dist/Tests/Types/ObjectID.test.js.map +0 -1
  587. package/build/dist/Tests/Types/OnCallDutyPolicy/LayerUtil.test.js +0 -530
  588. package/build/dist/Tests/Types/OnCallDutyPolicy/LayerUtil.test.js.map +0 -1
  589. package/build/dist/Tests/Types/Permission.test.js +0 -99
  590. package/build/dist/Tests/Types/Permission.test.js.map +0 -1
  591. package/build/dist/Tests/Types/Phone.test.js +0 -37
  592. package/build/dist/Tests/Types/Phone.test.js.map +0 -1
  593. package/build/dist/Tests/Types/Port.test.js +0 -35
  594. package/build/dist/Tests/Types/Port.test.js.map +0 -1
  595. package/build/dist/Tests/Types/PositiveNumber.test.js +0 -101
  596. package/build/dist/Tests/Types/PositiveNumber.test.js.map +0 -1
  597. package/build/dist/Tests/Types/SecuritySeverity.test.js +0 -16
  598. package/build/dist/Tests/Types/SecuritySeverity.test.js.map +0 -1
  599. package/build/dist/Tests/Types/SerializableObject.test.js +0 -37
  600. package/build/dist/Tests/Types/SerializableObject.test.js.map +0 -1
  601. package/build/dist/Tests/Types/Sleep.test.js +0 -14
  602. package/build/dist/Tests/Types/Sleep.test.js.map +0 -1
  603. package/build/dist/Tests/Types/Text.test.js +0 -8
  604. package/build/dist/Tests/Types/Text.test.js.map +0 -1
  605. package/build/dist/Tests/Types/Timezone.test.js +0 -596
  606. package/build/dist/Tests/Types/Timezone.test.js.map +0 -1
  607. package/build/dist/Tests/Types/Typeof.test.js +0 -16
  608. package/build/dist/Tests/Types/Typeof.test.js.map +0 -1
  609. package/build/dist/Tests/Types/UserType.test.js +0 -16
  610. package/build/dist/Tests/Types/UserType.test.js.map +0 -1
  611. package/build/dist/Tests/Types/Version.test.js +0 -35
  612. package/build/dist/Tests/Types/Version.test.js.map +0 -1
  613. package/build/dist/Tests/Types/XML.test.js +0 -35
  614. package/build/dist/Tests/Types/XML.test.js.map +0 -1
  615. package/build/dist/Tests/UI/Components/404.test.js +0 -59
  616. package/build/dist/Tests/UI/Components/404.test.js.map +0 -1
  617. package/build/dist/Tests/UI/Components/Alert.test.js +0 -83
  618. package/build/dist/Tests/UI/Components/Alert.test.js.map +0 -1
  619. package/build/dist/Tests/UI/Components/Badge.test.js +0 -59
  620. package/build/dist/Tests/UI/Components/Badge.test.js.map +0 -1
  621. package/build/dist/Tests/UI/Components/BasicForm.test.js +0 -92
  622. package/build/dist/Tests/UI/Components/BasicForm.test.js.map +0 -1
  623. package/build/dist/Tests/UI/Components/Breadcrumbs.test.js +0 -69
  624. package/build/dist/Tests/UI/Components/Breadcrumbs.test.js.map +0 -1
  625. package/build/dist/Tests/UI/Components/Button.test.js +0 -104
  626. package/build/dist/Tests/UI/Components/Button.test.js.map +0 -1
  627. package/build/dist/Tests/UI/Components/Card.test.js +0 -81
  628. package/build/dist/Tests/UI/Components/Card.test.js.map +0 -1
  629. package/build/dist/Tests/UI/Components/ColorViewer.test.js +0 -42
  630. package/build/dist/Tests/UI/Components/ColorViewer.test.js.map +0 -1
  631. package/build/dist/Tests/UI/Components/ComponentsModal.test.js +0 -233
  632. package/build/dist/Tests/UI/Components/ComponentsModal.test.js.map +0 -1
  633. package/build/dist/Tests/UI/Components/ConfirmModal.test.js +0 -57
  634. package/build/dist/Tests/UI/Components/ConfirmModal.test.js.map +0 -1
  635. package/build/dist/Tests/UI/Components/DictionaryOfStrings.test.js +0 -84
  636. package/build/dist/Tests/UI/Components/DictionaryOfStrings.test.js.map +0 -1
  637. package/build/dist/Tests/UI/Components/Dropdown.test.js +0 -146
  638. package/build/dist/Tests/UI/Components/Dropdown.test.js.map +0 -1
  639. package/build/dist/Tests/UI/Components/DuplicateModel.test.js +0 -229
  640. package/build/dist/Tests/UI/Components/DuplicateModel.test.js.map +0 -1
  641. package/build/dist/Tests/UI/Components/EmptyState/EmptyState.test.js +0 -26
  642. package/build/dist/Tests/UI/Components/EmptyState/EmptyState.test.js.map +0 -1
  643. package/build/dist/Tests/UI/Components/ErrorBoundary.test.js +0 -32
  644. package/build/dist/Tests/UI/Components/ErrorBoundary.test.js.map +0 -1
  645. package/build/dist/Tests/UI/Components/FilePicker.test.js +0 -342
  646. package/build/dist/Tests/UI/Components/FilePicker.test.js.map +0 -1
  647. package/build/dist/Tests/UI/Components/HiddenText.test.js +0 -50
  648. package/build/dist/Tests/UI/Components/HiddenText.test.js.map +0 -1
  649. package/build/dist/Tests/UI/Components/Input.test.js +0 -223
  650. package/build/dist/Tests/UI/Components/Input.test.js.map +0 -1
  651. package/build/dist/Tests/UI/Components/Item.test.js +0 -58
  652. package/build/dist/Tests/UI/Components/Item.test.js.map +0 -1
  653. package/build/dist/Tests/UI/Components/List.test.js +0 -83
  654. package/build/dist/Tests/UI/Components/List.test.js.map +0 -1
  655. package/build/dist/Tests/UI/Components/Loader.test.js +0 -19
  656. package/build/dist/Tests/UI/Components/Loader.test.js.map +0 -1
  657. package/build/dist/Tests/UI/Components/MarkdownEditor.test.js +0 -85
  658. package/build/dist/Tests/UI/Components/MarkdownEditor.test.js.map +0 -1
  659. package/build/dist/Tests/UI/Components/MasterPage.test.js +0 -46
  660. package/build/dist/Tests/UI/Components/MasterPage.test.js.map +0 -1
  661. package/build/dist/Tests/UI/Components/Modal.test.js +0 -127
  662. package/build/dist/Tests/UI/Components/Modal.test.js.map +0 -1
  663. package/build/dist/Tests/UI/Components/NavBar.test.js +0 -52
  664. package/build/dist/Tests/UI/Components/NavBar.test.js.map +0 -1
  665. package/build/dist/Tests/UI/Components/OrderedStatesList.test.js +0 -86
  666. package/build/dist/Tests/UI/Components/OrderedStatesList.test.js.map +0 -1
  667. package/build/dist/Tests/UI/Components/Pagination.test.js +0 -137
  668. package/build/dist/Tests/UI/Components/Pagination.test.js.map +0 -1
  669. package/build/dist/Tests/UI/Components/Pill.test.js +0 -55
  670. package/build/dist/Tests/UI/Components/Pill.test.js.map +0 -1
  671. package/build/dist/Tests/UI/Components/Probe.test.js +0 -52
  672. package/build/dist/Tests/UI/Components/Probe.test.js.map +0 -1
  673. package/build/dist/Tests/UI/Components/ProgressBar.test.js +0 -41
  674. package/build/dist/Tests/UI/Components/ProgressBar.test.js.map +0 -1
  675. package/build/dist/Tests/UI/Components/RadioButtons.test.js +0 -66
  676. package/build/dist/Tests/UI/Components/RadioButtons.test.js.map +0 -1
  677. package/build/dist/Tests/UI/Components/SideMenuItem.test.js +0 -99
  678. package/build/dist/Tests/UI/Components/SideMenuItem.test.js.map +0 -1
  679. package/build/dist/Tests/UI/Components/SideOver.test.js +0 -77
  680. package/build/dist/Tests/UI/Components/SideOver.test.js.map +0 -1
  681. package/build/dist/Tests/UI/Components/Tabs.test.js +0 -56
  682. package/build/dist/Tests/UI/Components/Tabs.test.js.map +0 -1
  683. package/build/dist/Tests/UI/Components/Template/Template.test.js +0 -15
  684. package/build/dist/Tests/UI/Components/Template/Template.test.js.map +0 -1
  685. package/build/dist/Tests/UI/Components/TextArea.test.js +0 -112
  686. package/build/dist/Tests/UI/Components/TextArea.test.js.map +0 -1
  687. package/build/dist/Tests/UI/Components/TimePicker/TimePicker.test.js +0 -352
  688. package/build/dist/Tests/UI/Components/TimePicker/TimePicker.test.js.map +0 -1
  689. package/build/dist/Tests/UI/Components/Toast.test.js +0 -48
  690. package/build/dist/Tests/UI/Components/Toast.test.js.map +0 -1
  691. package/build/dist/Tests/UI/Components/Toggle.test.js +0 -95
  692. package/build/dist/Tests/UI/Components/Toggle.test.js.map +0 -1
  693. package/build/dist/Tests/UI/Components/TopSection.test.js +0 -33
  694. package/build/dist/Tests/UI/Components/TopSection.test.js.map +0 -1
  695. package/build/dist/Tests/UI/Components/XAxis.test.js +0 -21
  696. package/build/dist/Tests/UI/Components/XAxis.test.js.map +0 -1
  697. package/build/dist/Tests/UI/Index.js +0 -2
  698. package/build/dist/Tests/UI/Index.js.map +0 -1
  699. package/build/dist/Tests/UI/Mocks/FileMock.js +0 -3
  700. package/build/dist/Tests/UI/Mocks/FileMock.js.map +0 -1
  701. package/build/dist/Tests/Utils/API.test.js +0 -399
  702. package/build/dist/Tests/Utils/API.test.js.map +0 -1
  703. package/build/dist/Tests/Utils/Analytics.test.js +0 -67
  704. package/build/dist/Tests/Utils/Analytics.test.js.map +0 -1
  705. package/build/dist/Tests/Utils/CronTime.test.js +0 -22
  706. package/build/dist/Tests/Utils/CronTime.test.js.map +0 -1
  707. package/build/dist/Tests/Utils/Faker.test.js +0 -27
  708. package/build/dist/Tests/Utils/Faker.test.js.map +0 -1
  709. package/build/dist/Tests/Utils/MetricUnitUtil.test.js +0 -187
  710. package/build/dist/Tests/Utils/MetricUnitUtil.test.js.map +0 -1
  711. package/build/dist/Tests/Utils/Metrics/MetricFormulaEvaluator.test.js +0 -224
  712. package/build/dist/Tests/Utils/Metrics/MetricFormulaEvaluator.test.js.map +0 -1
  713. package/build/dist/Tests/Utils/Metrics/MetricResultUnitConverter.test.js +0 -180
  714. package/build/dist/Tests/Utils/Metrics/MetricResultUnitConverter.test.js.map +0 -1
  715. package/build/dist/Tests/Utils/RecordingRuleExpression.test.js +0 -142
  716. package/build/dist/Tests/Utils/RecordingRuleExpression.test.js.map +0 -1
  717. package/build/dist/Tests/Utils/Slug.test.js +0 -20
  718. package/build/dist/Tests/Utils/Slug.test.js.map +0 -1
  719. package/build/dist/Tests/Utils/UUID.test.js +0 -48
  720. package/build/dist/Tests/Utils/UUID.test.js.map +0 -1
  721. package/build/dist/Tests/jest.setup.js +0 -30
  722. package/build/dist/Tests/jest.setup.js.map +0 -1
  723. package/build/dist/Types/Profile/ProfileMetricType.js +0 -17
  724. package/build/dist/Types/Profile/ProfileMetricType.js.map +0 -1
@@ -0,0 +1,403 @@
1
+ import TraceAggregationService, {
2
+ FacetRequest,
3
+ HistogramRequest,
4
+ TraceAnalyticsRequest,
5
+ } from "../../../Server/Services/TraceAggregationService";
6
+ import { Statement } from "../../../Server/Utils/AnalyticsDatabase/Statement";
7
+ import ObjectID from "../../../Types/ObjectID";
8
+ import { describe, expect, test } from "@jest/globals";
9
+
10
+ describe("TraceAggregationService", () => {
11
+ const defaultRequest: HistogramRequest = {
12
+ projectId: ObjectID.generate(),
13
+ startTime: new Date("2026-06-01T00:00:00.000Z"),
14
+ endTime: new Date("2026-06-02T00:00:00.000Z"),
15
+ bucketSizeInMinutes: 5,
16
+ };
17
+
18
+ const buildHistogramStatement: (
19
+ overrides?: Partial<HistogramRequest>,
20
+ ) => Statement = (overrides: Partial<HistogramRequest> = {}): Statement => {
21
+ return (TraceAggregationService as any).buildHistogramStatement({
22
+ ...defaultRequest,
23
+ ...overrides,
24
+ });
25
+ };
26
+
27
+ const paramValues: (statement: Statement) => Array<unknown> = (
28
+ statement: Statement,
29
+ ): Array<unknown> => {
30
+ return Object.values(statement.query_params);
31
+ };
32
+
33
+ /*
34
+ * The query getter dedents the rendered SQL, so appended predicates can
35
+ * land at line start with no leading space — normalize all whitespace
36
+ * before asserting on SQL fragments.
37
+ */
38
+ const normalizedQuery: (statement: Statement) => string = (
39
+ statement: Statement,
40
+ ): string => {
41
+ return statement.query.replace(/\s+/g, " ");
42
+ };
43
+
44
+ /*
45
+ * The span list compiles a single `name` filter to `name ILIKE '%v%'`
46
+ * (Search). The histogram/facets must use the same semantics for the same
47
+ * filter or the chart disagrees with the list — a partial name like
48
+ * "ShipShipment" against spans named "POST /Shipment/ShipShipment/" would
49
+ * fill the list but empty the chart.
50
+ */
51
+ test("spanNameSearches compiles to substring ILIKE, matching list semantics", () => {
52
+ const statement: Statement = buildHistogramStatement({
53
+ spanNameSearches: ["ShipShipment"],
54
+ });
55
+
56
+ expect(normalizedQuery(statement)).toContain(" AND name ILIKE ");
57
+ expect(normalizedQuery(statement)).not.toContain(" AND name IN ");
58
+ expect(paramValues(statement)).toContain("%ShipShipment%");
59
+ });
60
+
61
+ test("whitespace-only spanNameSearches entries are skipped", () => {
62
+ const statement: Statement = buildHistogramStatement({
63
+ spanNameSearches: [" ", "checkout"],
64
+ });
65
+
66
+ const ilikeMatches: Array<string> =
67
+ normalizedQuery(statement).match(/ AND name ILIKE /g) || [];
68
+ expect(ilikeMatches).toHaveLength(1);
69
+ expect(paramValues(statement)).toContain("%checkout%");
70
+ });
71
+
72
+ test("multiple spanNameSearches entries AND together", () => {
73
+ const statement: Statement = buildHistogramStatement({
74
+ spanNameSearches: ["Shipment", "POST"],
75
+ });
76
+
77
+ const ilikeMatches: Array<string> =
78
+ normalizedQuery(statement).match(/ AND name ILIKE /g) || [];
79
+ expect(ilikeMatches).toHaveLength(2);
80
+ expect(paramValues(statement)).toContain("%Shipment%");
81
+ expect(paramValues(statement)).toContain("%POST%");
82
+ });
83
+
84
+ test("search values are kept verbatim — list-side Search does not trim", () => {
85
+ const statement: Statement = buildHistogramStatement({
86
+ spanNameSearches: [" GET /api "],
87
+ statusMessageSearchText: " connection reset ",
88
+ });
89
+
90
+ expect(paramValues(statement)).toContain("% GET /api %");
91
+ expect(paramValues(statement)).toContain("% connection reset %");
92
+ });
93
+
94
+ test("statusMessages compiles to exact statusMessage IN", () => {
95
+ const statement: Statement = buildHistogramStatement({
96
+ statusMessages: ["timeout", "connection reset"],
97
+ });
98
+
99
+ expect(normalizedQuery(statement)).toContain(" AND statusMessage IN (");
100
+ expect(paramValues(statement)).toContainEqual([
101
+ "timeout",
102
+ "connection reset",
103
+ ]);
104
+ });
105
+
106
+ test("spanNames stays exact-match (multi-value list filters use Includes)", () => {
107
+ const statement: Statement = buildHistogramStatement({
108
+ spanNames: ["POST /Shipment/ShipShipment/"],
109
+ });
110
+
111
+ expect(normalizedQuery(statement)).toContain(" AND name IN (");
112
+ expect(normalizedQuery(statement)).not.toContain(" AND name ILIKE ");
113
+ expect(paramValues(statement)).toContainEqual([
114
+ "POST /Shipment/ShipShipment/",
115
+ ]);
116
+ });
117
+
118
+ test("spanIds compiles to spanId IN", () => {
119
+ const statement: Statement = buildHistogramStatement({
120
+ spanIds: ["abc123", "def456"],
121
+ });
122
+
123
+ expect(normalizedQuery(statement)).toContain(" AND spanId IN (");
124
+ expect(paramValues(statement)).toContainEqual(["abc123", "def456"]);
125
+ });
126
+
127
+ test("hasException compiles to a boolean predicate only when set", () => {
128
+ expect(
129
+ normalizedQuery(buildHistogramStatement({ hasException: true })),
130
+ ).toContain(" AND hasException = 1");
131
+ expect(
132
+ normalizedQuery(buildHistogramStatement({ hasException: false })),
133
+ ).toContain(" AND hasException = 0");
134
+ expect(normalizedQuery(buildHistogramStatement())).not.toContain(
135
+ "hasException",
136
+ );
137
+ });
138
+
139
+ test("statusMessageSearchText compiles to substring ILIKE", () => {
140
+ const statement: Statement = buildHistogramStatement({
141
+ statusMessageSearchText: "timeout",
142
+ });
143
+
144
+ expect(normalizedQuery(statement)).toContain(" AND statusMessage ILIKE ");
145
+ expect(paramValues(statement)).toContain("%timeout%");
146
+ });
147
+
148
+ test("duration bounds compile to strict Int128 comparisons", () => {
149
+ /*
150
+ * Strict `>` / `<` mirror the list's GreaterThan/LessThan compilation.
151
+ * Int128 (LongNumber) is required: an Int32 param overflows for spans
152
+ * longer than ~2.1 seconds (durations are in nanoseconds).
153
+ */
154
+ const statement: Statement = buildHistogramStatement({
155
+ minDurationNano: 5_000_000_000,
156
+ maxDurationNano: 90_000_000_000,
157
+ });
158
+
159
+ expect(normalizedQuery(statement)).toMatch(
160
+ / AND durationUnixNano > \{p\d+:Int128\}/,
161
+ );
162
+ expect(normalizedQuery(statement)).toMatch(
163
+ / AND durationUnixNano < \{p\d+:Int128\}/,
164
+ );
165
+ expect(paramValues(statement)).toContain(5_000_000_000);
166
+ expect(paramValues(statement)).toContain(90_000_000_000);
167
+ });
168
+
169
+ test("a zero duration bound still compiles (duration:>0)", () => {
170
+ const statement: Statement = buildHistogramStatement({
171
+ minDurationNano: 0,
172
+ });
173
+
174
+ expect(normalizedQuery(statement)).toMatch(
175
+ / AND durationUnixNano > \{p\d+:Int128\}/,
176
+ );
177
+ expect(paramValues(statement)).toContain(0);
178
+ });
179
+
180
+ test("exactDurationNano compiles to equality (duration:N without operator)", () => {
181
+ const statement: Statement = buildHistogramStatement({
182
+ exactDurationNano: 500_000_000,
183
+ });
184
+
185
+ expect(normalizedQuery(statement)).toMatch(
186
+ / AND durationUnixNano = \{p\d+:Int128\}/,
187
+ );
188
+ expect(paramValues(statement)).toContain(500_000_000);
189
+ });
190
+
191
+ test("facet queries share the same filter compilation", () => {
192
+ const facetRequest: FacetRequest = {
193
+ projectId: defaultRequest.projectId,
194
+ startTime: defaultRequest.startTime,
195
+ endTime: defaultRequest.endTime,
196
+ facetKey: "kind",
197
+ spanNameSearches: ["ShipShipment"],
198
+ hasException: true,
199
+ };
200
+
201
+ const statement: Statement = (
202
+ TraceAggregationService as any
203
+ ).buildFacetStatement(facetRequest);
204
+
205
+ expect(statement.query).toContain(" AND name ILIKE ");
206
+ expect(statement.query).toContain(" AND hasException = 1");
207
+ expect(paramValues(statement)).toContain("%ShipShipment%");
208
+ });
209
+
210
+ test("attributeSearches compiles to case-insensitive-key contains match", () => {
211
+ const statement: Statement = buildHistogramStatement({
212
+ attributeSearches: { "url.host": "starship.online" },
213
+ });
214
+
215
+ expect(statement.query).toContain(
216
+ "arrayExists((k, v) -> lowerUTF8(k) = lowerUTF8(",
217
+ );
218
+ expect(statement.query).toContain(") AND v ILIKE ");
219
+ expect(paramValues(statement)).toContain("url.host");
220
+ expect(paramValues(statement)).toContain("%starship.online%");
221
+ });
222
+
223
+ test("attributeSearches rejects malicious keys and skips blank values", () => {
224
+ expect(() => {
225
+ buildHistogramStatement({
226
+ attributeSearches: { "x') OR 1=1 --": "v" },
227
+ });
228
+ }).toThrow("Invalid facetKey");
229
+
230
+ const statement: Statement = buildHistogramStatement({
231
+ attributeSearches: { "url.host": " " },
232
+ });
233
+ expect(statement.query).not.toContain("ILIKE");
234
+ });
235
+
236
+ describe("analytics builders", () => {
237
+ const analyticsRequest: TraceAnalyticsRequest = {
238
+ projectId: defaultRequest.projectId,
239
+ startTime: defaultRequest.startTime,
240
+ endTime: defaultRequest.endTime,
241
+ bucketSizeInMinutes: 5,
242
+ chartType: "timeseries",
243
+ metric: "p50Duration",
244
+ };
245
+
246
+ test("timeseries groups by an attribute dimension with sanitized alias", () => {
247
+ const statement: Statement = (
248
+ TraceAggregationService as any
249
+ ).buildAnalyticsTimeseriesStatement({
250
+ ...analyticsRequest,
251
+ groupBy: ["url.host"],
252
+ });
253
+
254
+ const query: string = normalizedQuery(statement);
255
+ expect(query).toContain(
256
+ "quantile(0.5)(durationUnixNano) / 1000000 AS val",
257
+ );
258
+ // The alias binds as an Identifier param (same as the logs builder).
259
+ expect(query).toMatch(
260
+ /attributes\[\{p\d+:String\}\] AS \{p\d+:Identifier\}/,
261
+ );
262
+ expect(query).toContain("mapContains(attributes, ");
263
+ expect(query).toContain(" GROUP BY bucket, attr_0_url_host");
264
+ expect(paramValues(statement)).toContain("url.host");
265
+ expect(paramValues(statement)).toContain("attr_0_url_host");
266
+ });
267
+
268
+ test("timeseries caps series to pre-resolved top dimension values", () => {
269
+ const statement: Statement = (
270
+ TraceAggregationService as any
271
+ ).buildAnalyticsTimeseriesStatement(
272
+ {
273
+ ...analyticsRequest,
274
+ groupBy: ["url.host"],
275
+ },
276
+ ["torginol.starship.online", "daymotorsports.starship.online"],
277
+ );
278
+
279
+ const query: string = normalizedQuery(statement);
280
+ expect(query).toMatch(/attributes\[\{p\d+:String\}\] IN \(/);
281
+ expect(paramValues(statement)).toContainEqual([
282
+ "torginol.starship.online",
283
+ "daymotorsports.starship.online",
284
+ ]);
285
+ });
286
+
287
+ test("timeseries groups by a top-level column without parameterization", () => {
288
+ const statement: Statement = (
289
+ TraceAggregationService as any
290
+ ).buildAnalyticsTimeseriesStatement({
291
+ ...analyticsRequest,
292
+ metric: "count",
293
+ groupBy: ["name"],
294
+ });
295
+
296
+ const query: string = normalizedQuery(statement);
297
+ expect(query).toContain("count() AS val");
298
+ expect(query).toContain(", toString(name) AS name");
299
+ expect(query).toContain(" GROUP BY bucket, name");
300
+ });
301
+
302
+ test("top list ranks by the selected metric and returns counts", () => {
303
+ const statement: Statement = (
304
+ TraceAggregationService as any
305
+ ).buildAnalyticsTopListStatement({
306
+ ...analyticsRequest,
307
+ metric: "errorCount",
308
+ groupBy: ["url.host"],
309
+ limit: 25,
310
+ });
311
+
312
+ const query: string = normalizedQuery(statement);
313
+ expect(query).toContain("countIf(statusCode = 2) AS val");
314
+ expect(query).toContain("count() AS cnt");
315
+ expect(query).toContain(" GROUP BY dim ORDER BY val DESC LIMIT ");
316
+ expect(paramValues(statement)).toContain(25);
317
+ });
318
+
319
+ test("table returns the full duration stat set per dimension", () => {
320
+ const statement: Statement = (
321
+ TraceAggregationService as any
322
+ ).buildAnalyticsTableStatement({
323
+ ...analyticsRequest,
324
+ chartType: "table",
325
+ groupBy: ["url.host"],
326
+ spanNames: ["/Shipment/ShipShipment"],
327
+ });
328
+
329
+ const query: string = normalizedQuery(statement);
330
+ expect(query).toContain("count() AS cnt");
331
+ expect(query).toContain("avg(durationUnixNano) / 1000000 AS avg_ms");
332
+ expect(query).toContain(
333
+ "quantile(0.5)(durationUnixNano) / 1000000 AS p50_ms",
334
+ );
335
+ expect(query).toContain("min(durationUnixNano) / 1000000 AS min_ms");
336
+ expect(query).toContain("max(durationUnixNano) / 1000000 AS max_ms");
337
+ expect(query).toContain(" AND name IN (");
338
+ expect(query).toContain(" GROUP BY attr_0_url_host ORDER BY cnt DESC");
339
+ });
340
+
341
+ test("group-by rejects malicious dimension keys and >2 dimensions", () => {
342
+ expect(() => {
343
+ (TraceAggregationService as any).buildAnalyticsTimeseriesStatement({
344
+ ...analyticsRequest,
345
+ groupBy: ["x') AS v FROM system.tables --"],
346
+ });
347
+ }).toThrow("Invalid facetKey");
348
+
349
+ expect(() => {
350
+ (TraceAggregationService as any).buildAnalyticsTimeseriesStatement({
351
+ ...analyticsRequest,
352
+ groupBy: ["name", "kind", "statusCode"],
353
+ });
354
+ }).toThrow("groupBy supports at most 2 dimensions");
355
+ });
356
+
357
+ test("colliding attribute keys get distinct index-based aliases", () => {
358
+ const statement: Statement = (
359
+ TraceAggregationService as any
360
+ ).buildAnalyticsTimeseriesStatement({
361
+ ...analyticsRequest,
362
+ groupBy: ["url.host", "url:host"],
363
+ });
364
+
365
+ const query: string = normalizedQuery(statement);
366
+ expect(query).toContain(
367
+ " GROUP BY bucket, attr_0_url_host, attr_1_url_host",
368
+ );
369
+ expect(paramValues(statement)).toContain("attr_0_url_host");
370
+ expect(paramValues(statement)).toContain("attr_1_url_host");
371
+ });
372
+
373
+ test("Service dimension is restricted to telemetry-service spans", () => {
374
+ const statement: Statement = (
375
+ TraceAggregationService as any
376
+ ).buildAnalyticsTableStatement({
377
+ ...analyticsRequest,
378
+ chartType: "table",
379
+ groupBy: ["primaryEntityId"],
380
+ });
381
+
382
+ const query: string = normalizedQuery(statement);
383
+ expect(query).toContain(
384
+ " AND (primaryEntityType = '' OR primaryEntityType = ",
385
+ );
386
+ });
387
+
388
+ test("metric validation", () => {
389
+ expect(TraceAggregationService.isValidAnalyticsMetric("count")).toBe(
390
+ true,
391
+ );
392
+ expect(
393
+ TraceAggregationService.isValidAnalyticsMetric("p95Duration"),
394
+ ).toBe(true);
395
+ expect(TraceAggregationService.isValidAnalyticsMetric("drop table")).toBe(
396
+ false,
397
+ );
398
+ expect(TraceAggregationService.isValidAnalyticsMetric("__proto__")).toBe(
399
+ false,
400
+ );
401
+ });
402
+ });
403
+ });
@@ -0,0 +1,114 @@
1
+ import DatabaseRequestType from "../../../../Server/Types/BaseDatabase/DatabaseRequestType";
2
+ import ModelPermission from "../../../../Server/Types/AnalyticsDatabase/ModelPermission";
3
+ import Log from "../../../../Models/AnalyticsModels/Log";
4
+ import DatabaseCommonInteractionProps from "../../../../Types/BaseDatabase/DatabaseCommonInteractionProps";
5
+ import Includes from "../../../../Types/BaseDatabase/Includes";
6
+ import PermissionScope from "../../../../Types/Database/AccessControl/PermissionScope";
7
+ import ObjectID from "../../../../Types/ObjectID";
8
+ import Permission, {
9
+ UserTenantAccessPermission,
10
+ } from "../../../../Types/Permission";
11
+
12
+ describe("Analytics ModelPermission owned scope", () => {
13
+ const projectId: ObjectID = ObjectID.generate();
14
+ const userId: ObjectID = ObjectID.generate();
15
+ const ownedServiceA: ObjectID = ObjectID.generate();
16
+ const ownedServiceB: ObjectID = ObjectID.generate();
17
+
18
+ function makeOwnedScopedMemberProps(): DatabaseCommonInteractionProps {
19
+ const tenantPermission: UserTenantAccessPermission = {
20
+ projectId,
21
+ _type: "UserTenantAccessPermission",
22
+ permissions: [
23
+ {
24
+ _type: "UserPermission",
25
+ permission: Permission.ProjectMember,
26
+ labelIds: [],
27
+ isBlockPermission: false,
28
+ scope: PermissionScope.Owned,
29
+ },
30
+ ],
31
+ };
32
+
33
+ return {
34
+ userId,
35
+ tenantId: projectId,
36
+ userTenantAccessPermission: {
37
+ [projectId.toString()]: tenantPermission,
38
+ },
39
+ };
40
+ }
41
+
42
+ beforeEach(() => {
43
+ jest
44
+ .spyOn(ModelPermission as any, "resolveOwnedParentIds")
45
+ .mockResolvedValue(
46
+ new Set<string>([ownedServiceA.toString(), ownedServiceB.toString()]),
47
+ );
48
+ });
49
+
50
+ afterEach(() => {
51
+ jest.restoreAllMocks();
52
+ });
53
+
54
+ async function addOwnedScope(query: any): Promise<any> {
55
+ return await (ModelPermission as any).addOwnedScopeToQuery(
56
+ Log,
57
+ query,
58
+ makeOwnedScopedMemberProps(),
59
+ DatabaseRequestType.Read,
60
+ );
61
+ }
62
+
63
+ it("intersects a caller-supplied primaryEntityId filter with owned ids", async () => {
64
+ const result: any = await addOwnedScope({
65
+ projectId,
66
+ primaryEntityId: ownedServiceA,
67
+ });
68
+
69
+ /*
70
+ * Regression: the owned-scope filter used to overwrite the caller's
71
+ * primaryEntityId, so a per-service telemetry page showed logs from
72
+ * every owned service.
73
+ */
74
+ expect(result.primaryEntityId).toBeInstanceOf(Includes);
75
+ expect(result.primaryEntityId.values).toEqual([ownedServiceA.toString()]);
76
+ });
77
+
78
+ it("matches nothing when the requested service is not owned", async () => {
79
+ const result: any = await addOwnedScope({
80
+ projectId,
81
+ primaryEntityId: ObjectID.generate(),
82
+ });
83
+
84
+ expect(result.primaryEntityId).toBeInstanceOf(Includes);
85
+ expect(result.primaryEntityId.values).toEqual([
86
+ ObjectID.getZeroObjectID().toString(),
87
+ ]);
88
+ });
89
+
90
+ it("intersects a caller-supplied Includes filter", async () => {
91
+ const unownedService: ObjectID = ObjectID.generate();
92
+ const result: any = await addOwnedScope({
93
+ projectId,
94
+ primaryEntityId: new Includes([ownedServiceB, unownedService]),
95
+ });
96
+
97
+ expect(result.primaryEntityId).toBeInstanceOf(Includes);
98
+ expect(result.primaryEntityId.values).toEqual([ownedServiceB.toString()]);
99
+ });
100
+
101
+ it("applies all allowed ids when the caller has no FK filter", async () => {
102
+ const result: any = await addOwnedScope({ projectId });
103
+
104
+ expect(result.primaryEntityId).toBeInstanceOf(Includes);
105
+ // Owned services plus the project-scope bucket for unattributed telemetry.
106
+ expect(new Set(result.primaryEntityId.values)).toEqual(
107
+ new Set([
108
+ ownedServiceA.toString(),
109
+ ownedServiceB.toString(),
110
+ projectId.toString(),
111
+ ]),
112
+ );
113
+ });
114
+ });
@@ -0,0 +1,189 @@
1
+ import DatabaseRequestType from "../../../../../Server/Types/BaseDatabase/DatabaseRequestType";
2
+ import AccessControlPermission from "../../../../../Server/Types/Database/Permissions/AccessControlPermission";
3
+ import QueryUtil from "../../../../../Server/Types/Database/QueryUtil";
4
+ import Monitor from "../../../../../Models/DatabaseModels/Monitor";
5
+ import DatabaseCommonInteractionProps from "../../../../../Types/BaseDatabase/DatabaseCommonInteractionProps";
6
+ import ObjectID from "../../../../../Types/ObjectID";
7
+ import Permission, {
8
+ UserTenantAccessPermission,
9
+ } from "../../../../../Types/Permission";
10
+ import { FindOperator } from "typeorm";
11
+
12
+ describe("AccessControlPermission.addAccessControlIdsToQuery", () => {
13
+ const projectId: ObjectID = ObjectID.generate();
14
+ const userId: ObjectID = ObjectID.generate();
15
+ const permittedLabelA: ObjectID = ObjectID.generate();
16
+ const permittedLabelB: ObjectID = ObjectID.generate();
17
+
18
+ function makeLabelRestrictedProps(): DatabaseCommonInteractionProps {
19
+ // A user whose ONLY read grant on Monitor is label-restricted.
20
+ const tenantPermission: UserTenantAccessPermission = {
21
+ projectId,
22
+ _type: "UserTenantAccessPermission",
23
+ permissions: [
24
+ {
25
+ _type: "UserPermission",
26
+ permission: Permission.ReadProjectMonitor,
27
+ labelIds: [permittedLabelA, permittedLabelB],
28
+ isBlockPermission: false,
29
+ },
30
+ ],
31
+ };
32
+
33
+ return {
34
+ userId,
35
+ tenantId: projectId,
36
+ userTenantAccessPermission: {
37
+ [projectId.toString()]: tenantPermission,
38
+ },
39
+ };
40
+ }
41
+
42
+ function mockJoinTableMetadata(): void {
43
+ jest.spyOn(QueryUtil, "getManyToManyRelationMetadata").mockReturnValue({
44
+ joinTableName: "MonitorLabel",
45
+ ownerColumnName: "monitorId",
46
+ relationColumnName: "labelId",
47
+ });
48
+ }
49
+
50
+ afterEach(() => {
51
+ jest.restoreAllMocks();
52
+ });
53
+
54
+ it("adds the permitted-label filter when the caller has no label filter", async () => {
55
+ mockJoinTableMetadata();
56
+ const query: any = { projectId };
57
+
58
+ const result: any =
59
+ await AccessControlPermission.addAccessControlIdsToQuery(
60
+ Monitor,
61
+ query,
62
+ null,
63
+ makeLabelRestrictedProps(),
64
+ DatabaseRequestType.Read,
65
+ );
66
+
67
+ expect(
68
+ (result.labels as Array<ObjectID>).map((id: ObjectID) => {
69
+ return id.toString();
70
+ }),
71
+ ).toEqual([permittedLabelA.toString(), permittedLabelB.toString()]);
72
+ expect(result._id).toBeUndefined();
73
+ });
74
+
75
+ it("preserves a caller-supplied label filter and ANDs the permitted set onto _id", async () => {
76
+ mockJoinTableMetadata();
77
+ const requestedLabel: ObjectID = ObjectID.generate();
78
+ const callerLabelFilter: Array<ObjectID> = [requestedLabel];
79
+ const query: any = { projectId, labels: callerLabelFilter };
80
+
81
+ const result: any =
82
+ await AccessControlPermission.addAccessControlIdsToQuery(
83
+ Monitor,
84
+ query,
85
+ null,
86
+ makeLabelRestrictedProps(),
87
+ DatabaseRequestType.Read,
88
+ );
89
+
90
+ /*
91
+ * Regression: the permitted set used to overwrite the caller's label
92
+ * filter, so "filter by label X" silently widened to "any permitted
93
+ * label". The caller's filter must survive untouched, with the
94
+ * permitted-set predicate applied separately (join-table subquery on
95
+ * _id) so both must hold.
96
+ */
97
+ expect(result.labels).toBe(callerLabelFilter);
98
+ expect(result._id).toBeInstanceOf(FindOperator);
99
+ expect(result._id.type).toBe("raw");
100
+ expect(Object.values(result._id.objectLiteralParameters)).toEqual([
101
+ [permittedLabelA.toString(), permittedLabelB.toString()],
102
+ ]);
103
+ });
104
+
105
+ it("AND-combines the permitted-set predicate with an existing _id filter", async () => {
106
+ mockJoinTableMetadata();
107
+ const monitorId: ObjectID = ObjectID.generate();
108
+ const query: any = {
109
+ projectId,
110
+ _id: monitorId.toString(),
111
+ labels: [ObjectID.generate()],
112
+ };
113
+
114
+ const result: any =
115
+ await AccessControlPermission.addAccessControlIdsToQuery(
116
+ Monitor,
117
+ query,
118
+ null,
119
+ makeLabelRestrictedProps(),
120
+ DatabaseRequestType.Read,
121
+ );
122
+
123
+ expect(result._id).toBeInstanceOf(FindOperator);
124
+ expect(result._id.type).toBe("and");
125
+ expect(result._id.value[0].type).toBe("equal");
126
+ expect(result._id.value[0].value).toBe(monitorId.toString());
127
+ expect(result._id.value[1].type).toBe("raw");
128
+ });
129
+
130
+ it("fails closed to the permitted set when join metadata is unavailable", async () => {
131
+ jest
132
+ .spyOn(QueryUtil, "getManyToManyRelationMetadata")
133
+ .mockReturnValue(null);
134
+ const query: any = { projectId, labels: [ObjectID.generate()] };
135
+
136
+ const result: any =
137
+ await AccessControlPermission.addAccessControlIdsToQuery(
138
+ Monitor,
139
+ query,
140
+ null,
141
+ makeLabelRestrictedProps(),
142
+ DatabaseRequestType.Read,
143
+ );
144
+
145
+ expect(
146
+ (result.labels as Array<ObjectID>).map((id: ObjectID) => {
147
+ return id.toString();
148
+ }),
149
+ ).toEqual([permittedLabelA.toString(), permittedLabelB.toString()]);
150
+ expect(result._id).toBeUndefined();
151
+ });
152
+
153
+ it("leaves the query untouched for users with an unrestricted grant", async () => {
154
+ mockJoinTableMetadata();
155
+ const callerLabelFilter: Array<ObjectID> = [ObjectID.generate()];
156
+ const query: any = { projectId, labels: callerLabelFilter };
157
+
158
+ const tenantPermission: UserTenantAccessPermission = {
159
+ projectId,
160
+ _type: "UserTenantAccessPermission",
161
+ permissions: [
162
+ {
163
+ _type: "UserPermission",
164
+ permission: Permission.ProjectMember,
165
+ labelIds: [],
166
+ isBlockPermission: false,
167
+ },
168
+ ],
169
+ };
170
+
171
+ const result: any =
172
+ await AccessControlPermission.addAccessControlIdsToQuery(
173
+ Monitor,
174
+ query,
175
+ null,
176
+ {
177
+ userId,
178
+ tenantId: projectId,
179
+ userTenantAccessPermission: {
180
+ [projectId.toString()]: tenantPermission,
181
+ },
182
+ },
183
+ DatabaseRequestType.Read,
184
+ );
185
+
186
+ expect(result.labels).toBe(callerLabelFilter);
187
+ expect(result._id).toBeUndefined();
188
+ });
189
+ });