chore: continue execution if subsequent JSON.parse on config failed (#2353)
All checks were successful
Build Docker image / docker-arm64 (push) Successful in 1m3s
Build / build (push) Successful in 58s
Build Docker image / docker-amd64 (push) Successful in 1m20s

By calling JSON.parse before setting everything to undefined, we don't lose the old config in case of an error.

Reviewed-on: #2353
Co-authored-by: Sainan <63328889+Sainan@users.noreply.github.com>
Co-committed-by: Sainan <63328889+Sainan@users.noreply.github.com>
This commit is contained in:
Sainan 2025-06-29 11:54:20 -07:00 committed by Sainan
parent 8c19aec340
commit 1a2d8ab19a
2 changed files with 5 additions and 3 deletions

View File

@ -103,11 +103,13 @@ export const config: IConfig = {
};
export const loadConfig = (): void => {
const newConfig = JSON.parse(fs.readFileSync(configPath, "utf-8")) as IConfig;
// Set all values to undefined now so if the new config.json omits some fields that were previously present, it's correct in-memory.
for (const key of Object.keys(config)) {
// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access
(config as any)[key] = undefined;
}
Object.assign(config, JSON.parse(fs.readFileSync(configPath, "utf-8")));
Object.assign(config, newConfig);
};

View File

@ -14,8 +14,8 @@ chokidar.watch(configPath).on("change", () => {
try {
loadConfig();
} catch (e) {
logger.error("FATAL ERROR: Config failed to be reloaded: " + (e as Error).message);
process.exit(1);
logger.error("Config changes were not applied: " + (e as Error).message);
return;
}
validateConfig();
syncConfigWithDatabase();