fix: abort startup if not connected to MongoDB server
This commit is contained in:
parent
e41022f176
commit
d897f40c92
42
src/index.ts
42
src/index.ts
@ -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);
|
||||||
});
|
});
|
||||||
})();
|
|
||||||
|
@ -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}`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
Loading…
x
Reference in New Issue
Block a user