-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
118 lines (104 loc) · 4.43 KB
/
server.js
File metadata and controls
118 lines (104 loc) · 4.43 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
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
109
110
111
112
113
114
115
116
117
118
//requires
const express = require("express");
const bodyParser = require('body-parser');
const authenticateController=require('./modules/controllers/authenticate-controller');
const registerController=require('./modules/controllers/register-controller');
const forgotpassword = require('./modules/resetpass/resetPasswordRequest');
const moment = require('moment');
const isValidToken = require("./modules/resetpass/isValidResetToken");
const changePass= require("./modules/resetpass/changePass");
//misc express config
const app = express();
app.use(express.static(__dirname + '/public'));
app.set('views', __dirname + '/views');
app.set("view engine", "jade");
app.use(bodyParser.urlencoded({extended:true}));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
//port app listens on
const PORT = 8080;
//====================ROUTING===================================
//DEFAULT LOGIN PAGE
app.get('/', function (req, res) {
res.sendFile(__dirname + "/views/mock.html");
})
//registration page
app.get('/register', function(req,res){
res.sendFile(__dirname + "/views/register.html");
});
//forgot password page
app.get('/forgot', function(req,res){
res.sendFile(__dirname + "/views/resetrequest.html");
});
app.get('/form', function(req, res){
res.sendFile(__dirname + "/views/form.html");
});
app.get('/login', function(req, res){
res.sendFile(__dirname + "/views/index.html");
})
//once user follows email link, they are sent here
app.get('/reset/:token', function(req,res){
//check if valid token
var token = req.params.token;
isValidToken(token, function(code, email){
switch(code){
case 0: res.sendFile(__dirname + "/views/404.html");break;
case 1: res.render("resetpass", {email});break;
}
});
});
//Registration POST request, send req to REGISTRATIONCONTROLLER and change res based on results
app.post('/register', function(req,res){
registerController(req,res, function(code){
res.set("Content-type", "application/json");
switch (code){
case 0 : res.status(500).json({"code" : "0", "message" : "SQL Query Error"});break;
case 1 : res.status(200).json({"code" : "1", "message" : "User successfully Registered"});break;
case 2 : res.status(400).json({"code" : "2", "message" : "Email already registerd"});break;
}
})
});
//Authentication POST request, Send req to AUTHENTICATECONTROLLER and change res based on results
app.post('/auth',function(req,res){
authenticateController(req,res, function(code){
res.set("Content-type", "application/json");
switch(code){
case 0 : res.status(500).json({"code" : "0", "message" : "SQL Query Error"});break;
case 1 : res.status(200).json({"code" : "1", "message" : "User successfully authenticated"});break;
case 2 : res.status(400).json({"code" : "2", "message" : "incorrect password"});break;
case 3 : res.status(400).json({"code" : "3", "message" : "no such email found"});break;
}
});
});
//reset password POST for opening a request
app.post('/resetrequest', function(req,res){
callback = false;
forgotpassword(req,res, function(code){
callback = true;
res.set("Content-type", "application/json");
switch(code){
case 0 : res.status(500).json({"code" : "0", "message" : "Server error"});break;
case 1 : res.status(200).json({"code" : "1", "message" : "Password reset email sent"});break;
case 2 : res.status(400).json({"code" : "2", "message" : "Email does not match any existing records"});break;
case 3 : res.status(400).json({"code" : "3", "message" : "Already a pending reset request for that email"});break;
}
});
});
app.post('/changepass', function(req,res){
var email = req.body.email;
var pass = req.body.password;
console.log("POST: '/changepass' recieved: \n" + email + " " + pass);
changePass(email, pass, function(status){
switch(status){
case 0: res.status(500).json({"message" : "could not change password, sorry"});break;
case 1: res.status(200).json({"message" : "password changes successfully"});break;
}
});
});
//PORT
app.listen(PORT, function(){
var date = new Date();
console.log(moment(Date.now()).format('YYYY-MM-DD HH:mm:ss') +
": server listening on port " + PORT +"\n");
console.log('link => http://localhost:'+PORT+'/')
})