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.

198 lines
6.2 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
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.json({limit: '50mb'}));
  18. app.use(bodyParser.urlencoded({limit: '50mb', extended: true}));
  19. app.use(methodOverride());
  20. // use morgan to log requests to the console
  21. app.use(morgan('dev'));
  22. // Import Models and controllers
  23. /*
  24. var userMdl = require('./models/userModel')(app, mongoose);
  25. */
  26. var userMdl = require('./models/userModel');
  27. var notificationMdl = require('./models/notificationModel');
  28. var travelMdl = require('./models/travelModel');
  29. var commentMdl = require('./models/commentModel');
  30. var adminMdl = require('./models/adminModel');
  31. var userCtrl = require('./controllers/userController');
  32. var searchCtrl = require('./controllers/searchController');
  33. var travelCtrl = require('./controllers/travelController');
  34. var adminCtrl = require('./controllers/adminController');
  35. app.use(express.static(__dirname + '/www'));
  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. // public routes
  46. apiRoutes.route('/login')
  47. .post(userCtrl.login);
  48. apiRoutes.route('/signup')
  49. .post(userCtrl.signup);
  50. apiRoutes.route('/users')
  51. .get(userCtrl.getAllUsers);
  52. apiRoutes.route('/users/id/:userid')
  53. .get(userCtrl.getUserById);
  54. apiRoutes.route('/travels')
  55. .get(travelCtrl.getAllTravels);
  56. apiRoutes.route('/travels/id/:travelid')
  57. .get(travelCtrl.getTravelById);
  58. apiRoutes.route('/admin/login')
  59. .post(adminCtrl.login);
  60. /*apiRoutes.route('/admin/signup')
  61. .post(adminCtrl.signup);*/
  62. // route middleware to verify the token
  63. apiRoutes.use(function(req, res, next) {
  64. // check header or url parameters or post parameters for token
  65. var token = req.body.token || req.query.token || req.headers['x-access-token'];
  66. // decode token
  67. if (token) {// verifies secret and checks exp
  68. jwt.verify(token, app.get('superSecret'), function(err, decoded) {
  69. if (err) {
  70. return res.send(204,
  71. {
  72. success: false,
  73. message: 'Failed to authenticate token.'
  74. });
  75. } else {// if everything is good, save to request for use in other routes
  76. req.decoded = decoded;
  77. next();
  78. }
  79. });
  80. } else {
  81. // if there is no token, return an error
  82. return res.status(204).send({
  83. success: false,
  84. message: 'No token provided.'
  85. });
  86. }
  87. }); //end token verification middleware
  88. // private routes (needs to be logged)
  89. //admin routes
  90. apiRoutes.route('/admins')
  91. .get(adminCtrl.getAllAdmins);
  92. apiRoutes.route('/admin/network')
  93. .get(adminCtrl.network);
  94. apiRoutes.route('/admin/user/network/:userid')
  95. .get(adminCtrl.getUserNetwork);
  96. apiRoutes.route('/admin/travels/id/:travelid')
  97. .delete(adminCtrl.deleteTravel);
  98. apiRoutes.route('/admin/users/id/:userid')
  99. .delete(adminCtrl.deleteUser);
  100. apiRoutes.route('/admin/users/validate/id/:userid')
  101. .post(adminCtrl.validateUser);
  102. apiRoutes.route('/admin/users/unvalidate/id/:userid')
  103. .post(adminCtrl.unvalidateUser);
  104. // general routes
  105. apiRoutes.route('/search/:searchstring')
  106. .get(searchCtrl.searchByString);
  107. apiRoutes.route('/numnotifications')
  108. .get(userCtrl.getNumNotificationsByToken);
  109. apiRoutes.route('/notifications')
  110. .get(userCtrl.getNotifications);
  111. // user routes
  112. apiRoutes.route('/users/token')
  113. .get(userCtrl.getUserByToken);
  114. apiRoutes.route('/users')//agafa l'user a partir del token
  115. .put(userCtrl.updateUser)//no comprovat
  116. .delete(userCtrl.deleteUser);
  117. apiRoutes.route('/changePassword')//agafa l'user a partir del token
  118. .put(userCtrl.changePassword);
  119. apiRoutes.route('/users/id/likes/:userid')
  120. .get(userCtrl.getUserLikes);
  121. apiRoutes.route('/users/id/like/:userid')
  122. .post(userCtrl.likeUser);
  123. apiRoutes.route('/users/id/unlike/:userid')
  124. .post(userCtrl.unlikeUser);
  125. //travels routes
  126. apiRoutes.route('/users/id/travels/:userid')
  127. .get(userCtrl.getTravelsByUserId);
  128. apiRoutes.route('/travels')
  129. .post(travelCtrl.addTravel);
  130. apiRoutes.route('/travels/id/modify/:travelid')
  131. .put(travelCtrl.updateTravel)
  132. .delete(travelCtrl.deleteTravel);
  133. apiRoutes.route('/travels/join/:travelid')
  134. .post(travelCtrl.addJoinPetition);
  135. apiRoutes.route('/travels/unjoin/:travelid')
  136. .post(travelCtrl.unJoin);
  137. apiRoutes.route('/travels/leave/:travelid')
  138. .post(travelCtrl.leave);
  139. apiRoutes.route('/travels/declineJoin/:travelid')
  140. .post(travelCtrl.declineJoin);
  141. apiRoutes.route('/travels/acceptJoin/:travelid')
  142. .post(travelCtrl.acceptJoin);
  143. //not yet used routes
  144. apiRoutes.route('/travels/comment/:travelid')
  145. .get(travelCtrl.getCommentsByTravelId);
  146. /*apiRoutes.route('/travels/join/:travelId')
  147. .post(travelCtrl.addJoin);
  148. apiRoutes.route('/travels/unjoin/:travelId')
  149. .post(travelCtrl.doUnjoin);*/
  150. /*apiRoutes.route('/travels/:travelId/join')
  151. .post(travelCtrl.addJoin);
  152. apiRoutes.route('/travels/:travelId/unjoin')
  153. .post(travelCtrl.doUnjoin);
  154. */
  155. apiRoutes.route('/users/:userId/fav')
  156. .post(userCtrl.addFav);
  157. apiRoutes.route('/users/:userId/unfav')
  158. .post(userCtrl.doUnfav);
  159. apiRoutes.route('/travels/:travelId/comment')
  160. .post(travelCtrl.addComment);
  161. app.use('/api', apiRoutes);
  162. // end of API routes -------------------------------------
  163. // Start server
  164. app.listen(config.port, function() {
  165. console.log("Node server running on http://localhost:" + config.port);
  166. });