2021-06-19 14:47:10 +02:00
|
|
|
/**
|
|
|
|
* This file exports a function, used by the write config endpoint.
|
|
|
|
* It will make a backup of the users conf.yml file
|
|
|
|
* and then write their new config into the main conf.yml file.
|
|
|
|
* Finally, it will call a function with the status message
|
|
|
|
*/
|
|
|
|
const fsPromises = require('fs').promises;
|
2023-09-22 16:27:31 +02:00
|
|
|
const path = require('path');
|
2021-06-19 14:47:10 +02:00
|
|
|
|
|
|
|
module.exports = async (newConfig, render) => {
|
2022-05-01 23:26:55 +02:00
|
|
|
/* Either returns nothing (if using default path), or strips navigational characters from path */
|
|
|
|
const makeSafeFileName = (configObj) => {
|
|
|
|
if (!configObj || !configObj.filename) return undefined;
|
|
|
|
return configObj.filename.replaceAll('/', '').replaceAll('..', '');
|
|
|
|
};
|
|
|
|
|
|
|
|
const usersFileName = makeSafeFileName(newConfig);
|
|
|
|
|
2021-06-18 19:01:42 +02:00
|
|
|
// Define constants for the config file
|
|
|
|
const settings = {
|
2024-04-10 23:59:35 +02:00
|
|
|
defaultLocation: process.env.USER_DATA_DIR || './user-data/',
|
2021-06-18 19:01:42 +02:00
|
|
|
defaultFile: 'conf.yml',
|
|
|
|
filename: 'conf',
|
|
|
|
backupDenominator: '.backup.yml',
|
|
|
|
};
|
|
|
|
|
|
|
|
// Make the full file name and path to save the backup config file
|
2024-04-08 21:36:35 +02:00
|
|
|
const backupFilePath = `${path.normalize(process.env.BACKUP_DIR || settings.defaultLocation)
|
|
|
|
}/${usersFileName || settings.filename}-`
|
2021-06-18 19:01:42 +02:00
|
|
|
+ `${Math.round(new Date() / 1000)}${settings.backupDenominator}`;
|
|
|
|
|
|
|
|
// The path where the main conf.yml should be read and saved to
|
2022-05-01 23:26:55 +02:00
|
|
|
const defaultFilePath = settings.defaultLocation + (usersFileName || settings.defaultFile);
|
2021-06-18 19:01:42 +02:00
|
|
|
|
|
|
|
// Returns a string confirming successful job
|
|
|
|
const getSuccessMessage = () => `Successfully backed up ${settings.defaultFile} to`
|
|
|
|
+ ` ${backupFilePath}, and updated the contents of ${defaultFilePath}`;
|
|
|
|
|
2021-06-19 14:47:10 +02:00
|
|
|
// Encoding options for writing to conf file
|
|
|
|
const writeFileOptions = { encoding: 'utf8' };
|
|
|
|
|
2021-06-18 19:01:42 +02:00
|
|
|
// Prepare the response returned by the API
|
|
|
|
const getRenderMessage = (success, errorMsg) => JSON.stringify({
|
|
|
|
success,
|
|
|
|
message: !success ? errorMsg : getSuccessMessage(),
|
|
|
|
});
|
|
|
|
|
2021-06-19 14:47:10 +02:00
|
|
|
// Makes a backup of the existing config file
|
2022-04-24 17:02:14 +02:00
|
|
|
await fsPromises
|
|
|
|
.copyFile(defaultFilePath, backupFilePath)
|
2024-04-08 21:36:35 +02:00
|
|
|
.catch((error) => render(getRenderMessage(false, `Unable to backup ${settings.defaultFile}: ${error}`)));
|
2021-06-19 14:47:10 +02:00
|
|
|
|
|
|
|
// Writes the new content to the conf.yml file
|
2022-04-24 17:02:14 +02:00
|
|
|
await fsPromises
|
|
|
|
.writeFile(defaultFilePath, newConfig.config.toString(), writeFileOptions)
|
2024-04-08 21:36:35 +02:00
|
|
|
.catch((error) => render(getRenderMessage(false, `Unable to write to ${settings.defaultFile}: ${error}`)));
|
2021-06-18 19:01:42 +02:00
|
|
|
|
2021-06-19 14:47:10 +02:00
|
|
|
// If successful, then render hasn't yet been called- call it
|
|
|
|
await render(getRenderMessage(true));
|
2021-06-18 19:01:42 +02:00
|
|
|
};
|