-
Notifications
You must be signed in to change notification settings - Fork 2
/
app.js
108 lines (93 loc) · 2.32 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
106
107
108
const express = require('express')
const app = express();
const session = require('express-session');
const static = express.static(__dirname + '/public');
const configRoutes = require('./routes');
const exphbs = require('express-handlebars');
const rewriteUnsupportedBrowserMethods = (req, res, next) => {
// If the user posts to the server with a property called _method, rewrite the request's method
// To be that method; so if they post _method=PUT you can now allow browsers to POST to a route that gets
// rewritten in this middleware to a PUT route
if (req.body && req.body._method) {
req.method = req.body._method;
delete req.body._method;
}
next();
}
app.use;
app.use('/public', static);
app.use(express.json());
app.use(express.urlencoded({extended: true}));
app.use(rewriteUnsupportedBrowserMethods);
app.engine('handlebars',exphbs({defaultLayout: 'main'}));
app.set('view engine', 'handlebars');
app.use(session({
name: 'AuthCookie',
secret: 'some secret string!',
resave: false,
saveUninitialized: true,
cookie: { maxAge: 1600000 }
})
);
//Need to check which route to take for logged in user...
/*app.use('/private', (req,res,next) => {
//console.log(req.session.id);
if(!req.session.user){
//return res.redirect('/');
//res.status(403).render('users/notauthenticated', {title: "Error"});
res.status(403).json({error:"Not authenticated"});
}else{
next();
}
});*/
/*
app.use('/broadband/newPlan', (req,res,next) => {
if(req.session.user){
if(req.session.user.userName === 'admin'){
res.redirect('/broadband/newPlan');
}
else{
res.redirect('/')
}
}
else{
res.redirect('/')
}
});*/
app.use('/users/login' , (req,res,next) => {
if(req.session.user){
res.redirect('/');
}
else{
next();
}
})
app.use('/users/signup' , (req,res,next) => {
if(req.session.user){
res.redirect('/');
}
else{
next();
}
});
app.use('/users/profile', (req,res,next) => {
if(!req.session.user){
res.redirect('/');
}
else{
next();
}
});
app.use('/users/logout', (req,res,next) => {
if(!req.session.user){
res.redirect('/');
}
else{
next();
}
});
configRoutes(app);
app.listen(3000, () => {
console.log("We've now got a server!");
console.log('Your routes will be running on http://localhost:3000');
});