-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
121 lines (106 loc) · 3.84 KB
/
server.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
/**
* Created by claudio on 17/01/17.
*/
"use strict";
let express = require('express');
let dotenv = require('dotenv');
let logger = require('morgan');
let moment = require('moment');//keep even if it is not used directly
var compression = require('compression');
var bodyParser = require('body-parser');
var expressValidator = require('express-validator');
var jwt = require('jsonwebtoken');
let User = require('./models/User');
let config = require('./knexfile');
let knex = require('knex')(config);
//controllers
let user = require('./controllers/user');
let game = require('./controllers/game');
let play = require('./controllers/play');
dotenv.load();
let app = express();
//config defaults
//post body limit
let requestLimit = process.env.REQUEST_LIMIT || 1024*1024*50; //50MB limit
//authentication
app.use((req, res, next) => {
req.isAuthenticated = () => {
let token = (req.headers.authorization && req.headers.authorization.split(' ')[1]);// || req.cookies.token;
try {
return jwt.verify(token, process.env.TOKEN_SECRET);
} catch (err) {
return false;
}
};
if (req.isAuthenticated()) {
let payload = req.isAuthenticated();
new User({ id: payload.sub })
.fetch()
.then(function(user) {
req.user = user;
next();
});
} else {
next();
}
});
let ensureAuthenticated = (req, res, next) => {
if (req.isAuthenticated() && req.user) {
next();
} else {
res.status(401).send({ msg: 'Unauthorized' });
}
};
app.set('port', process.env.PORT || 3000);
app.use(logger('dev'));
app.use(bodyParser.json({limit:requestLimit, type:'application/json'}));
app.use(bodyParser.urlencoded({ extended:true,limit:requestLimit,type:'application/x-www-form-urlencoding' }));
app.use(expressValidator());
app.use(compression());//gzip compression
//routes
/*app.get('/', function (req, res) {
res.send('Hello World!');
});*/
//user
app.get('/users/', user.list);
app.get('/users/:id', user.get);
app.post('/users/', user.post);
app.put('/users/:id', ensureAuthenticated, user.put);
app.delete('/users/:id', ensureAuthenticated, user.delete);
app.post('/users/login', user.login);
app.options('/users/',(req,res)=>res.set('Allow', 'GET,POST').status(200).send());
app.options('/users/login',(req,res)=>res.set('Allow', 'POST').status(200).send()); //this must be before :id version
app.options('/users/:id',(req,res)=>res.set('Allow', 'GET,PUT,DELETE').status(200).send());
//games
app.get('/games/', game.list);
app.get('/games/:id', game.get);
app.post('/games/', ensureAuthenticated, game.post);
app.options('/games/',(req,res)=>res.set('Allow', 'GET,POST').status(200).send());
app.options('/games/:id',(req,res)=>res.set('Allow', 'GET').status(200).send());
//plays
app.get('/users/:userId/plays/', play.userMiddleware, play.list);
app.get('/users/:userId/plays/:id', play.userMiddleware, play.get);
app.post('/users/:userId/plays/', ensureAuthenticated, play.userMiddleware, play.post);
app.options('/users/:userId/plays/',(req,res)=>res.set('Allow', 'GET,POST').status(200).send());
app.options('/users/:userId/plays/:id',(req,res)=>res.set('Allow', 'GET').status(200).send());
//needed just for tests
app.delete('/clean', (req, res, next)=>{
Promise.all([
knex('users').del(),
knex('games').del(),
knex('plays').del()
]).then(()=>res.send('OK'));
});
//errors
let notImplemented = (req, res, next) =>{
res.status(405).send(`Cannot ${req.method} ${req.url}`);
};
app.get('*', notImplemented);
app.post('*', notImplemented);
app.put('*', notImplemented);
app.delete('*', notImplemented);
app.options('*', (req,res)=>res.set('Allow', '').status(200).send());
app.listen(app.get('port'), function() {
console.log('Express server listening on port ' + app.get('port'));
});
module.exports = app;