fix: abort startup if not connected to MongoDB server

This commit is contained in:
Sainan 2024-12-30 04:11:32 +01:00
parent e41022f176
commit d897f40c92
2 changed files with 25 additions and 37 deletions

View File

@ -7,30 +7,38 @@ import https from "https";
import fs from "node:fs"; import fs from "node:fs";
import { app } from "./app"; import { app } from "./app";
import { config, validateConfig } from "./services/configService"; import { config, validateConfig } from "./services/configService";
import { connectDatabase } from "@/src/services/mongoService";
import { registerLogFileCreationListener } from "@/src/utils/logger"; import { registerLogFileCreationListener } from "@/src/utils/logger";
import mongoose from "mongoose";
registerLogFileCreationListener(); registerLogFileCreationListener();
validateConfig(); validateConfig();
void (async (): Promise<void> => { mongoose
await connectDatabase(); .connect(config.mongodbUrl)
.then(() => {
logger.info("Connected to MongoDB");
const httpPort = config.httpPort || 80; const httpPort = config.httpPort || 80;
const httpsPort = config.httpsPort || 443; const httpsPort = config.httpsPort || 443;
const options = { const options = {
key: fs.readFileSync("static/certs/key.pem"), key: fs.readFileSync("static/certs/key.pem"),
cert: fs.readFileSync("static/certs/cert.pem") cert: fs.readFileSync("static/certs/cert.pem")
}; };
http.createServer(app).listen(httpPort, () => { http.createServer(app).listen(httpPort, () => {
logger.info("HTTP server started on port " + httpPort); logger.info("HTTP server started on port " + httpPort);
https.createServer(options, app).listen(httpsPort, () => { https.createServer(options, app).listen(httpsPort, () => {
logger.info("HTTPS server started on port " + httpsPort); logger.info("HTTPS server started on port " + httpsPort);
logger.info( logger.info(
"Access the WebUI in your browser at http://localhost" + (httpPort == 80 ? "" : ":" + httpPort) "Access the WebUI in your browser at http://localhost" + (httpPort == 80 ? "" : ":" + httpPort)
); );
});
}); });
})
.catch(error => {
if (error instanceof Error) {
logger.error(`Error connecting to MongoDB server: ${error.message}`);
}
process.exit(1);
}); });
})();

View File

@ -1,20 +0,0 @@
import { logger } from "@/src/utils/logger";
import { config } from "@/src/services/configService";
import mongoose from "mongoose";
const url = config.mongodbUrl;
if (url === undefined) {
throw new Error("MONGODB_URL not found. Make sure you have a .env file in the root of the project!");
}
export const connectDatabase = async (): Promise<void> => {
try {
await mongoose.connect(`${url}`);
logger.info("Connected to MongoDB");
} catch (error: unknown) {
if (error instanceof Error) {
logger.error(`Error connecting to MongoDB ${error.message}`);
}
}
};