-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.js
More file actions
79 lines (65 loc) · 2.24 KB
/
Copy pathindex.js
File metadata and controls
79 lines (65 loc) · 2.24 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
const express = require("express");
const path = require("path");
const cookieParser = require("cookie-parser");
const { connectToMongoDB, redisClient } = require("./connect");
const urlRoute = require("./routes/url");
const { restrictToLoggedinUserOnly } = require("./middlewares/auth");
const errorHandler = require("./middlewares/errorHandler");
const rateLimiter = require("./middlewares/rateLimiter");
const logger = require("./middlewares/logger");
const staticRoute = require("./routes/staticRouter");
const userRoute = require("./routes/user");
const URL = require("./models/url");
const helmet = require("helmet");
const cors = require("cors");
const app = express();
app.use(helmet());
const PORT = 8001;
connectToMongoDB("mongodb://localhost:27017/short-url").then(() =>
console.log("MongoDB Connected")
);
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(cors({ origin: "*" }));
app.use(errorHandler);
app.use((req, res, next) => {
logger.info(`Received ${req.method} request for ${req.url}`);
next();
});
app.use("/url", restrictToLoggedinUserOnly, rateLimiter, urlRoute);
app.use(express.static(path.join(__dirname, "public")));
app.set("view engine", "ejs");
app.set("views", path.resolve("./views"));
app.use("/", staticRoute);
app.use("/user", userRoute);
app.get("/urls/:shortId", async (req, res) => {
try {
const shortId = req.params.shortId;
let cachedURL = await redisClient.get(shortId);
if (cachedURL) {
console.log("Cache Hit! Redirecting...");
return res.redirect(cachedURL);
}
const entry = await URL.findOneAndUpdate(
{ shortId },
{
$push: {
visitHistory: {
timeStamp: Date.now(),
ip: req.ip,
userAgent: req.headers["user-agent"],
},
},
},
{ new: true }
);
if (!entry) return res.status(404).json({ error: "Short URL not found" });
await redisClient.setEx(shortId, 86400, entry.redirectURL);
console.log("Cache Miss! Stored in Redis.");
res.redirect(entry.redirectURL);
} catch (error) {
res.status(500).json({ error: "Internal Server Error" });
}
});
app.listen(PORT, () => console.log(`Server started at PORT: ${PORT}`));