mirror of
https://github.com/OneUptime/oneuptime.git
synced 2026-01-11 19:56:44 +00:00
113 lines
3.1 KiB
TypeScript
113 lines
3.1 KiB
TypeScript
import DataMigrationBase from "./DataMigrationBase";
|
|
import SortOrder from "Common/Types/BaseDatabase/SortOrder";
|
|
import LIMIT_MAX from "Common/Types/Database/LimitMax";
|
|
import MonitorService from "CommonServer/Services/MonitorService";
|
|
import MonitorStatusTimelineService from "CommonServer/Services/MonitorStatusTimelineService";
|
|
import ProjectService from "CommonServer/Services/ProjectService";
|
|
import Monitor from "Model/Models/Monitor";
|
|
import MonitorStatusTimeline from "Model/Models/MonitorStatusTimeline";
|
|
import Project from "Model/Models/Project";
|
|
|
|
export default class AddEndDateToMonitorStatusTimelineWhereEndDateIsMissing extends DataMigrationBase {
|
|
public constructor() {
|
|
super("AddEndDateToMonitorStatusTimelineWhereEndDateIsMissing");
|
|
}
|
|
|
|
public override async migrate(): Promise<void> {
|
|
// get all the users with email isVerified true.
|
|
|
|
const projects: Array<Project> = await ProjectService.findBy({
|
|
query: {},
|
|
select: {
|
|
_id: true,
|
|
},
|
|
skip: 0,
|
|
limit: LIMIT_MAX,
|
|
props: {
|
|
isRoot: true,
|
|
},
|
|
});
|
|
|
|
for (const project of projects) {
|
|
// add ended scheduled maintenance state for each of these projects.
|
|
// first fetch resolved state. Ended state order is -1 of resolved state.
|
|
|
|
const monitors: Array<Monitor> = await MonitorService.findBy({
|
|
query: {
|
|
projectId: project.id!,
|
|
},
|
|
select: {
|
|
_id: true,
|
|
},
|
|
skip: 0,
|
|
limit: LIMIT_MAX,
|
|
props: {
|
|
isRoot: true,
|
|
},
|
|
});
|
|
|
|
for (const monitor of monitors) {
|
|
let statusTimelines: Array<MonitorStatusTimeline> =
|
|
await MonitorStatusTimelineService.findBy({
|
|
query: {
|
|
monitorId: monitor.id!,
|
|
},
|
|
select: {
|
|
_id: true,
|
|
createdAt: true,
|
|
},
|
|
skip: 0,
|
|
limit: LIMIT_MAX,
|
|
props: {
|
|
isRoot: true,
|
|
},
|
|
sort: {
|
|
createdAt: SortOrder.Descending,
|
|
},
|
|
});
|
|
|
|
// reverse the status timelines
|
|
statusTimelines = statusTimelines.reverse();
|
|
|
|
for (let i: number = 0; i < statusTimelines.length; i++) {
|
|
const statusTimeline: MonitorStatusTimeline | undefined =
|
|
statusTimelines[i];
|
|
|
|
if (!statusTimeline) {
|
|
continue;
|
|
}
|
|
|
|
if (statusTimeline.endsAt) {
|
|
continue;
|
|
}
|
|
|
|
let endDate: Date | null = statusTimeline.endsAt || null;
|
|
|
|
if (
|
|
!endDate &&
|
|
statusTimelines[i + 1] &&
|
|
statusTimelines[i + 1]?.createdAt
|
|
) {
|
|
endDate = statusTimelines[i + 1]!.createdAt!;
|
|
}
|
|
|
|
if (endDate) {
|
|
await MonitorStatusTimelineService.updateOneById({
|
|
id: statusTimeline!.id!,
|
|
data: {
|
|
endsAt: endDate,
|
|
},
|
|
props: {
|
|
isRoot: true,
|
|
},
|
|
});
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public override async rollback(): Promise<void> {
|
|
return;
|
|
}
|
|
}
|