mirror of
https://github.com/outline/outline.git
synced 2025-12-30 23:40:46 -06:00
* Refactor worker, all emails on task system * fix * lint * fix: Remove a bunch of expect-error comments in related tests * refactor: Move work from utils.gc into tasks * test * Add tracing to tasks and processors fix: DebounceProcessor triggering on all events Event.add -> Event.schedule
41 lines
1.1 KiB
TypeScript
41 lines
1.1 KiB
TypeScript
import { subDays } from "date-fns";
|
|
import { Op } from "sequelize";
|
|
import Logger from "@server/logging/logger";
|
|
import { APM } from "@server/logging/tracing";
|
|
import { FileOperation } from "@server/models";
|
|
import BaseTask, { TaskPriority } from "./BaseTask";
|
|
|
|
type Props = {
|
|
limit: number;
|
|
};
|
|
|
|
@APM.trace()
|
|
export default class CleanupExpiredFileOperationsTask extends BaseTask<Props> {
|
|
public async perform({ limit }: Props) {
|
|
Logger.info("task", `Expiring export file operations older than 30 days…`);
|
|
const fileOperations = await FileOperation.unscoped().findAll({
|
|
where: {
|
|
type: "export",
|
|
createdAt: {
|
|
[Op.lt]: subDays(new Date(), 30),
|
|
},
|
|
state: {
|
|
[Op.ne]: "expired",
|
|
},
|
|
},
|
|
limit,
|
|
});
|
|
await Promise.all(
|
|
fileOperations.map((fileOperation) => fileOperation.expire())
|
|
);
|
|
Logger.info("task", `Expired ${fileOperations.length} file operations`);
|
|
}
|
|
|
|
public get options() {
|
|
return {
|
|
attempts: 1,
|
|
priority: TaskPriority.Background,
|
|
};
|
|
}
|
|
}
|