aboutsummaryrefslogblamecommitdiffstatshomepage
path: root/controllers/system.js
blob: 31b48f766d83295fbaa6810049b33ec7e015d7af (plain) (tree)
1
2
3
4
5
6
7
8
9



                      
                                  

                                       

                                    






                                                                  
                                           




                                   




                        


                                   












                                  

 





                                      









                                                                  



                                                                 
                                                                                                                           


                                                                 
                                                                                                                                       






                                                           
                                                                                                                           








                                                                                                   
 

           
       

  
                                          
                                                                                                                           




                                 
         
 



                                      





                                                                                                                           

 









                                                                                      
                                          






                                                                                                                           
                              


                                                                                                            
 



                                              
 














































                                                                                                                                      
                                         
                                                                         

 

                                             
                                
                                



                                                                                                                                                











                                                                                                              
       
 

 

/**
 * Module dependencies
 */
var mongoose = require('mongoose')
  , 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) {

}

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);
    var projectId = req.sanitize('project').escape();

    // 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 });


    Access.findOne({ user: req.user._id }).where('project').equals(projectId).exec(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;
      console.log('ppost.user = ' + req.user._id);

        ppost.for = req.user._id;

        ppost.project = req.sanitize('project').escape(); // escape will escape html-specific characters, like " & > etc."
      console.log('ppost.project = ' + ppost.project);

        ppost.what = req.sanitize('what').escape();
      console.log('ppost.what = ' + ppost.what);

        ppost.comment = req.sanitize('comment').xss(); // xss will remove cross-site-scripting in the textfield.

        ppost.participants = req.sanitize('participants').escape();
      console.log('ppost.participants = ' + ppost.participants);

        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');
      console.log('ppost.when = ' + ppost.when);

        console.log('req.profile: ' + req.profile);
        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('/dashboard');
        })
    });
}
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 = 1;
        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');
        });
    });

}