2021-10-09 15:33:47 +00:00
|
|
|
const { log, exit, connectDb } = require("./util-worker");
|
2021-09-27 15:40:38 +00:00
|
|
|
const { R } = require("redbean-node");
|
2021-10-09 15:33:47 +00:00
|
|
|
const { setSetting, setting } = require("../util-server");
|
2021-09-27 15:40:38 +00:00
|
|
|
|
2021-10-12 15:28:21 +00:00
|
|
|
const DEFAULT_KEEP_PERIOD = 180;
|
2021-09-27 15:40:38 +00:00
|
|
|
|
|
|
|
(async () => {
|
2021-10-09 15:33:47 +00:00
|
|
|
await connectDb();
|
|
|
|
|
|
|
|
let period = await setting("keepDataPeriodDays");
|
|
|
|
|
|
|
|
// Set Default Period
|
|
|
|
if (period == null) {
|
2021-10-09 16:16:13 +00:00
|
|
|
await setSetting("keepDataPeriodDays", DEFAULT_KEEP_PERIOD, "general");
|
2021-10-09 15:33:47 +00:00
|
|
|
period = DEFAULT_KEEP_PERIOD;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Try parse setting
|
|
|
|
let parsedPeriod;
|
|
|
|
try {
|
|
|
|
parsedPeriod = parseInt(period);
|
|
|
|
} catch (_) {
|
|
|
|
log("Failed to parse setting, resetting to default..");
|
2021-10-09 16:16:13 +00:00
|
|
|
await setSetting("keepDataPeriodDays", DEFAULT_KEEP_PERIOD, "general");
|
2021-10-09 15:33:47 +00:00
|
|
|
parsedPeriod = DEFAULT_KEEP_PERIOD;
|
|
|
|
}
|
|
|
|
|
2023-01-08 19:09:06 +00:00
|
|
|
if (parsedPeriod < 1) {
|
|
|
|
log(`Data deletion has been disabled as period is less than 1. Period is ${parsedPeriod} days.`);
|
|
|
|
} else {
|
|
|
|
|
|
|
|
log(`Clearing Data older than ${parsedPeriod} days...`);
|
|
|
|
|
|
|
|
try {
|
|
|
|
await R.exec(
|
|
|
|
"DELETE FROM heartbeat WHERE time < DATETIME('now', '-' || ? || ' days') ",
|
|
|
|
[ parsedPeriod ]
|
|
|
|
);
|
|
|
|
} catch (e) {
|
|
|
|
log(`Failed to clear old data: ${e.message}`);
|
|
|
|
}
|
2021-10-09 15:33:47 +00:00
|
|
|
}
|
2021-09-27 15:40:38 +00:00
|
|
|
|
2021-10-09 15:33:47 +00:00
|
|
|
exit();
|
2021-09-27 15:40:38 +00:00
|
|
|
})();
|