Notes/src/services/backup.js

79 lines
2.1 KiB
JavaScript
Raw Normal View History

2017-10-21 21:10:33 -04:00
"use strict";
2018-04-02 20:46:46 -04:00
const dateUtils = require('./date_utils');
const optionService = require('./options');
const fs = require('fs-extra');
const dataDir = require('./data_dir');
2017-10-24 22:17:48 -04:00
const log = require('./log');
const syncMutexService = require('./sync_mutex');
const cls = require('./cls');
const sql = require('./sql');
const path = require('path');
function getExistingBackups() {
if (!fs.existsSync(dataDir.BACKUP_DIR)) {
return [];
}
return fs.readdirSync(dataDir.BACKUP_DIR)
.filter(fileName => fileName.includes("backup"))
.map(fileName => ({
fileName: fileName,
filePath: path.resolve(dataDir.BACKUP_DIR, fileName)
}));
}
2020-06-20 12:31:38 +02:00
function regularBackup() {
2020-07-04 00:20:23 +02:00
cls.init(() => {
periodBackup('lastDailyBackupDate', 'daily', 24 * 3600);
2020-07-04 00:20:23 +02:00
periodBackup('lastWeeklyBackupDate', 'weekly', 7 * 24 * 3600);
2020-07-04 00:20:23 +02:00
periodBackup('lastMonthlyBackupDate', 'monthly', 30 * 24 * 3600);
});
}
2021-10-11 22:30:23 +02:00
function isBackupEnabled(backupType) {
const optionName = `${backupType}BackupEnabled`;
return optionService.getOptionBool(optionName);
}
function periodBackup(optionName, backupType, periodInSeconds) {
if (!isBackupEnabled(backupType)) {
return;
}
const now = new Date();
2021-10-11 22:30:23 +02:00
const lastBackupDate = dateUtils.parseDateTime(optionService.getOption(optionName));
2021-10-11 22:30:23 +02:00
if (now.getTime() - lastBackupDate.getTime() > periodInSeconds * 1000) {
backupNow(backupType);
2020-06-20 12:31:38 +02:00
optionService.setOption(optionName, dateUtils.utcNowDateTime());
}
}
2020-06-02 23:13:55 +02:00
async function backupNow(name) {
// we don't want to back up DB in the middle of sync with potentially inconsistent DB state
return await syncMutexService.doExclusively(async () => {
const backupFile = `${dataDir.BACKUP_DIR}/backup-${name}.db`;
2017-10-24 22:17:48 -04:00
await sql.copyDatabase(backupFile);
log.info(`Created backup at ${backupFile}`);
return backupFile;
});
}
if (!fs.existsSync(dataDir.BACKUP_DIR)) {
fs.mkdirSync(dataDir.BACKUP_DIR, 0o700);
}
module.exports = {
getExistingBackups,
2020-06-02 23:13:55 +02:00
backupNow,
2020-07-02 22:57:17 +02:00
regularBackup
};