//File: controllers/tvshows.js var mongoose = require('mongoose'); var userModel = mongoose.model('userModel'); /* */ var jwt = require('jsonwebtoken'); // used to create, sign, and verify tokens var express = require("express"); var app = express(); var config = require('../config'); // get our config file app.set('superSecret', config.secret); // secret variable /* */ //GET - Return all tvshows in the DB exports.findAllUsers = function(req, res) { userModel.find(function(err, users) { if(err) res.send(500, err.message); console.log('GET /users'); res.status(200).jsonp(users); }); }; //GET - Return a TVShow with specified ID exports.findById = function(req, res) { userModel.findById(req.params.id, function(err, user) { if(err) return res.send(500, err.message); console.log('GET /users/' + req.params.id); res.status(200).jsonp(user); }); }; exports.findUserByUsername = function(req, res) { userModel.find({ username: req.params.username }, function(err, user) { if (err) throw err; if (!user) { res.json({ success: false, message: 'no user found' }); } else if (user) { console.log(user); // return the information including token as JSON res.jsonp(user); } }); }; //POST - Insert a new TVShow in the DB exports.addUser = function(req, res) { console.log('POST new user, name: ' + req.body.username); //console.log(req.body); var user = new userModel({ username: req.body.username, password: req.body.password, description: req.body.description, avatar: req.body.avatar, mail: req.body.mail, admin: req.body.admin }); user.save(function(err, user) { if(err) return res.send(500, err.message); res.status(200).jsonp(user); }); }; //PUT - Update a register already exists exports.updateActivity = function(req, res) { ActivityModel.findById(req.params.id, function(err, tvshow) { tvshow.title = req.body.petId; tvshow.year = req.body.year; tvshow.country = req.body.country; tvshow.poster = req.body.poster; tvshow.seasons = req.body.seasons; tvshow.genre = req.body.genre; tvshow.summary = req.body.summary; tvshow.save(function(err) { if(err) return res.send(500, err.message); res.status(200).jsonp(tvshow); }); }); }; //DELETE - Delete a TVShow with specified ID exports.deleteActivity = function(req, res) { ActivityModel.findById(req.params.id, function(err, activity) { activity.remove(function(err) { if(err) return res.send(500, err.message); res.status(200).jsonp(req.params.id); console.log('DELETE /activities/' + req.params.id); }) }); }; //POST - auth user exports.login = function(req, res) { // find the user userModel.findOne({ username: req.body.username }, function(err, user) { if (err) throw err; if (!user) { res.json({ success: false, message: 'Authentication failed. User not found.' }); } else if (user) { // check if password matches if (user.password != req.body.password) { res.json({ success: false, message: 'Authentication failed. Wrong password.' }); } else { // if user is found and password is right // create a token var token = jwt.sign(user, app.get('superSecret'), { //expiresInMinutes: 1440 // expires in 24 hours expiresIn: '60m' }); console.log(user); // return the information including token as JSON res.json({ success: true, message: 'Enjoy your token!', token: token, avatar: user.avatar }); } } }); };