-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapi.js
146 lines (146 loc) · 4.85 KB
/
api.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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
"use strict";
const dotenv = require("dotenv");
const express = require("express");
const bodyParser = require("body-parser");
const mongoSanitize = require("express-mongo-sanitize");
const jwt = require("jsonwebtoken");
const db = require("./db");
dotenv.config();
exports.router = express.Router();
const jsonParser = bodyParser.json();
const authenticateUser = (req, res, next) => {
let token = req.get('Authorization') == undefined ? false : req.get('Authorization');
if (!token) {
req.APIAuthenticatedUser = false;
return next();
}
// Check for a valid token
jwt.verify(token, process.env.VOTE_APP_JWT_SECRET, function (err, payload) {
if (err) {
req.APIAuthenticatedUser = false;
}
else {
req.APIAuthenticatedUser = payload.user;
}
next();
});
};
const validateUser = (req, res, next) => {
if (req.APIAuthenticatedUser == false) {
res.status(500).json({ error: "Invalid User" });
}
else {
next();
}
};
exports.router.use(jsonParser);
exports.router.use(mongoSanitize());
exports.router.use(authenticateUser);
exports.router.post('/register', function (req, res) {
let username = req.body.username;
let email = req.body.email;
let password = req.body.password;
db.addUser(username, email, password)
.then(() => { res.json({ message: "User added!" }); })
.catch((e) => { res.status(500).json(e); });
});
exports.router.get('/polls', function (req, res) {
db.getRecentPolls(req.APIAuthenticatedUser, req.ip)
.then((polls) => res.json(polls))
.catch(error => res.status(500).json({ error: "Error retrieving polls" }));
});
exports.router.post('/polls', validateUser, function (req, res) {
// Validate poll
if (req.body.question.length < 1 || req.body.responses.length < 2) {
return res.status(400).json({
error: "Invalid input. A poll must have at least one question and at least two responses."
});
}
let newPoll = {
question: req.body.question,
responses: req.body.responses,
username: req.APIAuthenticatedUser,
addedAt: new Date()
};
db.addPoll(newPoll, req.body.user, req.ip)
.then(poll => {
res.json({
message: "Post added! Yippee!",
poll: poll
});
})
.catch(error => { res.status(500).json({ error: "Server Error" }); });
});
exports.router.get('/polls/:poll_id', function (req, res) {
db.getPoll(req.params.poll_id, req.APIAuthenticatedUser, req.ip)
.then((polls) => {
if (polls.length > 0) {
res.json(polls);
}
else {
res.status(404).json({
error: "Poll not found"
});
}
})
.catch(error => res.status(500).json({
error: "Error getting poll"
}));
});
exports.router.delete('/polls/:poll_id', validateUser, function (req, res) {
console.log("Got request to delete poll #" + req.params.poll_id);
db.deletePoll(Number(req.params.poll_id), req.APIAuthenticatedUser, req.ip)
.then(json => res.json(json))
.catch(error => res.status(500).json(error));
});
exports.router.post('/polls/:poll_id/vote', function (req, res) {
db.castVote(Number(req.params.poll_id), Number(req.body.response), req.body.newResponse, req.body.user, req.ip)
.then(result => res.json(result))
.catch(error => {
console.log(error);
res.status(500).json({
message: error
});
});
});
exports.router.get('/users/:user/polls', function (req, res) {
db.getPollsByUser(req.params.user, req.APIAuthenticatedUser, req.ip)
.then(result => res.json(result))
.catch(error => res.status(500).json({
error: "Unable to retrieve polls for user " + req.params.user
}));
});
exports.router.post('/login', function (req, res) {
const username = req.body.username;
const password = req.body.password;
db.verifyPassword(username, password)
.then(success => {
if (success) {
// Set JSON Web Token for future API authentication
let payload = {
user: username
};
let jwtOptions = {
expiresIn: "7d"
};
jwt.sign(payload, process.env.VOTE_APP_JWT_SECRET, jwtOptions, function (err, token) {
if (err) {
res.status(500).json({ error: "Error setting JSON Web Token" });
}
else {
res.json({ apiToken: token });
}
});
}
else {
res.status(500).json({ error: "Invalid credentials" });
}
})
.catch(e => {
res.status(401).json({
error: {
description: "Invalid username or password"
}
});
});
});