Files
2024-09-24 09:44:53 +08:00

49 lines
1.3 KiB
JavaScript

const express = require("express");
const dotenv = require("dotenv");
const jwt = require("jsonwebtoken");
const app = express();
dotenv.config();
app.use(express.json());
const authenticateToken = (req, res, next) => {
const authHeader = req.header("Authorization");
const token = authHeader && authHeader.split(" ")[1];
if (!token) {
return res.status(403).json({ error: "A token is required for authentication" });
}
try {
const jwtSecretKey = process.env.JWT_SECRET_KEY;
const verified = jwt.verify(token, jwtSecretKey);
req.user = verified;
} catch (err) {
return res.status(401).json({ error: "Invalid token" });
}
next();
};
const popcenRoutes = require("./api/routes/popcen");
const popcenCountRoutes = require("./api/routes/popcenCount");
const userRoutes = require("./api/routes/user");
const registerRoutes = require("./api/routes/register");
app.use("/user", userRoutes);
app.use("/user/register", registerRoutes);
app.use("/popcen", authenticateToken, popcenRoutes);
app.use("/popcenCount", authenticateToken, popcenCountRoutes);
app.get('/health', (req, res) => {
res.status(200).send('OK');
});
const PORT = process.env.PORT || 3000;
app.listen(PORT, '0.0.0.0', () => {
console.log(`Server is running on port ${PORT} in ${process.env.NODE_ENV || 'development'} mode`);
});