-
Notifications
You must be signed in to change notification settings - Fork 4
/
middleware.js
73 lines (66 loc) · 2.19 KB
/
middleware.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
const Resume = require('./models/resume');
const ExpressError = require('./utils/expressError');
const { companySchema, resumeSchema } = require('./schemas.js');
module.exports.validateCompany = (req, res, next) => {
const { error } = companySchema.validate(req.body);
if (error) {
const msg = error.details.map(el => el.message).join(',')
throw new ExpressError(msg, 400);
} else {
next();
}
}
module.exports.isLoggedIn = (req, res, next) => {
if (!req.isAuthenticated()) {
req.flash('error', 'You must be logged in');
return res.redirect('/login')
}
next();
}
module.exports.isValidUser = (req, res, next) => {
let s = req.body.email.slice(-14);
let str = s.slice(1, 3);
console.log(req.body.email);
if (str === 'ce' || str === 'it' || str === 'et' || str === 'el' || str === 'ee' || str === 'me' || str === 'ci' || str === 'pe' || str === 'tx') {
if (!(s === `@${str}.vjti.ac.in`)) {
req.flash('error', 'NOT A VALID VJTI STUDENT');
res.redirect('/register');
}
next();
}
else {
req.flash('error', 'NOT A VALID VJTI STUDENT');
res.redirect('/register');
}
}
module.exports.validateResume = (req, res, next) => {
const { error } = resumeSchema.validate(req.body)
if (error) {
const msg = error.details.map(el => el.message).join(',')
throw new ExpressError(msg, 400)
} else {
next();
}
}
module.exports.isAuthor = async (req, res, next) => {
const { id } = req.params;
const resume = await Resume.findById(id);
if (!resume.author.equals(req.user._id)) {
req.flash('error', 'You dont have permission to do that');
return res.redirect("/students/resume");
}
next();
}
module.exports.isAdmin = async (req, res, next) => {
if (req.user.email === 'tpowebsite2021@gmail.com') {
next();
} else {
req.flash('error', 'You are not an admin');
const redirectUrl = req.session.returnTo;
if (redirectUrl[1] === "c") {
return res.redirect('/companies');
} else if (redirectUrl[1] === "e") {
return res.redirect("/events");
}
}
}