2025-04-05 06:50:57 -07:00
|
|
|
// First, init config.
|
|
|
|
import { config, loadConfig } from "@/src/services/configService";
|
|
|
|
try {
|
|
|
|
loadConfig();
|
|
|
|
} catch (e) {
|
|
|
|
console.log("ERROR: Failed to load config.json. You can copy config.json.example to create your config.json.");
|
|
|
|
process.exit(1);
|
|
|
|
}
|
2024-05-30 13:33:49 +02:00
|
|
|
|
2025-04-05 06:50:57 -07:00
|
|
|
// Now we can init the logger with the settings provided in the config.
|
|
|
|
import { logger } from "@/src/utils/logger";
|
2024-05-30 13:33:49 +02:00
|
|
|
logger.info("Starting up...");
|
|
|
|
|
2025-04-05 06:50:57 -07:00
|
|
|
// Proceed with normal startup: bring up config watcher service, validate config, connect to MongoDB, and finally start listening for HTTP.
|
2024-12-31 01:41:47 +01:00
|
|
|
import mongoose from "mongoose";
|
2025-05-08 08:22:06 -07:00
|
|
|
import { JSONStringify } from "json-with-bigint";
|
2025-05-24 01:48:25 -07:00
|
|
|
import { startWebServer } from "./services/webService";
|
|
|
|
|
2025-04-05 06:50:57 -07:00
|
|
|
import { validateConfig } from "@/src/services/configWatcherService";
|
2023-05-19 15:22:48 -03:00
|
|
|
|
2025-03-24 11:31:53 -07:00
|
|
|
// Patch JSON.stringify to work flawlessly with Bigints.
|
2025-05-08 08:22:06 -07:00
|
|
|
JSON.stringify = JSONStringify;
|
2025-03-20 05:36:09 -07:00
|
|
|
|
2024-12-29 23:34:26 +01:00
|
|
|
validateConfig();
|
2023-05-19 15:22:48 -03:00
|
|
|
|
2024-12-31 01:41:47 +01:00
|
|
|
mongoose
|
|
|
|
.connect(config.mongodbUrl)
|
|
|
|
.then(() => {
|
|
|
|
logger.info("Connected to MongoDB");
|
2025-05-24 01:48:25 -07:00
|
|
|
startWebServer();
|
2024-12-31 01:41:47 +01:00
|
|
|
})
|
|
|
|
.catch(error => {
|
|
|
|
if (error instanceof Error) {
|
|
|
|
logger.error(`Error connecting to MongoDB server: ${error.message}`);
|
|
|
|
}
|
|
|
|
process.exit(1);
|
2024-12-23 22:48:16 +01:00
|
|
|
});
|