|
|
var express = require("express"), app = express(), bodyParser = require("body-parser"), methodOverride = require("method-override"), mongoose = require('mongoose');
var morgan = require('morgan'); var jwt = require('jsonwebtoken'); // used to create, sign, and verify tokens
var config = require('./config'); // get our config file
mongoose.Promise = global.Promise; // Connection to DB
mongoose.connect(config.database, function(err, res) { if (err) throw err; console.log('Connected to Database'); }); app.set('superSecret', config.secret); // secret variable
// Middlewares
app.use(bodyParser.urlencoded({ extended: false })); app.use(bodyParser.json()); app.use(methodOverride());
// use morgan to log requests to the console
app.use(morgan('dev'));
// Import Models and controllers
var userMdl = require('./models/userModel')(app, mongoose); var userCtrl = require('./controllers/userController');
var travelMdl = require('./models/travelModel')(app, mongoose); var commentMdl = require('./models/commentModel')(app, mongoose); var travelCtrl = require('./controllers/travelController');
/*// Example Route var router = express.Router(); router.get('/', function(req, res) { res.send("Hello world!"); }); app.use(router);*/ app.use(express.static(__dirname + '/www'));
//CORS
app.use(function(req, res, next) { res.header("Access-Control-Allow-Origin", "*"); res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS'); res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, X-Access-Token"); next(); });
// API routes ------------------------------------------------------
var apiRoutes = express.Router();
apiRoutes.route('/login') .post(userCtrl.login); apiRoutes.route('/signup') .post(userCtrl.signup); apiRoutes.route('/users') .get(userCtrl.getAllUsers); apiRoutes.route('/users/getById/:userid') .get(userCtrl.getUserById); apiRoutes.route('/travels') .get(travelCtrl.getAllTravels); apiRoutes.route('/travels/getById/:travelid') .get(travelCtrl.getTravelById);
// OJU AQUÏ TREC la verificació de token temporalment, per fer les proves des de l'app
// route middleware to verify a token
apiRoutes.use(function(req, res, next) {
// check header or url parameters or post parameters for token
var token = req.body.token || req.query.token || req.headers['x-access-token'];
// decode token
if (token) { // verifies secret and checks exp
jwt.verify(token, app.get('superSecret'), function(err, decoded) { if (err) { return res.json({ success: false, message: 'Failed to authenticate token.' }); } else { // if everything is good, save to request for use in other routes
req.decoded = decoded; //console.log("decoded " + decoded);
next(); } });
} else {
// if there is no token
// return an error
return res.status(201).send({ success: false, message: 'No token provided.' });
} }); //fi verificació de token
apiRoutes.route('/users/getByToken') .get(userCtrl.getUserByToken); apiRoutes.route('/users')//agafa l'user a partir del token
.put(userCtrl.updateUser)//no comprovat
.delete(userCtrl.deleteUser); apiRoutes.route('/travels') .post(travelCtrl.addTravel); apiRoutes.route('/travels/modifyById/:travelid') .put(travelCtrl.updateTravel)//no comprovat
.delete(travelCtrl.deleteTravel); apiRoutes.route('/travels/join/:travelid') .get(travelCtrl.addJoinPetition); apiRoutes.route('/travels/unjoin/:travelid') .get(travelCtrl.unJoin); //FINS AQUÏ COMPROVAT
apiRoutes.route('/travels/comment/:travelid') .get(travelCtrl.getCommentsByTravelId);
/*apiRoutes.route('/travels/join/:travelId') .post(travelCtrl.addJoin); apiRoutes.route('/travels/unjoin/:travelId') .post(travelCtrl.doUnjoin);*/
/*apiRoutes.route('/travels/:travelId/join') .post(travelCtrl.addJoin); apiRoutes.route('/travels/:travelId/unjoin') .post(travelCtrl.doUnjoin); */ apiRoutes.route('/users/:userId/fav') .post(userCtrl.addFav); apiRoutes.route('/users/:userId/unfav') .post(userCtrl.doUnfav);
apiRoutes.route('/travels/:travelId/comment') .post(travelCtrl.addComment);
app.use('/api', apiRoutes); // end of API routes -------------------------------------
// Start server
app.listen(config.port, function() { console.log("Node server running on http://localhost:3000"); });
|