-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathapp.js
105 lines (76 loc) · 2.36 KB
/
app.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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
require('dotenv').config();
const express = require('express');
const expressLayout = require('express-ejs-layouts');
const methodOverride = require('method-override');
const session = require('express-session');
const User = require ('./server/models/user');
const connectDB = require('./server/config/db');
const bcrypt = require ('bcrypt')
const app = express();
const port = process.env.PORT || 5000;
// Connect to Database
connectDB();
app.use(express.urlencoded({ extended: true }));
app.use(session({secret: 'nonrealistic'}))
const requirelogin = require('./authMdlwr')
// Middleware to pass the logged-in user's name to every view
app.use((req, res, next) => {
res.locals.userName = req.session.userName;
next();
});
app.use(express.json());
app.use(methodOverride('_method'));
// Static Files
app.use(express.static('public'));
// Templating Engine
app.use(expressLayout);
app.set('layout', './layouts/main');
app.set('view engine', 'ejs');
// Routes
app.use('/', require('./server/routes/student'))
app.get('/login', (req, res) => {
const errorMessage = req.session.errorMessage || '';
req.session.errorMessage = null;
res.render('login', { errorMessage });
});
app.get('/addAdmin',requirelogin,(req,res)=>{
res.render('addAdmin')
})
// Handle 404
// app.get('*', (req, res) => {
// res.status(404).render('404');
// });
///// loign post
app.post('/login', async (req, res) => {
const { userName, password } = req.body;
const foundUser = await User.findAndValidate(userName, password);
if (foundUser) {
req.session.user_id = foundUser._id;
req.session.userName = foundUser.userName;
res.redirect('/dash');
} else {
req.session.errorMessage = "Invalid username or password";
res.redirect('/login');
}
});
// signup post
app.post('/addAdmin',async(req,res)=>{
const {userName,password} = req.body
const user = new User ({userName,password})
await user.save()
req.session.user_id = user._id;
req.session.userName = user.userName;
res.redirect('/')
})
app.get('/logout', (req, res) => {
req.session.destroy();
res.redirect('/');
});
//// LOGOUT POST
app.post('/logout', (req, res) => {
req.session.destroy();
res.redirect('/');
});
app.listen(port, () => {
console.log(`App is listening on port http://localhost:${port}`)
});