@oneuptime/common 9.4.12 → 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.
- package/Models/DatabaseModels/Incident.ts +77 -0
- package/Models/DatabaseModels/IncidentEpisode.ts +1223 -0
- package/Models/DatabaseModels/IncidentEpisodeFeed.ts +533 -0
- package/Models/DatabaseModels/IncidentEpisodeInternalNote.ts +456 -0
- package/Models/DatabaseModels/IncidentEpisodeMember.ts +587 -0
- package/Models/DatabaseModels/IncidentEpisodeOwnerTeam.ts +421 -0
- package/Models/DatabaseModels/IncidentEpisodeOwnerUser.ts +419 -0
- package/Models/DatabaseModels/IncidentEpisodeStateTimeline.ts +524 -0
- package/Models/DatabaseModels/IncidentGroupingRule.ts +1430 -0
- package/Models/DatabaseModels/Index.ts +18 -0
- package/Models/DatabaseModels/OnCallDutyPolicyExecutionLog.ts +70 -0
- package/Models/DatabaseModels/OnCallDutyPolicyExecutionLogTimeline.ts +59 -0
- package/Models/DatabaseModels/UserOnCallLog.ts +48 -0
- package/Models/DatabaseModels/UserOnCallLogTimeline.ts +49 -0
- package/Models/DatabaseModels/WorkspaceNotificationLog.ts +57 -0
- package/Server/API/IncidentEpisodeAPI.ts +150 -0
- package/Server/API/SlackAPI.ts +23 -0
- package/Server/API/UserOnCallLogTimelineAPI.ts +24 -4
- package/Server/Infrastructure/Postgres/SchemaMigrations/1769626069479-MigrationName.ts +729 -0
- package/Server/Infrastructure/Postgres/SchemaMigrations/1769629928240-MigrationName.ts +261 -0
- package/Server/Infrastructure/Postgres/SchemaMigrations/1769676117342-RenameEvaluateOverTimeInCriteriaFilter.ts +28 -0
- package/Server/Infrastructure/Postgres/SchemaMigrations/Index.ts +6 -0
- package/Server/Services/BillingService.ts +1 -3
- package/Server/Services/CallService.ts +1 -0
- package/Server/Services/IncidentEpisodeFeedService.ts +94 -0
- package/Server/Services/IncidentEpisodeInternalNoteService.ts +71 -0
- package/Server/Services/IncidentEpisodeMemberService.ts +321 -0
- package/Server/Services/IncidentEpisodeOwnerTeamService.ts +10 -0
- package/Server/Services/IncidentEpisodeOwnerUserService.ts +10 -0
- package/Server/Services/IncidentEpisodeService.ts +1045 -0
- package/Server/Services/IncidentEpisodeStateTimelineService.ts +566 -0
- package/Server/Services/IncidentGroupingEngineService.ts +1047 -0
- package/Server/Services/IncidentGroupingRuleService.ts +14 -0
- package/Server/Services/IncidentService.ts +11 -0
- package/Server/Services/Index.ts +18 -0
- package/Server/Services/MailService.ts +1 -0
- package/Server/Services/MonitorService.ts +9 -0
- package/Server/Services/OnCallDutyPolicyEscalationRuleService.ts +18 -0
- package/Server/Services/OnCallDutyPolicyExecutionLogService.ts +64 -2
- package/Server/Services/OnCallDutyPolicyExecutionLogTimelineService.ts +26 -1
- package/Server/Services/OnCallDutyPolicyService.ts +15 -0
- package/Server/Services/SmsService.ts +1 -0
- package/Server/Services/UserNotificationRuleService.ts +48 -2
- package/Server/Services/UserNotificationSettingService.ts +23 -0
- package/Server/Services/UserOnCallLogService.ts +41 -4
- package/Server/Services/WhatsAppService.ts +1 -0
- package/Server/Services/WorkspaceNotificationLogService.ts +16 -0
- package/Server/Services/WorkspaceNotificationRuleService.ts +116 -0
- package/Server/Utils/AI/IncidentEpisodeAIContextBuilder.ts +490 -0
- package/Server/Utils/Monitor/Criteria/APIRequestCriteria.ts +1 -1
- package/Server/Utils/Monitor/Criteria/CompareCriteria.ts +1 -1
- package/Server/Utils/Monitor/Criteria/IncomingRequestCriteria.ts +1 -1
- package/Server/Utils/Monitor/Criteria/SSLMonitorCriteria.ts +1 -1
- package/Server/Utils/Monitor/Criteria/ServerMonitorCriteria.ts +2 -2
- package/Server/Utils/Monitor/Criteria/SnmpMonitorCriteria.ts +182 -0
- package/Server/Utils/Monitor/MonitorCriteriaEvaluator.ts +13 -0
- package/Server/Utils/Monitor/MonitorCriteriaExpectationBuilder.ts +1 -1
- package/Server/Utils/Monitor/MonitorTemplateUtil.ts +37 -0
- package/Server/Utils/PushNotificationUtil.ts +31 -0
- package/Server/Utils/WhatsAppTemplateUtil.ts +14 -0
- package/Server/Utils/Workspace/MicrosoftTeams/Actions/ActionTypes.ts +18 -0
- package/Server/Utils/Workspace/MicrosoftTeams/Actions/IncidentEpisode.ts +702 -0
- package/Server/Utils/Workspace/MicrosoftTeams/MicrosoftTeams.ts +20 -0
- package/Server/Utils/Workspace/Slack/Actions/ActionTypes.ts +11 -0
- package/Server/Utils/Workspace/Slack/Actions/IncidentEpisode.ts +918 -0
- package/Server/Utils/Workspace/Slack/Messages/IncidentEpisode.ts +120 -0
- package/Server/Utils/Workspace/WorkspaceMessages/IncidentEpisode.ts +74 -0
- package/Types/Email/EmailTemplateType.ts +6 -0
- package/Types/Monitor/CriteriaFilter.ts +24 -4
- package/Types/Monitor/MonitorCriteriaInstance.ts +67 -0
- package/Types/Monitor/MonitorStep.ts +37 -0
- package/Types/Monitor/MonitorStepSnmpMonitor.ts +102 -0
- package/Types/Monitor/MonitorType.ts +15 -2
- package/Types/Monitor/SnmpMonitor/SnmpAuthProtocol.ts +8 -0
- package/Types/Monitor/SnmpMonitor/SnmpDataType.ts +21 -0
- package/Types/Monitor/SnmpMonitor/SnmpMonitorResponse.ts +16 -0
- package/Types/Monitor/SnmpMonitor/SnmpOid.ts +60 -0
- package/Types/Monitor/SnmpMonitor/SnmpPrivProtocol.ts +7 -0
- package/Types/Monitor/SnmpMonitor/SnmpSecurityLevel.ts +7 -0
- package/Types/Monitor/SnmpMonitor/SnmpV3Auth.ts +12 -0
- package/Types/Monitor/SnmpMonitor/SnmpVersion.ts +7 -0
- package/Types/NotificationSetting/NotificationSettingEventType.ts +7 -0
- package/Types/Permission.ts +311 -0
- package/Types/Probe/ProbeMonitorResponse.ts +2 -0
- package/Types/UserNotification/UserNotificationEventType.ts +1 -0
- package/Types/WhatsApp/WhatsAppTemplates.ts +24 -0
- package/Types/Workspace/NotificationRules/EventType.ts +1 -0
- package/Types/Workspace/NotificationRules/NotificationRuleCondition.ts +38 -1
- package/Utils/Monitor/MonitorMetricType.ts +2 -1
- package/build/dist/Models/DatabaseModels/Incident.js +78 -0
- package/build/dist/Models/DatabaseModels/Incident.js.map +1 -1
- package/build/dist/Models/DatabaseModels/IncidentEpisode.js +1250 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisode.js.map +1 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeFeed.js +555 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeFeed.js.map +1 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeInternalNote.js +467 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeInternalNote.js.map +1 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeMember.js +607 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeMember.js.map +1 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerTeam.js +437 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerTeam.js.map +1 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerUser.js +436 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeOwnerUser.js.map +1 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeStateTimeline.js +546 -0
- package/build/dist/Models/DatabaseModels/IncidentEpisodeStateTimeline.js.map +1 -0
- package/build/dist/Models/DatabaseModels/IncidentGroupingRule.js +1437 -0
- package/build/dist/Models/DatabaseModels/IncidentGroupingRule.js.map +1 -0
- package/build/dist/Models/DatabaseModels/Index.js +16 -0
- package/build/dist/Models/DatabaseModels/Index.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyExecutionLog.js +69 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyExecutionLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyExecutionLogTimeline.js +58 -0
- package/build/dist/Models/DatabaseModels/OnCallDutyPolicyExecutionLogTimeline.js.map +1 -1
- package/build/dist/Models/DatabaseModels/UserOnCallLog.js +47 -0
- package/build/dist/Models/DatabaseModels/UserOnCallLog.js.map +1 -1
- package/build/dist/Models/DatabaseModels/UserOnCallLogTimeline.js +48 -0
- package/build/dist/Models/DatabaseModels/UserOnCallLogTimeline.js.map +1 -1
- package/build/dist/Models/DatabaseModels/WorkspaceNotificationLog.js +58 -0
- package/build/dist/Models/DatabaseModels/WorkspaceNotificationLog.js.map +1 -1
- package/build/dist/Server/API/IncidentEpisodeAPI.js +97 -0
- package/build/dist/Server/API/IncidentEpisodeAPI.js.map +1 -0
- package/build/dist/Server/API/SlackAPI.js +18 -0
- package/build/dist/Server/API/SlackAPI.js.map +1 -1
- package/build/dist/Server/API/UserOnCallLogTimelineAPI.js +30 -10
- package/build/dist/Server/API/UserOnCallLogTimelineAPI.js.map +1 -1
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769626069479-MigrationName.js +256 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769626069479-MigrationName.js.map +1 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769629928240-MigrationName.js +96 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769629928240-MigrationName.js.map +1 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769676117342-RenameEvaluateOverTimeInCriteriaFilter.js +25 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/1769676117342-RenameEvaluateOverTimeInCriteriaFilter.js.map +1 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js +6 -0
- package/build/dist/Server/Infrastructure/Postgres/SchemaMigrations/Index.js.map +1 -1
- package/build/dist/Server/Services/BillingService.js +1 -2
- package/build/dist/Server/Services/BillingService.js.map +1 -1
- package/build/dist/Server/Services/CallService.js.map +1 -1
- package/build/dist/Server/Services/IncidentEpisodeFeedService.js +83 -0
- package/build/dist/Server/Services/IncidentEpisodeFeedService.js.map +1 -0
- package/build/dist/Server/Services/IncidentEpisodeInternalNoteService.js +70 -0
- package/build/dist/Server/Services/IncidentEpisodeInternalNoteService.js.map +1 -0
- package/build/dist/Server/Services/IncidentEpisodeMemberService.js +298 -0
- package/build/dist/Server/Services/IncidentEpisodeMemberService.js.map +1 -0
- package/build/dist/Server/Services/IncidentEpisodeOwnerTeamService.js +9 -0
- package/build/dist/Server/Services/IncidentEpisodeOwnerTeamService.js.map +1 -0
- package/build/dist/Server/Services/IncidentEpisodeOwnerUserService.js +9 -0
- package/build/dist/Server/Services/IncidentEpisodeOwnerUserService.js.map +1 -0
- package/build/dist/Server/Services/IncidentEpisodeService.js +933 -0
- package/build/dist/Server/Services/IncidentEpisodeService.js.map +1 -0
- package/build/dist/Server/Services/IncidentEpisodeStateTimelineService.js +498 -0
- package/build/dist/Server/Services/IncidentEpisodeStateTimelineService.js.map +1 -0
- package/build/dist/Server/Services/IncidentGroupingEngineService.js +799 -0
- package/build/dist/Server/Services/IncidentGroupingEngineService.js.map +1 -0
- package/build/dist/Server/Services/IncidentGroupingRuleService.js +13 -0
- package/build/dist/Server/Services/IncidentGroupingRuleService.js.map +1 -0
- package/build/dist/Server/Services/IncidentService.js +10 -0
- package/build/dist/Server/Services/IncidentService.js.map +1 -1
- package/build/dist/Server/Services/Index.js +16 -0
- package/build/dist/Server/Services/Index.js.map +1 -1
- package/build/dist/Server/Services/MailService.js.map +1 -1
- package/build/dist/Server/Services/MonitorService.js +9 -1
- package/build/dist/Server/Services/MonitorService.js.map +1 -1
- package/build/dist/Server/Services/OnCallDutyPolicyEscalationRuleService.js +10 -0
- package/build/dist/Server/Services/OnCallDutyPolicyEscalationRuleService.js.map +1 -1
- package/build/dist/Server/Services/OnCallDutyPolicyExecutionLogService.js +48 -2
- package/build/dist/Server/Services/OnCallDutyPolicyExecutionLogService.js.map +1 -1
- package/build/dist/Server/Services/OnCallDutyPolicyExecutionLogTimelineService.js +20 -1
- package/build/dist/Server/Services/OnCallDutyPolicyExecutionLogTimelineService.js.map +1 -1
- package/build/dist/Server/Services/OnCallDutyPolicyService.js +8 -0
- package/build/dist/Server/Services/OnCallDutyPolicyService.js.map +1 -1
- package/build/dist/Server/Services/SmsService.js.map +1 -1
- package/build/dist/Server/Services/UserNotificationRuleService.js +39 -2
- package/build/dist/Server/Services/UserNotificationRuleService.js.map +1 -1
- package/build/dist/Server/Services/UserNotificationSettingService.js +9 -0
- package/build/dist/Server/Services/UserNotificationSettingService.js.map +1 -1
- package/build/dist/Server/Services/UserOnCallLogService.js +35 -3
- package/build/dist/Server/Services/UserOnCallLogService.js.map +1 -1
- package/build/dist/Server/Services/WhatsAppService.js.map +1 -1
- package/build/dist/Server/Services/WorkspaceNotificationLogService.js +12 -0
- package/build/dist/Server/Services/WorkspaceNotificationLogService.js.map +1 -1
- package/build/dist/Server/Services/WorkspaceNotificationRuleService.js +95 -1
- package/build/dist/Server/Services/WorkspaceNotificationRuleService.js.map +1 -1
- package/build/dist/Server/Utils/AI/IncidentEpisodeAIContextBuilder.js +402 -0
- package/build/dist/Server/Utils/AI/IncidentEpisodeAIContextBuilder.js.map +1 -0
- package/build/dist/Server/Utils/Monitor/Criteria/APIRequestCriteria.js +1 -1
- package/build/dist/Server/Utils/Monitor/Criteria/CompareCriteria.js +1 -1
- package/build/dist/Server/Utils/Monitor/Criteria/IncomingRequestCriteria.js +1 -1
- package/build/dist/Server/Utils/Monitor/Criteria/SSLMonitorCriteria.js +1 -1
- package/build/dist/Server/Utils/Monitor/Criteria/ServerMonitorCriteria.js +2 -2
- package/build/dist/Server/Utils/Monitor/Criteria/SnmpMonitorCriteria.js +135 -0
- package/build/dist/Server/Utils/Monitor/Criteria/SnmpMonitorCriteria.js.map +1 -0
- package/build/dist/Server/Utils/Monitor/MonitorCriteriaEvaluator.js +10 -0
- package/build/dist/Server/Utils/Monitor/MonitorCriteriaEvaluator.js.map +1 -1
- package/build/dist/Server/Utils/Monitor/MonitorCriteriaExpectationBuilder.js +1 -1
- package/build/dist/Server/Utils/Monitor/MonitorTemplateUtil.js +26 -0
- package/build/dist/Server/Utils/Monitor/MonitorTemplateUtil.js.map +1 -1
- package/build/dist/Server/Utils/PushNotificationUtil.js +20 -0
- package/build/dist/Server/Utils/PushNotificationUtil.js.map +1 -1
- package/build/dist/Server/Utils/WhatsAppTemplateUtil.js +8 -0
- package/build/dist/Server/Utils/WhatsAppTemplateUtil.js.map +1 -1
- package/build/dist/Server/Utils/Workspace/MicrosoftTeams/Actions/ActionTypes.js +17 -0
- package/build/dist/Server/Utils/Workspace/MicrosoftTeams/Actions/ActionTypes.js.map +1 -1
- package/build/dist/Server/Utils/Workspace/MicrosoftTeams/Actions/IncidentEpisode.js +547 -0
- package/build/dist/Server/Utils/Workspace/MicrosoftTeams/Actions/IncidentEpisode.js.map +1 -0
- package/build/dist/Server/Utils/Workspace/MicrosoftTeams/MicrosoftTeams.js +15 -0
- package/build/dist/Server/Utils/Workspace/MicrosoftTeams/MicrosoftTeams.js.map +1 -1
- package/build/dist/Server/Utils/Workspace/Slack/Actions/ActionTypes.js +10 -0
- package/build/dist/Server/Utils/Workspace/Slack/Actions/ActionTypes.js.map +1 -1
- package/build/dist/Server/Utils/Workspace/Slack/Actions/IncidentEpisode.js +651 -0
- package/build/dist/Server/Utils/Workspace/Slack/Actions/IncidentEpisode.js.map +1 -0
- package/build/dist/Server/Utils/Workspace/Slack/Messages/IncidentEpisode.js +100 -0
- package/build/dist/Server/Utils/Workspace/Slack/Messages/IncidentEpisode.js.map +1 -0
- package/build/dist/Server/Utils/Workspace/WorkspaceMessages/IncidentEpisode.js +70 -0
- package/build/dist/Server/Utils/Workspace/WorkspaceMessages/IncidentEpisode.js.map +1 -0
- package/build/dist/Types/Email/EmailTemplateType.js +5 -0
- package/build/dist/Types/Email/EmailTemplateType.js.map +1 -1
- package/build/dist/Types/Monitor/CriteriaFilter.js +16 -3
- package/build/dist/Types/Monitor/CriteriaFilter.js.map +1 -1
- package/build/dist/Types/Monitor/MonitorCriteriaInstance.js +62 -0
- package/build/dist/Types/Monitor/MonitorCriteriaInstance.js.map +1 -1
- package/build/dist/Types/Monitor/MonitorStep.js +26 -0
- package/build/dist/Types/Monitor/MonitorStep.js.map +1 -1
- package/build/dist/Types/Monitor/MonitorStepSnmpMonitor.js +77 -0
- package/build/dist/Types/Monitor/MonitorStepSnmpMonitor.js.map +1 -0
- package/build/dist/Types/Monitor/MonitorType.js +13 -2
- package/build/dist/Types/Monitor/MonitorType.js.map +1 -1
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpAuthProtocol.js +9 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpAuthProtocol.js.map +1 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpDataType.js +22 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpDataType.js.map +1 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpMonitorResponse.js +2 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpMonitorResponse.js.map +1 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpOid.js +55 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpOid.js.map +1 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpPrivProtocol.js +8 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpPrivProtocol.js.map +1 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpSecurityLevel.js +8 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpSecurityLevel.js.map +1 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpV3Auth.js +2 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpV3Auth.js.map +1 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpVersion.js +8 -0
- package/build/dist/Types/Monitor/SnmpMonitor/SnmpVersion.js.map +1 -0
- package/build/dist/Types/NotificationSetting/NotificationSettingEventType.js +5 -0
- package/build/dist/Types/NotificationSetting/NotificationSettingEventType.js.map +1 -1
- package/build/dist/Types/Permission.js +264 -0
- package/build/dist/Types/Permission.js.map +1 -1
- package/build/dist/Types/UserNotification/UserNotificationEventType.js +1 -0
- package/build/dist/Types/UserNotification/UserNotificationEventType.js.map +1 -1
- package/build/dist/Types/WhatsApp/WhatsAppTemplates.js +15 -0
- package/build/dist/Types/WhatsApp/WhatsAppTemplates.js.map +1 -1
- package/build/dist/Types/Workspace/NotificationRules/EventType.js +1 -0
- package/build/dist/Types/Workspace/NotificationRules/EventType.js.map +1 -1
- package/build/dist/Types/Workspace/NotificationRules/NotificationRuleCondition.js +33 -1
- package/build/dist/Types/Workspace/NotificationRules/NotificationRuleCondition.js.map +1 -1
- package/build/dist/Utils/Monitor/MonitorMetricType.js +2 -1
- package/build/dist/Utils/Monitor/MonitorMetricType.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,261 @@
|
|
|
1
|
+
import { MigrationInterface, QueryRunner } from "typeorm";
|
|
2
|
+
|
|
3
|
+
export class MigrationName1769629928240 implements MigrationInterface {
|
|
4
|
+
public name = "MigrationName1769629928240";
|
|
5
|
+
|
|
6
|
+
public async up(queryRunner: QueryRunner): Promise<void> {
|
|
7
|
+
await queryRunner.query(
|
|
8
|
+
`CREATE TABLE "IncidentGroupingRule" ("_id" uuid NOT NULL DEFAULT uuid_generate_v4(), "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT now(), "deletedAt" TIMESTAMP WITH TIME ZONE, "version" integer NOT NULL, "projectId" uuid NOT NULL, "name" character varying(100) NOT NULL, "description" character varying(500), "priority" integer NOT NULL DEFAULT '1', "isEnabled" boolean NOT NULL DEFAULT true, "matchCriteria" jsonb, "incidentTitlePattern" character varying(500), "incidentDescriptionPattern" character varying(500), "monitorNamePattern" character varying(500), "monitorDescriptionPattern" character varying(500), "groupByMonitor" boolean NOT NULL DEFAULT true, "groupBySeverity" boolean NOT NULL DEFAULT false, "groupByIncidentTitle" boolean NOT NULL DEFAULT false, "groupByService" boolean NOT NULL DEFAULT false, "enableTimeWindow" boolean NOT NULL DEFAULT false, "timeWindowMinutes" integer NOT NULL DEFAULT '60', "groupByFields" jsonb, "episodeTitleTemplate" character varying, "episodeDescriptionTemplate" character varying, "enableResolveDelay" boolean NOT NULL DEFAULT false, "resolveDelayMinutes" integer NOT NULL DEFAULT '0', "enableReopenWindow" boolean NOT NULL DEFAULT false, "reopenWindowMinutes" integer NOT NULL DEFAULT '0', "enableInactivityTimeout" boolean NOT NULL DEFAULT false, "inactivityTimeoutMinutes" integer NOT NULL DEFAULT '60', "defaultAssignToUserId" uuid, "defaultAssignToTeamId" uuid, "createdByUserId" uuid, "deletedByUserId" uuid, CONSTRAINT "PK_94c61c1e38617f17072f6b6ad8e" PRIMARY KEY ("_id"))`,
|
|
9
|
+
);
|
|
10
|
+
await queryRunner.query(
|
|
11
|
+
`CREATE INDEX "IDX_b3b80cf4883fbd326b9bbd3a75" ON "IncidentGroupingRule" ("projectId") `,
|
|
12
|
+
);
|
|
13
|
+
await queryRunner.query(
|
|
14
|
+
`CREATE INDEX "IDX_505e5c53bda97f6f31701d27af" ON "IncidentGroupingRule" ("name") `,
|
|
15
|
+
);
|
|
16
|
+
await queryRunner.query(
|
|
17
|
+
`CREATE INDEX "IDX_672943fcdc88c0bff4668cebb4" ON "IncidentGroupingRule" ("priority") `,
|
|
18
|
+
);
|
|
19
|
+
await queryRunner.query(
|
|
20
|
+
`CREATE INDEX "IDX_5dc2e7fd35a5fe8b7bcfd5a21d" ON "IncidentGroupingRule" ("isEnabled") `,
|
|
21
|
+
);
|
|
22
|
+
await queryRunner.query(
|
|
23
|
+
`CREATE INDEX "IDX_aac63b94b4af39a7160adaad2f" ON "IncidentGroupingRule" ("defaultAssignToUserId") `,
|
|
24
|
+
);
|
|
25
|
+
await queryRunner.query(
|
|
26
|
+
`CREATE INDEX "IDX_fe5bdf8166514940897662bcbd" ON "IncidentGroupingRule" ("defaultAssignToTeamId") `,
|
|
27
|
+
);
|
|
28
|
+
await queryRunner.query(
|
|
29
|
+
`CREATE TABLE "IncidentGroupingRuleMonitor" ("incidentGroupingRuleId" uuid NOT NULL, "monitorId" uuid NOT NULL, CONSTRAINT "PK_733aff4e3760e917f30aeea6fef" PRIMARY KEY ("incidentGroupingRuleId", "monitorId"))`,
|
|
30
|
+
);
|
|
31
|
+
await queryRunner.query(
|
|
32
|
+
`CREATE INDEX "IDX_306e6908e7e2ad0dd71be881ba" ON "IncidentGroupingRuleMonitor" ("incidentGroupingRuleId") `,
|
|
33
|
+
);
|
|
34
|
+
await queryRunner.query(
|
|
35
|
+
`CREATE INDEX "IDX_d285e375f967fc59fa9b96d7bd" ON "IncidentGroupingRuleMonitor" ("monitorId") `,
|
|
36
|
+
);
|
|
37
|
+
await queryRunner.query(
|
|
38
|
+
`CREATE TABLE "IncidentGroupingRuleIncidentSeverity" ("incidentGroupingRuleId" uuid NOT NULL, "incidentSeverityId" uuid NOT NULL, CONSTRAINT "PK_6428963c1ee00831295b6f0d852" PRIMARY KEY ("incidentGroupingRuleId", "incidentSeverityId"))`,
|
|
39
|
+
);
|
|
40
|
+
await queryRunner.query(
|
|
41
|
+
`CREATE INDEX "IDX_a739768a8dac3516afe08743c0" ON "IncidentGroupingRuleIncidentSeverity" ("incidentGroupingRuleId") `,
|
|
42
|
+
);
|
|
43
|
+
await queryRunner.query(
|
|
44
|
+
`CREATE INDEX "IDX_3b4f50b01923d34ce7dd1d12db" ON "IncidentGroupingRuleIncidentSeverity" ("incidentSeverityId") `,
|
|
45
|
+
);
|
|
46
|
+
await queryRunner.query(
|
|
47
|
+
`CREATE TABLE "IncidentGroupingRuleIncidentLabel" ("incidentGroupingRuleId" uuid NOT NULL, "labelId" uuid NOT NULL, CONSTRAINT "PK_933daef4671d705d7830fec0fd1" PRIMARY KEY ("incidentGroupingRuleId", "labelId"))`,
|
|
48
|
+
);
|
|
49
|
+
await queryRunner.query(
|
|
50
|
+
`CREATE INDEX "IDX_723a687aa549c95a0df19d8da8" ON "IncidentGroupingRuleIncidentLabel" ("incidentGroupingRuleId") `,
|
|
51
|
+
);
|
|
52
|
+
await queryRunner.query(
|
|
53
|
+
`CREATE INDEX "IDX_930efbf2a450f944d33cb83f8c" ON "IncidentGroupingRuleIncidentLabel" ("labelId") `,
|
|
54
|
+
);
|
|
55
|
+
await queryRunner.query(
|
|
56
|
+
`CREATE TABLE "IncidentGroupingRuleMonitorLabel" ("incidentGroupingRuleId" uuid NOT NULL, "labelId" uuid NOT NULL, CONSTRAINT "PK_7cc99b79bc44599600a5959b8c6" PRIMARY KEY ("incidentGroupingRuleId", "labelId"))`,
|
|
57
|
+
);
|
|
58
|
+
await queryRunner.query(
|
|
59
|
+
`CREATE INDEX "IDX_77880aadd07a2ca077b648b40d" ON "IncidentGroupingRuleMonitorLabel" ("incidentGroupingRuleId") `,
|
|
60
|
+
);
|
|
61
|
+
await queryRunner.query(
|
|
62
|
+
`CREATE INDEX "IDX_97830e8e0a8164acf30e88fee0" ON "IncidentGroupingRuleMonitorLabel" ("labelId") `,
|
|
63
|
+
);
|
|
64
|
+
await queryRunner.query(
|
|
65
|
+
`CREATE TABLE "IncidentGroupingRuleOnCallDutyPolicy" ("incidentGroupingRuleId" uuid NOT NULL, "onCallDutyPolicyId" uuid NOT NULL, CONSTRAINT "PK_34cbe036592b89b84bfb9838c85" PRIMARY KEY ("incidentGroupingRuleId", "onCallDutyPolicyId"))`,
|
|
66
|
+
);
|
|
67
|
+
await queryRunner.query(
|
|
68
|
+
`CREATE INDEX "IDX_f2de7b843c3513ba7551dc1219" ON "IncidentGroupingRuleOnCallDutyPolicy" ("incidentGroupingRuleId") `,
|
|
69
|
+
);
|
|
70
|
+
await queryRunner.query(
|
|
71
|
+
`CREATE INDEX "IDX_3a98852815612d72d638624735" ON "IncidentGroupingRuleOnCallDutyPolicy" ("onCallDutyPolicyId") `,
|
|
72
|
+
);
|
|
73
|
+
await queryRunner.query(
|
|
74
|
+
`ALTER TABLE "IncidentEpisode" ADD "incidentGroupingRuleId" uuid`,
|
|
75
|
+
);
|
|
76
|
+
await queryRunner.query(
|
|
77
|
+
`ALTER TABLE "OnCallDutyPolicyScheduleLayer" ALTER COLUMN "rotation" SET DEFAULT '{"_type":"Recurring","value":{"intervalType":"Day","intervalCount":{"_type":"PositiveNumber","value":1}}}'`,
|
|
78
|
+
);
|
|
79
|
+
await queryRunner.query(
|
|
80
|
+
`ALTER TABLE "OnCallDutyPolicyScheduleLayer" ALTER COLUMN "restrictionTimes" SET DEFAULT '{"_type":"RestrictionTimes","value":{"restictionType":"None","dayRestrictionTimes":null,"weeklyRestrictionTimes":[]}}'`,
|
|
81
|
+
);
|
|
82
|
+
await queryRunner.query(
|
|
83
|
+
`CREATE INDEX "IDX_b74f982a546755197371a7b565" ON "IncidentEpisode" ("incidentGroupingRuleId") `,
|
|
84
|
+
);
|
|
85
|
+
await queryRunner.query(
|
|
86
|
+
`ALTER TABLE "IncidentGroupingRule" ADD CONSTRAINT "FK_b3b80cf4883fbd326b9bbd3a750" FOREIGN KEY ("projectId") REFERENCES "Project"("_id") ON DELETE CASCADE ON UPDATE NO ACTION`,
|
|
87
|
+
);
|
|
88
|
+
await queryRunner.query(
|
|
89
|
+
`ALTER TABLE "IncidentGroupingRule" ADD CONSTRAINT "FK_aac63b94b4af39a7160adaad2f1" FOREIGN KEY ("defaultAssignToUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
|
|
90
|
+
);
|
|
91
|
+
await queryRunner.query(
|
|
92
|
+
`ALTER TABLE "IncidentGroupingRule" ADD CONSTRAINT "FK_fe5bdf8166514940897662bcbd3" FOREIGN KEY ("defaultAssignToTeamId") REFERENCES "Team"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
|
|
93
|
+
);
|
|
94
|
+
await queryRunner.query(
|
|
95
|
+
`ALTER TABLE "IncidentGroupingRule" ADD CONSTRAINT "FK_6ec3a9100f6af789dc869b18220" FOREIGN KEY ("createdByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
|
|
96
|
+
);
|
|
97
|
+
await queryRunner.query(
|
|
98
|
+
`ALTER TABLE "IncidentGroupingRule" ADD CONSTRAINT "FK_7a0da098649113cb8251f48c0b5" FOREIGN KEY ("deletedByUserId") REFERENCES "User"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
|
|
99
|
+
);
|
|
100
|
+
await queryRunner.query(
|
|
101
|
+
`ALTER TABLE "IncidentEpisode" ADD CONSTRAINT "FK_b74f982a546755197371a7b565e" FOREIGN KEY ("incidentGroupingRuleId") REFERENCES "IncidentGroupingRule"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
|
|
102
|
+
);
|
|
103
|
+
await queryRunner.query(
|
|
104
|
+
`ALTER TABLE "IncidentEpisodeMember" ADD CONSTRAINT "FK_b8e5a102d8effb7d56ee952df93" FOREIGN KEY ("matchedRuleId") REFERENCES "IncidentGroupingRule"("_id") ON DELETE SET NULL ON UPDATE NO ACTION`,
|
|
105
|
+
);
|
|
106
|
+
await queryRunner.query(
|
|
107
|
+
`ALTER TABLE "IncidentGroupingRuleMonitor" ADD CONSTRAINT "FK_306e6908e7e2ad0dd71be881bae" FOREIGN KEY ("incidentGroupingRuleId") REFERENCES "IncidentGroupingRule"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
|
|
108
|
+
);
|
|
109
|
+
await queryRunner.query(
|
|
110
|
+
`ALTER TABLE "IncidentGroupingRuleMonitor" ADD CONSTRAINT "FK_d285e375f967fc59fa9b96d7bd5" FOREIGN KEY ("monitorId") REFERENCES "Monitor"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
|
|
111
|
+
);
|
|
112
|
+
await queryRunner.query(
|
|
113
|
+
`ALTER TABLE "IncidentGroupingRuleIncidentSeverity" ADD CONSTRAINT "FK_a739768a8dac3516afe08743c08" FOREIGN KEY ("incidentGroupingRuleId") REFERENCES "IncidentGroupingRule"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
|
|
114
|
+
);
|
|
115
|
+
await queryRunner.query(
|
|
116
|
+
`ALTER TABLE "IncidentGroupingRuleIncidentSeverity" ADD CONSTRAINT "FK_3b4f50b01923d34ce7dd1d12dbc" FOREIGN KEY ("incidentSeverityId") REFERENCES "IncidentSeverity"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
|
|
117
|
+
);
|
|
118
|
+
await queryRunner.query(
|
|
119
|
+
`ALTER TABLE "IncidentGroupingRuleIncidentLabel" ADD CONSTRAINT "FK_723a687aa549c95a0df19d8da83" FOREIGN KEY ("incidentGroupingRuleId") REFERENCES "IncidentGroupingRule"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
|
|
120
|
+
);
|
|
121
|
+
await queryRunner.query(
|
|
122
|
+
`ALTER TABLE "IncidentGroupingRuleIncidentLabel" ADD CONSTRAINT "FK_930efbf2a450f944d33cb83f8c5" FOREIGN KEY ("labelId") REFERENCES "Label"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
|
|
123
|
+
);
|
|
124
|
+
await queryRunner.query(
|
|
125
|
+
`ALTER TABLE "IncidentGroupingRuleMonitorLabel" ADD CONSTRAINT "FK_77880aadd07a2ca077b648b40dc" FOREIGN KEY ("incidentGroupingRuleId") REFERENCES "IncidentGroupingRule"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
|
|
126
|
+
);
|
|
127
|
+
await queryRunner.query(
|
|
128
|
+
`ALTER TABLE "IncidentGroupingRuleMonitorLabel" ADD CONSTRAINT "FK_97830e8e0a8164acf30e88fee0e" FOREIGN KEY ("labelId") REFERENCES "Label"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
|
|
129
|
+
);
|
|
130
|
+
await queryRunner.query(
|
|
131
|
+
`ALTER TABLE "IncidentGroupingRuleOnCallDutyPolicy" ADD CONSTRAINT "FK_f2de7b843c3513ba7551dc12195" FOREIGN KEY ("incidentGroupingRuleId") REFERENCES "IncidentGroupingRule"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
|
|
132
|
+
);
|
|
133
|
+
await queryRunner.query(
|
|
134
|
+
`ALTER TABLE "IncidentGroupingRuleOnCallDutyPolicy" ADD CONSTRAINT "FK_3a98852815612d72d638624735b" FOREIGN KEY ("onCallDutyPolicyId") REFERENCES "OnCallDutyPolicy"("_id") ON DELETE CASCADE ON UPDATE CASCADE`,
|
|
135
|
+
);
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
public async down(queryRunner: QueryRunner): Promise<void> {
|
|
139
|
+
await queryRunner.query(
|
|
140
|
+
`ALTER TABLE "IncidentGroupingRuleOnCallDutyPolicy" DROP CONSTRAINT "FK_3a98852815612d72d638624735b"`,
|
|
141
|
+
);
|
|
142
|
+
await queryRunner.query(
|
|
143
|
+
`ALTER TABLE "IncidentGroupingRuleOnCallDutyPolicy" DROP CONSTRAINT "FK_f2de7b843c3513ba7551dc12195"`,
|
|
144
|
+
);
|
|
145
|
+
await queryRunner.query(
|
|
146
|
+
`ALTER TABLE "IncidentGroupingRuleMonitorLabel" DROP CONSTRAINT "FK_97830e8e0a8164acf30e88fee0e"`,
|
|
147
|
+
);
|
|
148
|
+
await queryRunner.query(
|
|
149
|
+
`ALTER TABLE "IncidentGroupingRuleMonitorLabel" DROP CONSTRAINT "FK_77880aadd07a2ca077b648b40dc"`,
|
|
150
|
+
);
|
|
151
|
+
await queryRunner.query(
|
|
152
|
+
`ALTER TABLE "IncidentGroupingRuleIncidentLabel" DROP CONSTRAINT "FK_930efbf2a450f944d33cb83f8c5"`,
|
|
153
|
+
);
|
|
154
|
+
await queryRunner.query(
|
|
155
|
+
`ALTER TABLE "IncidentGroupingRuleIncidentLabel" DROP CONSTRAINT "FK_723a687aa549c95a0df19d8da83"`,
|
|
156
|
+
);
|
|
157
|
+
await queryRunner.query(
|
|
158
|
+
`ALTER TABLE "IncidentGroupingRuleIncidentSeverity" DROP CONSTRAINT "FK_3b4f50b01923d34ce7dd1d12dbc"`,
|
|
159
|
+
);
|
|
160
|
+
await queryRunner.query(
|
|
161
|
+
`ALTER TABLE "IncidentGroupingRuleIncidentSeverity" DROP CONSTRAINT "FK_a739768a8dac3516afe08743c08"`,
|
|
162
|
+
);
|
|
163
|
+
await queryRunner.query(
|
|
164
|
+
`ALTER TABLE "IncidentGroupingRuleMonitor" DROP CONSTRAINT "FK_d285e375f967fc59fa9b96d7bd5"`,
|
|
165
|
+
);
|
|
166
|
+
await queryRunner.query(
|
|
167
|
+
`ALTER TABLE "IncidentGroupingRuleMonitor" DROP CONSTRAINT "FK_306e6908e7e2ad0dd71be881bae"`,
|
|
168
|
+
);
|
|
169
|
+
await queryRunner.query(
|
|
170
|
+
`ALTER TABLE "IncidentEpisodeMember" DROP CONSTRAINT "FK_b8e5a102d8effb7d56ee952df93"`,
|
|
171
|
+
);
|
|
172
|
+
await queryRunner.query(
|
|
173
|
+
`ALTER TABLE "IncidentEpisode" DROP CONSTRAINT "FK_b74f982a546755197371a7b565e"`,
|
|
174
|
+
);
|
|
175
|
+
await queryRunner.query(
|
|
176
|
+
`ALTER TABLE "IncidentGroupingRule" DROP CONSTRAINT "FK_7a0da098649113cb8251f48c0b5"`,
|
|
177
|
+
);
|
|
178
|
+
await queryRunner.query(
|
|
179
|
+
`ALTER TABLE "IncidentGroupingRule" DROP CONSTRAINT "FK_6ec3a9100f6af789dc869b18220"`,
|
|
180
|
+
);
|
|
181
|
+
await queryRunner.query(
|
|
182
|
+
`ALTER TABLE "IncidentGroupingRule" DROP CONSTRAINT "FK_fe5bdf8166514940897662bcbd3"`,
|
|
183
|
+
);
|
|
184
|
+
await queryRunner.query(
|
|
185
|
+
`ALTER TABLE "IncidentGroupingRule" DROP CONSTRAINT "FK_aac63b94b4af39a7160adaad2f1"`,
|
|
186
|
+
);
|
|
187
|
+
await queryRunner.query(
|
|
188
|
+
`ALTER TABLE "IncidentGroupingRule" DROP CONSTRAINT "FK_b3b80cf4883fbd326b9bbd3a750"`,
|
|
189
|
+
);
|
|
190
|
+
await queryRunner.query(
|
|
191
|
+
`DROP INDEX "public"."IDX_b74f982a546755197371a7b565"`,
|
|
192
|
+
);
|
|
193
|
+
await queryRunner.query(
|
|
194
|
+
`ALTER TABLE "OnCallDutyPolicyScheduleLayer" ALTER COLUMN "restrictionTimes" SET DEFAULT '{"_type": "RestrictionTimes", "value": {"restictionType": "None", "dayRestrictionTimes": null, "weeklyRestrictionTimes": []}}'`,
|
|
195
|
+
);
|
|
196
|
+
await queryRunner.query(
|
|
197
|
+
`ALTER TABLE "OnCallDutyPolicyScheduleLayer" ALTER COLUMN "rotation" SET DEFAULT '{"_type": "Recurring", "value": {"intervalType": "Day", "intervalCount": {"_type": "PositiveNumber", "value": 1}}}'`,
|
|
198
|
+
);
|
|
199
|
+
await queryRunner.query(
|
|
200
|
+
`ALTER TABLE "IncidentEpisode" DROP COLUMN "incidentGroupingRuleId"`,
|
|
201
|
+
);
|
|
202
|
+
await queryRunner.query(
|
|
203
|
+
`DROP INDEX "public"."IDX_3a98852815612d72d638624735"`,
|
|
204
|
+
);
|
|
205
|
+
await queryRunner.query(
|
|
206
|
+
`DROP INDEX "public"."IDX_f2de7b843c3513ba7551dc1219"`,
|
|
207
|
+
);
|
|
208
|
+
await queryRunner.query(
|
|
209
|
+
`DROP TABLE "IncidentGroupingRuleOnCallDutyPolicy"`,
|
|
210
|
+
);
|
|
211
|
+
await queryRunner.query(
|
|
212
|
+
`DROP INDEX "public"."IDX_97830e8e0a8164acf30e88fee0"`,
|
|
213
|
+
);
|
|
214
|
+
await queryRunner.query(
|
|
215
|
+
`DROP INDEX "public"."IDX_77880aadd07a2ca077b648b40d"`,
|
|
216
|
+
);
|
|
217
|
+
await queryRunner.query(`DROP TABLE "IncidentGroupingRuleMonitorLabel"`);
|
|
218
|
+
await queryRunner.query(
|
|
219
|
+
`DROP INDEX "public"."IDX_930efbf2a450f944d33cb83f8c"`,
|
|
220
|
+
);
|
|
221
|
+
await queryRunner.query(
|
|
222
|
+
`DROP INDEX "public"."IDX_723a687aa549c95a0df19d8da8"`,
|
|
223
|
+
);
|
|
224
|
+
await queryRunner.query(`DROP TABLE "IncidentGroupingRuleIncidentLabel"`);
|
|
225
|
+
await queryRunner.query(
|
|
226
|
+
`DROP INDEX "public"."IDX_3b4f50b01923d34ce7dd1d12db"`,
|
|
227
|
+
);
|
|
228
|
+
await queryRunner.query(
|
|
229
|
+
`DROP INDEX "public"."IDX_a739768a8dac3516afe08743c0"`,
|
|
230
|
+
);
|
|
231
|
+
await queryRunner.query(
|
|
232
|
+
`DROP TABLE "IncidentGroupingRuleIncidentSeverity"`,
|
|
233
|
+
);
|
|
234
|
+
await queryRunner.query(
|
|
235
|
+
`DROP INDEX "public"."IDX_d285e375f967fc59fa9b96d7bd"`,
|
|
236
|
+
);
|
|
237
|
+
await queryRunner.query(
|
|
238
|
+
`DROP INDEX "public"."IDX_306e6908e7e2ad0dd71be881ba"`,
|
|
239
|
+
);
|
|
240
|
+
await queryRunner.query(`DROP TABLE "IncidentGroupingRuleMonitor"`);
|
|
241
|
+
await queryRunner.query(
|
|
242
|
+
`DROP INDEX "public"."IDX_fe5bdf8166514940897662bcbd"`,
|
|
243
|
+
);
|
|
244
|
+
await queryRunner.query(
|
|
245
|
+
`DROP INDEX "public"."IDX_aac63b94b4af39a7160adaad2f"`,
|
|
246
|
+
);
|
|
247
|
+
await queryRunner.query(
|
|
248
|
+
`DROP INDEX "public"."IDX_5dc2e7fd35a5fe8b7bcfd5a21d"`,
|
|
249
|
+
);
|
|
250
|
+
await queryRunner.query(
|
|
251
|
+
`DROP INDEX "public"."IDX_672943fcdc88c0bff4668cebb4"`,
|
|
252
|
+
);
|
|
253
|
+
await queryRunner.query(
|
|
254
|
+
`DROP INDEX "public"."IDX_505e5c53bda97f6f31701d27af"`,
|
|
255
|
+
);
|
|
256
|
+
await queryRunner.query(
|
|
257
|
+
`DROP INDEX "public"."IDX_b3b80cf4883fbd326b9bbd3a75"`,
|
|
258
|
+
);
|
|
259
|
+
await queryRunner.query(`DROP TABLE "IncidentGroupingRule"`);
|
|
260
|
+
}
|
|
261
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { MigrationInterface, QueryRunner } from "typeorm";
|
|
2
|
+
|
|
3
|
+
export class RenameEvaluateOverTimeInCriteriaFilter1769676117342
|
|
4
|
+
implements MigrationInterface
|
|
5
|
+
{
|
|
6
|
+
public name = "RenameEvaluateOverTimeInCriteriaFilter1769676117342";
|
|
7
|
+
|
|
8
|
+
public async up(queryRunner: QueryRunner): Promise<void> {
|
|
9
|
+
/*
|
|
10
|
+
* Update the monitorSteps JSONB column in Monitor table
|
|
11
|
+
* Replace all occurrences of "eveluateOverTime" with "evaluateOverTime"
|
|
12
|
+
*/
|
|
13
|
+
await queryRunner.query(`
|
|
14
|
+
UPDATE "Monitor"
|
|
15
|
+
SET "monitorSteps" = REPLACE("monitorSteps"::text, '"eveluateOverTime"', '"evaluateOverTime"')::jsonb
|
|
16
|
+
WHERE "monitorSteps"::text LIKE '%eveluateOverTime%'
|
|
17
|
+
`);
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
public async down(queryRunner: QueryRunner): Promise<void> {
|
|
21
|
+
// Rollback: rename evaluateOverTime back to eveluateOverTime
|
|
22
|
+
await queryRunner.query(`
|
|
23
|
+
UPDATE "Monitor"
|
|
24
|
+
SET "monitorSteps" = REPLACE("monitorSteps"::text, '"evaluateOverTime"', '"eveluateOverTime"')::jsonb
|
|
25
|
+
WHERE "monitorSteps"::text LIKE '%evaluateOverTime%'
|
|
26
|
+
`);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
@@ -237,6 +237,9 @@ import { MigrationName1769428821686 } from "./1769428821686-MigrationName";
|
|
|
237
237
|
import { MigrationName1769469813786 } from "./1769469813786-MigrationName";
|
|
238
238
|
import { RenameNotificationRuleTypes1769517677937 } from "./1769517677937-RenameNotificationRuleTypes";
|
|
239
239
|
import { MigrationName1769599843642 } from "./1769599843642-MigrationName";
|
|
240
|
+
import { MigrationName1769626069479 } from "./1769626069479-MigrationName";
|
|
241
|
+
import { MigrationName1769629928240 } from "./1769629928240-MigrationName";
|
|
242
|
+
import { RenameEvaluateOverTimeInCriteriaFilter1769676117342 } from "./1769676117342-RenameEvaluateOverTimeInCriteriaFilter";
|
|
240
243
|
|
|
241
244
|
export default [
|
|
242
245
|
InitialMigration,
|
|
@@ -478,4 +481,7 @@ export default [
|
|
|
478
481
|
MigrationName1769469813786,
|
|
479
482
|
RenameNotificationRuleTypes1769517677937,
|
|
480
483
|
MigrationName1769599843642,
|
|
484
|
+
MigrationName1769626069479,
|
|
485
|
+
MigrationName1769629928240,
|
|
486
|
+
RenameEvaluateOverTimeInCriteriaFilter1769676117342,
|
|
481
487
|
];
|
|
@@ -10,6 +10,7 @@ import Errors from "../Utils/Errors";
|
|
|
10
10
|
import logger from "../Utils/Logger";
|
|
11
11
|
import BaseService from "./BaseService";
|
|
12
12
|
import MailService from "./MailService";
|
|
13
|
+
import ProjectService from "./ProjectService";
|
|
13
14
|
import SubscriptionPlan from "../../Types/Billing/SubscriptionPlan";
|
|
14
15
|
import SubscriptionStatus, {
|
|
15
16
|
SubscriptionStatusUtil,
|
|
@@ -1327,9 +1328,6 @@ export class BillingService extends BaseService {
|
|
|
1327
1328
|
`[Invoice Email] Customer ${customerId} has invoice emails enabled, looking up project`,
|
|
1328
1329
|
);
|
|
1329
1330
|
|
|
1330
|
-
// Lazy import to avoid circular dependency
|
|
1331
|
-
const { default: ProjectService } = await import("./ProjectService");
|
|
1332
|
-
|
|
1333
1331
|
// Find the project by Stripe customer ID
|
|
1334
1332
|
const project: Project | null = await ProjectService.findOneBy({
|
|
1335
1333
|
query: {
|
|
@@ -29,6 +29,7 @@ export class CallService extends BaseService {
|
|
|
29
29
|
incidentId?: ObjectID | undefined;
|
|
30
30
|
alertId?: ObjectID | undefined;
|
|
31
31
|
alertEpisodeId?: ObjectID | undefined;
|
|
32
|
+
incidentEpisodeId?: ObjectID | undefined;
|
|
32
33
|
scheduledMaintenanceId?: ObjectID | undefined;
|
|
33
34
|
statusPageId?: ObjectID | undefined;
|
|
34
35
|
statusPageAnnouncementId?: ObjectID | undefined;
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { Blue500 } from "../../Types/BrandColors";
|
|
2
|
+
import Color from "../../Types/Color";
|
|
3
|
+
import OneUptimeDate from "../../Types/Date";
|
|
4
|
+
import BadDataException from "../../Types/Exception/BadDataException";
|
|
5
|
+
import ObjectID from "../../Types/ObjectID";
|
|
6
|
+
import { IsBillingEnabled } from "../EnvironmentConfig";
|
|
7
|
+
import logger from "../Utils/Logger";
|
|
8
|
+
import DatabaseService from "./DatabaseService";
|
|
9
|
+
import Model, {
|
|
10
|
+
IncidentEpisodeFeedEventType,
|
|
11
|
+
} from "../../Models/DatabaseModels/IncidentEpisodeFeed";
|
|
12
|
+
import CaptureSpan from "../Utils/Telemetry/CaptureSpan";
|
|
13
|
+
|
|
14
|
+
export class Service extends DatabaseService<Model> {
|
|
15
|
+
public constructor() {
|
|
16
|
+
super(Model);
|
|
17
|
+
|
|
18
|
+
if (IsBillingEnabled) {
|
|
19
|
+
this.hardDeleteItemsOlderThanInDays("createdAt", 3 * 365); // 3 years
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
@CaptureSpan()
|
|
24
|
+
public async createIncidentEpisodeFeedItem(data: {
|
|
25
|
+
incidentEpisodeId: ObjectID;
|
|
26
|
+
feedInfoInMarkdown: string;
|
|
27
|
+
incidentEpisodeFeedEventType: IncidentEpisodeFeedEventType;
|
|
28
|
+
projectId: ObjectID;
|
|
29
|
+
moreInformationInMarkdown?: string | undefined;
|
|
30
|
+
displayColor?: Color | undefined;
|
|
31
|
+
userId?: ObjectID | undefined;
|
|
32
|
+
postedAt?: Date | undefined;
|
|
33
|
+
}): Promise<void> {
|
|
34
|
+
try {
|
|
35
|
+
if (!data.incidentEpisodeId) {
|
|
36
|
+
throw new BadDataException("Incident Episode ID is required");
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
if (!data.feedInfoInMarkdown) {
|
|
40
|
+
throw new BadDataException("Log in markdown is required");
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
if (!data.incidentEpisodeFeedEventType) {
|
|
44
|
+
throw new BadDataException("Incident episode log event is required");
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
if (!data.projectId) {
|
|
48
|
+
throw new BadDataException("Project ID is required");
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
const incidentEpisodeFeed: Model = new Model();
|
|
52
|
+
|
|
53
|
+
if (!data.displayColor) {
|
|
54
|
+
data.displayColor = Blue500;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
if (data.userId) {
|
|
58
|
+
incidentEpisodeFeed.userId = data.userId;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
incidentEpisodeFeed.displayColor = data.displayColor;
|
|
62
|
+
|
|
63
|
+
incidentEpisodeFeed.incidentEpisodeId = data.incidentEpisodeId;
|
|
64
|
+
incidentEpisodeFeed.feedInfoInMarkdown = data.feedInfoInMarkdown;
|
|
65
|
+
incidentEpisodeFeed.incidentEpisodeFeedEventType =
|
|
66
|
+
data.incidentEpisodeFeedEventType;
|
|
67
|
+
incidentEpisodeFeed.projectId = data.projectId;
|
|
68
|
+
|
|
69
|
+
if (!data.postedAt) {
|
|
70
|
+
incidentEpisodeFeed.postedAt = OneUptimeDate.getCurrentDate();
|
|
71
|
+
} else {
|
|
72
|
+
incidentEpisodeFeed.postedAt = data.postedAt;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
if (data.moreInformationInMarkdown) {
|
|
76
|
+
incidentEpisodeFeed.moreInformationInMarkdown =
|
|
77
|
+
data.moreInformationInMarkdown;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
await this.create({
|
|
81
|
+
data: incidentEpisodeFeed,
|
|
82
|
+
props: {
|
|
83
|
+
isRoot: true,
|
|
84
|
+
},
|
|
85
|
+
});
|
|
86
|
+
} catch (error) {
|
|
87
|
+
logger.error("IncidentEpisodeFeedService.createIncidentEpisodeFeedItem");
|
|
88
|
+
logger.error(error);
|
|
89
|
+
// we dont want to throw the error here, as this is a non-critical operation
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
export default new Service();
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import ObjectID from "../../Types/ObjectID";
|
|
2
|
+
import DatabaseService from "./DatabaseService";
|
|
3
|
+
import Model from "../../Models/DatabaseModels/IncidentEpisodeInternalNote";
|
|
4
|
+
import CaptureSpan from "../Utils/Telemetry/CaptureSpan";
|
|
5
|
+
import File from "../../Models/DatabaseModels/File";
|
|
6
|
+
|
|
7
|
+
export class Service extends DatabaseService<Model> {
|
|
8
|
+
public constructor() {
|
|
9
|
+
super(Model);
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
@CaptureSpan()
|
|
13
|
+
public async addNote(data: {
|
|
14
|
+
userId: ObjectID;
|
|
15
|
+
incidentEpisodeId: ObjectID;
|
|
16
|
+
projectId: ObjectID;
|
|
17
|
+
note: string;
|
|
18
|
+
attachmentFileIds?: Array<ObjectID>;
|
|
19
|
+
postedFromSlackMessageId?: string;
|
|
20
|
+
}): Promise<Model> {
|
|
21
|
+
const internalNote: Model = new Model();
|
|
22
|
+
internalNote.createdByUserId = data.userId;
|
|
23
|
+
internalNote.incidentEpisodeId = data.incidentEpisodeId;
|
|
24
|
+
internalNote.projectId = data.projectId;
|
|
25
|
+
internalNote.note = data.note;
|
|
26
|
+
|
|
27
|
+
if (data.postedFromSlackMessageId) {
|
|
28
|
+
internalNote.postedFromSlackMessageId = data.postedFromSlackMessageId;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
if (data.attachmentFileIds && data.attachmentFileIds.length > 0) {
|
|
32
|
+
internalNote.attachments = data.attachmentFileIds.map(
|
|
33
|
+
(fileId: ObjectID) => {
|
|
34
|
+
const file: File = new File();
|
|
35
|
+
file.id = fileId;
|
|
36
|
+
return file;
|
|
37
|
+
},
|
|
38
|
+
);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
return this.create({
|
|
42
|
+
data: internalNote,
|
|
43
|
+
props: {
|
|
44
|
+
isRoot: true,
|
|
45
|
+
},
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
@CaptureSpan()
|
|
50
|
+
public async hasNoteFromSlackMessage(data: {
|
|
51
|
+
incidentEpisodeId: ObjectID;
|
|
52
|
+
postedFromSlackMessageId: string;
|
|
53
|
+
}): Promise<boolean> {
|
|
54
|
+
const existingNote: Model | null = await this.findOneBy({
|
|
55
|
+
query: {
|
|
56
|
+
incidentEpisodeId: data.incidentEpisodeId,
|
|
57
|
+
postedFromSlackMessageId: data.postedFromSlackMessageId,
|
|
58
|
+
},
|
|
59
|
+
select: {
|
|
60
|
+
_id: true,
|
|
61
|
+
},
|
|
62
|
+
props: {
|
|
63
|
+
isRoot: true,
|
|
64
|
+
},
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
return existingNote !== null;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
export default new Service();
|