mirror of
https://github.com/zulip/zulip-desktop.git
synced 2025-10-24 00:23:36 +00:00
All of our loggers have timestamp: true. Signed-off-by: Anders Kaseorg <anders@zulip.com>
60 lines
1.3 KiB
TypeScript
60 lines
1.3 KiB
TypeScript
import {app, dialog} from "electron";
|
|
import fs from "fs";
|
|
import path from "path";
|
|
|
|
import {JsonDB} from "node-json-db";
|
|
|
|
import Logger from "../common/logger-util";
|
|
|
|
const logger = new Logger({
|
|
file: "linux-update-util.log",
|
|
});
|
|
|
|
let db: JsonDB;
|
|
|
|
reloadDB();
|
|
|
|
export function getUpdateItem(key: string, defaultValue: unknown = null): any {
|
|
reloadDB();
|
|
const value = db.getData("/")[key];
|
|
if (value === undefined) {
|
|
setUpdateItem(key, defaultValue);
|
|
return defaultValue;
|
|
}
|
|
|
|
return value;
|
|
}
|
|
|
|
export function setUpdateItem(key: string, value: unknown): void {
|
|
db.push(`/${key}`, value, true);
|
|
reloadDB();
|
|
}
|
|
|
|
export function removeUpdateItem(key: string): void {
|
|
db.delete(`/${key}`);
|
|
reloadDB();
|
|
}
|
|
|
|
function reloadDB(): void {
|
|
const linuxUpdateJsonPath = path.join(
|
|
app.getPath("userData"),
|
|
"/config/updates.json",
|
|
);
|
|
try {
|
|
const file = fs.readFileSync(linuxUpdateJsonPath, "utf8");
|
|
JSON.parse(file);
|
|
} catch (error: unknown) {
|
|
if (fs.existsSync(linuxUpdateJsonPath)) {
|
|
fs.unlinkSync(linuxUpdateJsonPath);
|
|
dialog.showErrorBox(
|
|
"Error saving update notifications.",
|
|
"We encountered an error while saving the update notifications.",
|
|
);
|
|
logger.error("Error while JSON parsing updates.json: ");
|
|
logger.error(error);
|
|
}
|
|
}
|
|
|
|
db = new JsonDB(linuxUpdateJsonPath, true, true);
|
|
}
|