/** * Module dependencies */ var mongoose = require('mongoose') , env = process.env.NODE_ENV || 'development' , config = require('../config/config.js')[env] , Project = mongoose.model('Project') , Access = mongoose.model('Access') , User = mongoose.model('User') , pPost = mongoose.model('pPost'); /** * Before the user log in * =============================================================== */ exports.index = function(req, res) { res.render('index', { title: 'DERS' }); }; exports.test = function(req, res) { res.render('test', { title: 'test', loggedin: false }); }; exports.home = function(req, res) { res.render('home', { title: 'home', loggedin: false }); }; exports.faq = function(req, res) { res.render('faq', { title: 'faq', loggedin: false }); } exports.contact = function(req, res) { res.render('contact', { title: 'contact', loggedin: false }); } /** * After the user has logged in * =============================================================== */ exports.dashboard = function(req, res) { console.log('/dashboard - ' + req.user._id); /* Access.find({ user: req.user._id }, function(err, accesses) { if (err) return res.status(500).render('error', { title: '500', text: 'En serverfeil oppstod', error: err.stack }); console.log('accesses ' + accesses); accesses.forEach(function(access) { Project.load(access.project, function(err, project) { if (err) return res.status(500).render('error', { title: '500', text: 'En serverfeil oppstod', error: err.stack }); projectList.push(project); console.log(project.user.username); }); }); }); */ Access.loadUser(req.user._id, function(err, projects) { if (err) return res.status(500).render('error', { title: '500', text: 'En serverfeil oppstod', error: err.stack }); Project.populate(projects, { path: 'project.user', model: User }, function(err, projects) { console.log('accesses: ' + projects); res.render('dashboard', { title: 'Dashboard', loggedin: true, projects: projects }); }); }); /* Project.find(function(err, projects) { if (err) return res.status(500).render('error', { title: '500', text: 'En serverfeil oppstod', error: err.stack }); res.render('dashboard', { title: 'Dashboad', loggedin: true, projects: projects }); });*/ } exports.project = function(req, res) { Project.loadShort(req.params.short, function(err, project) { if (err) return res.status(500).render('error', { title: '500', text: 'En serverfeil oppstod', error: err.stack }); res.render('project', { title: 'Harepus', loggedin: true, req: req, project: project }); }); } exports.projectParticipants = function(req, res) { res.render('projectParticipants', { title: 'Prosjektdeltakere', loggedin: true }); } exports.postProjectParticipants = function(req, res) { var email = require('emailjs'); var server = email.server.connect(config.email); console.log(server); var message = { text: 'lol', from: 'Divid ', to: 'dennis.se@gmail.com', subject: 'test' } server.send(message, function(err, message) { console.log(err || message);}); res.redirect('back'); } exports.projectPost = function(req, res) { /** ################################### * Need to check if user has access to this project!! */ console.log(req.loggedin); Project.loadShort(req.params.short, function(err, project) { if (err) return res.status(500).render('error', { title: '500', text: 'En serverfeil oppstod', error: err.stack }); req.project = project; res.render('projectPost', { title: 'Legg til utgift', loggedin: true, req: req, project: project }); }); } exports.postProjectPost = function(req, res) { // Validation req.assert('project', 'The project was lost').notEmpty(); req.assert('what', 'You need to fill in the what-field').notEmpty(); req.assert('value', 'The value must be a positive number').notEmpty().isInt().min(0); // error when validation fails var errors = req.validationErrors(); if (errors) return res.status(500).render('error', { title: '500', text: 'Det oppstod en valideringsfeil', error: errors.stack }); Project.load(req.sanitize('project').escape(), function(err, project) { if (err) return res.status(500).render('error', { title: '500', text: 'En serverfeil oppstod', error: err.stack }); // check if access Access.checkAccess(req.user._id, project._id, 0, function(err, access) { if (err || !access) return res.status(403).render('error', { title: '403', text: 'no sir.' }); // Time to fill in the model! var ppost = new pPost(); ppost.user = req.user._id; ppost.for = req.user._id; ppost.project = project._id; ppost.what = req.sanitize('what').escape(); ppost.comment = req.sanitize('comment').xss(); // xss will remove cross-site-scripting in the textfield. ppost.participants = req.sanitize('participants').escape(); ppost.value = req.sanitize('value').toInt(); // this will remove leading zeroes. '0123' => '123' ppost.when = new Date(req.sanitize('date').escape() + ' ' + req.sanitize('time').escape() + ':00'); ppost.save(function(err) { if (err) { console.log(err.errors); res.render('projectPost', { title: 'Legg til utgift - en feil oppstod', loggedin: true, req: req, project: project }); } return res.redirect('/project/' + project.shortURL); }) }); }); } exports.newProject = function(req, res) { res.render('newProject', { title: 'Nytt prosjekt', loggedin: true }); } exports.postNewProject = function(req, res) { var project = new Project(req.body); project.user = req.user._id; project.save(function(err) { if (err) { console.log(err.errors); return res.render('newproject', { title: 'Nytt prosjekt - en feil oppstod', loggedin: true, errors: err.errors, project: project }); } var access = new Access(); access.user = req.user._id; access.creator = req.user._id; access.project = project._id; access.permissions = 9; access.save(function(err) { if (err) { console.log(err.errors); return res.render('newproject', { title: 'Nytt prosjekt - en feil oppstod', loggedin: true }); } return res.redirect('/dashboard'); }); }); }