You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123 lines
3.8 KiB

  1. var express = require("express"),
  2. app = express(),
  3. bodyParser = require("body-parser"),
  4. methodOverride = require("method-override"),
  5. mongoose = require('mongoose');
  6. var morgan = require('morgan');
  7. var jwt = require('jsonwebtoken'); // used to create, sign, and verify tokens
  8. var config = require('./config'); // get our config file
  9. mongoose.Promise = global.Promise;
  10. // Connection to DB
  11. mongoose.connect(config.database, function(err, res) {
  12. if (err) throw err;
  13. console.log('Connected to Database');
  14. });
  15. app.set('superSecret', config.secret); // secret variable
  16. // Middlewares
  17. /*app.use(bodyParser.urlencoded({
  18. extended: false
  19. }));
  20. app.use(bodyParser.json());*/
  21. app.use(bodyParser.json({limit: '2mb'}));
  22. app.use(bodyParser.urlencoded({limit: '2mb', extended: true}));
  23. app.use(methodOverride());
  24. // use morgan to log requests to the console
  25. app.use(morgan('dev'));
  26. var userMdl = require('./models/userModel')(app, mongoose);
  27. var userCtrl = require('./controllers/userController');
  28. var eventMdl = require('./models/eventModel')(app, mongoose);
  29. var eventCtrl = require('./controllers/eventController');
  30. //var alertMdl = require('./models/alertModel')(app, mongoose);
  31. //var alertCtrl = require('./controllers/alertController');
  32. //CORS
  33. app.use(function(req, res, next) {
  34. res.header("Access-Control-Allow-Origin", "*");
  35. res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS');
  36. res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, X-Access-Token");
  37. next();
  38. });
  39. // API routes ------------------------------------------------------
  40. var apiRoutes = express.Router();
  41. apiRoutes.route('/login')
  42. .post(userCtrl.login);
  43. apiRoutes.route('/signup')
  44. .post(userCtrl.signup);
  45. apiRoutes.route('/users')
  46. .get(userCtrl.getAllUsers);
  47. apiRoutes.route('/users/id/:userid')
  48. .get(userCtrl.getUserById);
  49. apiRoutes.route('/events')
  50. .get(eventCtrl.getAllEvents);
  51. apiRoutes.route('/alerts')
  52. .get(eventCtrl.getAllAlerts);
  53. apiRoutes.route('/events/id/:eventid')
  54. .get(eventCtrl.getEventById);
  55. apiRoutes.route('/events/following')
  56. .post(eventCtrl.getEventsByFollowingArray);
  57. apiRoutes.route('/events/category/:category')
  58. .get(eventCtrl.getEventsByCategory);
  59. apiRoutes.route('/events/day/:day')
  60. .get(eventCtrl.getEventsByDay);
  61. apiRoutes.route('/categoriesList')
  62. .get(eventCtrl.getCategoriesList);
  63. // route middleware to verify a token
  64. apiRoutes.use(function(req, res, next) {
  65. // check header or url parameters or post parameters for token
  66. var token = req.body.token || req.query.token || req.headers['x-access-token'];
  67. // decode token
  68. if (token) {
  69. // verifies secret and checks exp
  70. jwt.verify(token, app.get('superSecret'), function(err, decoded) {
  71. if (err) {
  72. return res.send(204, {
  73. success: false,
  74. message: 'Failed to authenticate token.'
  75. });
  76. } else {
  77. // if everything is good, save to request for use in other routes
  78. req.decoded = decoded;
  79. //console.log("decoded " + decoded);
  80. next();
  81. }
  82. });
  83. } else {
  84. // if there is no token
  85. // return an error
  86. return res.status(204).send({
  87. success: false,
  88. message: 'No token provided.'
  89. });
  90. }
  91. }); //fi verificació de token
  92. apiRoutes.route('/events')
  93. .post(eventCtrl.addEvent);
  94. apiRoutes.route('/alerts')
  95. .post(eventCtrl.addAlert);
  96. apiRoutes.route('/events/id/:eventid')
  97. .delete(eventCtrl.deleteEvent);
  98. app.use('/api', apiRoutes);
  99. // end of API routes -------------------------------------
  100. // Start server
  101. app.listen(config.port, function() {
  102. console.log("Node server running on http://localhost:3000");
  103. });