From 67b1974718c287f01254c01b814ae99ba32c7cf0 Mon Sep 17 00:00:00 2001 From: Louis Lam Date: Thu, 3 Aug 2023 20:54:11 +0800 Subject: [PATCH] Allow specifying `DATA_DIR` without a tailing slash --- server/database.js | 7 ++++--- server/uptime-kuma-server.js | 3 ++- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/server/database.js b/server/database.js index 7deea83d..42d64279 100644 --- a/server/database.js +++ b/server/database.js @@ -3,6 +3,7 @@ const { R } = require("redbean-node"); const { setSetting, setting } = require("./util-server"); const { log, sleep } = require("../src/util"); const knex = require("knex"); +const path = require("path"); /** * Database & App Data Folder @@ -94,19 +95,19 @@ class Database { // Data Directory (must be end with "/") Database.dataDir = process.env.DATA_DIR || args["data-dir"] || "./data/"; - Database.path = Database.dataDir + "kuma.db"; + Database.path = path.join(Database.dataDir, "kuma.db"); if (! fs.existsSync(Database.dataDir)) { fs.mkdirSync(Database.dataDir, { recursive: true }); } - Database.uploadDir = Database.dataDir + "upload/"; + Database.uploadDir = path.join(Database.dataDir, "upload/"); if (! fs.existsSync(Database.uploadDir)) { fs.mkdirSync(Database.uploadDir, { recursive: true }); } // Create screenshot dir - Database.screenshotDir = Database.dataDir + "screenshots/"; + Database.screenshotDir = path.join(Database.dataDir, "screenshots/"); if (! fs.existsSync(Database.screenshotDir)) { fs.mkdirSync(Database.screenshotDir, { recursive: true }); } diff --git a/server/uptime-kuma-server.js b/server/uptime-kuma-server.js index 6781488e..7817c9e1 100644 --- a/server/uptime-kuma-server.js +++ b/server/uptime-kuma-server.js @@ -11,6 +11,7 @@ const { CacheableDnsHttpAgent } = require("./cacheable-dns-http-agent"); const { Settings } = require("./settings"); const dayjs = require("dayjs"); const childProcess = require("child_process"); +const path = require("path"); // DO NOT IMPORT HERE IF THE MODULES USED `UptimeKumaServer.getInstance()`, put at the bottom of this file instead. /** @@ -214,7 +215,7 @@ class UptimeKumaServer { * @param {boolean} outputToConsole Should the error also be output to console? */ static errorLog(error, outputToConsole = true) { - const errorLogStream = fs.createWriteStream(Database.dataDir + "/error.log", { + const errorLogStream = fs.createWriteStream(path.join(Database.dataDir, "/error.log"), { flags: "a" });