@oneuptime/common 9.4.11 → 9.4.13

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 (286) hide show
  1. package/Models/DatabaseModels/Incident.ts +77 -0
  2. package/Models/DatabaseModels/IncidentEpisode.ts +1223 -0
  3. package/Models/DatabaseModels/IncidentEpisodeFeed.ts +533 -0
  4. package/Models/DatabaseModels/IncidentEpisodeInternalNote.ts +456 -0
  5. package/Models/DatabaseModels/IncidentEpisodeMember.ts +587 -0
  6. package/Models/DatabaseModels/IncidentEpisodeOwnerTeam.ts +421 -0
  7. package/Models/DatabaseModels/IncidentEpisodeOwnerUser.ts +419 -0
  8. package/Models/DatabaseModels/IncidentEpisodeStateTimeline.ts +524 -0
  9. package/Models/DatabaseModels/IncidentGroupingRule.ts +1430 -0
  10. package/Models/DatabaseModels/Index.ts +18 -0
  11. package/Models/DatabaseModels/OnCallDutyPolicyExecutionLog.ts +70 -0
  12. package/Models/DatabaseModels/OnCallDutyPolicyExecutionLogTimeline.ts +59 -0
  13. package/Models/DatabaseModels/Project.ts +29 -0
  14. package/Models/DatabaseModels/UserOnCallLog.ts +48 -0
  15. package/Models/DatabaseModels/UserOnCallLogTimeline.ts +49 -0
  16. package/Models/DatabaseModels/WorkspaceNotificationLog.ts +57 -0
  17. package/Server/API/BillingAPI.ts +78 -1
  18. package/Server/API/IncidentEpisodeAPI.ts +150 -0
  19. package/Server/API/SlackAPI.ts +23 -0
  20. package/Server/API/UserOnCallLogTimelineAPI.ts +24 -4
  21. package/Server/BillingConfig.ts +3 -0
  22. package/Server/EnvironmentConfig.ts +1 -0
  23. package/Server/Infrastructure/Postgres/SchemaMigrations/1769599843642-MigrationName.ts +29 -0
  24. package/Server/Infrastructure/Postgres/SchemaMigrations/1769626069479-MigrationName.ts +729 -0
  25. package/Server/Infrastructure/Postgres/SchemaMigrations/1769629928240-MigrationName.ts +261 -0
  26. package/Server/Infrastructure/Postgres/SchemaMigrations/1769676117342-RenameEvaluateOverTimeInCriteriaFilter.ts +28 -0
  27. package/Server/Infrastructure/Postgres/SchemaMigrations/Index.ts +8 -0
  28. package/Server/Services/AIBillingService.ts +10 -0
  29. package/Server/Services/BillingService.ts +349 -1
  30. package/Server/Services/CallService.ts +1 -0
  31. package/Server/Services/IncidentEpisodeFeedService.ts +94 -0
  32. package/Server/Services/IncidentEpisodeInternalNoteService.ts +71 -0
  33. package/Server/Services/IncidentEpisodeMemberService.ts +321 -0
  34. package/Server/Services/IncidentEpisodeOwnerTeamService.ts +10 -0
  35. package/Server/Services/IncidentEpisodeOwnerUserService.ts +10 -0
  36. package/Server/Services/IncidentEpisodeService.ts +1045 -0
  37. package/Server/Services/IncidentEpisodeStateTimelineService.ts +566 -0
  38. package/Server/Services/IncidentGroupingEngineService.ts +1047 -0
  39. package/Server/Services/IncidentGroupingRuleService.ts +14 -0
  40. package/Server/Services/IncidentService.ts +11 -0
  41. package/Server/Services/Index.ts +18 -0
  42. package/Server/Services/MailService.ts +1 -0
  43. package/Server/Services/MonitorService.ts +9 -0
  44. package/Server/Services/NotificationService.ts +10 -0
  45. package/Server/Services/OnCallDutyPolicyEscalationRuleService.ts +18 -0
  46. package/Server/Services/OnCallDutyPolicyExecutionLogService.ts +64 -2
  47. package/Server/Services/OnCallDutyPolicyExecutionLogTimelineService.ts +26 -1
  48. package/Server/Services/OnCallDutyPolicyService.ts +15 -0
  49. package/Server/Services/ProjectService.ts +33 -2
  50. package/Server/Services/SmsService.ts +1 -0
  51. package/Server/Services/UserNotificationRuleService.ts +48 -2
  52. package/Server/Services/UserNotificationSettingService.ts +23 -0
  53. package/Server/Services/UserOnCallLogService.ts +41 -4
  54. package/Server/Services/UserService.ts +45 -1
  55. package/Server/Services/WhatsAppService.ts +1 -0
  56. package/Server/Services/WorkspaceNotificationLogService.ts +16 -0
  57. package/Server/Services/WorkspaceNotificationRuleService.ts +116 -0
  58. package/Server/Types/Database/Permissions/TenantPermission.ts +20 -0
  59. package/Server/Utils/AI/IncidentEpisodeAIContextBuilder.ts +490 -0
  60. package/Server/Utils/Monitor/Criteria/APIRequestCriteria.ts +1 -1
  61. package/Server/Utils/Monitor/Criteria/CompareCriteria.ts +1 -1
  62. package/Server/Utils/Monitor/Criteria/IncomingRequestCriteria.ts +1 -1
  63. package/Server/Utils/Monitor/Criteria/SSLMonitorCriteria.ts +1 -1
  64. package/Server/Utils/Monitor/Criteria/ServerMonitorCriteria.ts +2 -2
  65. package/Server/Utils/Monitor/Criteria/SnmpMonitorCriteria.ts +182 -0
  66. package/Server/Utils/Monitor/MonitorCriteriaEvaluator.ts +13 -0
  67. package/Server/Utils/Monitor/MonitorCriteriaExpectationBuilder.ts +1 -1
  68. package/Server/Utils/Monitor/MonitorTemplateUtil.ts +37 -0
  69. package/Server/Utils/PushNotificationUtil.ts +31 -0
  70. package/Server/Utils/WhatsAppTemplateUtil.ts +14 -0
  71. package/Server/Utils/Workspace/MicrosoftTeams/Actions/ActionTypes.ts +18 -0
  72. package/Server/Utils/Workspace/MicrosoftTeams/Actions/IncidentEpisode.ts +702 -0
  73. package/Server/Utils/Workspace/MicrosoftTeams/MicrosoftTeams.ts +20 -0
  74. package/Server/Utils/Workspace/Slack/Actions/ActionTypes.ts +11 -0
  75. package/Server/Utils/Workspace/Slack/Actions/IncidentEpisode.ts +918 -0
  76. package/Server/Utils/Workspace/Slack/Messages/IncidentEpisode.ts +120 -0
  77. package/Server/Utils/Workspace/WorkspaceMessages/IncidentEpisode.ts +74 -0
  78. package/Types/Email/EmailTemplateType.ts +7 -0
  79. package/Types/Monitor/CriteriaFilter.ts +24 -4
  80. package/Types/Monitor/MonitorCriteriaInstance.ts +67 -0
  81. package/Types/Monitor/MonitorStep.ts +37 -0
  82. package/Types/Monitor/MonitorStepSnmpMonitor.ts +102 -0
  83. package/Types/Monitor/MonitorType.ts +15 -2
  84. package/Types/Monitor/SnmpMonitor/SnmpAuthProtocol.ts +8 -0
  85. package/Types/Monitor/SnmpMonitor/SnmpDataType.ts +21 -0
  86. package/Types/Monitor/SnmpMonitor/SnmpMonitorResponse.ts +16 -0
  87. package/Types/Monitor/SnmpMonitor/SnmpOid.ts +60 -0
  88. package/Types/Monitor/SnmpMonitor/SnmpPrivProtocol.ts +7 -0
  89. package/Types/Monitor/SnmpMonitor/SnmpSecurityLevel.ts +7 -0
  90. package/Types/Monitor/SnmpMonitor/SnmpV3Auth.ts +12 -0
  91. package/Types/Monitor/SnmpMonitor/SnmpVersion.ts +7 -0
  92. package/Types/NotificationSetting/NotificationSettingEventType.ts +7 -0
  93. package/Types/Permission.ts +311 -0
  94. package/Types/Probe/ProbeMonitorResponse.ts +2 -0
  95. package/Types/UserNotification/UserNotificationEventType.ts +1 -0
  96. package/Types/WhatsApp/WhatsAppTemplates.ts +24 -0
  97. package/Types/Workspace/NotificationRules/EventType.ts +1 -0
  98. package/Types/Workspace/NotificationRules/NotificationRuleCondition.ts +38 -1
  99. package/Utils/Monitor/MonitorMetricType.ts +2 -1
  100. package/build/dist/Models/DatabaseModels/Incident.js +78 -0
  101. package/build/dist/Models/DatabaseModels/Incident.js.map +1 -1
  102. package/build/dist/Models/DatabaseModels/IncidentEpisode.js +1250 -0
  103. package/build/dist/Models/DatabaseModels/IncidentEpisode.js.map +1 -0
  104. package/build/dist/Models/DatabaseModels/IncidentEpisodeFeed.js +555 -0
  105. package/build/dist/Models/DatabaseModels/IncidentEpisodeFeed.js.map +1 -0
  106. package/build/dist/Models/DatabaseModels/IncidentEpisodeInternalNote.js +467 -0
  107. package/build/dist/Models/DatabaseModels/IncidentEpisodeInternalNote.js.map +1 -0
  108. package/build/dist/Models/DatabaseModels/IncidentEpisodeMember.js +607 -0
  109. package/build/dist/Models/DatabaseModels/IncidentEpisodeMember.js.map +1 -0
  110. package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerTeam.js +437 -0
  111. package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerTeam.js.map +1 -0
  112. package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerUser.js +436 -0
  113. package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerUser.js.map +1 -0
  114. package/build/dist/Models/DatabaseModels/IncidentEpisodeStateTimeline.js +546 -0
  115. package/build/dist/Models/DatabaseModels/IncidentEpisodeStateTimeline.js.map +1 -0
  116. package/build/dist/Models/DatabaseModels/IncidentGroupingRule.js +1437 -0
  117. package/build/dist/Models/DatabaseModels/IncidentGroupingRule.js.map +1 -0
  118. package/build/dist/Models/DatabaseModels/Index.js +16 -0
  119. package/build/dist/Models/DatabaseModels/Index.js.map +1 -1
  120. package/build/dist/Models/DatabaseModels/OnCallDutyPolicyExecutionLog.js +69 -0
  121. package/build/dist/Models/DatabaseModels/OnCallDutyPolicyExecutionLog.js.map +1 -1
  122. package/build/dist/Models/DatabaseModels/OnCallDutyPolicyExecutionLogTimeline.js +58 -0
  123. package/build/dist/Models/DatabaseModels/OnCallDutyPolicyExecutionLogTimeline.js.map +1 -1
  124. package/build/dist/Models/DatabaseModels/Project.js +30 -0
  125. package/build/dist/Models/DatabaseModels/Project.js.map +1 -1
  126. package/build/dist/Models/DatabaseModels/UserOnCallLog.js +47 -0
  127. package/build/dist/Models/DatabaseModels/UserOnCallLog.js.map +1 -1
  128. package/build/dist/Models/DatabaseModels/UserOnCallLogTimeline.js +48 -0
  129. package/build/dist/Models/DatabaseModels/UserOnCallLogTimeline.js.map +1 -1
  130. package/build/dist/Models/DatabaseModels/WorkspaceNotificationLog.js +58 -0
  131. package/build/dist/Models/DatabaseModels/WorkspaceNotificationLog.js.map +1 -1
  132. package/build/dist/Server/API/BillingAPI.js +44 -1
  133. package/build/dist/Server/API/BillingAPI.js.map +1 -1
  134. package/build/dist/Server/API/IncidentEpisodeAPI.js +97 -0
  135. package/build/dist/Server/API/IncidentEpisodeAPI.js.map +1 -0
  136. package/build/dist/Server/API/SlackAPI.js +18 -0
  137. package/build/dist/Server/API/SlackAPI.js.map +1 -1
  138. package/build/dist/Server/API/UserOnCallLogTimelineAPI.js +30 -10
  139. package/build/dist/Server/API/UserOnCallLogTimelineAPI.js.map +1 -1
  140. package/build/dist/Server/BillingConfig.js +2 -0
  141. package/build/dist/Server/BillingConfig.js.map +1 -1
  142. package/build/dist/Server/EnvironmentConfig.js +1 -0
  143. package/build/dist/Server/EnvironmentConfig.js.map +1 -1
  144. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769599843642-MigrationName.js +16 -0
  145. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769599843642-MigrationName.js.map +1 -0
  146. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769626069479-MigrationName.js +256 -0
  147. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769626069479-MigrationName.js.map +1 -0
  148. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769629928240-MigrationName.js +96 -0
  149. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769629928240-MigrationName.js.map +1 -0
  150. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769676117342-RenameEvaluateOverTimeInCriteriaFilter.js +25 -0
  151. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769676117342-RenameEvaluateOverTimeInCriteriaFilter.js.map +1 -0
  152. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js +8 -0
  153. package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js.map +1 -1
  154. package/build/dist/Server/Services/AIBillingService.js +10 -1
  155. package/build/dist/Server/Services/AIBillingService.js.map +1 -1
  156. package/build/dist/Server/Services/BillingService.js +224 -5
  157. package/build/dist/Server/Services/BillingService.js.map +1 -1
  158. package/build/dist/Server/Services/CallService.js.map +1 -1
  159. package/build/dist/Server/Services/IncidentEpisodeFeedService.js +83 -0
  160. package/build/dist/Server/Services/IncidentEpisodeFeedService.js.map +1 -0
  161. package/build/dist/Server/Services/IncidentEpisodeInternalNoteService.js +70 -0
  162. package/build/dist/Server/Services/IncidentEpisodeInternalNoteService.js.map +1 -0
  163. package/build/dist/Server/Services/IncidentEpisodeMemberService.js +298 -0
  164. package/build/dist/Server/Services/IncidentEpisodeMemberService.js.map +1 -0
  165. package/build/dist/Server/Services/IncidentEpisodeOwnerTeamService.js +9 -0
  166. package/build/dist/Server/Services/IncidentEpisodeOwnerTeamService.js.map +1 -0
  167. package/build/dist/Server/Services/IncidentEpisodeOwnerUserService.js +9 -0
  168. package/build/dist/Server/Services/IncidentEpisodeOwnerUserService.js.map +1 -0
  169. package/build/dist/Server/Services/IncidentEpisodeService.js +933 -0
  170. package/build/dist/Server/Services/IncidentEpisodeService.js.map +1 -0
  171. package/build/dist/Server/Services/IncidentEpisodeStateTimelineService.js +498 -0
  172. package/build/dist/Server/Services/IncidentEpisodeStateTimelineService.js.map +1 -0
  173. package/build/dist/Server/Services/IncidentGroupingEngineService.js +799 -0
  174. package/build/dist/Server/Services/IncidentGroupingEngineService.js.map +1 -0
  175. package/build/dist/Server/Services/IncidentGroupingRuleService.js +13 -0
  176. package/build/dist/Server/Services/IncidentGroupingRuleService.js.map +1 -0
  177. package/build/dist/Server/Services/IncidentService.js +10 -0
  178. package/build/dist/Server/Services/IncidentService.js.map +1 -1
  179. package/build/dist/Server/Services/Index.js +16 -0
  180. package/build/dist/Server/Services/Index.js.map +1 -1
  181. package/build/dist/Server/Services/MailService.js.map +1 -1
  182. package/build/dist/Server/Services/MonitorService.js +9 -1
  183. package/build/dist/Server/Services/MonitorService.js.map +1 -1
  184. package/build/dist/Server/Services/NotificationService.js +10 -1
  185. package/build/dist/Server/Services/NotificationService.js.map +1 -1
  186. package/build/dist/Server/Services/OnCallDutyPolicyEscalationRuleService.js +10 -0
  187. package/build/dist/Server/Services/OnCallDutyPolicyEscalationRuleService.js.map +1 -1
  188. package/build/dist/Server/Services/OnCallDutyPolicyExecutionLogService.js +48 -2
  189. package/build/dist/Server/Services/OnCallDutyPolicyExecutionLogService.js.map +1 -1
  190. package/build/dist/Server/Services/OnCallDutyPolicyExecutionLogTimelineService.js +20 -1
  191. package/build/dist/Server/Services/OnCallDutyPolicyExecutionLogTimelineService.js.map +1 -1
  192. package/build/dist/Server/Services/OnCallDutyPolicyService.js +8 -0
  193. package/build/dist/Server/Services/OnCallDutyPolicyService.js.map +1 -1
  194. package/build/dist/Server/Services/ProjectService.js +16 -3
  195. package/build/dist/Server/Services/ProjectService.js.map +1 -1
  196. package/build/dist/Server/Services/SmsService.js.map +1 -1
  197. package/build/dist/Server/Services/UserNotificationRuleService.js +39 -2
  198. package/build/dist/Server/Services/UserNotificationRuleService.js.map +1 -1
  199. package/build/dist/Server/Services/UserNotificationSettingService.js +9 -0
  200. package/build/dist/Server/Services/UserNotificationSettingService.js.map +1 -1
  201. package/build/dist/Server/Services/UserOnCallLogService.js +35 -3
  202. package/build/dist/Server/Services/UserOnCallLogService.js.map +1 -1
  203. package/build/dist/Server/Services/UserService.js +40 -0
  204. package/build/dist/Server/Services/UserService.js.map +1 -1
  205. package/build/dist/Server/Services/WhatsAppService.js.map +1 -1
  206. package/build/dist/Server/Services/WorkspaceNotificationLogService.js +12 -0
  207. package/build/dist/Server/Services/WorkspaceNotificationLogService.js.map +1 -1
  208. package/build/dist/Server/Services/WorkspaceNotificationRuleService.js +95 -1
  209. package/build/dist/Server/Services/WorkspaceNotificationRuleService.js.map +1 -1
  210. package/build/dist/Server/Types/Database/Permissions/TenantPermission.js +17 -0
  211. package/build/dist/Server/Types/Database/Permissions/TenantPermission.js.map +1 -1
  212. package/build/dist/Server/Utils/AI/IncidentEpisodeAIContextBuilder.js +402 -0
  213. package/build/dist/Server/Utils/AI/IncidentEpisodeAIContextBuilder.js.map +1 -0
  214. package/build/dist/Server/Utils/Monitor/Criteria/APIRequestCriteria.js +1 -1
  215. package/build/dist/Server/Utils/Monitor/Criteria/CompareCriteria.js +1 -1
  216. package/build/dist/Server/Utils/Monitor/Criteria/IncomingRequestCriteria.js +1 -1
  217. package/build/dist/Server/Utils/Monitor/Criteria/SSLMonitorCriteria.js +1 -1
  218. package/build/dist/Server/Utils/Monitor/Criteria/ServerMonitorCriteria.js +2 -2
  219. package/build/dist/Server/Utils/Monitor/Criteria/SnmpMonitorCriteria.js +135 -0
  220. package/build/dist/Server/Utils/Monitor/Criteria/SnmpMonitorCriteria.js.map +1 -0
  221. package/build/dist/Server/Utils/Monitor/MonitorCriteriaEvaluator.js +10 -0
  222. package/build/dist/Server/Utils/Monitor/MonitorCriteriaEvaluator.js.map +1 -1
  223. package/build/dist/Server/Utils/Monitor/MonitorCriteriaExpectationBuilder.js +1 -1
  224. package/build/dist/Server/Utils/Monitor/MonitorTemplateUtil.js +26 -0
  225. package/build/dist/Server/Utils/Monitor/MonitorTemplateUtil.js.map +1 -1
  226. package/build/dist/Server/Utils/PushNotificationUtil.js +20 -0
  227. package/build/dist/Server/Utils/PushNotificationUtil.js.map +1 -1
  228. package/build/dist/Server/Utils/WhatsAppTemplateUtil.js +8 -0
  229. package/build/dist/Server/Utils/WhatsAppTemplateUtil.js.map +1 -1
  230. package/build/dist/Server/Utils/Workspace/MicrosoftTeams/Actions/ActionTypes.js +17 -0
  231. package/build/dist/Server/Utils/Workspace/MicrosoftTeams/Actions/ActionTypes.js.map +1 -1
  232. package/build/dist/Server/Utils/Workspace/MicrosoftTeams/Actions/IncidentEpisode.js +547 -0
  233. package/build/dist/Server/Utils/Workspace/MicrosoftTeams/Actions/IncidentEpisode.js.map +1 -0
  234. package/build/dist/Server/Utils/Workspace/MicrosoftTeams/MicrosoftTeams.js +15 -0
  235. package/build/dist/Server/Utils/Workspace/MicrosoftTeams/MicrosoftTeams.js.map +1 -1
  236. package/build/dist/Server/Utils/Workspace/Slack/Actions/ActionTypes.js +10 -0
  237. package/build/dist/Server/Utils/Workspace/Slack/Actions/ActionTypes.js.map +1 -1
  238. package/build/dist/Server/Utils/Workspace/Slack/Actions/IncidentEpisode.js +651 -0
  239. package/build/dist/Server/Utils/Workspace/Slack/Actions/IncidentEpisode.js.map +1 -0
  240. package/build/dist/Server/Utils/Workspace/Slack/Messages/IncidentEpisode.js +100 -0
  241. package/build/dist/Server/Utils/Workspace/Slack/Messages/IncidentEpisode.js.map +1 -0
  242. package/build/dist/Server/Utils/Workspace/WorkspaceMessages/IncidentEpisode.js +70 -0
  243. package/build/dist/Server/Utils/Workspace/WorkspaceMessages/IncidentEpisode.js.map +1 -0
  244. package/build/dist/Types/Email/EmailTemplateType.js +6 -0
  245. package/build/dist/Types/Email/EmailTemplateType.js.map +1 -1
  246. package/build/dist/Types/Monitor/CriteriaFilter.js +16 -3
  247. package/build/dist/Types/Monitor/CriteriaFilter.js.map +1 -1
  248. package/build/dist/Types/Monitor/MonitorCriteriaInstance.js +62 -0
  249. package/build/dist/Types/Monitor/MonitorCriteriaInstance.js.map +1 -1
  250. package/build/dist/Types/Monitor/MonitorStep.js +26 -0
  251. package/build/dist/Types/Monitor/MonitorStep.js.map +1 -1
  252. package/build/dist/Types/Monitor/MonitorStepSnmpMonitor.js +77 -0
  253. package/build/dist/Types/Monitor/MonitorStepSnmpMonitor.js.map +1 -0
  254. package/build/dist/Types/Monitor/MonitorType.js +13 -2
  255. package/build/dist/Types/Monitor/MonitorType.js.map +1 -1
  256. package/build/dist/Types/Monitor/SnmpMonitor/SnmpAuthProtocol.js +9 -0
  257. package/build/dist/Types/Monitor/SnmpMonitor/SnmpAuthProtocol.js.map +1 -0
  258. package/build/dist/Types/Monitor/SnmpMonitor/SnmpDataType.js +22 -0
  259. package/build/dist/Types/Monitor/SnmpMonitor/SnmpDataType.js.map +1 -0
  260. package/build/dist/Types/Monitor/SnmpMonitor/SnmpMonitorResponse.js +2 -0
  261. package/build/dist/Types/Monitor/SnmpMonitor/SnmpMonitorResponse.js.map +1 -0
  262. package/build/dist/Types/Monitor/SnmpMonitor/SnmpOid.js +55 -0
  263. package/build/dist/Types/Monitor/SnmpMonitor/SnmpOid.js.map +1 -0
  264. package/build/dist/Types/Monitor/SnmpMonitor/SnmpPrivProtocol.js +8 -0
  265. package/build/dist/Types/Monitor/SnmpMonitor/SnmpPrivProtocol.js.map +1 -0
  266. package/build/dist/Types/Monitor/SnmpMonitor/SnmpSecurityLevel.js +8 -0
  267. package/build/dist/Types/Monitor/SnmpMonitor/SnmpSecurityLevel.js.map +1 -0
  268. package/build/dist/Types/Monitor/SnmpMonitor/SnmpV3Auth.js +2 -0
  269. package/build/dist/Types/Monitor/SnmpMonitor/SnmpV3Auth.js.map +1 -0
  270. package/build/dist/Types/Monitor/SnmpMonitor/SnmpVersion.js +8 -0
  271. package/build/dist/Types/Monitor/SnmpMonitor/SnmpVersion.js.map +1 -0
  272. package/build/dist/Types/NotificationSetting/NotificationSettingEventType.js +5 -0
  273. package/build/dist/Types/NotificationSetting/NotificationSettingEventType.js.map +1 -1
  274. package/build/dist/Types/Permission.js +264 -0
  275. package/build/dist/Types/Permission.js.map +1 -1
  276. package/build/dist/Types/UserNotification/UserNotificationEventType.js +1 -0
  277. package/build/dist/Types/UserNotification/UserNotificationEventType.js.map +1 -1
  278. package/build/dist/Types/WhatsApp/WhatsAppTemplates.js +15 -0
  279. package/build/dist/Types/WhatsApp/WhatsAppTemplates.js.map +1 -1
  280. package/build/dist/Types/Workspace/NotificationRules/EventType.js +1 -0
  281. package/build/dist/Types/Workspace/NotificationRules/EventType.js.map +1 -1
  282. package/build/dist/Types/Workspace/NotificationRules/NotificationRuleCondition.js +33 -1
  283. package/build/dist/Types/Workspace/NotificationRules/NotificationRuleCondition.js.map +1 -1
  284. package/build/dist/Utils/Monitor/MonitorMetricType.js +2 -1
  285. package/build/dist/Utils/Monitor/MonitorMetricType.js.map +1 -1
  286. package/package.json +1 -1
@@ -0,0 +1,1430 @@
1
+ import IncidentSeverity from "./IncidentSeverity";
2
+ import Label from "./Label";
3
+ import Monitor from "./Monitor";
4
+ import OnCallDutyPolicy from "./OnCallDutyPolicy";
5
+ import Project from "./Project";
6
+ import Team from "./Team";
7
+ import User from "./User";
8
+ import BaseModel from "./DatabaseBaseModel/DatabaseBaseModel";
9
+ import Route from "../../Types/API/Route";
10
+ import ColumnAccessControl from "../../Types/Database/AccessControl/ColumnAccessControl";
11
+ import TableAccessControl from "../../Types/Database/AccessControl/TableAccessControl";
12
+ import ColumnLength from "../../Types/Database/ColumnLength";
13
+ import ColumnType from "../../Types/Database/ColumnType";
14
+ import CrudApiEndpoint from "../../Types/Database/CrudApiEndpoint";
15
+ import EnableDocumentation from "../../Types/Database/EnableDocumentation";
16
+ import EnableWorkflow from "../../Types/Database/EnableWorkflow";
17
+ import TableColumn from "../../Types/Database/TableColumn";
18
+ import TableColumnType from "../../Types/Database/TableColumnType";
19
+ import TableMetadata from "../../Types/Database/TableMetadata";
20
+ import TenantColumn from "../../Types/Database/TenantColumn";
21
+ import IconProp from "../../Types/Icon/IconProp";
22
+ import ObjectID from "../../Types/ObjectID";
23
+ import Permission from "../../Types/Permission";
24
+ import {
25
+ Column,
26
+ Entity,
27
+ Index,
28
+ JoinColumn,
29
+ JoinTable,
30
+ ManyToMany,
31
+ ManyToOne,
32
+ } from "typeorm";
33
+
34
+ export interface IncidentGroupingRuleMatchCriteria {
35
+ monitorIds?: Array<string>;
36
+ monitorCustomFields?: Record<string, string>;
37
+ incidentSeverityIds?: Array<string>;
38
+ labelIds?: Array<string>;
39
+ incidentTitlePattern?: string;
40
+ incidentDescriptionPattern?: string;
41
+ }
42
+
43
+ export interface IncidentGroupingRuleGroupByFields {
44
+ monitorId?: boolean;
45
+ incidentSeverityId?: boolean;
46
+ incidentTitle?: boolean;
47
+ customFieldValues?: Array<string>;
48
+ }
49
+
50
+ @EnableDocumentation()
51
+ @TenantColumn("projectId")
52
+ @TableAccessControl({
53
+ create: [
54
+ Permission.ProjectOwner,
55
+ Permission.ProjectAdmin,
56
+ Permission.CreateIncidentGroupingRule,
57
+ ],
58
+ read: [
59
+ Permission.ProjectOwner,
60
+ Permission.ProjectAdmin,
61
+ Permission.ProjectMember,
62
+ Permission.ReadIncidentGroupingRule,
63
+ ],
64
+ delete: [
65
+ Permission.ProjectOwner,
66
+ Permission.ProjectAdmin,
67
+ Permission.DeleteIncidentGroupingRule,
68
+ ],
69
+ update: [
70
+ Permission.ProjectOwner,
71
+ Permission.ProjectAdmin,
72
+ Permission.EditIncidentGroupingRule,
73
+ ],
74
+ })
75
+ @CrudApiEndpoint(new Route("/incident-grouping-rule"))
76
+ @Entity({
77
+ name: "IncidentGroupingRule",
78
+ })
79
+ @EnableWorkflow({
80
+ create: true,
81
+ delete: true,
82
+ update: true,
83
+ read: true,
84
+ })
85
+ @TableMetadata({
86
+ tableName: "IncidentGroupingRule",
87
+ singularName: "Incident Grouping Rule",
88
+ pluralName: "Incident Grouping Rules",
89
+ icon: IconProp.Layers,
90
+ tableDescription:
91
+ "Configure rules for automatically grouping related incidents into episodes",
92
+ })
93
+ export default class IncidentGroupingRule extends BaseModel {
94
+ @ColumnAccessControl({
95
+ create: [
96
+ Permission.ProjectOwner,
97
+ Permission.ProjectAdmin,
98
+ Permission.CreateIncidentGroupingRule,
99
+ ],
100
+ read: [
101
+ Permission.ProjectOwner,
102
+ Permission.ProjectAdmin,
103
+ Permission.ProjectMember,
104
+ Permission.ReadIncidentGroupingRule,
105
+ ],
106
+ update: [],
107
+ })
108
+ @TableColumn({
109
+ manyToOneRelationColumn: "projectId",
110
+ type: TableColumnType.Entity,
111
+ modelType: Project,
112
+ title: "Project",
113
+ description: "Relation to Project Resource in which this object belongs",
114
+ })
115
+ @ManyToOne(
116
+ () => {
117
+ return Project;
118
+ },
119
+ {
120
+ eager: false,
121
+ nullable: true,
122
+ onDelete: "CASCADE",
123
+ orphanedRowAction: "nullify",
124
+ },
125
+ )
126
+ @JoinColumn({ name: "projectId" })
127
+ public project?: Project = undefined;
128
+
129
+ @ColumnAccessControl({
130
+ create: [
131
+ Permission.ProjectOwner,
132
+ Permission.ProjectAdmin,
133
+ Permission.CreateIncidentGroupingRule,
134
+ ],
135
+ read: [
136
+ Permission.ProjectOwner,
137
+ Permission.ProjectAdmin,
138
+ Permission.ProjectMember,
139
+ Permission.ReadIncidentGroupingRule,
140
+ ],
141
+ update: [],
142
+ })
143
+ @Index()
144
+ @TableColumn({
145
+ type: TableColumnType.ObjectID,
146
+ required: true,
147
+ canReadOnRelationQuery: true,
148
+ title: "Project ID",
149
+ description: "ID of your OneUptime Project in which this object belongs",
150
+ })
151
+ @Column({
152
+ type: ColumnType.ObjectID,
153
+ nullable: false,
154
+ transformer: ObjectID.getDatabaseTransformer(),
155
+ })
156
+ public projectId?: ObjectID = undefined;
157
+
158
+ @ColumnAccessControl({
159
+ create: [
160
+ Permission.ProjectOwner,
161
+ Permission.ProjectAdmin,
162
+ Permission.CreateIncidentGroupingRule,
163
+ ],
164
+ read: [
165
+ Permission.ProjectOwner,
166
+ Permission.ProjectAdmin,
167
+ Permission.ProjectMember,
168
+ Permission.ReadIncidentGroupingRule,
169
+ ],
170
+ update: [
171
+ Permission.ProjectOwner,
172
+ Permission.ProjectAdmin,
173
+ Permission.EditIncidentGroupingRule,
174
+ ],
175
+ })
176
+ @Index()
177
+ @TableColumn({
178
+ required: true,
179
+ type: TableColumnType.ShortText,
180
+ canReadOnRelationQuery: true,
181
+ title: "Name",
182
+ description: "Name of this incident grouping rule",
183
+ })
184
+ @Column({
185
+ nullable: false,
186
+ type: ColumnType.ShortText,
187
+ length: ColumnLength.ShortText,
188
+ })
189
+ public name?: string = undefined;
190
+
191
+ @ColumnAccessControl({
192
+ create: [
193
+ Permission.ProjectOwner,
194
+ Permission.ProjectAdmin,
195
+ Permission.CreateIncidentGroupingRule,
196
+ ],
197
+ read: [
198
+ Permission.ProjectOwner,
199
+ Permission.ProjectAdmin,
200
+ Permission.ProjectMember,
201
+ Permission.ReadIncidentGroupingRule,
202
+ ],
203
+ update: [
204
+ Permission.ProjectOwner,
205
+ Permission.ProjectAdmin,
206
+ Permission.EditIncidentGroupingRule,
207
+ ],
208
+ })
209
+ @TableColumn({
210
+ required: false,
211
+ type: TableColumnType.LongText,
212
+ title: "Description",
213
+ description: "Description of this incident grouping rule",
214
+ })
215
+ @Column({
216
+ nullable: true,
217
+ type: ColumnType.LongText,
218
+ length: ColumnLength.LongText,
219
+ })
220
+ public description?: string = undefined;
221
+
222
+ @ColumnAccessControl({
223
+ create: [
224
+ Permission.ProjectOwner,
225
+ Permission.ProjectAdmin,
226
+ Permission.CreateIncidentGroupingRule,
227
+ ],
228
+ read: [
229
+ Permission.ProjectOwner,
230
+ Permission.ProjectAdmin,
231
+ Permission.ProjectMember,
232
+ Permission.ReadIncidentGroupingRule,
233
+ ],
234
+ update: [
235
+ Permission.ProjectOwner,
236
+ Permission.ProjectAdmin,
237
+ Permission.EditIncidentGroupingRule,
238
+ ],
239
+ })
240
+ @Index()
241
+ @TableColumn({
242
+ required: true,
243
+ type: TableColumnType.Number,
244
+ title: "Priority",
245
+ description:
246
+ "Priority of this rule. Lower number = higher priority. Rules are evaluated in priority order.",
247
+ defaultValue: 1,
248
+ isDefaultValueColumn: true,
249
+ })
250
+ @Column({
251
+ type: ColumnType.Number,
252
+ nullable: false,
253
+ default: 1,
254
+ })
255
+ public priority?: number = undefined;
256
+
257
+ @ColumnAccessControl({
258
+ create: [
259
+ Permission.ProjectOwner,
260
+ Permission.ProjectAdmin,
261
+ Permission.CreateIncidentGroupingRule,
262
+ ],
263
+ read: [
264
+ Permission.ProjectOwner,
265
+ Permission.ProjectAdmin,
266
+ Permission.ProjectMember,
267
+ Permission.ReadIncidentGroupingRule,
268
+ ],
269
+ update: [
270
+ Permission.ProjectOwner,
271
+ Permission.ProjectAdmin,
272
+ Permission.EditIncidentGroupingRule,
273
+ ],
274
+ })
275
+ @Index()
276
+ @TableColumn({
277
+ required: true,
278
+ type: TableColumnType.Boolean,
279
+ title: "Is Enabled",
280
+ description: "Whether this rule is enabled",
281
+ defaultValue: true,
282
+ isDefaultValueColumn: true,
283
+ })
284
+ @Column({
285
+ type: ColumnType.Boolean,
286
+ nullable: false,
287
+ default: true,
288
+ })
289
+ public isEnabled?: boolean = undefined;
290
+
291
+ @ColumnAccessControl({
292
+ create: [
293
+ Permission.ProjectOwner,
294
+ Permission.ProjectAdmin,
295
+ Permission.CreateIncidentGroupingRule,
296
+ ],
297
+ read: [
298
+ Permission.ProjectOwner,
299
+ Permission.ProjectAdmin,
300
+ Permission.ProjectMember,
301
+ Permission.ReadIncidentGroupingRule,
302
+ ],
303
+ update: [
304
+ Permission.ProjectOwner,
305
+ Permission.ProjectAdmin,
306
+ Permission.EditIncidentGroupingRule,
307
+ ],
308
+ })
309
+ @TableColumn({
310
+ required: false,
311
+ type: TableColumnType.JSON,
312
+ title: "Match Criteria",
313
+ description:
314
+ "JSON object defining the criteria for matching incidents to this rule",
315
+ })
316
+ @Column({
317
+ type: ColumnType.JSON,
318
+ nullable: true,
319
+ })
320
+ public matchCriteria?: IncidentGroupingRuleMatchCriteria = undefined;
321
+
322
+ // Match Criteria Fields (individual columns for form support)
323
+
324
+ @ColumnAccessControl({
325
+ create: [
326
+ Permission.ProjectOwner,
327
+ Permission.ProjectAdmin,
328
+ Permission.CreateIncidentGroupingRule,
329
+ ],
330
+ read: [
331
+ Permission.ProjectOwner,
332
+ Permission.ProjectAdmin,
333
+ Permission.ProjectMember,
334
+ Permission.ReadIncidentGroupingRule,
335
+ ],
336
+ update: [
337
+ Permission.ProjectOwner,
338
+ Permission.ProjectAdmin,
339
+ Permission.EditIncidentGroupingRule,
340
+ ],
341
+ })
342
+ @TableColumn({
343
+ required: false,
344
+ type: TableColumnType.EntityArray,
345
+ modelType: Monitor,
346
+ title: "Monitors",
347
+ description:
348
+ "Only group incidents from these monitors. Leave empty to match incidents from any monitor.",
349
+ })
350
+ @ManyToMany(
351
+ () => {
352
+ return Monitor;
353
+ },
354
+ { eager: false },
355
+ )
356
+ @JoinTable({
357
+ name: "IncidentGroupingRuleMonitor",
358
+ inverseJoinColumn: {
359
+ name: "monitorId",
360
+ referencedColumnName: "_id",
361
+ },
362
+ joinColumn: {
363
+ name: "incidentGroupingRuleId",
364
+ referencedColumnName: "_id",
365
+ },
366
+ })
367
+ public monitors?: Array<Monitor> = undefined;
368
+
369
+ @ColumnAccessControl({
370
+ create: [
371
+ Permission.ProjectOwner,
372
+ Permission.ProjectAdmin,
373
+ Permission.CreateIncidentGroupingRule,
374
+ ],
375
+ read: [
376
+ Permission.ProjectOwner,
377
+ Permission.ProjectAdmin,
378
+ Permission.ProjectMember,
379
+ Permission.ReadIncidentGroupingRule,
380
+ ],
381
+ update: [
382
+ Permission.ProjectOwner,
383
+ Permission.ProjectAdmin,
384
+ Permission.EditIncidentGroupingRule,
385
+ ],
386
+ })
387
+ @TableColumn({
388
+ required: false,
389
+ type: TableColumnType.EntityArray,
390
+ modelType: IncidentSeverity,
391
+ title: "Incident Severities",
392
+ description:
393
+ "Only group incidents with these severities. Leave empty to match incidents of any severity.",
394
+ })
395
+ @ManyToMany(
396
+ () => {
397
+ return IncidentSeverity;
398
+ },
399
+ { eager: false },
400
+ )
401
+ @JoinTable({
402
+ name: "IncidentGroupingRuleIncidentSeverity",
403
+ inverseJoinColumn: {
404
+ name: "incidentSeverityId",
405
+ referencedColumnName: "_id",
406
+ },
407
+ joinColumn: {
408
+ name: "incidentGroupingRuleId",
409
+ referencedColumnName: "_id",
410
+ },
411
+ })
412
+ public incidentSeverities?: Array<IncidentSeverity> = undefined;
413
+
414
+ @ColumnAccessControl({
415
+ create: [
416
+ Permission.ProjectOwner,
417
+ Permission.ProjectAdmin,
418
+ Permission.CreateIncidentGroupingRule,
419
+ ],
420
+ read: [
421
+ Permission.ProjectOwner,
422
+ Permission.ProjectAdmin,
423
+ Permission.ProjectMember,
424
+ Permission.ReadIncidentGroupingRule,
425
+ ],
426
+ update: [
427
+ Permission.ProjectOwner,
428
+ Permission.ProjectAdmin,
429
+ Permission.EditIncidentGroupingRule,
430
+ ],
431
+ })
432
+ @TableColumn({
433
+ required: false,
434
+ type: TableColumnType.EntityArray,
435
+ modelType: Label,
436
+ title: "Incident Labels",
437
+ description:
438
+ "Only group incidents that have at least one of these labels. Leave empty to match incidents regardless of incident labels.",
439
+ })
440
+ @ManyToMany(
441
+ () => {
442
+ return Label;
443
+ },
444
+ { eager: false },
445
+ )
446
+ @JoinTable({
447
+ name: "IncidentGroupingRuleIncidentLabel",
448
+ inverseJoinColumn: {
449
+ name: "labelId",
450
+ referencedColumnName: "_id",
451
+ },
452
+ joinColumn: {
453
+ name: "incidentGroupingRuleId",
454
+ referencedColumnName: "_id",
455
+ },
456
+ })
457
+ public incidentLabels?: Array<Label> = undefined;
458
+
459
+ @ColumnAccessControl({
460
+ create: [
461
+ Permission.ProjectOwner,
462
+ Permission.ProjectAdmin,
463
+ Permission.CreateIncidentGroupingRule,
464
+ ],
465
+ read: [
466
+ Permission.ProjectOwner,
467
+ Permission.ProjectAdmin,
468
+ Permission.ProjectMember,
469
+ Permission.ReadIncidentGroupingRule,
470
+ ],
471
+ update: [
472
+ Permission.ProjectOwner,
473
+ Permission.ProjectAdmin,
474
+ Permission.EditIncidentGroupingRule,
475
+ ],
476
+ })
477
+ @TableColumn({
478
+ required: false,
479
+ type: TableColumnType.EntityArray,
480
+ modelType: Label,
481
+ title: "Monitor Labels",
482
+ description:
483
+ "Only group incidents from monitors that have at least one of these labels. Leave empty to match incidents regardless of monitor labels.",
484
+ })
485
+ @ManyToMany(
486
+ () => {
487
+ return Label;
488
+ },
489
+ { eager: false },
490
+ )
491
+ @JoinTable({
492
+ name: "IncidentGroupingRuleMonitorLabel",
493
+ inverseJoinColumn: {
494
+ name: "labelId",
495
+ referencedColumnName: "_id",
496
+ },
497
+ joinColumn: {
498
+ name: "incidentGroupingRuleId",
499
+ referencedColumnName: "_id",
500
+ },
501
+ })
502
+ public monitorLabels?: Array<Label> = undefined;
503
+
504
+ @ColumnAccessControl({
505
+ create: [
506
+ Permission.ProjectOwner,
507
+ Permission.ProjectAdmin,
508
+ Permission.CreateIncidentGroupingRule,
509
+ ],
510
+ read: [
511
+ Permission.ProjectOwner,
512
+ Permission.ProjectAdmin,
513
+ Permission.ProjectMember,
514
+ Permission.ReadIncidentGroupingRule,
515
+ ],
516
+ update: [
517
+ Permission.ProjectOwner,
518
+ Permission.ProjectAdmin,
519
+ Permission.EditIncidentGroupingRule,
520
+ ],
521
+ })
522
+ @TableColumn({
523
+ required: false,
524
+ type: TableColumnType.LongText,
525
+ title: "Incident Title Pattern",
526
+ description:
527
+ "Regular expression pattern to match incident titles. Leave empty to match any title. Example: 'CPU.*high' matches titles containing 'CPU' followed by 'high'.",
528
+ })
529
+ @Column({
530
+ type: ColumnType.LongText,
531
+ nullable: true,
532
+ length: ColumnLength.LongText,
533
+ })
534
+ public incidentTitlePattern?: string = undefined;
535
+
536
+ @ColumnAccessControl({
537
+ create: [
538
+ Permission.ProjectOwner,
539
+ Permission.ProjectAdmin,
540
+ Permission.CreateIncidentGroupingRule,
541
+ ],
542
+ read: [
543
+ Permission.ProjectOwner,
544
+ Permission.ProjectAdmin,
545
+ Permission.ProjectMember,
546
+ Permission.ReadIncidentGroupingRule,
547
+ ],
548
+ update: [
549
+ Permission.ProjectOwner,
550
+ Permission.ProjectAdmin,
551
+ Permission.EditIncidentGroupingRule,
552
+ ],
553
+ })
554
+ @TableColumn({
555
+ required: false,
556
+ type: TableColumnType.LongText,
557
+ title: "Incident Description Pattern",
558
+ description:
559
+ "Regular expression pattern to match incident descriptions. Leave empty to match any description.",
560
+ })
561
+ @Column({
562
+ type: ColumnType.LongText,
563
+ nullable: true,
564
+ length: ColumnLength.LongText,
565
+ })
566
+ public incidentDescriptionPattern?: string = undefined;
567
+
568
+ @ColumnAccessControl({
569
+ create: [
570
+ Permission.ProjectOwner,
571
+ Permission.ProjectAdmin,
572
+ Permission.CreateIncidentGroupingRule,
573
+ ],
574
+ read: [
575
+ Permission.ProjectOwner,
576
+ Permission.ProjectAdmin,
577
+ Permission.ProjectMember,
578
+ Permission.ReadIncidentGroupingRule,
579
+ ],
580
+ update: [
581
+ Permission.ProjectOwner,
582
+ Permission.ProjectAdmin,
583
+ Permission.EditIncidentGroupingRule,
584
+ ],
585
+ })
586
+ @TableColumn({
587
+ required: false,
588
+ type: TableColumnType.LongText,
589
+ title: "Monitor Name Pattern",
590
+ description:
591
+ "Regular expression pattern to match monitor names. Leave empty to match any monitor name. Example: 'prod-.*' matches monitors starting with 'prod-'.",
592
+ })
593
+ @Column({
594
+ type: ColumnType.LongText,
595
+ nullable: true,
596
+ length: ColumnLength.LongText,
597
+ })
598
+ public monitorNamePattern?: string = undefined;
599
+
600
+ @ColumnAccessControl({
601
+ create: [
602
+ Permission.ProjectOwner,
603
+ Permission.ProjectAdmin,
604
+ Permission.CreateIncidentGroupingRule,
605
+ ],
606
+ read: [
607
+ Permission.ProjectOwner,
608
+ Permission.ProjectAdmin,
609
+ Permission.ProjectMember,
610
+ Permission.ReadIncidentGroupingRule,
611
+ ],
612
+ update: [
613
+ Permission.ProjectOwner,
614
+ Permission.ProjectAdmin,
615
+ Permission.EditIncidentGroupingRule,
616
+ ],
617
+ })
618
+ @TableColumn({
619
+ required: false,
620
+ type: TableColumnType.LongText,
621
+ title: "Monitor Description Pattern",
622
+ description:
623
+ "Regular expression pattern to match monitor descriptions. Leave empty to match any monitor description.",
624
+ })
625
+ @Column({
626
+ type: ColumnType.LongText,
627
+ nullable: true,
628
+ length: ColumnLength.LongText,
629
+ })
630
+ public monitorDescriptionPattern?: string = undefined;
631
+
632
+ // Group By Fields (how to group matching incidents)
633
+
634
+ @ColumnAccessControl({
635
+ create: [
636
+ Permission.ProjectOwner,
637
+ Permission.ProjectAdmin,
638
+ Permission.CreateIncidentGroupingRule,
639
+ ],
640
+ read: [
641
+ Permission.ProjectOwner,
642
+ Permission.ProjectAdmin,
643
+ Permission.ProjectMember,
644
+ Permission.ReadIncidentGroupingRule,
645
+ ],
646
+ update: [
647
+ Permission.ProjectOwner,
648
+ Permission.ProjectAdmin,
649
+ Permission.EditIncidentGroupingRule,
650
+ ],
651
+ })
652
+ @TableColumn({
653
+ required: false,
654
+ type: TableColumnType.Boolean,
655
+ title: "Group By Monitor",
656
+ description:
657
+ "When enabled, incidents from different monitors will be grouped into separate episodes. When disabled, incidents from any monitor can be grouped together.",
658
+ defaultValue: true,
659
+ isDefaultValueColumn: true,
660
+ })
661
+ @Column({
662
+ type: ColumnType.Boolean,
663
+ nullable: false,
664
+ default: true,
665
+ })
666
+ public groupByMonitor?: boolean = undefined;
667
+
668
+ @ColumnAccessControl({
669
+ create: [
670
+ Permission.ProjectOwner,
671
+ Permission.ProjectAdmin,
672
+ Permission.CreateIncidentGroupingRule,
673
+ ],
674
+ read: [
675
+ Permission.ProjectOwner,
676
+ Permission.ProjectAdmin,
677
+ Permission.ProjectMember,
678
+ Permission.ReadIncidentGroupingRule,
679
+ ],
680
+ update: [
681
+ Permission.ProjectOwner,
682
+ Permission.ProjectAdmin,
683
+ Permission.EditIncidentGroupingRule,
684
+ ],
685
+ })
686
+ @TableColumn({
687
+ required: false,
688
+ type: TableColumnType.Boolean,
689
+ title: "Group By Incident Severity",
690
+ description:
691
+ "When enabled, incidents with different severities will be grouped into separate episodes. When disabled, incidents of any severity can be grouped together.",
692
+ defaultValue: false,
693
+ isDefaultValueColumn: true,
694
+ })
695
+ @Column({
696
+ type: ColumnType.Boolean,
697
+ nullable: false,
698
+ default: false,
699
+ })
700
+ public groupBySeverity?: boolean = undefined;
701
+
702
+ @ColumnAccessControl({
703
+ create: [
704
+ Permission.ProjectOwner,
705
+ Permission.ProjectAdmin,
706
+ Permission.CreateIncidentGroupingRule,
707
+ ],
708
+ read: [
709
+ Permission.ProjectOwner,
710
+ Permission.ProjectAdmin,
711
+ Permission.ProjectMember,
712
+ Permission.ReadIncidentGroupingRule,
713
+ ],
714
+ update: [
715
+ Permission.ProjectOwner,
716
+ Permission.ProjectAdmin,
717
+ Permission.EditIncidentGroupingRule,
718
+ ],
719
+ })
720
+ @TableColumn({
721
+ required: false,
722
+ type: TableColumnType.Boolean,
723
+ title: "Group By Incident Title",
724
+ description:
725
+ "When enabled, incidents with different titles will be grouped into separate episodes. When disabled, incidents with any title can be grouped together.",
726
+ defaultValue: false,
727
+ isDefaultValueColumn: true,
728
+ })
729
+ @Column({
730
+ type: ColumnType.Boolean,
731
+ nullable: false,
732
+ default: false,
733
+ })
734
+ public groupByIncidentTitle?: boolean = undefined;
735
+
736
+ @ColumnAccessControl({
737
+ create: [
738
+ Permission.ProjectOwner,
739
+ Permission.ProjectAdmin,
740
+ Permission.CreateIncidentGroupingRule,
741
+ ],
742
+ read: [
743
+ Permission.ProjectOwner,
744
+ Permission.ProjectAdmin,
745
+ Permission.ProjectMember,
746
+ Permission.ReadIncidentGroupingRule,
747
+ ],
748
+ update: [
749
+ Permission.ProjectOwner,
750
+ Permission.ProjectAdmin,
751
+ Permission.EditIncidentGroupingRule,
752
+ ],
753
+ })
754
+ @TableColumn({
755
+ required: false,
756
+ type: TableColumnType.Boolean,
757
+ title: "Group By Service",
758
+ description:
759
+ "When enabled, incidents from monitors belonging to different services will be grouped into separate episodes. When disabled, incidents can be grouped together regardless of which service the monitor belongs to.",
760
+ defaultValue: false,
761
+ isDefaultValueColumn: true,
762
+ })
763
+ @Column({
764
+ type: ColumnType.Boolean,
765
+ nullable: false,
766
+ default: false,
767
+ })
768
+ public groupByService?: boolean = undefined;
769
+
770
+ @ColumnAccessControl({
771
+ create: [
772
+ Permission.ProjectOwner,
773
+ Permission.ProjectAdmin,
774
+ Permission.CreateIncidentGroupingRule,
775
+ ],
776
+ read: [
777
+ Permission.ProjectOwner,
778
+ Permission.ProjectAdmin,
779
+ Permission.ProjectMember,
780
+ Permission.ReadIncidentGroupingRule,
781
+ ],
782
+ update: [
783
+ Permission.ProjectOwner,
784
+ Permission.ProjectAdmin,
785
+ Permission.EditIncidentGroupingRule,
786
+ ],
787
+ })
788
+ @TableColumn({
789
+ required: false,
790
+ type: TableColumnType.Boolean,
791
+ title: "Enable Time Window",
792
+ description:
793
+ "Enable time-based grouping. When enabled, incidents are grouped within the specified time window. When disabled, all matching incidents are grouped into a single ongoing episode regardless of time.",
794
+ defaultValue: false,
795
+ isDefaultValueColumn: true,
796
+ })
797
+ @Column({
798
+ type: ColumnType.Boolean,
799
+ nullable: false,
800
+ default: false,
801
+ })
802
+ public enableTimeWindow?: boolean = undefined;
803
+
804
+ @ColumnAccessControl({
805
+ create: [
806
+ Permission.ProjectOwner,
807
+ Permission.ProjectAdmin,
808
+ Permission.CreateIncidentGroupingRule,
809
+ ],
810
+ read: [
811
+ Permission.ProjectOwner,
812
+ Permission.ProjectAdmin,
813
+ Permission.ProjectMember,
814
+ Permission.ReadIncidentGroupingRule,
815
+ ],
816
+ update: [
817
+ Permission.ProjectOwner,
818
+ Permission.ProjectAdmin,
819
+ Permission.EditIncidentGroupingRule,
820
+ ],
821
+ })
822
+ @TableColumn({
823
+ required: false,
824
+ type: TableColumnType.Number,
825
+ title: "Time Window (Minutes)",
826
+ description:
827
+ "Rolling time window in minutes. Incidents are grouped if they arrive within this gap from the last incident.",
828
+ defaultValue: 60,
829
+ isDefaultValueColumn: true,
830
+ })
831
+ @Column({
832
+ type: ColumnType.Number,
833
+ nullable: false,
834
+ default: 60,
835
+ })
836
+ public timeWindowMinutes?: number = undefined;
837
+
838
+ @ColumnAccessControl({
839
+ create: [
840
+ Permission.ProjectOwner,
841
+ Permission.ProjectAdmin,
842
+ Permission.CreateIncidentGroupingRule,
843
+ ],
844
+ read: [
845
+ Permission.ProjectOwner,
846
+ Permission.ProjectAdmin,
847
+ Permission.ProjectMember,
848
+ Permission.ReadIncidentGroupingRule,
849
+ ],
850
+ update: [
851
+ Permission.ProjectOwner,
852
+ Permission.ProjectAdmin,
853
+ Permission.EditIncidentGroupingRule,
854
+ ],
855
+ })
856
+ @TableColumn({
857
+ required: false,
858
+ type: TableColumnType.JSON,
859
+ title: "Group By Fields",
860
+ description:
861
+ "JSON object defining the fields to group incidents by (e.g., monitorId, severity)",
862
+ })
863
+ @Column({
864
+ type: ColumnType.JSON,
865
+ nullable: true,
866
+ })
867
+ public groupByFields?: IncidentGroupingRuleGroupByFields = undefined;
868
+
869
+ @ColumnAccessControl({
870
+ create: [
871
+ Permission.ProjectOwner,
872
+ Permission.ProjectAdmin,
873
+ Permission.CreateIncidentGroupingRule,
874
+ ],
875
+ read: [
876
+ Permission.ProjectOwner,
877
+ Permission.ProjectAdmin,
878
+ Permission.ProjectMember,
879
+ Permission.ReadIncidentGroupingRule,
880
+ ],
881
+ update: [
882
+ Permission.ProjectOwner,
883
+ Permission.ProjectAdmin,
884
+ Permission.EditIncidentGroupingRule,
885
+ ],
886
+ })
887
+ @TableColumn({
888
+ required: false,
889
+ type: TableColumnType.LongText,
890
+ title: "Episode Title Template",
891
+ description:
892
+ "Template for generating episode titles. Supports placeholders like {{incidentSeverity}}, {{monitorName}}, {{incidentTitle}}, {{incidentDescription}}",
893
+ })
894
+ @Column({
895
+ type: ColumnType.LongText,
896
+ nullable: true,
897
+ })
898
+ public episodeTitleTemplate?: string = undefined;
899
+
900
+ @ColumnAccessControl({
901
+ create: [
902
+ Permission.ProjectOwner,
903
+ Permission.ProjectAdmin,
904
+ Permission.CreateIncidentGroupingRule,
905
+ ],
906
+ read: [
907
+ Permission.ProjectOwner,
908
+ Permission.ProjectAdmin,
909
+ Permission.ProjectMember,
910
+ Permission.ReadIncidentGroupingRule,
911
+ ],
912
+ update: [
913
+ Permission.ProjectOwner,
914
+ Permission.ProjectAdmin,
915
+ Permission.EditIncidentGroupingRule,
916
+ ],
917
+ })
918
+ @TableColumn({
919
+ required: false,
920
+ type: TableColumnType.LongText,
921
+ title: "Episode Description Template",
922
+ description:
923
+ "Template for generating episode descriptions. Supports placeholders like {{incidentSeverity}}, {{monitorName}}, {{incidentTitle}}, {{incidentDescription}}",
924
+ })
925
+ @Column({
926
+ type: ColumnType.LongText,
927
+ nullable: true,
928
+ })
929
+ public episodeDescriptionTemplate?: string = undefined;
930
+
931
+ @ColumnAccessControl({
932
+ create: [
933
+ Permission.ProjectOwner,
934
+ Permission.ProjectAdmin,
935
+ Permission.CreateIncidentGroupingRule,
936
+ ],
937
+ read: [
938
+ Permission.ProjectOwner,
939
+ Permission.ProjectAdmin,
940
+ Permission.ProjectMember,
941
+ Permission.ReadIncidentGroupingRule,
942
+ ],
943
+ update: [
944
+ Permission.ProjectOwner,
945
+ Permission.ProjectAdmin,
946
+ Permission.EditIncidentGroupingRule,
947
+ ],
948
+ })
949
+ @TableColumn({
950
+ required: false,
951
+ type: TableColumnType.Boolean,
952
+ title: "Enable Resolve Delay",
953
+ description:
954
+ "Enable grace period before auto-resolving episode after all incidents resolve. Helps prevent rapid state changes during incident flapping.",
955
+ defaultValue: false,
956
+ isDefaultValueColumn: true,
957
+ })
958
+ @Column({
959
+ type: ColumnType.Boolean,
960
+ nullable: false,
961
+ default: false,
962
+ })
963
+ public enableResolveDelay?: boolean = undefined;
964
+
965
+ @ColumnAccessControl({
966
+ create: [
967
+ Permission.ProjectOwner,
968
+ Permission.ProjectAdmin,
969
+ Permission.CreateIncidentGroupingRule,
970
+ ],
971
+ read: [
972
+ Permission.ProjectOwner,
973
+ Permission.ProjectAdmin,
974
+ Permission.ProjectMember,
975
+ Permission.ReadIncidentGroupingRule,
976
+ ],
977
+ update: [
978
+ Permission.ProjectOwner,
979
+ Permission.ProjectAdmin,
980
+ Permission.EditIncidentGroupingRule,
981
+ ],
982
+ })
983
+ @TableColumn({
984
+ required: false,
985
+ type: TableColumnType.Number,
986
+ title: "Resolve Delay (Minutes)",
987
+ description:
988
+ "Grace period in minutes before auto-resolving an episode after all incidents are resolved",
989
+ defaultValue: 0,
990
+ isDefaultValueColumn: true,
991
+ })
992
+ @Column({
993
+ type: ColumnType.Number,
994
+ nullable: false,
995
+ default: 0,
996
+ })
997
+ public resolveDelayMinutes?: number = undefined;
998
+
999
+ @ColumnAccessControl({
1000
+ create: [
1001
+ Permission.ProjectOwner,
1002
+ Permission.ProjectAdmin,
1003
+ Permission.CreateIncidentGroupingRule,
1004
+ ],
1005
+ read: [
1006
+ Permission.ProjectOwner,
1007
+ Permission.ProjectAdmin,
1008
+ Permission.ProjectMember,
1009
+ Permission.ReadIncidentGroupingRule,
1010
+ ],
1011
+ update: [
1012
+ Permission.ProjectOwner,
1013
+ Permission.ProjectAdmin,
1014
+ Permission.EditIncidentGroupingRule,
1015
+ ],
1016
+ })
1017
+ @TableColumn({
1018
+ required: false,
1019
+ type: TableColumnType.Boolean,
1020
+ title: "Enable Reopen Window",
1021
+ description:
1022
+ "Enable reopening recently resolved episodes instead of creating new ones. Useful when related issues recur shortly after resolution.",
1023
+ defaultValue: false,
1024
+ isDefaultValueColumn: true,
1025
+ })
1026
+ @Column({
1027
+ type: ColumnType.Boolean,
1028
+ nullable: false,
1029
+ default: false,
1030
+ })
1031
+ public enableReopenWindow?: boolean = undefined;
1032
+
1033
+ @ColumnAccessControl({
1034
+ create: [
1035
+ Permission.ProjectOwner,
1036
+ Permission.ProjectAdmin,
1037
+ Permission.CreateIncidentGroupingRule,
1038
+ ],
1039
+ read: [
1040
+ Permission.ProjectOwner,
1041
+ Permission.ProjectAdmin,
1042
+ Permission.ProjectMember,
1043
+ Permission.ReadIncidentGroupingRule,
1044
+ ],
1045
+ update: [
1046
+ Permission.ProjectOwner,
1047
+ Permission.ProjectAdmin,
1048
+ Permission.EditIncidentGroupingRule,
1049
+ ],
1050
+ })
1051
+ @TableColumn({
1052
+ required: false,
1053
+ type: TableColumnType.Number,
1054
+ title: "Reopen Window (Minutes)",
1055
+ description:
1056
+ "Time window in minutes to reopen a recently resolved episode instead of creating a new one",
1057
+ defaultValue: 0,
1058
+ isDefaultValueColumn: true,
1059
+ })
1060
+ @Column({
1061
+ type: ColumnType.Number,
1062
+ nullable: false,
1063
+ default: 0,
1064
+ })
1065
+ public reopenWindowMinutes?: number = undefined;
1066
+
1067
+ @ColumnAccessControl({
1068
+ create: [
1069
+ Permission.ProjectOwner,
1070
+ Permission.ProjectAdmin,
1071
+ Permission.CreateIncidentGroupingRule,
1072
+ ],
1073
+ read: [
1074
+ Permission.ProjectOwner,
1075
+ Permission.ProjectAdmin,
1076
+ Permission.ProjectMember,
1077
+ Permission.ReadIncidentGroupingRule,
1078
+ ],
1079
+ update: [
1080
+ Permission.ProjectOwner,
1081
+ Permission.ProjectAdmin,
1082
+ Permission.EditIncidentGroupingRule,
1083
+ ],
1084
+ })
1085
+ @TableColumn({
1086
+ required: false,
1087
+ type: TableColumnType.Boolean,
1088
+ title: "Enable Inactivity Timeout",
1089
+ description:
1090
+ "Enable auto-resolving episodes after a period of inactivity. Helps automatically close episodes when no new incidents arrive.",
1091
+ defaultValue: false,
1092
+ isDefaultValueColumn: true,
1093
+ })
1094
+ @Column({
1095
+ type: ColumnType.Boolean,
1096
+ nullable: false,
1097
+ default: false,
1098
+ })
1099
+ public enableInactivityTimeout?: boolean = undefined;
1100
+
1101
+ @ColumnAccessControl({
1102
+ create: [
1103
+ Permission.ProjectOwner,
1104
+ Permission.ProjectAdmin,
1105
+ Permission.CreateIncidentGroupingRule,
1106
+ ],
1107
+ read: [
1108
+ Permission.ProjectOwner,
1109
+ Permission.ProjectAdmin,
1110
+ Permission.ProjectMember,
1111
+ Permission.ReadIncidentGroupingRule,
1112
+ ],
1113
+ update: [
1114
+ Permission.ProjectOwner,
1115
+ Permission.ProjectAdmin,
1116
+ Permission.EditIncidentGroupingRule,
1117
+ ],
1118
+ })
1119
+ @TableColumn({
1120
+ required: false,
1121
+ type: TableColumnType.Number,
1122
+ title: "Inactivity Timeout (Minutes)",
1123
+ description:
1124
+ "Time in minutes after which an inactive episode will be auto-resolved",
1125
+ defaultValue: 60,
1126
+ isDefaultValueColumn: true,
1127
+ })
1128
+ @Column({
1129
+ type: ColumnType.Number,
1130
+ nullable: false,
1131
+ default: 60,
1132
+ })
1133
+ public inactivityTimeoutMinutes?: number = undefined;
1134
+
1135
+ @ColumnAccessControl({
1136
+ create: [
1137
+ Permission.ProjectOwner,
1138
+ Permission.ProjectAdmin,
1139
+ Permission.CreateIncidentGroupingRule,
1140
+ ],
1141
+ read: [
1142
+ Permission.ProjectOwner,
1143
+ Permission.ProjectAdmin,
1144
+ Permission.ProjectMember,
1145
+ Permission.ReadIncidentGroupingRule,
1146
+ ],
1147
+ update: [
1148
+ Permission.ProjectOwner,
1149
+ Permission.ProjectAdmin,
1150
+ Permission.EditIncidentGroupingRule,
1151
+ ],
1152
+ })
1153
+ @TableColumn({
1154
+ required: false,
1155
+ type: TableColumnType.EntityArray,
1156
+ modelType: OnCallDutyPolicy,
1157
+ title: "On-Call Duty Policies",
1158
+ description:
1159
+ "List of on-call duty policies to execute for episodes created by this rule.",
1160
+ })
1161
+ @ManyToMany(
1162
+ () => {
1163
+ return OnCallDutyPolicy;
1164
+ },
1165
+ { eager: false },
1166
+ )
1167
+ @JoinTable({
1168
+ name: "IncidentGroupingRuleOnCallDutyPolicy",
1169
+ inverseJoinColumn: {
1170
+ name: "onCallDutyPolicyId",
1171
+ referencedColumnName: "_id",
1172
+ },
1173
+ joinColumn: {
1174
+ name: "incidentGroupingRuleId",
1175
+ referencedColumnName: "_id",
1176
+ },
1177
+ })
1178
+ public onCallDutyPolicies?: Array<OnCallDutyPolicy> = undefined;
1179
+
1180
+ @ColumnAccessControl({
1181
+ create: [
1182
+ Permission.ProjectOwner,
1183
+ Permission.ProjectAdmin,
1184
+ Permission.CreateIncidentGroupingRule,
1185
+ ],
1186
+ read: [
1187
+ Permission.ProjectOwner,
1188
+ Permission.ProjectAdmin,
1189
+ Permission.ProjectMember,
1190
+ Permission.ReadIncidentGroupingRule,
1191
+ ],
1192
+ update: [
1193
+ Permission.ProjectOwner,
1194
+ Permission.ProjectAdmin,
1195
+ Permission.EditIncidentGroupingRule,
1196
+ ],
1197
+ })
1198
+ @TableColumn({
1199
+ manyToOneRelationColumn: "defaultAssignToUserId",
1200
+ type: TableColumnType.Entity,
1201
+ modelType: User,
1202
+ title: "Default Assign To User",
1203
+ description: "Default user to assign episodes created by this rule",
1204
+ })
1205
+ @ManyToOne(
1206
+ () => {
1207
+ return User;
1208
+ },
1209
+ {
1210
+ eager: false,
1211
+ nullable: true,
1212
+ onDelete: "SET NULL",
1213
+ orphanedRowAction: "nullify",
1214
+ },
1215
+ )
1216
+ @JoinColumn({ name: "defaultAssignToUserId" })
1217
+ public defaultAssignToUser?: User = undefined;
1218
+
1219
+ @ColumnAccessControl({
1220
+ create: [
1221
+ Permission.ProjectOwner,
1222
+ Permission.ProjectAdmin,
1223
+ Permission.CreateIncidentGroupingRule,
1224
+ ],
1225
+ read: [
1226
+ Permission.ProjectOwner,
1227
+ Permission.ProjectAdmin,
1228
+ Permission.ProjectMember,
1229
+ Permission.ReadIncidentGroupingRule,
1230
+ ],
1231
+ update: [
1232
+ Permission.ProjectOwner,
1233
+ Permission.ProjectAdmin,
1234
+ Permission.EditIncidentGroupingRule,
1235
+ ],
1236
+ })
1237
+ @Index()
1238
+ @TableColumn({
1239
+ type: TableColumnType.ObjectID,
1240
+ required: false,
1241
+ title: "Default Assign To User ID",
1242
+ description: "Default User ID to assign episodes created by this rule",
1243
+ })
1244
+ @Column({
1245
+ type: ColumnType.ObjectID,
1246
+ nullable: true,
1247
+ transformer: ObjectID.getDatabaseTransformer(),
1248
+ })
1249
+ public defaultAssignToUserId?: ObjectID = undefined;
1250
+
1251
+ @ColumnAccessControl({
1252
+ create: [
1253
+ Permission.ProjectOwner,
1254
+ Permission.ProjectAdmin,
1255
+ Permission.CreateIncidentGroupingRule,
1256
+ ],
1257
+ read: [
1258
+ Permission.ProjectOwner,
1259
+ Permission.ProjectAdmin,
1260
+ Permission.ProjectMember,
1261
+ Permission.ReadIncidentGroupingRule,
1262
+ ],
1263
+ update: [
1264
+ Permission.ProjectOwner,
1265
+ Permission.ProjectAdmin,
1266
+ Permission.EditIncidentGroupingRule,
1267
+ ],
1268
+ })
1269
+ @TableColumn({
1270
+ manyToOneRelationColumn: "defaultAssignToTeamId",
1271
+ type: TableColumnType.Entity,
1272
+ modelType: Team,
1273
+ title: "Default Assign To Team",
1274
+ description: "Default team to assign episodes created by this rule",
1275
+ })
1276
+ @ManyToOne(
1277
+ () => {
1278
+ return Team;
1279
+ },
1280
+ {
1281
+ eager: false,
1282
+ nullable: true,
1283
+ onDelete: "SET NULL",
1284
+ orphanedRowAction: "nullify",
1285
+ },
1286
+ )
1287
+ @JoinColumn({ name: "defaultAssignToTeamId" })
1288
+ public defaultAssignToTeam?: Team = undefined;
1289
+
1290
+ @ColumnAccessControl({
1291
+ create: [
1292
+ Permission.ProjectOwner,
1293
+ Permission.ProjectAdmin,
1294
+ Permission.CreateIncidentGroupingRule,
1295
+ ],
1296
+ read: [
1297
+ Permission.ProjectOwner,
1298
+ Permission.ProjectAdmin,
1299
+ Permission.ProjectMember,
1300
+ Permission.ReadIncidentGroupingRule,
1301
+ ],
1302
+ update: [
1303
+ Permission.ProjectOwner,
1304
+ Permission.ProjectAdmin,
1305
+ Permission.EditIncidentGroupingRule,
1306
+ ],
1307
+ })
1308
+ @Index()
1309
+ @TableColumn({
1310
+ type: TableColumnType.ObjectID,
1311
+ required: false,
1312
+ title: "Default Assign To Team ID",
1313
+ description: "Default Team ID to assign episodes created by this rule",
1314
+ })
1315
+ @Column({
1316
+ type: ColumnType.ObjectID,
1317
+ nullable: true,
1318
+ transformer: ObjectID.getDatabaseTransformer(),
1319
+ })
1320
+ public defaultAssignToTeamId?: ObjectID = undefined;
1321
+
1322
+ @ColumnAccessControl({
1323
+ create: [
1324
+ Permission.ProjectOwner,
1325
+ Permission.ProjectAdmin,
1326
+ Permission.CreateIncidentGroupingRule,
1327
+ ],
1328
+ read: [
1329
+ Permission.ProjectOwner,
1330
+ Permission.ProjectAdmin,
1331
+ Permission.ProjectMember,
1332
+ Permission.ReadIncidentGroupingRule,
1333
+ ],
1334
+ update: [],
1335
+ })
1336
+ @TableColumn({
1337
+ manyToOneRelationColumn: "createdByUserId",
1338
+ type: TableColumnType.Entity,
1339
+ modelType: User,
1340
+ title: "Created by User",
1341
+ description:
1342
+ "Relation to User who created this object (if this object was created by a User)",
1343
+ })
1344
+ @ManyToOne(
1345
+ () => {
1346
+ return User;
1347
+ },
1348
+ {
1349
+ eager: false,
1350
+ nullable: true,
1351
+ onDelete: "SET NULL",
1352
+ orphanedRowAction: "nullify",
1353
+ },
1354
+ )
1355
+ @JoinColumn({ name: "createdByUserId" })
1356
+ public createdByUser?: User = undefined;
1357
+
1358
+ @ColumnAccessControl({
1359
+ create: [
1360
+ Permission.ProjectOwner,
1361
+ Permission.ProjectAdmin,
1362
+ Permission.CreateIncidentGroupingRule,
1363
+ ],
1364
+ read: [
1365
+ Permission.ProjectOwner,
1366
+ Permission.ProjectAdmin,
1367
+ Permission.ProjectMember,
1368
+ Permission.ReadIncidentGroupingRule,
1369
+ ],
1370
+ update: [],
1371
+ })
1372
+ @TableColumn({
1373
+ type: TableColumnType.ObjectID,
1374
+ title: "Created by User ID",
1375
+ description:
1376
+ "User ID who created this object (if this object was created by a User)",
1377
+ })
1378
+ @Column({
1379
+ type: ColumnType.ObjectID,
1380
+ nullable: true,
1381
+ transformer: ObjectID.getDatabaseTransformer(),
1382
+ })
1383
+ public createdByUserId?: ObjectID = undefined;
1384
+
1385
+ @ColumnAccessControl({
1386
+ create: [],
1387
+ read: [],
1388
+ update: [],
1389
+ })
1390
+ @TableColumn({
1391
+ manyToOneRelationColumn: "deletedByUserId",
1392
+ type: TableColumnType.Entity,
1393
+ title: "Deleted by User",
1394
+ modelType: User,
1395
+ description:
1396
+ "Relation to User who deleted this object (if this object was deleted by a User)",
1397
+ })
1398
+ @ManyToOne(
1399
+ () => {
1400
+ return User;
1401
+ },
1402
+ {
1403
+ cascade: false,
1404
+ eager: false,
1405
+ nullable: true,
1406
+ onDelete: "SET NULL",
1407
+ orphanedRowAction: "nullify",
1408
+ },
1409
+ )
1410
+ @JoinColumn({ name: "deletedByUserId" })
1411
+ public deletedByUser?: User = undefined;
1412
+
1413
+ @ColumnAccessControl({
1414
+ create: [],
1415
+ read: [],
1416
+ update: [],
1417
+ })
1418
+ @TableColumn({
1419
+ type: TableColumnType.ObjectID,
1420
+ title: "Deleted by User ID",
1421
+ description:
1422
+ "User ID who deleted this object (if this object was deleted by a User)",
1423
+ })
1424
+ @Column({
1425
+ type: ColumnType.ObjectID,
1426
+ nullable: true,
1427
+ transformer: ObjectID.getDatabaseTransformer(),
1428
+ })
1429
+ public deletedByUserId?: ObjectID = undefined;
1430
+ }