@oneuptime/common 10.1.7 → 10.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (378) hide show
  1. package/Models/DatabaseModels/Alert.ts +41 -0
  2. package/Models/DatabaseModels/AlertEpisode.ts +41 -0
  3. package/Models/DatabaseModels/AlertEpisodeFeed.ts +4 -0
  4. package/Models/DatabaseModels/AlertEpisodeLabelRule.ts +584 -0
  5. package/Models/DatabaseModels/AlertEpisodeOnCallRule.ts +583 -0
  6. package/Models/DatabaseModels/AlertEpisodeOwnerRule.ts +668 -0
  7. package/Models/DatabaseModels/AlertEpisodePrivacyRule.ts +535 -0
  8. package/Models/DatabaseModels/AlertFeed.ts +4 -0
  9. package/Models/DatabaseModels/AlertLabelRule.ts +788 -0
  10. package/Models/DatabaseModels/AlertOnCallRule.ts +755 -0
  11. package/Models/DatabaseModels/AlertOwnerRule.ts +907 -0
  12. package/Models/DatabaseModels/AlertPrivacyRule.ts +704 -0
  13. package/Models/DatabaseModels/DatabaseBaseModel/FileModel.ts +27 -0
  14. package/Models/DatabaseModels/Incident.ts +41 -0
  15. package/Models/DatabaseModels/IncidentEpisode.ts +41 -0
  16. package/Models/DatabaseModels/IncidentEpisodeFeed.ts +4 -0
  17. package/Models/DatabaseModels/IncidentEpisodeLabelRule.ts +584 -0
  18. package/Models/DatabaseModels/IncidentEpisodeOnCallRule.ts +585 -0
  19. package/Models/DatabaseModels/IncidentEpisodeOwnerRule.ts +670 -0
  20. package/Models/DatabaseModels/IncidentEpisodePrivacyRule.ts +535 -0
  21. package/Models/DatabaseModels/IncidentFeed.ts +4 -0
  22. package/Models/DatabaseModels/IncidentLabelRule.ts +828 -0
  23. package/Models/DatabaseModels/IncidentOnCallRule.ts +755 -0
  24. package/Models/DatabaseModels/IncidentOwnerRule.ts +914 -0
  25. package/Models/DatabaseModels/IncidentPrivacyRule.ts +704 -0
  26. package/Models/DatabaseModels/Index.ts +32 -0
  27. package/Server/API/FileAPI.ts +89 -1
  28. package/Server/API/StatusPageAPI.ts +3 -0
  29. package/Server/Infrastructure/Postgres/SchemaMigrations/1778269764550-MigrationName.ts +395 -0
  30. package/Server/Infrastructure/Postgres/SchemaMigrations/1778271406963-MigrationName.ts +1003 -0
  31. package/Server/Infrastructure/Postgres/SchemaMigrations/1778274719786-MigrationName.ts +635 -0
  32. package/Server/Infrastructure/Postgres/SchemaMigrations/1778359982682-AddIncidentIsPrivate.ts +21 -0
  33. package/Server/Infrastructure/Postgres/SchemaMigrations/1778361904715-AddFileImageAccessToken.ts +25 -0
  34. package/Server/Infrastructure/Postgres/SchemaMigrations/1778413144103-AddOwnerRuleInheritFlags.ts +37 -0
  35. package/Server/Infrastructure/Postgres/SchemaMigrations/1778438949454-AddAlertIsPrivate.ts +21 -0
  36. package/Server/Infrastructure/Postgres/SchemaMigrations/1778440665575-AddPrivacyRules.ts +315 -0
  37. package/Server/Infrastructure/Postgres/SchemaMigrations/1778442385970-AddEpisodePrivacyRules.ts +233 -0
  38. package/Server/Infrastructure/Postgres/SchemaMigrations/Index.ts +18 -0
  39. package/Server/Services/AlertEpisodeFeedService.ts +51 -0
  40. package/Server/Services/AlertEpisodeInternalNoteService.ts +51 -1
  41. package/Server/Services/AlertEpisodeLabelRuleEngineService.ts +293 -0
  42. package/Server/Services/AlertEpisodeLabelRuleService.ts +14 -0
  43. package/Server/Services/AlertEpisodeOnCallRuleEngineService.ts +310 -0
  44. package/Server/Services/AlertEpisodeOnCallRuleService.ts +14 -0
  45. package/Server/Services/AlertEpisodeOwnerRuleEngineService.ts +325 -0
  46. package/Server/Services/AlertEpisodeOwnerRuleService.ts +14 -0
  47. package/Server/Services/AlertEpisodeOwnerTeamService.ts +43 -1
  48. package/Server/Services/AlertEpisodeOwnerUserService.ts +43 -1
  49. package/Server/Services/AlertEpisodePrivacyRuleEngineService.ts +218 -0
  50. package/Server/Services/AlertEpisodePrivacyRuleService.ts +14 -0
  51. package/Server/Services/AlertEpisodeService.ts +126 -1
  52. package/Server/Services/AlertFeedService.ts +51 -0
  53. package/Server/Services/AlertInternalNoteService.ts +51 -1
  54. package/Server/Services/AlertLabelRuleEngineService.ts +408 -0
  55. package/Server/Services/AlertLabelRuleService.ts +14 -0
  56. package/Server/Services/AlertOnCallRuleEngineService.ts +414 -0
  57. package/Server/Services/AlertOnCallRuleService.ts +14 -0
  58. package/Server/Services/AlertOwnerRuleEngineService.ts +559 -0
  59. package/Server/Services/AlertOwnerRuleService.ts +14 -0
  60. package/Server/Services/AlertOwnerTeamService.ts +43 -1
  61. package/Server/Services/AlertOwnerUserService.ts +43 -1
  62. package/Server/Services/AlertPrivacyRuleEngineService.ts +302 -0
  63. package/Server/Services/AlertPrivacyRuleService.ts +14 -0
  64. package/Server/Services/AlertService.ts +106 -1
  65. package/Server/Services/FileService.ts +24 -1
  66. package/Server/Services/HostService.ts +96 -0
  67. package/Server/Services/IncidentEpisodeFeedService.ts +51 -0
  68. package/Server/Services/IncidentEpisodeInternalNoteService.ts +51 -1
  69. package/Server/Services/IncidentEpisodeLabelRuleEngineService.ts +294 -0
  70. package/Server/Services/IncidentEpisodeLabelRuleService.ts +14 -0
  71. package/Server/Services/IncidentEpisodeOnCallRuleEngineService.ts +312 -0
  72. package/Server/Services/IncidentEpisodeOnCallRuleService.ts +14 -0
  73. package/Server/Services/IncidentEpisodeOwnerRuleEngineService.ts +309 -0
  74. package/Server/Services/IncidentEpisodeOwnerRuleService.ts +14 -0
  75. package/Server/Services/IncidentEpisodeOwnerTeamService.ts +43 -1
  76. package/Server/Services/IncidentEpisodeOwnerUserService.ts +43 -1
  77. package/Server/Services/IncidentEpisodePrivacyRuleEngineService.ts +220 -0
  78. package/Server/Services/IncidentEpisodePrivacyRuleService.ts +14 -0
  79. package/Server/Services/IncidentEpisodeService.ts +126 -1
  80. package/Server/Services/IncidentFeedService.ts +51 -0
  81. package/Server/Services/IncidentInternalNoteService.ts +51 -1
  82. package/Server/Services/IncidentLabelRuleEngineService.ts +484 -0
  83. package/Server/Services/IncidentLabelRuleService.ts +14 -0
  84. package/Server/Services/IncidentOnCallRuleEngineService.ts +452 -0
  85. package/Server/Services/IncidentOnCallRuleService.ts +14 -0
  86. package/Server/Services/IncidentOwnerRuleEngineService.ts +623 -0
  87. package/Server/Services/IncidentOwnerRuleService.ts +14 -0
  88. package/Server/Services/IncidentOwnerTeamService.ts +44 -1
  89. package/Server/Services/IncidentOwnerUserService.ts +44 -1
  90. package/Server/Services/IncidentPrivacyRuleEngineService.ts +347 -0
  91. package/Server/Services/IncidentPrivacyRuleService.ts +14 -0
  92. package/Server/Services/IncidentService.ts +173 -1
  93. package/Server/Services/LabelService.ts +143 -0
  94. package/Server/Services/OpenTelemetryIngestService.ts +56 -0
  95. package/Server/Services/ServiceService.ts +92 -0
  96. package/Server/Services/WorkspaceNotificationRuleService.ts +8 -0
  97. package/Server/Utils/Alert/AlertPrivacyFilter.ts +148 -0
  98. package/Server/Utils/AlertEpisode/AlertEpisodePrivacyFilter.ts +131 -0
  99. package/Server/Utils/Incident/IncidentPrivacyFilter.ts +148 -0
  100. package/Server/Utils/IncidentEpisode/IncidentEpisodePrivacyFilter.ts +137 -0
  101. package/Server/Utils/InlineImageAccessTokenSync.ts +83 -0
  102. package/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.ts +23 -0
  103. package/Server/Utils/Monitor/MonitorAlert.ts +4 -0
  104. package/Server/Utils/Monitor/MonitorCriteriaObservationBuilder.ts +98 -3
  105. package/Server/Utils/Monitor/MonitorIncident.ts +4 -0
  106. package/Server/Utils/Telemetry/OneuptimeLabel.ts +78 -0
  107. package/Server/Utils/Workspace/MicrosoftTeams/MicrosoftTeams.ts +2 -1
  108. package/Server/Utils/Workspace/Slack/Slack.ts +10 -3
  109. package/Server/Utils/Workspace/WorkspaceBase.ts +1 -0
  110. package/Server/Utils/Workspace/WorkspaceMessages/Alert.ts +2 -0
  111. package/Server/Utils/Workspace/WorkspaceMessages/AlertEpisode.ts +2 -0
  112. package/Server/Utils/Workspace/WorkspaceMessages/Incident.ts +2 -0
  113. package/Server/Utils/Workspace/WorkspaceMessages/IncidentEpisode.ts +2 -0
  114. package/Tests/UI/Components/MarkdownEditor.test.tsx +39 -31
  115. package/Tests/Utils/MetricUnitUtil.test.ts +38 -1
  116. package/Types/Monitor/CriteriaAlert.ts +2 -0
  117. package/Types/Monitor/CriteriaIncident.ts +2 -0
  118. package/Types/Monitor/MetricMonitor/MetricMonitorResponse.ts +8 -0
  119. package/Types/Permission.ts +764 -0
  120. package/UI/Components/Charts/Utils/DataPoint.ts +2 -47
  121. package/UI/Components/Forms/BasicForm.tsx +106 -75
  122. package/UI/Components/Forms/Types/Field.ts +8 -0
  123. package/UI/Components/Forms/Types/FormStep.ts +5 -0
  124. package/UI/Components/Markdown.tsx/MarkdownConverters.ts +0 -0
  125. package/UI/Components/Markdown.tsx/MarkdownEditor.tsx +745 -46
  126. package/UI/Components/Markdown.tsx/MarkdownViewer.tsx +9 -0
  127. package/Utils/MetricUnitUtil.ts +24 -0
  128. package/Utils/ValueFormatter.ts +19 -4
  129. package/build/dist/Models/DatabaseModels/Alert.js +42 -0
  130. package/build/dist/Models/DatabaseModels/Alert.js.map +1 -1
  131. package/build/dist/Models/DatabaseModels/AlertEpisode.js +42 -0
  132. package/build/dist/Models/DatabaseModels/AlertEpisode.js.map +1 -1
  133. package/build/dist/Models/DatabaseModels/AlertEpisodeFeed.js +4 -0
  134. package/build/dist/Models/DatabaseModels/AlertEpisodeFeed.js.map +1 -1
  135. package/build/dist/Models/DatabaseModels/AlertEpisodeLabelRule.js +592 -0
  136. package/build/dist/Models/DatabaseModels/AlertEpisodeLabelRule.js.map +1 -0
  137. package/build/dist/Models/DatabaseModels/AlertEpisodeOnCallRule.js +592 -0
  138. package/build/dist/Models/DatabaseModels/AlertEpisodeOnCallRule.js.map +1 -0
  139. package/build/dist/Models/DatabaseModels/AlertEpisodeOwnerRule.js +676 -0
  140. package/build/dist/Models/DatabaseModels/AlertEpisodeOwnerRule.js.map +1 -0
  141. package/build/dist/Models/DatabaseModels/AlertEpisodePrivacyRule.js +545 -0
  142. package/build/dist/Models/DatabaseModels/AlertEpisodePrivacyRule.js.map +1 -0
  143. package/build/dist/Models/DatabaseModels/AlertFeed.js +4 -0
  144. package/build/dist/Models/DatabaseModels/AlertFeed.js.map +1 -1
  145. package/build/dist/Models/DatabaseModels/AlertLabelRule.js +795 -0
  146. package/build/dist/Models/DatabaseModels/AlertLabelRule.js.map +1 -0
  147. package/build/dist/Models/DatabaseModels/AlertOnCallRule.js +759 -0
  148. package/build/dist/Models/DatabaseModels/AlertOnCallRule.js.map +1 -0
  149. package/build/dist/Models/DatabaseModels/AlertOwnerRule.js +917 -0
  150. package/build/dist/Models/DatabaseModels/AlertOwnerRule.js.map +1 -0
  151. package/build/dist/Models/DatabaseModels/AlertPrivacyRule.js +711 -0
  152. package/build/dist/Models/DatabaseModels/AlertPrivacyRule.js.map +1 -0
  153. package/build/dist/Models/DatabaseModels/DatabaseBaseModel/FileModel.js +29 -0
  154. package/build/dist/Models/DatabaseModels/DatabaseBaseModel/FileModel.js.map +1 -1
  155. package/build/dist/Models/DatabaseModels/Incident.js +42 -0
  156. package/build/dist/Models/DatabaseModels/Incident.js.map +1 -1
  157. package/build/dist/Models/DatabaseModels/IncidentEpisode.js +42 -0
  158. package/build/dist/Models/DatabaseModels/IncidentEpisode.js.map +1 -1
  159. package/build/dist/Models/DatabaseModels/IncidentEpisodeFeed.js +4 -0
  160. package/build/dist/Models/DatabaseModels/IncidentEpisodeFeed.js.map +1 -1
  161. package/build/dist/Models/DatabaseModels/IncidentEpisodeLabelRule.js +592 -0
  162. package/build/dist/Models/DatabaseModels/IncidentEpisodeLabelRule.js.map +1 -0
  163. package/build/dist/Models/DatabaseModels/IncidentEpisodeOnCallRule.js +593 -0
  164. package/build/dist/Models/DatabaseModels/IncidentEpisodeOnCallRule.js.map +1 -0
  165. package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerRule.js +677 -0
  166. package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerRule.js.map +1 -0
  167. package/build/dist/Models/DatabaseModels/IncidentEpisodePrivacyRule.js +545 -0
  168. package/build/dist/Models/DatabaseModels/IncidentEpisodePrivacyRule.js.map +1 -0
  169. package/build/dist/Models/DatabaseModels/IncidentFeed.js +4 -0
  170. package/build/dist/Models/DatabaseModels/IncidentFeed.js.map +1 -1
  171. package/build/dist/Models/DatabaseModels/IncidentLabelRule.js +834 -0
  172. package/build/dist/Models/DatabaseModels/IncidentLabelRule.js.map +1 -0
  173. package/build/dist/Models/DatabaseModels/IncidentOnCallRule.js +759 -0
  174. package/build/dist/Models/DatabaseModels/IncidentOnCallRule.js.map +1 -0
  175. package/build/dist/Models/DatabaseModels/IncidentOwnerRule.js +919 -0
  176. package/build/dist/Models/DatabaseModels/IncidentOwnerRule.js.map +1 -0
  177. package/build/dist/Models/DatabaseModels/IncidentPrivacyRule.js +711 -0
  178. package/build/dist/Models/DatabaseModels/IncidentPrivacyRule.js.map +1 -0
  179. package/build/dist/Models/DatabaseModels/Index.js +32 -0
  180. package/build/dist/Models/DatabaseModels/Index.js.map +1 -1
  181. package/build/dist/Server/API/FileAPI.js +64 -3
  182. package/build/dist/Server/API/FileAPI.js.map +1 -1
  183. package/build/dist/Server/API/StatusPageAPI.js +3 -0
  184. package/build/dist/Server/API/StatusPageAPI.js.map +1 -1
  185. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778269764550-MigrationName.js +146 -0
  186. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778269764550-MigrationName.js.map +1 -0
  187. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778271406963-MigrationName.js +358 -0
  188. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778271406963-MigrationName.js.map +1 -0
  189. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778274719786-MigrationName.js +230 -0
  190. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778274719786-MigrationName.js.map +1 -0
  191. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778359982682-AddIncidentIsPrivate.js +14 -0
  192. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778359982682-AddIncidentIsPrivate.js.map +1 -0
  193. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778361904715-AddFileImageAccessToken.js +14 -0
  194. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778361904715-AddFileImageAccessToken.js.map +1 -0
  195. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778413144103-AddOwnerRuleInheritFlags.js +18 -0
  196. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778413144103-AddOwnerRuleInheritFlags.js.map +1 -0
  197. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778438949454-AddAlertIsPrivate.js +14 -0
  198. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778438949454-AddAlertIsPrivate.js.map +1 -0
  199. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778440665575-AddPrivacyRules.js +118 -0
  200. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778440665575-AddPrivacyRules.js.map +1 -0
  201. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778442385970-AddEpisodePrivacyRules.js +86 -0
  202. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1778442385970-AddEpisodePrivacyRules.js.map +1 -0
  203. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js +18 -0
  204. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js.map +1 -1
  205. package/build/dist/Server/Services/AlertEpisodeFeedService.js +41 -0
  206. package/build/dist/Server/Services/AlertEpisodeFeedService.js.map +1 -1
  207. package/build/dist/Server/Services/AlertEpisodeInternalNoteService.js +41 -0
  208. package/build/dist/Server/Services/AlertEpisodeInternalNoteService.js.map +1 -1
  209. package/build/dist/Server/Services/AlertEpisodeLabelRuleEngineService.js +245 -0
  210. package/build/dist/Server/Services/AlertEpisodeLabelRuleEngineService.js.map +1 -0
  211. package/build/dist/Server/Services/AlertEpisodeLabelRuleService.js +13 -0
  212. package/build/dist/Server/Services/AlertEpisodeLabelRuleService.js.map +1 -0
  213. package/build/dist/Server/Services/AlertEpisodeOnCallRuleEngineService.js +260 -0
  214. package/build/dist/Server/Services/AlertEpisodeOnCallRuleEngineService.js.map +1 -0
  215. package/build/dist/Server/Services/AlertEpisodeOnCallRuleService.js +13 -0
  216. package/build/dist/Server/Services/AlertEpisodeOnCallRuleService.js.map +1 -0
  217. package/build/dist/Server/Services/AlertEpisodeOwnerRuleEngineService.js +269 -0
  218. package/build/dist/Server/Services/AlertEpisodeOwnerRuleEngineService.js.map +1 -0
  219. package/build/dist/Server/Services/AlertEpisodeOwnerRuleService.js +13 -0
  220. package/build/dist/Server/Services/AlertEpisodeOwnerRuleService.js.map +1 -0
  221. package/build/dist/Server/Services/AlertEpisodeOwnerTeamService.js +32 -0
  222. package/build/dist/Server/Services/AlertEpisodeOwnerTeamService.js.map +1 -1
  223. package/build/dist/Server/Services/AlertEpisodeOwnerUserService.js +32 -0
  224. package/build/dist/Server/Services/AlertEpisodeOwnerUserService.js.map +1 -1
  225. package/build/dist/Server/Services/AlertEpisodePrivacyRuleEngineService.js +184 -0
  226. package/build/dist/Server/Services/AlertEpisodePrivacyRuleEngineService.js.map +1 -0
  227. package/build/dist/Server/Services/AlertEpisodePrivacyRuleService.js +13 -0
  228. package/build/dist/Server/Services/AlertEpisodePrivacyRuleService.js.map +1 -0
  229. package/build/dist/Server/Services/AlertEpisodeService.js +106 -2
  230. package/build/dist/Server/Services/AlertEpisodeService.js.map +1 -1
  231. package/build/dist/Server/Services/AlertFeedService.js +41 -0
  232. package/build/dist/Server/Services/AlertFeedService.js.map +1 -1
  233. package/build/dist/Server/Services/AlertInternalNoteService.js +41 -0
  234. package/build/dist/Server/Services/AlertInternalNoteService.js.map +1 -1
  235. package/build/dist/Server/Services/AlertLabelRuleEngineService.js +354 -0
  236. package/build/dist/Server/Services/AlertLabelRuleEngineService.js.map +1 -0
  237. package/build/dist/Server/Services/AlertLabelRuleService.js +13 -0
  238. package/build/dist/Server/Services/AlertLabelRuleService.js.map +1 -0
  239. package/build/dist/Server/Services/AlertOnCallRuleEngineService.js +353 -0
  240. package/build/dist/Server/Services/AlertOnCallRuleEngineService.js.map +1 -0
  241. package/build/dist/Server/Services/AlertOnCallRuleService.js +13 -0
  242. package/build/dist/Server/Services/AlertOnCallRuleService.js.map +1 -0
  243. package/build/dist/Server/Services/AlertOwnerRuleEngineService.js +469 -0
  244. package/build/dist/Server/Services/AlertOwnerRuleEngineService.js.map +1 -0
  245. package/build/dist/Server/Services/AlertOwnerRuleService.js +13 -0
  246. package/build/dist/Server/Services/AlertOwnerRuleService.js.map +1 -0
  247. package/build/dist/Server/Services/AlertOwnerTeamService.js +32 -0
  248. package/build/dist/Server/Services/AlertOwnerTeamService.js.map +1 -1
  249. package/build/dist/Server/Services/AlertOwnerUserService.js +32 -0
  250. package/build/dist/Server/Services/AlertOwnerUserService.js.map +1 -1
  251. package/build/dist/Server/Services/AlertPrivacyRuleEngineService.js +265 -0
  252. package/build/dist/Server/Services/AlertPrivacyRuleEngineService.js.map +1 -0
  253. package/build/dist/Server/Services/AlertPrivacyRuleService.js +13 -0
  254. package/build/dist/Server/Services/AlertPrivacyRuleService.js.map +1 -0
  255. package/build/dist/Server/Services/AlertService.js +98 -2
  256. package/build/dist/Server/Services/AlertService.js.map +1 -1
  257. package/build/dist/Server/Services/FileService.js +21 -0
  258. package/build/dist/Server/Services/FileService.js.map +1 -1
  259. package/build/dist/Server/Services/HostService.js +78 -0
  260. package/build/dist/Server/Services/HostService.js.map +1 -1
  261. package/build/dist/Server/Services/IncidentEpisodeFeedService.js +41 -0
  262. package/build/dist/Server/Services/IncidentEpisodeFeedService.js.map +1 -1
  263. package/build/dist/Server/Services/IncidentEpisodeInternalNoteService.js +41 -0
  264. package/build/dist/Server/Services/IncidentEpisodeInternalNoteService.js.map +1 -1
  265. package/build/dist/Server/Services/IncidentEpisodeLabelRuleEngineService.js +245 -0
  266. package/build/dist/Server/Services/IncidentEpisodeLabelRuleEngineService.js.map +1 -0
  267. package/build/dist/Server/Services/IncidentEpisodeLabelRuleService.js +13 -0
  268. package/build/dist/Server/Services/IncidentEpisodeLabelRuleService.js.map +1 -0
  269. package/build/dist/Server/Services/IncidentEpisodeOnCallRuleEngineService.js +261 -0
  270. package/build/dist/Server/Services/IncidentEpisodeOnCallRuleEngineService.js.map +1 -0
  271. package/build/dist/Server/Services/IncidentEpisodeOnCallRuleService.js +13 -0
  272. package/build/dist/Server/Services/IncidentEpisodeOnCallRuleService.js.map +1 -0
  273. package/build/dist/Server/Services/IncidentEpisodeOwnerRuleEngineService.js +263 -0
  274. package/build/dist/Server/Services/IncidentEpisodeOwnerRuleEngineService.js.map +1 -0
  275. package/build/dist/Server/Services/IncidentEpisodeOwnerRuleService.js +13 -0
  276. package/build/dist/Server/Services/IncidentEpisodeOwnerRuleService.js.map +1 -0
  277. package/build/dist/Server/Services/IncidentEpisodeOwnerTeamService.js +32 -0
  278. package/build/dist/Server/Services/IncidentEpisodeOwnerTeamService.js.map +1 -1
  279. package/build/dist/Server/Services/IncidentEpisodeOwnerUserService.js +32 -0
  280. package/build/dist/Server/Services/IncidentEpisodeOwnerUserService.js.map +1 -1
  281. package/build/dist/Server/Services/IncidentEpisodePrivacyRuleEngineService.js +186 -0
  282. package/build/dist/Server/Services/IncidentEpisodePrivacyRuleEngineService.js.map +1 -0
  283. package/build/dist/Server/Services/IncidentEpisodePrivacyRuleService.js +13 -0
  284. package/build/dist/Server/Services/IncidentEpisodePrivacyRuleService.js.map +1 -0
  285. package/build/dist/Server/Services/IncidentEpisodeService.js +106 -2
  286. package/build/dist/Server/Services/IncidentEpisodeService.js.map +1 -1
  287. package/build/dist/Server/Services/IncidentFeedService.js +41 -0
  288. package/build/dist/Server/Services/IncidentFeedService.js.map +1 -1
  289. package/build/dist/Server/Services/IncidentInternalNoteService.js +41 -0
  290. package/build/dist/Server/Services/IncidentInternalNoteService.js.map +1 -1
  291. package/build/dist/Server/Services/IncidentLabelRuleEngineService.js +407 -0
  292. package/build/dist/Server/Services/IncidentLabelRuleEngineService.js.map +1 -0
  293. package/build/dist/Server/Services/IncidentLabelRuleService.js +13 -0
  294. package/build/dist/Server/Services/IncidentLabelRuleService.js.map +1 -0
  295. package/build/dist/Server/Services/IncidentOnCallRuleEngineService.js +376 -0
  296. package/build/dist/Server/Services/IncidentOnCallRuleEngineService.js.map +1 -0
  297. package/build/dist/Server/Services/IncidentOnCallRuleService.js +13 -0
  298. package/build/dist/Server/Services/IncidentOnCallRuleService.js.map +1 -0
  299. package/build/dist/Server/Services/IncidentOwnerRuleEngineService.js +510 -0
  300. package/build/dist/Server/Services/IncidentOwnerRuleEngineService.js.map +1 -0
  301. package/build/dist/Server/Services/IncidentOwnerRuleService.js +13 -0
  302. package/build/dist/Server/Services/IncidentOwnerRuleService.js.map +1 -0
  303. package/build/dist/Server/Services/IncidentOwnerTeamService.js +32 -0
  304. package/build/dist/Server/Services/IncidentOwnerTeamService.js.map +1 -1
  305. package/build/dist/Server/Services/IncidentOwnerUserService.js +32 -0
  306. package/build/dist/Server/Services/IncidentOwnerUserService.js.map +1 -1
  307. package/build/dist/Server/Services/IncidentPrivacyRuleEngineService.js +288 -0
  308. package/build/dist/Server/Services/IncidentPrivacyRuleEngineService.js.map +1 -0
  309. package/build/dist/Server/Services/IncidentPrivacyRuleService.js +13 -0
  310. package/build/dist/Server/Services/IncidentPrivacyRuleService.js.map +1 -0
  311. package/build/dist/Server/Services/IncidentService.js +134 -2
  312. package/build/dist/Server/Services/IncidentService.js.map +1 -1
  313. package/build/dist/Server/Services/LabelService.js +117 -0
  314. package/build/dist/Server/Services/LabelService.js.map +1 -1
  315. package/build/dist/Server/Services/OpenTelemetryIngestService.js +42 -0
  316. package/build/dist/Server/Services/OpenTelemetryIngestService.js.map +1 -1
  317. package/build/dist/Server/Services/ServiceService.js +74 -0
  318. package/build/dist/Server/Services/ServiceService.js.map +1 -1
  319. package/build/dist/Server/Services/WorkspaceNotificationRuleService.js +4 -9
  320. package/build/dist/Server/Services/WorkspaceNotificationRuleService.js.map +1 -1
  321. package/build/dist/Server/Utils/Alert/AlertPrivacyFilter.js +96 -0
  322. package/build/dist/Server/Utils/Alert/AlertPrivacyFilter.js.map +1 -0
  323. package/build/dist/Server/Utils/AlertEpisode/AlertEpisodePrivacyFilter.js +79 -0
  324. package/build/dist/Server/Utils/AlertEpisode/AlertEpisodePrivacyFilter.js.map +1 -0
  325. package/build/dist/Server/Utils/Incident/IncidentPrivacyFilter.js +96 -0
  326. package/build/dist/Server/Utils/Incident/IncidentPrivacyFilter.js.map +1 -0
  327. package/build/dist/Server/Utils/IncidentEpisode/IncidentEpisodePrivacyFilter.js +85 -0
  328. package/build/dist/Server/Utils/IncidentEpisode/IncidentEpisodePrivacyFilter.js.map +1 -0
  329. package/build/dist/Server/Utils/InlineImageAccessTokenSync.js +67 -0
  330. package/build/dist/Server/Utils/InlineImageAccessTokenSync.js.map +1 -0
  331. package/build/dist/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.js +25 -8
  332. package/build/dist/Server/Utils/Monitor/Criteria/MetricMonitorCriteria.js.map +1 -1
  333. package/build/dist/Server/Utils/Monitor/MonitorAlert.js +3 -0
  334. package/build/dist/Server/Utils/Monitor/MonitorAlert.js.map +1 -1
  335. package/build/dist/Server/Utils/Monitor/MonitorCriteriaObservationBuilder.js +71 -1
  336. package/build/dist/Server/Utils/Monitor/MonitorCriteriaObservationBuilder.js.map +1 -1
  337. package/build/dist/Server/Utils/Monitor/MonitorIncident.js +3 -0
  338. package/build/dist/Server/Utils/Monitor/MonitorIncident.js.map +1 -1
  339. package/build/dist/Server/Utils/Telemetry/OneuptimeLabel.js +61 -0
  340. package/build/dist/Server/Utils/Telemetry/OneuptimeLabel.js.map +1 -0
  341. package/build/dist/Server/Utils/Workspace/MicrosoftTeams/MicrosoftTeams.js +1 -1
  342. package/build/dist/Server/Utils/Workspace/MicrosoftTeams/MicrosoftTeams.js.map +1 -1
  343. package/build/dist/Server/Utils/Workspace/Slack/Slack.js +7 -3
  344. package/build/dist/Server/Utils/Workspace/Slack/Slack.js.map +1 -1
  345. package/build/dist/Server/Utils/Workspace/WorkspaceBase.js.map +1 -1
  346. package/build/dist/Server/Utils/Workspace/WorkspaceMessages/Alert.js +2 -7
  347. package/build/dist/Server/Utils/Workspace/WorkspaceMessages/Alert.js.map +1 -1
  348. package/build/dist/Server/Utils/Workspace/WorkspaceMessages/AlertEpisode.js +2 -7
  349. package/build/dist/Server/Utils/Workspace/WorkspaceMessages/AlertEpisode.js.map +1 -1
  350. package/build/dist/Server/Utils/Workspace/WorkspaceMessages/Incident.js +2 -7
  351. package/build/dist/Server/Utils/Workspace/WorkspaceMessages/Incident.js.map +1 -1
  352. package/build/dist/Server/Utils/Workspace/WorkspaceMessages/IncidentEpisode.js +2 -7
  353. package/build/dist/Server/Utils/Workspace/WorkspaceMessages/IncidentEpisode.js.map +1 -1
  354. package/build/dist/Tests/UI/Components/MarkdownEditor.test.js +34 -21
  355. package/build/dist/Tests/UI/Components/MarkdownEditor.test.js.map +1 -1
  356. package/build/dist/Tests/Utils/MetricUnitUtil.test.js +29 -1
  357. package/build/dist/Tests/Utils/MetricUnitUtil.test.js.map +1 -1
  358. package/build/dist/Types/Monitor/CriteriaAlert.js +1 -0
  359. package/build/dist/Types/Monitor/CriteriaAlert.js.map +1 -1
  360. package/build/dist/Types/Monitor/CriteriaIncident.js +1 -0
  361. package/build/dist/Types/Monitor/CriteriaIncident.js.map +1 -1
  362. package/build/dist/Types/Permission.js +668 -0
  363. package/build/dist/Types/Permission.js.map +1 -1
  364. package/build/dist/UI/Components/Charts/Utils/DataPoint.js +1 -27
  365. package/build/dist/UI/Components/Charts/Utils/DataPoint.js.map +1 -1
  366. package/build/dist/UI/Components/Forms/BasicForm.js +29 -17
  367. package/build/dist/UI/Components/Forms/BasicForm.js.map +1 -1
  368. package/build/dist/UI/Components/Markdown.tsx/MarkdownConverters.js +0 -0
  369. package/build/dist/UI/Components/Markdown.tsx/MarkdownConverters.js.map +1 -0
  370. package/build/dist/UI/Components/Markdown.tsx/MarkdownEditor.js +604 -66
  371. package/build/dist/UI/Components/Markdown.tsx/MarkdownEditor.js.map +1 -1
  372. package/build/dist/UI/Components/Markdown.tsx/MarkdownViewer.js +4 -0
  373. package/build/dist/UI/Components/Markdown.tsx/MarkdownViewer.js.map +1 -1
  374. package/build/dist/Utils/MetricUnitUtil.js +22 -0
  375. package/build/dist/Utils/MetricUnitUtil.js.map +1 -1
  376. package/build/dist/Utils/ValueFormatter.js +18 -4
  377. package/build/dist/Utils/ValueFormatter.js.map +1 -1
  378. package/package.json +1 -1
@@ -0,0 +1,914 @@
1
+ import IncidentSeverity from "./IncidentSeverity";
2
+ import Label from "./Label";
3
+ import Monitor from "./Monitor";
4
+ import Project from "./Project";
5
+ import Team from "./Team";
6
+ import User from "./User";
7
+ import BaseModel from "./DatabaseBaseModel/DatabaseBaseModel";
8
+ import Route from "../../Types/API/Route";
9
+ import ColumnAccessControl from "../../Types/Database/AccessControl/ColumnAccessControl";
10
+ import TableAccessControl from "../../Types/Database/AccessControl/TableAccessControl";
11
+ import ColumnLength from "../../Types/Database/ColumnLength";
12
+ import ColumnType from "../../Types/Database/ColumnType";
13
+ import CrudApiEndpoint from "../../Types/Database/CrudApiEndpoint";
14
+ import EnableDocumentation from "../../Types/Database/EnableDocumentation";
15
+ import EnableWorkflow from "../../Types/Database/EnableWorkflow";
16
+ import TableColumn from "../../Types/Database/TableColumn";
17
+ import TableColumnType from "../../Types/Database/TableColumnType";
18
+ import TableMetadata from "../../Types/Database/TableMetadata";
19
+ import TenantColumn from "../../Types/Database/TenantColumn";
20
+ import IconProp from "../../Types/Icon/IconProp";
21
+ import ObjectID from "../../Types/ObjectID";
22
+ import Permission from "../../Types/Permission";
23
+ import {
24
+ Column,
25
+ Entity,
26
+ Index,
27
+ JoinColumn,
28
+ JoinTable,
29
+ ManyToMany,
30
+ ManyToOne,
31
+ } from "typeorm";
32
+
33
+ @EnableDocumentation()
34
+ @TenantColumn("projectId")
35
+ @TableAccessControl({
36
+ create: [
37
+ Permission.ProjectOwner,
38
+ Permission.ProjectAdmin,
39
+ Permission.CreateIncidentOwnerRule,
40
+ ],
41
+ read: [
42
+ Permission.ProjectOwner,
43
+ Permission.ProjectAdmin,
44
+ Permission.ProjectMember,
45
+ Permission.Viewer,
46
+ Permission.IncidentManager,
47
+ Permission.ReadIncidentOwnerRule,
48
+ Permission.ReadAllProjectResources,
49
+ ],
50
+ delete: [
51
+ Permission.ProjectOwner,
52
+ Permission.ProjectAdmin,
53
+ Permission.DeleteIncidentOwnerRule,
54
+ ],
55
+ update: [
56
+ Permission.ProjectOwner,
57
+ Permission.ProjectAdmin,
58
+ Permission.EditIncidentOwnerRule,
59
+ ],
60
+ })
61
+ @CrudApiEndpoint(new Route("/incident-owner-rule"))
62
+ @Entity({
63
+ name: "IncidentOwnerRule",
64
+ })
65
+ @EnableWorkflow({
66
+ create: true,
67
+ delete: true,
68
+ update: true,
69
+ read: true,
70
+ })
71
+ @TableMetadata({
72
+ tableName: "IncidentOwnerRule",
73
+ singularName: "Incident Owner Rule",
74
+ pluralName: "Incident Owner Rules",
75
+ icon: IconProp.User,
76
+ tableDescription:
77
+ "Configure rules for automatically assigning owner users and teams when matching incidents are created",
78
+ })
79
+ export default class IncidentOwnerRule extends BaseModel {
80
+ @ColumnAccessControl({
81
+ create: [
82
+ Permission.ProjectOwner,
83
+ Permission.ProjectAdmin,
84
+ Permission.CreateIncidentOwnerRule,
85
+ ],
86
+ read: [
87
+ Permission.ProjectOwner,
88
+ Permission.ProjectAdmin,
89
+ Permission.ProjectMember,
90
+ Permission.Viewer,
91
+ Permission.IncidentManager,
92
+ Permission.ReadIncidentOwnerRule,
93
+ Permission.ReadAllProjectResources,
94
+ ],
95
+ update: [],
96
+ })
97
+ @TableColumn({
98
+ manyToOneRelationColumn: "projectId",
99
+ type: TableColumnType.Entity,
100
+ modelType: Project,
101
+ title: "Project",
102
+ description: "Relation to Project Resource in which this object belongs",
103
+ })
104
+ @ManyToOne(
105
+ () => {
106
+ return Project;
107
+ },
108
+ {
109
+ eager: false,
110
+ nullable: true,
111
+ onDelete: "CASCADE",
112
+ orphanedRowAction: "nullify",
113
+ },
114
+ )
115
+ @JoinColumn({ name: "projectId" })
116
+ public project?: Project = undefined;
117
+
118
+ @ColumnAccessControl({
119
+ create: [
120
+ Permission.ProjectOwner,
121
+ Permission.ProjectAdmin,
122
+ Permission.CreateIncidentOwnerRule,
123
+ ],
124
+ read: [
125
+ Permission.ProjectOwner,
126
+ Permission.ProjectAdmin,
127
+ Permission.ProjectMember,
128
+ Permission.Viewer,
129
+ Permission.IncidentManager,
130
+ Permission.ReadIncidentOwnerRule,
131
+ Permission.ReadAllProjectResources,
132
+ ],
133
+ update: [],
134
+ })
135
+ @Index()
136
+ @TableColumn({
137
+ type: TableColumnType.ObjectID,
138
+ required: true,
139
+ canReadOnRelationQuery: true,
140
+ title: "Project ID",
141
+ description: "ID of your OneUptime Project in which this object belongs",
142
+ })
143
+ @Column({
144
+ type: ColumnType.ObjectID,
145
+ nullable: false,
146
+ transformer: ObjectID.getDatabaseTransformer(),
147
+ })
148
+ public projectId?: ObjectID = undefined;
149
+
150
+ @ColumnAccessControl({
151
+ create: [
152
+ Permission.ProjectOwner,
153
+ Permission.ProjectAdmin,
154
+ Permission.CreateIncidentOwnerRule,
155
+ ],
156
+ read: [
157
+ Permission.ProjectOwner,
158
+ Permission.ProjectAdmin,
159
+ Permission.ProjectMember,
160
+ Permission.Viewer,
161
+ Permission.IncidentManager,
162
+ Permission.ReadIncidentOwnerRule,
163
+ Permission.ReadAllProjectResources,
164
+ ],
165
+ update: [
166
+ Permission.ProjectOwner,
167
+ Permission.ProjectAdmin,
168
+ Permission.EditIncidentOwnerRule,
169
+ ],
170
+ })
171
+ @Index()
172
+ @TableColumn({
173
+ required: true,
174
+ type: TableColumnType.ShortText,
175
+ canReadOnRelationQuery: true,
176
+ title: "Name",
177
+ description: "Name of this incident owner rule",
178
+ })
179
+ @Column({
180
+ nullable: false,
181
+ type: ColumnType.ShortText,
182
+ length: ColumnLength.ShortText,
183
+ })
184
+ public name?: string = undefined;
185
+
186
+ @ColumnAccessControl({
187
+ create: [
188
+ Permission.ProjectOwner,
189
+ Permission.ProjectAdmin,
190
+ Permission.CreateIncidentOwnerRule,
191
+ ],
192
+ read: [
193
+ Permission.ProjectOwner,
194
+ Permission.ProjectAdmin,
195
+ Permission.ProjectMember,
196
+ Permission.Viewer,
197
+ Permission.IncidentManager,
198
+ Permission.ReadIncidentOwnerRule,
199
+ Permission.ReadAllProjectResources,
200
+ ],
201
+ update: [
202
+ Permission.ProjectOwner,
203
+ Permission.ProjectAdmin,
204
+ Permission.EditIncidentOwnerRule,
205
+ ],
206
+ })
207
+ @TableColumn({
208
+ required: false,
209
+ type: TableColumnType.LongText,
210
+ title: "Description",
211
+ description: "Description of this incident owner rule",
212
+ })
213
+ @Column({
214
+ nullable: true,
215
+ type: ColumnType.LongText,
216
+ length: ColumnLength.LongText,
217
+ })
218
+ public description?: string = undefined;
219
+
220
+ @ColumnAccessControl({
221
+ create: [
222
+ Permission.ProjectOwner,
223
+ Permission.ProjectAdmin,
224
+ Permission.CreateIncidentOwnerRule,
225
+ ],
226
+ read: [
227
+ Permission.ProjectOwner,
228
+ Permission.ProjectAdmin,
229
+ Permission.ProjectMember,
230
+ Permission.Viewer,
231
+ Permission.IncidentManager,
232
+ Permission.ReadIncidentOwnerRule,
233
+ Permission.ReadAllProjectResources,
234
+ ],
235
+ update: [
236
+ Permission.ProjectOwner,
237
+ Permission.ProjectAdmin,
238
+ Permission.EditIncidentOwnerRule,
239
+ ],
240
+ })
241
+ @Index()
242
+ @TableColumn({
243
+ required: true,
244
+ type: TableColumnType.Boolean,
245
+ title: "Is Enabled",
246
+ description: "Whether this rule is enabled",
247
+ defaultValue: true,
248
+ isDefaultValueColumn: true,
249
+ })
250
+ @Column({
251
+ type: ColumnType.Boolean,
252
+ nullable: false,
253
+ default: true,
254
+ })
255
+ public isEnabled?: boolean = undefined;
256
+
257
+ @ColumnAccessControl({
258
+ create: [
259
+ Permission.ProjectOwner,
260
+ Permission.ProjectAdmin,
261
+ Permission.CreateIncidentOwnerRule,
262
+ ],
263
+ read: [
264
+ Permission.ProjectOwner,
265
+ Permission.ProjectAdmin,
266
+ Permission.ProjectMember,
267
+ Permission.Viewer,
268
+ Permission.IncidentManager,
269
+ Permission.ReadIncidentOwnerRule,
270
+ Permission.ReadAllProjectResources,
271
+ ],
272
+ update: [
273
+ Permission.ProjectOwner,
274
+ Permission.ProjectAdmin,
275
+ Permission.EditIncidentOwnerRule,
276
+ ],
277
+ })
278
+ @TableColumn({
279
+ required: false,
280
+ type: TableColumnType.Boolean,
281
+ title: "Notify Owners",
282
+ description:
283
+ "Send notifications to owner users and teams when they are added by this rule",
284
+ defaultValue: true,
285
+ isDefaultValueColumn: true,
286
+ })
287
+ @Column({
288
+ type: ColumnType.Boolean,
289
+ nullable: false,
290
+ default: true,
291
+ })
292
+ public notifyOwners?: boolean = undefined;
293
+
294
+ // Match Criteria
295
+
296
+ @ColumnAccessControl({
297
+ create: [
298
+ Permission.ProjectOwner,
299
+ Permission.ProjectAdmin,
300
+ Permission.CreateIncidentOwnerRule,
301
+ ],
302
+ read: [
303
+ Permission.ProjectOwner,
304
+ Permission.ProjectAdmin,
305
+ Permission.ProjectMember,
306
+ Permission.Viewer,
307
+ Permission.IncidentManager,
308
+ Permission.ReadIncidentOwnerRule,
309
+ Permission.ReadAllProjectResources,
310
+ ],
311
+ update: [
312
+ Permission.ProjectOwner,
313
+ Permission.ProjectAdmin,
314
+ Permission.EditIncidentOwnerRule,
315
+ ],
316
+ })
317
+ @TableColumn({
318
+ required: false,
319
+ type: TableColumnType.EntityArray,
320
+ modelType: Monitor,
321
+ title: "Monitors",
322
+ description:
323
+ "Only trigger for incidents from these monitors. Leave empty to match incidents from any monitor.",
324
+ })
325
+ @ManyToMany(
326
+ () => {
327
+ return Monitor;
328
+ },
329
+ { eager: false },
330
+ )
331
+ @JoinTable({
332
+ name: "IncidentOwnerRuleMonitor",
333
+ inverseJoinColumn: {
334
+ name: "monitorId",
335
+ referencedColumnName: "_id",
336
+ },
337
+ joinColumn: {
338
+ name: "incidentOwnerRuleId",
339
+ referencedColumnName: "_id",
340
+ },
341
+ })
342
+ public monitors?: Array<Monitor> = undefined;
343
+
344
+ @ColumnAccessControl({
345
+ create: [
346
+ Permission.ProjectOwner,
347
+ Permission.ProjectAdmin,
348
+ Permission.CreateIncidentOwnerRule,
349
+ ],
350
+ read: [
351
+ Permission.ProjectOwner,
352
+ Permission.ProjectAdmin,
353
+ Permission.ProjectMember,
354
+ Permission.Viewer,
355
+ Permission.IncidentManager,
356
+ Permission.ReadIncidentOwnerRule,
357
+ Permission.ReadAllProjectResources,
358
+ ],
359
+ update: [
360
+ Permission.ProjectOwner,
361
+ Permission.ProjectAdmin,
362
+ Permission.EditIncidentOwnerRule,
363
+ ],
364
+ })
365
+ @TableColumn({
366
+ required: false,
367
+ type: TableColumnType.EntityArray,
368
+ modelType: IncidentSeverity,
369
+ title: "Incident Severities",
370
+ description:
371
+ "Only trigger for incidents with these severities. Leave empty to match incidents of any severity.",
372
+ })
373
+ @ManyToMany(
374
+ () => {
375
+ return IncidentSeverity;
376
+ },
377
+ { eager: false },
378
+ )
379
+ @JoinTable({
380
+ name: "IncidentOwnerRuleIncidentSeverity",
381
+ inverseJoinColumn: {
382
+ name: "incidentSeverityId",
383
+ referencedColumnName: "_id",
384
+ },
385
+ joinColumn: {
386
+ name: "incidentOwnerRuleId",
387
+ referencedColumnName: "_id",
388
+ },
389
+ })
390
+ public incidentSeverities?: Array<IncidentSeverity> = undefined;
391
+
392
+ @ColumnAccessControl({
393
+ create: [
394
+ Permission.ProjectOwner,
395
+ Permission.ProjectAdmin,
396
+ Permission.CreateIncidentOwnerRule,
397
+ ],
398
+ read: [
399
+ Permission.ProjectOwner,
400
+ Permission.ProjectAdmin,
401
+ Permission.ProjectMember,
402
+ Permission.Viewer,
403
+ Permission.IncidentManager,
404
+ Permission.ReadIncidentOwnerRule,
405
+ Permission.ReadAllProjectResources,
406
+ ],
407
+ update: [
408
+ Permission.ProjectOwner,
409
+ Permission.ProjectAdmin,
410
+ Permission.EditIncidentOwnerRule,
411
+ ],
412
+ })
413
+ @TableColumn({
414
+ required: false,
415
+ type: TableColumnType.EntityArray,
416
+ modelType: Label,
417
+ title: "Incident Labels",
418
+ description:
419
+ "Only trigger for incidents that have at least one of these labels. Leave empty to match regardless of incident labels.",
420
+ })
421
+ @ManyToMany(
422
+ () => {
423
+ return Label;
424
+ },
425
+ { eager: false },
426
+ )
427
+ @JoinTable({
428
+ name: "IncidentOwnerRuleIncidentLabel",
429
+ inverseJoinColumn: {
430
+ name: "labelId",
431
+ referencedColumnName: "_id",
432
+ },
433
+ joinColumn: {
434
+ name: "incidentOwnerRuleId",
435
+ referencedColumnName: "_id",
436
+ },
437
+ })
438
+ public incidentLabels?: Array<Label> = undefined;
439
+
440
+ @ColumnAccessControl({
441
+ create: [
442
+ Permission.ProjectOwner,
443
+ Permission.ProjectAdmin,
444
+ Permission.CreateIncidentOwnerRule,
445
+ ],
446
+ read: [
447
+ Permission.ProjectOwner,
448
+ Permission.ProjectAdmin,
449
+ Permission.ProjectMember,
450
+ Permission.Viewer,
451
+ Permission.IncidentManager,
452
+ Permission.ReadIncidentOwnerRule,
453
+ Permission.ReadAllProjectResources,
454
+ ],
455
+ update: [
456
+ Permission.ProjectOwner,
457
+ Permission.ProjectAdmin,
458
+ Permission.EditIncidentOwnerRule,
459
+ ],
460
+ })
461
+ @TableColumn({
462
+ required: false,
463
+ type: TableColumnType.EntityArray,
464
+ modelType: Label,
465
+ title: "Monitor Labels",
466
+ description:
467
+ "Only trigger for incidents from monitors that have at least one of these labels. Leave empty to match regardless of monitor labels.",
468
+ })
469
+ @ManyToMany(
470
+ () => {
471
+ return Label;
472
+ },
473
+ { eager: false },
474
+ )
475
+ @JoinTable({
476
+ name: "IncidentOwnerRuleMonitorLabel",
477
+ inverseJoinColumn: {
478
+ name: "labelId",
479
+ referencedColumnName: "_id",
480
+ },
481
+ joinColumn: {
482
+ name: "incidentOwnerRuleId",
483
+ referencedColumnName: "_id",
484
+ },
485
+ })
486
+ public monitorLabels?: Array<Label> = undefined;
487
+
488
+ @ColumnAccessControl({
489
+ create: [
490
+ Permission.ProjectOwner,
491
+ Permission.ProjectAdmin,
492
+ Permission.CreateIncidentOwnerRule,
493
+ ],
494
+ read: [
495
+ Permission.ProjectOwner,
496
+ Permission.ProjectAdmin,
497
+ Permission.ProjectMember,
498
+ Permission.Viewer,
499
+ Permission.IncidentManager,
500
+ Permission.ReadIncidentOwnerRule,
501
+ Permission.ReadAllProjectResources,
502
+ ],
503
+ update: [
504
+ Permission.ProjectOwner,
505
+ Permission.ProjectAdmin,
506
+ Permission.EditIncidentOwnerRule,
507
+ ],
508
+ })
509
+ @TableColumn({
510
+ required: false,
511
+ type: TableColumnType.LongText,
512
+ title: "Incident Title Pattern",
513
+ description:
514
+ "Regex (case-insensitive) matched against the incident title. Leave empty to match any title.",
515
+ })
516
+ @Column({
517
+ type: ColumnType.LongText,
518
+ nullable: true,
519
+ length: ColumnLength.LongText,
520
+ })
521
+ public incidentTitlePattern?: string = undefined;
522
+
523
+ @ColumnAccessControl({
524
+ create: [
525
+ Permission.ProjectOwner,
526
+ Permission.ProjectAdmin,
527
+ Permission.CreateIncidentOwnerRule,
528
+ ],
529
+ read: [
530
+ Permission.ProjectOwner,
531
+ Permission.ProjectAdmin,
532
+ Permission.ProjectMember,
533
+ Permission.Viewer,
534
+ Permission.IncidentManager,
535
+ Permission.ReadIncidentOwnerRule,
536
+ Permission.ReadAllProjectResources,
537
+ ],
538
+ update: [
539
+ Permission.ProjectOwner,
540
+ Permission.ProjectAdmin,
541
+ Permission.EditIncidentOwnerRule,
542
+ ],
543
+ })
544
+ @TableColumn({
545
+ required: false,
546
+ type: TableColumnType.LongText,
547
+ title: "Incident Description Pattern",
548
+ description:
549
+ "Regex (case-insensitive) matched against the incident description. Leave empty to match any description.",
550
+ })
551
+ @Column({
552
+ type: ColumnType.LongText,
553
+ nullable: true,
554
+ length: ColumnLength.LongText,
555
+ })
556
+ public incidentDescriptionPattern?: string = undefined;
557
+
558
+ @ColumnAccessControl({
559
+ create: [
560
+ Permission.ProjectOwner,
561
+ Permission.ProjectAdmin,
562
+ Permission.CreateIncidentOwnerRule,
563
+ ],
564
+ read: [
565
+ Permission.ProjectOwner,
566
+ Permission.ProjectAdmin,
567
+ Permission.ProjectMember,
568
+ Permission.Viewer,
569
+ Permission.IncidentManager,
570
+ Permission.ReadIncidentOwnerRule,
571
+ Permission.ReadAllProjectResources,
572
+ ],
573
+ update: [
574
+ Permission.ProjectOwner,
575
+ Permission.ProjectAdmin,
576
+ Permission.EditIncidentOwnerRule,
577
+ ],
578
+ })
579
+ @TableColumn({
580
+ required: false,
581
+ type: TableColumnType.LongText,
582
+ title: "Monitor Name Pattern",
583
+ description:
584
+ "Regex (case-insensitive) matched against any of the incident's monitor names. Leave empty to match any monitor.",
585
+ })
586
+ @Column({
587
+ type: ColumnType.LongText,
588
+ nullable: true,
589
+ length: ColumnLength.LongText,
590
+ })
591
+ public monitorNamePattern?: string = undefined;
592
+
593
+ @ColumnAccessControl({
594
+ create: [
595
+ Permission.ProjectOwner,
596
+ Permission.ProjectAdmin,
597
+ Permission.CreateIncidentOwnerRule,
598
+ ],
599
+ read: [
600
+ Permission.ProjectOwner,
601
+ Permission.ProjectAdmin,
602
+ Permission.ProjectMember,
603
+ Permission.Viewer,
604
+ Permission.IncidentManager,
605
+ Permission.ReadIncidentOwnerRule,
606
+ Permission.ReadAllProjectResources,
607
+ ],
608
+ update: [
609
+ Permission.ProjectOwner,
610
+ Permission.ProjectAdmin,
611
+ Permission.EditIncidentOwnerRule,
612
+ ],
613
+ })
614
+ @TableColumn({
615
+ required: false,
616
+ type: TableColumnType.LongText,
617
+ title: "Monitor Description Pattern",
618
+ description:
619
+ "Regex (case-insensitive) matched against any of the incident's monitor descriptions. Leave empty to match any description.",
620
+ })
621
+ @Column({
622
+ type: ColumnType.LongText,
623
+ nullable: true,
624
+ length: ColumnLength.LongText,
625
+ })
626
+ public monitorDescriptionPattern?: string = undefined;
627
+
628
+ // Action: Owner Users + Teams
629
+
630
+ @ColumnAccessControl({
631
+ create: [
632
+ Permission.ProjectOwner,
633
+ Permission.ProjectAdmin,
634
+ Permission.CreateIncidentOwnerRule,
635
+ ],
636
+ read: [
637
+ Permission.ProjectOwner,
638
+ Permission.ProjectAdmin,
639
+ Permission.ProjectMember,
640
+ Permission.Viewer,
641
+ Permission.IncidentManager,
642
+ Permission.ReadIncidentOwnerRule,
643
+ Permission.ReadAllProjectResources,
644
+ ],
645
+ update: [
646
+ Permission.ProjectOwner,
647
+ Permission.ProjectAdmin,
648
+ Permission.EditIncidentOwnerRule,
649
+ ],
650
+ })
651
+ @TableColumn({
652
+ required: false,
653
+ type: TableColumnType.EntityArray,
654
+ modelType: User,
655
+ title: "Owner Users",
656
+ description:
657
+ "Users to add as owners on the incident when this rule matches.",
658
+ })
659
+ @ManyToMany(
660
+ () => {
661
+ return User;
662
+ },
663
+ { eager: false },
664
+ )
665
+ @JoinTable({
666
+ name: "IncidentOwnerRuleOwnerUser",
667
+ inverseJoinColumn: {
668
+ name: "userId",
669
+ referencedColumnName: "_id",
670
+ },
671
+ joinColumn: {
672
+ name: "incidentOwnerRuleId",
673
+ referencedColumnName: "_id",
674
+ },
675
+ })
676
+ public ownerUsers?: Array<User> = undefined;
677
+
678
+ @ColumnAccessControl({
679
+ create: [
680
+ Permission.ProjectOwner,
681
+ Permission.ProjectAdmin,
682
+ Permission.CreateIncidentOwnerRule,
683
+ ],
684
+ read: [
685
+ Permission.ProjectOwner,
686
+ Permission.ProjectAdmin,
687
+ Permission.ProjectMember,
688
+ Permission.Viewer,
689
+ Permission.IncidentManager,
690
+ Permission.ReadIncidentOwnerRule,
691
+ Permission.ReadAllProjectResources,
692
+ ],
693
+ update: [
694
+ Permission.ProjectOwner,
695
+ Permission.ProjectAdmin,
696
+ Permission.EditIncidentOwnerRule,
697
+ ],
698
+ })
699
+ @TableColumn({
700
+ required: false,
701
+ type: TableColumnType.EntityArray,
702
+ modelType: Team,
703
+ title: "Owner Teams",
704
+ description:
705
+ "Teams to add as owners on the incident when this rule matches.",
706
+ })
707
+ @ManyToMany(
708
+ () => {
709
+ return Team;
710
+ },
711
+ { eager: false },
712
+ )
713
+ @JoinTable({
714
+ name: "IncidentOwnerRuleOwnerTeam",
715
+ inverseJoinColumn: {
716
+ name: "teamId",
717
+ referencedColumnName: "_id",
718
+ },
719
+ joinColumn: {
720
+ name: "incidentOwnerRuleId",
721
+ referencedColumnName: "_id",
722
+ },
723
+ })
724
+ public ownerTeams?: Array<Team> = undefined;
725
+
726
+ @ColumnAccessControl({
727
+ create: [
728
+ Permission.ProjectOwner,
729
+ Permission.ProjectAdmin,
730
+ Permission.CreateIncidentOwnerRule,
731
+ ],
732
+ read: [
733
+ Permission.ProjectOwner,
734
+ Permission.ProjectAdmin,
735
+ Permission.ProjectMember,
736
+ Permission.Viewer,
737
+ Permission.IncidentManager,
738
+ Permission.ReadIncidentOwnerRule,
739
+ Permission.ReadAllProjectResources,
740
+ ],
741
+ update: [
742
+ Permission.ProjectOwner,
743
+ Permission.ProjectAdmin,
744
+ Permission.EditIncidentOwnerRule,
745
+ ],
746
+ })
747
+ @TableColumn({
748
+ required: false,
749
+ type: TableColumnType.Boolean,
750
+ title: "Inherit Owners From Monitors",
751
+ description:
752
+ "When this rule matches, also assign every owner of the incident's monitors to the incident.",
753
+ defaultValue: false,
754
+ isDefaultValueColumn: true,
755
+ })
756
+ @Column({
757
+ type: ColumnType.Boolean,
758
+ nullable: false,
759
+ default: false,
760
+ })
761
+ public inheritOwnersFromMonitors?: boolean = undefined;
762
+
763
+ @ColumnAccessControl({
764
+ create: [
765
+ Permission.ProjectOwner,
766
+ Permission.ProjectAdmin,
767
+ Permission.CreateIncidentOwnerRule,
768
+ ],
769
+ read: [
770
+ Permission.ProjectOwner,
771
+ Permission.ProjectAdmin,
772
+ Permission.ProjectMember,
773
+ Permission.Viewer,
774
+ Permission.IncidentManager,
775
+ Permission.ReadIncidentOwnerRule,
776
+ Permission.ReadAllProjectResources,
777
+ ],
778
+ update: [
779
+ Permission.ProjectOwner,
780
+ Permission.ProjectAdmin,
781
+ Permission.EditIncidentOwnerRule,
782
+ ],
783
+ })
784
+ @TableColumn({
785
+ required: false,
786
+ type: TableColumnType.Boolean,
787
+ title: "Inherit Owners From Hosts",
788
+ description:
789
+ "When this rule matches, also assign every owner of the incident's affected hosts to the incident.",
790
+ defaultValue: false,
791
+ isDefaultValueColumn: true,
792
+ })
793
+ @Column({
794
+ type: ColumnType.Boolean,
795
+ nullable: false,
796
+ default: false,
797
+ })
798
+ public inheritOwnersFromHosts?: boolean = undefined;
799
+
800
+ @ColumnAccessControl({
801
+ create: [
802
+ Permission.ProjectOwner,
803
+ Permission.ProjectAdmin,
804
+ Permission.CreateIncidentOwnerRule,
805
+ ],
806
+ read: [
807
+ Permission.ProjectOwner,
808
+ Permission.ProjectAdmin,
809
+ Permission.ProjectMember,
810
+ Permission.Viewer,
811
+ Permission.IncidentManager,
812
+ Permission.ReadIncidentOwnerRule,
813
+ Permission.ReadAllProjectResources,
814
+ ],
815
+ update: [],
816
+ })
817
+ @TableColumn({
818
+ manyToOneRelationColumn: "createdByUserId",
819
+ type: TableColumnType.Entity,
820
+ modelType: User,
821
+ title: "Created by User",
822
+ description:
823
+ "Relation to User who created this object (if this object was created by a User)",
824
+ })
825
+ @ManyToOne(
826
+ () => {
827
+ return User;
828
+ },
829
+ {
830
+ eager: false,
831
+ nullable: true,
832
+ onDelete: "SET NULL",
833
+ orphanedRowAction: "nullify",
834
+ },
835
+ )
836
+ @JoinColumn({ name: "createdByUserId" })
837
+ public createdByUser?: User = undefined;
838
+
839
+ @ColumnAccessControl({
840
+ create: [
841
+ Permission.ProjectOwner,
842
+ Permission.ProjectAdmin,
843
+ Permission.CreateIncidentOwnerRule,
844
+ ],
845
+ read: [
846
+ Permission.ProjectOwner,
847
+ Permission.ProjectAdmin,
848
+ Permission.ProjectMember,
849
+ Permission.Viewer,
850
+ Permission.IncidentManager,
851
+ Permission.ReadIncidentOwnerRule,
852
+ Permission.ReadAllProjectResources,
853
+ ],
854
+ update: [],
855
+ })
856
+ @TableColumn({
857
+ type: TableColumnType.ObjectID,
858
+ title: "Created by User ID",
859
+ description:
860
+ "User ID who created this object (if this object was created by a User)",
861
+ })
862
+ @Column({
863
+ type: ColumnType.ObjectID,
864
+ nullable: true,
865
+ transformer: ObjectID.getDatabaseTransformer(),
866
+ })
867
+ public createdByUserId?: ObjectID = undefined;
868
+
869
+ @ColumnAccessControl({
870
+ create: [],
871
+ read: [],
872
+ update: [],
873
+ })
874
+ @TableColumn({
875
+ manyToOneRelationColumn: "deletedByUserId",
876
+ type: TableColumnType.Entity,
877
+ title: "Deleted by User",
878
+ modelType: User,
879
+ description:
880
+ "Relation to User who deleted this object (if this object was deleted by a User)",
881
+ })
882
+ @ManyToOne(
883
+ () => {
884
+ return User;
885
+ },
886
+ {
887
+ cascade: false,
888
+ eager: false,
889
+ nullable: true,
890
+ onDelete: "SET NULL",
891
+ orphanedRowAction: "nullify",
892
+ },
893
+ )
894
+ @JoinColumn({ name: "deletedByUserId" })
895
+ public deletedByUser?: User = undefined;
896
+
897
+ @ColumnAccessControl({
898
+ create: [],
899
+ read: [],
900
+ update: [],
901
+ })
902
+ @TableColumn({
903
+ type: TableColumnType.ObjectID,
904
+ title: "Deleted by User ID",
905
+ description:
906
+ "User ID who deleted this object (if this object was deleted by a User)",
907
+ })
908
+ @Column({
909
+ type: ColumnType.ObjectID,
910
+ nullable: true,
911
+ transformer: ObjectID.getDatabaseTransformer(),
912
+ })
913
+ public deletedByUserId?: ObjectID = undefined;
914
+ }