monkeytype/backend/jobs/delete-old-logs.js
2022-02-01 00:08:49 +01:00

21 lines
642 B
JavaScript

const { CronJob } = require("cron");
const { mongoDB } = require("../init/mongodb");
const Logger = require("../handlers/logger");
const CRON_SCHEDULE = "0 0 0 * * *";
const LOG_MAX_AGE_DAYS = 7;
const LOG_MAX_AGE_MILLISECONDS = LOG_MAX_AGE_DAYS * 24 * 60 * 60 * 1000;
async function deleteOldLogs() {
const data = await mongoDB()
.collection("logs")
.deleteMany({ timestamp: { $lt: Date.now() - LOG_MAX_AGE_MILLISECONDS } });
Logger.log(
"system_logs_deleted",
`${data.deletedCount} logs deleted older than ${LOG_MAX_AGE_DAYS} day(s)`,
undefined
);
}
module.exports = new CronJob(CRON_SCHEDULE, deleteOldLogs);