-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathapp.js
More file actions
136 lines (116 loc) · 3.17 KB
/
app.js
File metadata and controls
136 lines (116 loc) · 3.17 KB
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
const express = require("express");
const path = require("path");
const mongoose = require("mongoose");
const session = require("express-session");
const MongoDBStore = require("connect-mongodb-session")(session);
const flash = require("connect-flash");
const helmet = require("helmet");
const compression = require("compression");
const morgan = require("morgan");
const fs = require("fs");
const cors = require("cors");
const { config } = require("dotenv");
const port = process.env.PORT || 4000;
const errorController = require("./controllers/error");
const User = require("./models/user");
config();
const app = express();
const MONGODB_URI = process.env.MONGO_URL;
// CORS Configuration
app.use(
cors({
origin: ["http://localhost:3000","https://nextjs-firefly.vercel.app"], // Replace with your frontend's domain
credentials: true, // Allow cookies or Authorization headers
})
);
// Body Parser Middleware
app.use(express.json({ limit: "10mb" }));
app.use(express.urlencoded({ extended: true, limit: "10mb" }));
// Session Store Configuration
const store = new MongoDBStore({
uri: MONGODB_URI,
collection: "sessions",
});
// Session Middleware
app.use(
session({
secret: "my secret",
resave: false,
saveUninitialized: false,
store: store,
cookie: {
httpOnly: true,
secure: false, // Set to true in production with HTTPS
maxAge: 1000 * 60 * 60 * 24, // 1 day
},
})
);
// Logging Middleware
const logStream = fs.createWriteStream(path.join(__dirname, "access.log"), {
flags: "a",
});
app.use(morgan("combined", { stream: logStream }));
// Security & Performance Middleware
app.use(helmet());
app.use(compression());
// Static Files Middleware
app.use(express.static(path.join(__dirname, "public")));
app.use("/images", express.static(path.join(__dirname, "images")));
// User Retrieval Middleware
app.use((req, res, next) => {
if (!req.session.userId) {
return next();
}
User.findById(req.session.userId)
.then((user) => {
if (!user) {
return next();
}
req.user = user;
next();
})
.catch((err) => {
console.log(err);
next(err);
});
});
// Flash Messages Middleware
app.use(flash());
// Global Variables Middleware
app.use((req, res, next) => {
res.locals.isLoggedIn = req.session.isLoggedIn;
next();
});
// Routes
const adminRoutes = require("./routes/admin");
const shopRoutes = require("./routes/shop");
const authRoutes = require("./routes/auth");
app.use("/admin", adminRoutes);
app.use(shopRoutes);
app.use(authRoutes);
// Error Handling Middleware
app.use((error, req, res, next) => {
console.error(error);
res.status(error.statusCode || 500).json({ message: error.message });
});
// Fallback Routes for 404 and 500 Errors
app.get("/500", errorController.get500);
// Server startup
app.listen(port, () => {
console.log(`Server is running on port ${port}`);
});
// MongoDB Connection
mongoose
.connect(process.env.MONGO_URL)
.then(() => {
console.log("Connected to MongoDB");
})
.catch((err) => {
console.log("Failed to connect to MongoDB", err);
});
app.get("/", (req, res) => {
res.send({
message: "Project Firefly Server",
health: "ok",
});
});