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.

145 lines
4.0 KiB

7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
  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({ extended: false }));
  18. app.use(bodyParser.json());
  19. app.use(methodOverride());
  20. // use morgan to log requests to the console
  21. app.use(morgan('dev'));
  22. // Import Models and controllers
  23. var userMdl = require('./models/userModel')(app, mongoose);
  24. var userCtrl = require('./controllers/userController');
  25. var projectMdl = require('./models/projectModel')(app, mongoose);
  26. var projectCtrl = require('./controllers/projectController');
  27. var intervalComprovations = require('./intervalComprovations');
  28. intervalComprovations.lastConnectionUser();
  29. /*// Example Route
  30. var router = express.Router();
  31. router.get('/', function(req, res) {
  32. res.send("Hello world!");
  33. });
  34. app.use(router);*/
  35. app.use(express.static(__dirname + '/webapp'));
  36. //CORS
  37. app.use(function(req, res, next) {
  38. res.header("Access-Control-Allow-Origin", "*");
  39. res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS');
  40. res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, X-Access-Token");
  41. next();
  42. });
  43. // API routes ------------------------------------------------------
  44. var apiRoutes = express.Router();
  45. apiRoutes.route('/users')
  46. .post(userCtrl.addUser);
  47. apiRoutes.route('/auth')
  48. .post(userCtrl.login);
  49. // OJU AQUÏ TREC la verificació de token temporalment, per fer les proves des de l'app
  50. // route middleware to verify a token
  51. apiRoutes.use(function(req, res, next) {
  52. // check header or url parameters or post parameters for token
  53. var token = req.body.token || req.query.token || req.headers['x-access-token'];
  54. // decode token
  55. if (token) {
  56. // verifies secret and checks exp
  57. jwt.verify(token, app.get('superSecret'), function(err, decoded) {
  58. if (err) {
  59. return res.json({ success: false, message: 'Failed to authenticate token.' });
  60. } else {
  61. // if everything is good, save to request for use in other routes
  62. req.decoded = decoded;
  63. //console.log("decoded " + decoded);
  64. next();
  65. }
  66. });
  67. } else {
  68. // if there is no token
  69. // return an error
  70. return res.status(201).send({
  71. success: false,
  72. message: 'No token provided.'
  73. });
  74. }
  75. }); //fi verificació de token
  76. apiRoutes.route('/logout')
  77. .post(userCtrl.logout);
  78. apiRoutes.route('/users')
  79. .get(userCtrl.findAllUsers);
  80. apiRoutes.route('/users/:id')
  81. .get(userCtrl.findById);
  82. apiRoutes.route('/users/loggeduser/:username')
  83. .get(userCtrl.findLoggedUserByUsername);
  84. apiRoutes.route('/projects/user/:username')
  85. .get(projectCtrl.findAllProjectsFromUsername);
  86. apiRoutes.route('/projects')
  87. .get(projectCtrl.findAllProjects);
  88. apiRoutes.route('/projects/:id')
  89. .get(projectCtrl.findById);
  90. apiRoutes.route('/users/:id')
  91. .put(userCtrl.updateUser)
  92. .delete(userCtrl.deleteUser);
  93. apiRoutes.route('/projects')
  94. .post(projectCtrl.addProject);
  95. apiRoutes.route('/projects/:id')
  96. .put(projectCtrl.updateProject)
  97. .delete(projectCtrl.deleteProject);
  98. apiRoutes.route('/projects/:id/adduser')
  99. .put(projectCtrl.addUserToProject);
  100. apiRoutes.route('/projects/:id/startworking')
  101. .put(projectCtrl.userStartWorking);
  102. apiRoutes.route('/projects/:id/stopworking')
  103. .put(projectCtrl.userStopWorking);
  104. app.use('/api', apiRoutes);
  105. // end of API routes -------------------------------------
  106. // Start server
  107. app.listen(config.port, "localhost", function() {
  108. console.log("Node server running on http://localhost:3000");
  109. });