-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.js
64 lines (52 loc) · 1.77 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
require("dotenv").config();
require("./db"); // Ensures database setup runs before starting the server
const express = require("express");
const wordsRouter = require("./routes/words");
const app = express();
const PORT = process.env.PORT || 3000;
app.use(express.json());
// Health Check
// Health Check with Environment Variable Check and DB Connectivity Check
app.get("/health", (req, res) => {
const missingEnvVars = [];
// Check for missing environment variables
const requiredEnvVars = [
{ name: "DB_HOST", example: "localhost" },
{ name: "DB_USER", example: "root" },
{ name: "DB_PASSWORD", example: "yourpassword" },
{ name: "DB_NAME", example: "yourdatabase" }
];
requiredEnvVars.forEach((envVar) => {
if (!process.env[envVar.name]) {
missingEnvVars.push({ name: envVar.name, example: envVar.example });
}
});
// If any environment variables are missing, log and return an error
if (missingEnvVars.length > 0) {
console.error("Missing environment variables:", missingEnvVars);
return res.status(500).json({
status: "error",
message: "Missing environment variables",
missing: missingEnvVars
});
}
// Check MySQL connection using the already created connection from db.js
const connection = require("./db");
connection.ping((err) => {
if (err) {
console.error("Database connection failed:", err);
return res.status(500).json({
status: "error",
message: "Database connection failed",
error: err.message
});
}
// If the DB connection is successful, send a healthy status
res.json({ status: "healthy" });
});
});
// Word Routes
app.use("/api/words", wordsRouter);
app.listen(PORT, () => {
console.log(`Server running on http://localhost:${PORT}`);
});