mirror of
https://github.com/OneUptime/oneuptime.git
synced 2026-04-06 00:32:12 +02:00
183 lines
6.1 KiB
TypeScript
183 lines
6.1 KiB
TypeScript
import ObjectID from "../../Types/ObjectID";
|
|
import DatabaseService from "./DatabaseService";
|
|
import Model from "../../Models/DatabaseModels/IncidentOwnerUser";
|
|
import IncidentFeedService from "./IncidentFeedService";
|
|
import { IncidentFeedEventType } from "../../Models/DatabaseModels/IncidentFeed";
|
|
import { Gray500, Red500 } from "../../Types/BrandColors";
|
|
import User from "../../Models/DatabaseModels/User";
|
|
import UserService from "./UserService";
|
|
import { OnCreate, OnDelete } from "../Types/Database/Hooks";
|
|
import DeleteBy from "../Types/Database/DeleteBy";
|
|
import IncidentService from "./IncidentService";
|
|
import WorkspaceNotificationRuleService from "./WorkspaceNotificationRuleService";
|
|
import NotificationRuleEventType from "../../Types/Workspace/NotificationRules/EventType";
|
|
import WorkspaceNotificationRule from "../../Models/DatabaseModels/WorkspaceNotificationRule";
|
|
import logger from "../Utils/Logger";
|
|
import CaptureSpan from "../Utils/Telemetry/CaptureSpan";
|
|
|
|
export class Service extends DatabaseService<Model> {
|
|
public constructor() {
|
|
super(Model);
|
|
}
|
|
|
|
@CaptureSpan()
|
|
protected override async onBeforeDelete(
|
|
deleteBy: DeleteBy<Model>,
|
|
): Promise<OnDelete<Model>> {
|
|
const itemsToDelete: Model[] = await this.findBy({
|
|
query: deleteBy.query,
|
|
limit: deleteBy.limit,
|
|
skip: deleteBy.skip,
|
|
props: {
|
|
isRoot: true,
|
|
},
|
|
select: {
|
|
incidentId: true,
|
|
projectId: true,
|
|
userId: true,
|
|
},
|
|
});
|
|
|
|
return {
|
|
carryForward: {
|
|
itemsToDelete: itemsToDelete,
|
|
},
|
|
deleteBy: deleteBy,
|
|
};
|
|
}
|
|
|
|
@CaptureSpan()
|
|
protected override async onDeleteSuccess(
|
|
onDelete: OnDelete<Model>,
|
|
_itemIdsBeforeDelete: Array<ObjectID>,
|
|
): Promise<OnDelete<Model>> {
|
|
const deleteByUserId: ObjectID | undefined =
|
|
onDelete.deleteBy.deletedByUser?.id || onDelete.deleteBy.props.userId;
|
|
|
|
const itemsToDelete: Model[] = onDelete.carryForward.itemsToDelete;
|
|
|
|
for (const item of itemsToDelete) {
|
|
const incidentId: ObjectID | undefined = item.incidentId;
|
|
const projectId: ObjectID | undefined = item.projectId;
|
|
const userId: ObjectID | undefined = item.userId;
|
|
|
|
if (incidentId && userId && projectId) {
|
|
const user: User | null = await UserService.findOneById({
|
|
id: userId,
|
|
select: {
|
|
name: true,
|
|
email: true,
|
|
},
|
|
props: {
|
|
isRoot: true,
|
|
},
|
|
});
|
|
|
|
const incidentNumberResult: {
|
|
number: number | null;
|
|
numberWithPrefix: string | null;
|
|
} = await IncidentService.getIncidentNumber({
|
|
incidentId: incidentId,
|
|
});
|
|
const incidentNumberDisplay: string =
|
|
incidentNumberResult.numberWithPrefix ||
|
|
"#" + incidentNumberResult.number;
|
|
|
|
if (user && user.name) {
|
|
await IncidentFeedService.createIncidentFeedItem({
|
|
incidentId: incidentId,
|
|
projectId: projectId,
|
|
incidentFeedEventType: IncidentFeedEventType.OwnerUserRemoved,
|
|
displayColor: Red500,
|
|
feedInfoInMarkdown: `👨🏻💻 Removed **${user.name.toString()}** (${user.email?.toString()}) from the [Incident ${incidentNumberDisplay}](${(await IncidentService.getIncidentLinkInDashboard(projectId!, incidentId!)).toString()}) as the owner.`,
|
|
userId: deleteByUserId || undefined,
|
|
workspaceNotification: {
|
|
sendWorkspaceNotification: true,
|
|
notifyUserId: userId || undefined,
|
|
},
|
|
});
|
|
}
|
|
}
|
|
}
|
|
|
|
return onDelete;
|
|
}
|
|
|
|
@CaptureSpan()
|
|
public override async onCreateSuccess(
|
|
onCreate: OnCreate<Model>,
|
|
createdItem: Model,
|
|
): Promise<Model> {
|
|
// add incident feed.
|
|
|
|
const incidentId: ObjectID | undefined = createdItem.incidentId;
|
|
const projectId: ObjectID | undefined = createdItem.projectId;
|
|
const userId: ObjectID | undefined = createdItem.userId;
|
|
const createdByUserId: ObjectID | undefined =
|
|
createdItem.createdByUserId || onCreate.createBy.props.userId;
|
|
|
|
if (incidentId && userId && projectId) {
|
|
const incidentNumberResult: {
|
|
number: number | null;
|
|
numberWithPrefix: string | null;
|
|
} = await IncidentService.getIncidentNumber({
|
|
incidentId: incidentId,
|
|
});
|
|
const incidentNumberDisplay: string =
|
|
incidentNumberResult.numberWithPrefix ||
|
|
"#" + incidentNumberResult.number;
|
|
|
|
if (userId) {
|
|
await IncidentFeedService.createIncidentFeedItem({
|
|
incidentId: incidentId,
|
|
projectId: projectId,
|
|
incidentFeedEventType: IncidentFeedEventType.OwnerUserAdded,
|
|
displayColor: Gray500,
|
|
feedInfoInMarkdown: `👨🏻💻 Added **${await UserService.getUserMarkdownString(
|
|
{
|
|
userId: userId,
|
|
projectId: projectId,
|
|
},
|
|
)}** to the [Incident ${incidentNumberDisplay}](${(await IncidentService.getIncidentLinkInDashboard(projectId!, incidentId!)).toString()}) as the owner.`,
|
|
userId: createdByUserId || undefined,
|
|
workspaceNotification: {
|
|
sendWorkspaceNotification: true,
|
|
notifyUserId: userId || undefined,
|
|
},
|
|
});
|
|
}
|
|
}
|
|
|
|
// get notification rule where inviteOwners is true.
|
|
const notificationRules: Array<WorkspaceNotificationRule> =
|
|
await WorkspaceNotificationRuleService.getNotificationRulesWhereInviteOwnersIsTrue(
|
|
{
|
|
projectId: projectId!,
|
|
notificationFor: {
|
|
incidentId: incidentId,
|
|
},
|
|
notificationRuleEventType: NotificationRuleEventType.Incident,
|
|
},
|
|
);
|
|
|
|
WorkspaceNotificationRuleService.inviteUsersBasedOnRulesAndWorkspaceChannels(
|
|
{
|
|
notificationRules: notificationRules,
|
|
projectId: projectId!,
|
|
workspaceChannels: await IncidentService.getWorkspaceChannelForIncident(
|
|
{
|
|
incidentId: incidentId!,
|
|
},
|
|
),
|
|
userIds: [userId!],
|
|
},
|
|
).catch((error: Error) => {
|
|
logger.error(error);
|
|
});
|
|
|
|
return createdItem;
|
|
}
|
|
}
|
|
|
|
export default new Service();
|