-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmiddlewares.js
executable file
·84 lines (80 loc) · 2.49 KB
/
middlewares.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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
const jwt = require("jsonwebtoken");
const multer = require("multer");
const checkToken = (token) => {
let response = {};
const secrets = {
admin: process.env.ADMINKEY,
student: process.env.STUDENTKEY,
supervisor: process.env.SUPERVISORKEY,
industrysupervisor: process.env.INDUSTRYSUPERVISORKEY,
};
jwt.verify(token, secrets.admin, (err, payload) => {
if (err) {
jwt.verify(token, secrets.student, (err, payload) => {
if (err) {
jwt.verify(token, secrets.supervisor, (err, payload) => {
if (err) {
jwt.verify(token, secrets.industrysupervisor, (err, payload) => {
if (err) {
response["error"] = "You must be logged in";
} else {
response["userid"] = payload.userid;
response["key"] = secrets.industrysupervisor;
}
});
} else {
response["userid"] = payload.userid;
response["key"] = secrets.supervisor;
}
});
} else {
response["userid"] = payload.userid;
response["key"] = secrets.student;
}
});
} else {
response["userid"] = payload.userid;
response["key"] = secrets.admin;
}
});
return response;
};
module.exports = {
isAuthorized: function (secretKey) {
return (req, res, next) => {
let authorization = req.headers.authorization;
if (!authorization) {
return res.status(401).send({ error: "You must be logged in" });
}
const token = authorization.replace("Bearer ", "");
if (!secretKey) {
const payload = checkToken(token);
if (payload.error) {
return res.status(401).send({ error: "You must be logged in" });
}
req.userId = payload.userid;
req.key = payload.key;
next();
} else {
jwt.verify(token, secretKey, (err, payload) => {
if (err) {
return res.status(401).send({ error: "You must be logged in" });
}
req.userId = payload.userid;
next();
});
}
};
},
multerSetup: multer({
limits: {
fileSize: 5000000,
},
fileFilter(req, file, cb) {
if (!file.originalname.match(/\.(jpg|jpeg|png|mp4|mov|avi)$/)) {
return cb(new Error("Please upload an image or video"));
}
cb(undefined, true);
},
}),
};