@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,761 @@
1
+ import TelemetryEntity, {
2
+ EntityAttributes,
3
+ ExtractedEntity,
4
+ ResourceEntityRef,
5
+ } from "../../../../Server/Utils/Telemetry/TelemetryEntity";
6
+ import EntityType from "../../../../Types/Telemetry/EntityType";
7
+ import {
8
+ keyForHost,
9
+ keyForService,
10
+ keyForKubernetesCluster,
11
+ } from "../../../../Utils/Telemetry/EntityKey";
12
+ import logger from "../../../../Server/Utils/Logger";
13
+ import { describe, expect, test } from "@jest/globals";
14
+ import { createHash } from "crypto";
15
+
16
+ const PROJECT: string = "proj1";
17
+
18
+ function keysFor(
19
+ attrs: EntityAttributes,
20
+ projectId: string = PROJECT,
21
+ ): Array<string> {
22
+ return TelemetryEntity.extractEntityKeys({ projectId, attributes: attrs });
23
+ }
24
+
25
+ function typesFor(attrs: EntityAttributes): Array<EntityType> {
26
+ return TelemetryEntity.extractEntities({
27
+ projectId: PROJECT,
28
+ attributes: attrs,
29
+ }).map((e: ExtractedEntity) => {
30
+ return e.entityType;
31
+ });
32
+ }
33
+
34
+ function entityOfType(
35
+ attrs: EntityAttributes,
36
+ type: EntityType,
37
+ ): ExtractedEntity | undefined {
38
+ return TelemetryEntity.extractEntities({
39
+ projectId: PROJECT,
40
+ attributes: attrs,
41
+ }).find((e: ExtractedEntity) => {
42
+ return e.entityType === type;
43
+ });
44
+ }
45
+
46
+ /*
47
+ * Independent reimplementation of the documented preimage so the test
48
+ * breaks if the key construction ever silently changes.
49
+ */
50
+ function expectedKey(
51
+ projectId: string,
52
+ type: EntityType,
53
+ id: Record<string, string>,
54
+ ): string {
55
+ const escape: (token: string) => string = (token: string) => {
56
+ return token.replace(/([\\|=])/g, "\\$1");
57
+ };
58
+ const parts: Array<string> = Object.keys(id)
59
+ .sort()
60
+ .map((k: string) => {
61
+ return `${escape(k)}=${escape(id[k]!.trim().toLowerCase())}`;
62
+ });
63
+ return createHash("sha256")
64
+ .update(`${projectId}|${type}|${parts.join("|")}`)
65
+ .digest("hex")
66
+ .slice(0, 16);
67
+ }
68
+
69
+ describe("TelemetryEntity.computeEntityKey", () => {
70
+ test("matches the documented preimage format", () => {
71
+ const key: string = TelemetryEntity.computeEntityKey({
72
+ projectId: PROJECT,
73
+ entityType: EntityType.Service,
74
+ identifyingAttributes: { "service.name": "checkout" },
75
+ });
76
+ expect(key).toBe(
77
+ expectedKey(PROJECT, EntityType.Service, { "service.name": "checkout" }),
78
+ );
79
+ expect(key).toMatch(/^[0-9a-f]{16}$/);
80
+ });
81
+
82
+ test("is deterministic and order-independent", () => {
83
+ const a: string = TelemetryEntity.computeEntityKey({
84
+ projectId: PROJECT,
85
+ entityType: EntityType.Service,
86
+ identifyingAttributes: {
87
+ "service.name": "checkout",
88
+ "service.namespace": "shop",
89
+ },
90
+ });
91
+ const b: string = TelemetryEntity.computeEntityKey({
92
+ projectId: PROJECT,
93
+ entityType: EntityType.Service,
94
+ identifyingAttributes: {
95
+ "service.namespace": "shop",
96
+ "service.name": "checkout",
97
+ },
98
+ });
99
+ expect(a).toBe(b);
100
+ });
101
+
102
+ test("canonicalizes casing and whitespace (no identity fork)", () => {
103
+ const a: string = TelemetryEntity.computeEntityKey({
104
+ projectId: PROJECT,
105
+ entityType: EntityType.Host,
106
+ identifyingAttributes: { "host.name": "Web-1" },
107
+ });
108
+ const b: string = TelemetryEntity.computeEntityKey({
109
+ projectId: PROJECT,
110
+ entityType: EntityType.Host,
111
+ identifyingAttributes: { "host.name": " web-1 " },
112
+ });
113
+ expect(a).toBe(b);
114
+ });
115
+
116
+ test("is tenant-scoped (projectId folds into the key)", () => {
117
+ const a: string = TelemetryEntity.computeEntityKey({
118
+ projectId: "projA",
119
+ entityType: EntityType.Service,
120
+ identifyingAttributes: { "service.name": "checkout" },
121
+ });
122
+ const b: string = TelemetryEntity.computeEntityKey({
123
+ projectId: "projB",
124
+ entityType: EntityType.Service,
125
+ identifyingAttributes: { "service.name": "checkout" },
126
+ });
127
+ expect(a).not.toBe(b);
128
+ });
129
+
130
+ test("type discriminates the key (same value, different type)", () => {
131
+ const asService: string = TelemetryEntity.computeEntityKey({
132
+ projectId: PROJECT,
133
+ entityType: EntityType.Service,
134
+ identifyingAttributes: { name: "x" },
135
+ });
136
+ const asHost: string = TelemetryEntity.computeEntityKey({
137
+ projectId: PROJECT,
138
+ entityType: EntityType.Host,
139
+ identifyingAttributes: { name: "x" },
140
+ });
141
+ expect(asService).not.toBe(asHost);
142
+ });
143
+ });
144
+
145
+ describe("TelemetryEntity.extractEntities — per type", () => {
146
+ test("service: from service.name, folds in namespace", () => {
147
+ const e: ExtractedEntity | undefined = entityOfType(
148
+ { "service.name": "checkout", "service.namespace": "shop" },
149
+ EntityType.Service,
150
+ );
151
+ expect(e).toBeDefined();
152
+ expect(e!.identifyingAttributes).toEqual({
153
+ "service.name": "checkout",
154
+ "service.namespace": "shop",
155
+ });
156
+ expect(e!.entityKey).toBe(
157
+ expectedKey(PROJECT, EntityType.Service, {
158
+ "service.name": "checkout",
159
+ "service.namespace": "shop",
160
+ }),
161
+ );
162
+ });
163
+
164
+ test("service.instance: requires both name and instance.id", () => {
165
+ expect(typesFor({ "service.name": "checkout" })).not.toContain(
166
+ EntityType.ServiceInstance,
167
+ );
168
+ expect(
169
+ typesFor({
170
+ "service.name": "checkout",
171
+ "service.instance.id": "i-1",
172
+ }),
173
+ ).toContain(EntityType.ServiceInstance);
174
+ });
175
+
176
+ test("host: keyed on host.name (matches hostIdentifier), ignoring host.id", () => {
177
+ const e: ExtractedEntity | undefined = entityOfType(
178
+ { "host.id": "h-123", "host.name": "Web-1" },
179
+ EntityType.Host,
180
+ );
181
+ /*
182
+ * host.id is not part of host identity; value canonicalized (lowercased)
183
+ * so it matches the Host row's hostIdentifier.
184
+ */
185
+ expect(e!.identifyingAttributes).toEqual({ "host.name": "web-1" });
186
+ });
187
+
188
+ test("host: no host entity without host.name (host.id alone is not a host)", () => {
189
+ expect(typesFor({ "host.id": "h-123" })).not.toContain(EntityType.Host);
190
+ });
191
+
192
+ test("k8s.cluster: keyed on name only, ignoring uid (read side is name-based)", () => {
193
+ const e: ExtractedEntity | undefined = entityOfType(
194
+ { "k8s.cluster.uid": "u-1", "k8s.cluster.name": "prod-us" },
195
+ EntityType.KubernetesCluster,
196
+ );
197
+ expect(e!.identifyingAttributes).toEqual({ "k8s.cluster.name": "prod-us" });
198
+ });
199
+
200
+ test("k8s.cluster: no cluster entity from uid alone", () => {
201
+ expect(typesFor({ "k8s.cluster.uid": "u-1" })).not.toContain(
202
+ EntityType.KubernetesCluster,
203
+ );
204
+ });
205
+
206
+ test("k8s composite children fold in the name-based cluster identity even when uid is present", () => {
207
+ const e: ExtractedEntity | undefined = entityOfType(
208
+ {
209
+ "k8s.cluster.uid": "u-1",
210
+ "k8s.cluster.name": "prod-us",
211
+ "k8s.namespace.name": "shop",
212
+ },
213
+ EntityType.KubernetesNamespace,
214
+ );
215
+ expect(e!.identifyingAttributes).toEqual({
216
+ "k8s.cluster.name": "prod-us",
217
+ "k8s.namespace.name": "shop",
218
+ });
219
+ });
220
+
221
+ test("k8s.pod: composes cluster + namespace + pod identity", () => {
222
+ const e: ExtractedEntity | undefined = entityOfType(
223
+ {
224
+ "k8s.cluster.name": "prod-us",
225
+ "k8s.namespace.name": "shop",
226
+ "k8s.pod.name": "checkout-7d9f",
227
+ },
228
+ EntityType.KubernetesPod,
229
+ );
230
+ expect(e!.identifyingAttributes).toEqual({
231
+ "k8s.cluster.name": "prod-us",
232
+ "k8s.namespace.name": "shop",
233
+ "k8s.pod.name": "checkout-7d9f",
234
+ });
235
+ });
236
+
237
+ test("container & process flow as membership keys", () => {
238
+ const types: Array<EntityType> = typesFor({
239
+ "container.id": "c-1",
240
+ "process.pid": 1234,
241
+ "host.id": "h-1",
242
+ });
243
+ expect(types).toContain(EntityType.Container);
244
+ expect(types).toContain(EntityType.Process);
245
+ });
246
+
247
+ test("process: numeric pid coerces to string identity", () => {
248
+ const e: ExtractedEntity | undefined = entityOfType(
249
+ { "process.pid": 1234, "host.id": "h-1" },
250
+ EntityType.Process,
251
+ );
252
+ expect(e!.identifyingAttributes).toEqual({
253
+ "process.pid": "1234",
254
+ "host.id": "h-1",
255
+ });
256
+ });
257
+
258
+ test("telemetry.sdk: from sdk name + language", () => {
259
+ const e: ExtractedEntity | undefined = entityOfType(
260
+ {
261
+ "telemetry.sdk.name": "opentelemetry",
262
+ "telemetry.sdk.language": "nodejs",
263
+ },
264
+ EntityType.TelemetrySdk,
265
+ );
266
+ expect(e!.identifyingAttributes).toEqual({
267
+ "telemetry.sdk.name": "opentelemetry",
268
+ "telemetry.sdk.language": "nodejs",
269
+ });
270
+ });
271
+ });
272
+
273
+ describe("TelemetryEntity.extractEntities — composition & safety", () => {
274
+ test("no phantom entities when identity is absent", () => {
275
+ expect(keysFor({})).toEqual([]);
276
+ // host.* missing, only an unrelated attr present
277
+ expect(typesFor({ "http.method": "GET" })).toEqual([]);
278
+ });
279
+
280
+ test("a full k8s resource yields the whole entity set", () => {
281
+ const types: Array<EntityType> = typesFor({
282
+ "service.name": "checkout",
283
+ "service.instance.id": "i-1",
284
+ "host.name": "ip-10-0-1-5",
285
+ "k8s.cluster.name": "prod-us",
286
+ "k8s.namespace.name": "shop",
287
+ "k8s.node.name": "ip-10-0-1-5",
288
+ "k8s.pod.name": "checkout-7d9f",
289
+ "k8s.deployment.name": "checkout",
290
+ "container.id": "c-1",
291
+ "process.pid": 1234,
292
+ "telemetry.sdk.name": "opentelemetry",
293
+ });
294
+ expect(new Set(types)).toEqual(
295
+ new Set([
296
+ EntityType.Service,
297
+ EntityType.ServiceInstance,
298
+ EntityType.Host,
299
+ EntityType.KubernetesCluster,
300
+ EntityType.KubernetesNamespace,
301
+ EntityType.KubernetesNode,
302
+ EntityType.KubernetesPod,
303
+ EntityType.KubernetesDeployment,
304
+ EntityType.Container,
305
+ EntityType.Process,
306
+ EntityType.TelemetrySdk,
307
+ ]),
308
+ );
309
+ });
310
+
311
+ test("extractEntityKeys is sorted, deduped, and a superset of the primary", () => {
312
+ const attrs: EntityAttributes = {
313
+ "service.name": "checkout",
314
+ "host.name": "web-1",
315
+ };
316
+ const keys: Array<string> = keysFor(attrs);
317
+ // sorted
318
+ expect([...keys].sort()).toEqual(keys);
319
+ // deduped
320
+ expect(new Set(keys).size).toBe(keys.length);
321
+ // includes the service (primary) key
322
+ const serviceKey: string = TelemetryEntity.computeEntityKey({
323
+ projectId: PROJECT,
324
+ entityType: EntityType.Service,
325
+ identifyingAttributes: { "service.name": "checkout" },
326
+ });
327
+ expect(keys).toContain(serviceKey);
328
+ });
329
+
330
+ test("same namespace name in two clusters does not collide", () => {
331
+ const clusterA: string = TelemetryEntity.computeEntityKey({
332
+ projectId: PROJECT,
333
+ entityType: EntityType.KubernetesNamespace,
334
+ identifyingAttributes: {
335
+ "k8s.cluster.name": "prod-us",
336
+ "k8s.namespace.name": "default",
337
+ },
338
+ });
339
+ const clusterB: string = TelemetryEntity.computeEntityKey({
340
+ projectId: PROJECT,
341
+ entityType: EntityType.KubernetesNamespace,
342
+ identifyingAttributes: {
343
+ "k8s.cluster.name": "prod-eu",
344
+ "k8s.namespace.name": "default",
345
+ },
346
+ });
347
+ expect(clusterA).not.toBe(clusterB);
348
+ });
349
+ });
350
+
351
+ describe("read-side keyFor* helpers match ingest-side extraction", () => {
352
+ test("keyForHost matches the host entity stamped from host.name", () => {
353
+ const stamped: ExtractedEntity | undefined = entityOfType(
354
+ { "host.name": "web-1" },
355
+ EntityType.Host,
356
+ );
357
+ expect(stamped).toBeDefined();
358
+ expect(keyForHost(PROJECT, "web-1")).toBe(stamped!.entityKey);
359
+ });
360
+
361
+ test("keyForHost canonicalizes casing/whitespace like ingest", () => {
362
+ const stamped: ExtractedEntity | undefined = entityOfType(
363
+ { "host.name": "Web-1" },
364
+ EntityType.Host,
365
+ );
366
+ expect(keyForHost(PROJECT, "web-1")).toBe(stamped!.entityKey);
367
+ expect(keyForHost(PROJECT, " WEB-1 ")).toBe(stamped!.entityKey);
368
+ });
369
+
370
+ test("keyForService matches the service entity stamped from service.name", () => {
371
+ const stamped: ExtractedEntity | undefined = entityOfType(
372
+ { "service.name": "checkout" },
373
+ EntityType.Service,
374
+ );
375
+ expect(keyForService(PROJECT, "checkout")).toBe(stamped!.entityKey);
376
+ // An undefined or blank namespace must not alter the key.
377
+ expect(keyForService(PROJECT, "checkout", undefined)).toBe(
378
+ stamped!.entityKey,
379
+ );
380
+ expect(keyForService(PROJECT, "checkout", " ")).toBe(stamped!.entityKey);
381
+ });
382
+
383
+ test("keyForService matches the namespaced service entity stamped from service.name + service.namespace", () => {
384
+ const stamped: ExtractedEntity | undefined = entityOfType(
385
+ { "service.name": "checkout", "service.namespace": "shop" },
386
+ EntityType.Service,
387
+ );
388
+ expect(stamped).toBeDefined();
389
+ expect(keyForService(PROJECT, "checkout", "shop")).toBe(stamped!.entityKey);
390
+ // Namespace is part of the identity: without it the key matches nothing.
391
+ expect(keyForService(PROJECT, "checkout")).not.toBe(stamped!.entityKey);
392
+ });
393
+
394
+ test("keyForKubernetesCluster matches the cluster entity stamped from k8s.cluster.name", () => {
395
+ const stamped: ExtractedEntity | undefined = entityOfType(
396
+ { "k8s.cluster.name": "prod-us" },
397
+ EntityType.KubernetesCluster,
398
+ );
399
+ expect(keyForKubernetesCluster(PROJECT, "prod-us")).toBe(
400
+ stamped!.entityKey,
401
+ );
402
+ });
403
+
404
+ test("keyForKubernetesCluster still matches when the resource also carries a uid", () => {
405
+ const stamped: ExtractedEntity | undefined = entityOfType(
406
+ { "k8s.cluster.uid": "u-1", "k8s.cluster.name": "prod-us" },
407
+ EntityType.KubernetesCluster,
408
+ );
409
+ expect(keyForKubernetesCluster(PROJECT, "prod-us")).toBe(
410
+ stamped!.entityKey,
411
+ );
412
+ });
413
+ });
414
+
415
+ describe("descriptive attributes & labels (never identity-bearing)", () => {
416
+ test("host: allowlisted descriptive attributes are emitted, key unchanged", () => {
417
+ const bare: ExtractedEntity | undefined = entityOfType(
418
+ { "host.name": "web-1" },
419
+ EntityType.Host,
420
+ );
421
+ const decorated: ExtractedEntity | undefined = entityOfType(
422
+ {
423
+ "host.name": "web-1",
424
+ "os.type": "linux",
425
+ "host.arch": "arm64",
426
+ "cloud.provider": "aws",
427
+ "cloud.region": "us-east-1",
428
+ "cloud.availability_zone": "us-east-1a",
429
+ // not in the allowlist — must not leak into descriptive.
430
+ "host.ip": ["10.0.0.1"],
431
+ },
432
+ EntityType.Host,
433
+ );
434
+
435
+ expect(decorated!.entityKey).toBe(bare!.entityKey);
436
+ expect(decorated!.identifyingAttributes).toEqual(
437
+ bare!.identifyingAttributes,
438
+ );
439
+ expect(decorated!.descriptiveAttributes).toEqual({
440
+ "os.type": "linux",
441
+ "host.arch": "arm64",
442
+ "cloud.provider": "aws",
443
+ "cloud.region": "us-east-1",
444
+ "cloud.availability_zone": "us-east-1a",
445
+ });
446
+ expect(bare!.descriptiveAttributes).toBeUndefined();
447
+ });
448
+
449
+ test("service: sdk descriptive attributes captured, key unchanged", () => {
450
+ const bare: ExtractedEntity | undefined = entityOfType(
451
+ { "service.name": "checkout" },
452
+ EntityType.Service,
453
+ );
454
+ const decorated: ExtractedEntity | undefined = entityOfType(
455
+ {
456
+ "service.name": "checkout",
457
+ "telemetry.sdk.name": "opentelemetry",
458
+ "telemetry.sdk.language": "nodejs",
459
+ "telemetry.sdk.version": "1.30.0",
460
+ },
461
+ EntityType.Service,
462
+ );
463
+
464
+ expect(decorated!.entityKey).toBe(bare!.entityKey);
465
+ expect(decorated!.descriptiveAttributes).toEqual({
466
+ "telemetry.sdk.name": "opentelemetry",
467
+ "telemetry.sdk.language": "nodejs",
468
+ "telemetry.sdk.version": "1.30.0",
469
+ });
470
+ });
471
+
472
+ test("k8s.node: instance-type descriptive when present", () => {
473
+ const e: ExtractedEntity | undefined = entityOfType(
474
+ {
475
+ "k8s.cluster.name": "prod-us",
476
+ "k8s.node.name": "node-1",
477
+ "node.kubernetes.io/instance-type": "n2-standard-4",
478
+ },
479
+ EntityType.KubernetesNode,
480
+ );
481
+ expect(e!.descriptiveAttributes).toEqual({
482
+ "node.kubernetes.io/instance-type": "n2-standard-4",
483
+ });
484
+ });
485
+
486
+ test("container: image name/tag descriptive; array-valued tags accepted", () => {
487
+ const e: ExtractedEntity | undefined = entityOfType(
488
+ {
489
+ "container.id": "c-1",
490
+ "container.image.name": "redis",
491
+ "container.image.tags": ["7.2", "latest"],
492
+ },
493
+ EntityType.Container,
494
+ );
495
+ expect(e!.identifyingAttributes).toEqual({ "container.id": "c-1" });
496
+ expect(e!.descriptiveAttributes).toEqual({
497
+ "container.image.name": "redis",
498
+ "container.image.tags": "7.2",
499
+ });
500
+ });
501
+
502
+ test("the full membership key set is byte-identical with and without descriptive attrs / labels", () => {
503
+ const identityOnly: EntityAttributes = {
504
+ "service.name": "checkout",
505
+ "host.name": "web-1",
506
+ "k8s.cluster.name": "prod-us",
507
+ "k8s.node.name": "node-1",
508
+ "container.id": "c-1",
509
+ };
510
+ const decorated: EntityAttributes = {
511
+ ...identityOnly,
512
+ "os.type": "linux",
513
+ "host.arch": "amd64",
514
+ "cloud.provider": "gcp",
515
+ "cloud.region": "europe-west1",
516
+ "cloud.availability_zone": "europe-west1-b",
517
+ "telemetry.sdk.language": "go",
518
+ "node.kubernetes.io/instance-type": "n2-standard-4",
519
+ "container.image.name": "ghcr.io/acme/checkout",
520
+ "container.image.tag": "1.2.3",
521
+ "oneuptime.label.team": "payments",
522
+ };
523
+ expect(keysFor(decorated)).toEqual(keysFor(identityOnly));
524
+ });
525
+
526
+ test("oneuptime.label.* suffixes become labels on every extracted entity", () => {
527
+ const entities: Array<ExtractedEntity> = TelemetryEntity.extractEntities({
528
+ projectId: PROJECT,
529
+ attributes: {
530
+ "service.name": "checkout",
531
+ "host.name": "web-1",
532
+ "oneuptime.label.team": "payments",
533
+ "oneuptime.label.env": "prod",
534
+ // empty suffix is skipped
535
+ "oneuptime.label.": "ignored",
536
+ },
537
+ });
538
+ expect(entities.length).toBeGreaterThan(0);
539
+ for (const entity of entities) {
540
+ expect(entity.labels).toEqual(["env", "team"]);
541
+ }
542
+ });
543
+
544
+ test("no labels attribute → labels field omitted", () => {
545
+ const e: ExtractedEntity | undefined = entityOfType(
546
+ { "service.name": "checkout" },
547
+ EntityType.Service,
548
+ );
549
+ expect(e!.labels).toBeUndefined();
550
+ });
551
+ });
552
+
553
+ describe("extractEntities — OTLP entity_refs (authoritative path)", () => {
554
+ const attrs: EntityAttributes = {
555
+ "service.name": "checkout",
556
+ "service.namespace": "shop",
557
+ "host.name": "web-1",
558
+ "telemetry.sdk.language": "nodejs",
559
+ };
560
+
561
+ test("builds entities from refs instead of the heuristics", () => {
562
+ const entities: Array<ExtractedEntity> = TelemetryEntity.extractEntities({
563
+ projectId: PROJECT,
564
+ attributes: attrs,
565
+ entityRefs: [
566
+ {
567
+ type: "service",
568
+ idKeys: ["service.name", "service.namespace"],
569
+ descriptionKeys: ["telemetry.sdk.language"],
570
+ },
571
+ { type: "host", idKeys: ["host.name"] },
572
+ ],
573
+ });
574
+
575
+ /*
576
+ * Refs are authoritative: only the two declared entities, no
577
+ * heuristic extras (the resource would heuristically also yield a
578
+ * telemetry.sdk entity if telemetry.sdk.name were present, etc.).
579
+ */
580
+ expect(entities).toHaveLength(2);
581
+
582
+ const service: ExtractedEntity = entities.find((e: ExtractedEntity) => {
583
+ return e.entityType === EntityType.Service;
584
+ })!;
585
+ expect(service.identifyingAttributes).toEqual({
586
+ "service.name": "checkout",
587
+ "service.namespace": "shop",
588
+ });
589
+ expect(service.descriptiveAttributes).toEqual({
590
+ "telemetry.sdk.language": "nodejs",
591
+ });
592
+ // Ref-built keys are byte-identical to read-side/heuristic keys.
593
+ expect(service.entityKey).toBe(keyForService(PROJECT, "checkout", "shop"));
594
+
595
+ const host: ExtractedEntity = entities.find((e: ExtractedEntity) => {
596
+ return e.entityType === EntityType.Host;
597
+ })!;
598
+ expect(host.entityKey).toBe(keyForHost(PROJECT, "web-1"));
599
+ });
600
+
601
+ test("unknown ref types are skipped (debug log), known refs still built", () => {
602
+ const debugSpy: jest.SpyInstance = jest
603
+ .spyOn(logger, "debug")
604
+ .mockImplementation(() => {});
605
+ try {
606
+ const entities: Array<ExtractedEntity> = TelemetryEntity.extractEntities({
607
+ projectId: PROJECT,
608
+ attributes: attrs,
609
+ entityRefs: [
610
+ { type: "acme.custom.widget", idKeys: ["service.name"] },
611
+ { type: "service", idKeys: ["service.name"] },
612
+ ],
613
+ });
614
+ expect(
615
+ entities.map((e: ExtractedEntity) => {
616
+ return e.entityType;
617
+ }),
618
+ ).toEqual([EntityType.Service]);
619
+ expect(debugSpy).toHaveBeenCalled();
620
+ } finally {
621
+ debugSpy.mockRestore();
622
+ }
623
+ });
624
+
625
+ test("a ref whose identifying value is missing from the resource is skipped", () => {
626
+ const entities: Array<ExtractedEntity> = TelemetryEntity.extractEntities({
627
+ projectId: PROJECT,
628
+ attributes: attrs,
629
+ entityRefs: [
630
+ { type: "service", idKeys: ["service.name"] },
631
+ // k8s.pod.name is not in attrs — no half-identified entity.
632
+ { type: "k8s.pod", idKeys: ["k8s.pod.name"] },
633
+ ],
634
+ });
635
+ expect(
636
+ entities.map((e: ExtractedEntity) => {
637
+ return e.entityType;
638
+ }),
639
+ ).toEqual([EntityType.Service]);
640
+ });
641
+
642
+ test("absent or empty refs fall back to the heuristic resolvers", () => {
643
+ const heuristic: Array<ExtractedEntity> = TelemetryEntity.extractEntities({
644
+ projectId: PROJECT,
645
+ attributes: attrs,
646
+ });
647
+ expect(heuristic.length).toBeGreaterThan(0);
648
+ expect(
649
+ TelemetryEntity.extractEntities({
650
+ projectId: PROJECT,
651
+ attributes: attrs,
652
+ entityRefs: [],
653
+ }),
654
+ ).toEqual(heuristic);
655
+ });
656
+
657
+ test("when every ref is unusable the heuristics still produce membership keys", () => {
658
+ const debugSpy: jest.SpyInstance = jest
659
+ .spyOn(logger, "debug")
660
+ .mockImplementation(() => {});
661
+ try {
662
+ const entities: Array<ExtractedEntity> = TelemetryEntity.extractEntities({
663
+ projectId: PROJECT,
664
+ attributes: attrs,
665
+ entityRefs: [{ type: "acme.custom.widget", idKeys: ["whatever"] }],
666
+ });
667
+ expect(entities).toEqual(
668
+ TelemetryEntity.extractEntities({
669
+ projectId: PROJECT,
670
+ attributes: attrs,
671
+ }),
672
+ );
673
+ } finally {
674
+ debugSpy.mockRestore();
675
+ }
676
+ });
677
+
678
+ test("a mutable value declared as identifying is honored with a cardinality warning", () => {
679
+ const warnSpy: jest.SpyInstance = jest
680
+ .spyOn(logger, "warn")
681
+ .mockImplementation(() => {});
682
+ try {
683
+ const entities: Array<ExtractedEntity> = TelemetryEntity.extractEntities({
684
+ projectId: PROJECT,
685
+ attributes: {
686
+ "container.id": "c-1",
687
+ "container.image.tag": "1.2.3",
688
+ },
689
+ entityRefs: [
690
+ {
691
+ type: "container",
692
+ idKeys: ["container.id", "container.image.tag"],
693
+ },
694
+ ],
695
+ });
696
+ // Honored: the mutable key IS part of identity (per the producer).
697
+ expect(entities).toHaveLength(1);
698
+ expect(entities[0]!.identifyingAttributes).toEqual({
699
+ "container.id": "c-1",
700
+ "container.image.tag": "1.2.3",
701
+ });
702
+ expect(warnSpy).toHaveBeenCalled();
703
+ } finally {
704
+ warnSpy.mockRestore();
705
+ }
706
+ });
707
+
708
+ test("labels attach on the refs path too", () => {
709
+ const entities: Array<ExtractedEntity> = TelemetryEntity.extractEntities({
710
+ projectId: PROJECT,
711
+ attributes: { ...attrs, "oneuptime.label.team": "payments" },
712
+ entityRefs: [{ type: "service", idKeys: ["service.name"] }],
713
+ });
714
+ expect(entities).toHaveLength(1);
715
+ expect(entities[0]!.labels).toEqual(["team"]);
716
+ });
717
+ });
718
+
719
+ describe("TelemetryEntity.parseEntityRefs", () => {
720
+ test("normalizes camelCase and snake_case shapes; drops malformed entries", () => {
721
+ const refs: Array<ResourceEntityRef> = TelemetryEntity.parseEntityRefs([
722
+ {
723
+ type: "service",
724
+ idKeys: ["service.name"],
725
+ descriptionKeys: ["telemetry.sdk.language"],
726
+ schemaUrl: "https://opentelemetry.io/schemas/1.30.0",
727
+ },
728
+ {
729
+ type: "host",
730
+ id_keys: ["host.name"],
731
+ description_keys: [],
732
+ schema_url: "https://opentelemetry.io/schemas/1.30.0",
733
+ },
734
+ "garbage",
735
+ null,
736
+ 42,
737
+ ["not", "a", "ref"],
738
+ ]);
739
+
740
+ expect(refs).toHaveLength(2);
741
+ expect(refs[0]).toEqual({
742
+ type: "service",
743
+ idKeys: ["service.name"],
744
+ descriptionKeys: ["telemetry.sdk.language"],
745
+ schemaUrl: "https://opentelemetry.io/schemas/1.30.0",
746
+ });
747
+ expect(refs[1]).toEqual({
748
+ type: "host",
749
+ idKeys: ["host.name"],
750
+ descriptionKeys: [],
751
+ schemaUrl: "https://opentelemetry.io/schemas/1.30.0",
752
+ });
753
+ });
754
+
755
+ test("non-array input yields no refs", () => {
756
+ expect(TelemetryEntity.parseEntityRefs(undefined)).toEqual([]);
757
+ expect(TelemetryEntity.parseEntityRefs(null)).toEqual([]);
758
+ expect(TelemetryEntity.parseEntityRefs({})).toEqual([]);
759
+ expect(TelemetryEntity.parseEntityRefs("nope")).toEqual([]);
760
+ });
761
+ });