aboutsummaryrefslogblamecommitdiffstatshomepage
path: root/router.js
blob: e77766aa49e363f68b4cc442d6d6994650bba7c7 (plain) (tree)
1
2
3
 

                                               



















                                                                             
                                               






                                                           






                                         



                            

       

      









                                                                                 
                                                   

                                                                              
                                                     
                                                                
                   
                                                       
             
                                            
                
                                                    





         





                                          





                                                                             
                                               


                                                                      


       







                                                                             


                                                                      
                 
                                           





             
      









                                                         




















                                            
 
      
             

       
             
                                     
                                                                       

       



                                                                                           

 
  

var AM = require('./modules/account-manager');
var EM = require('./modules/email-dispatcher');





module.exports = function(app) {
    /*
     * GET home page.
     *
     * '/'
     */

    app.get('/', function(req, res){
        // check if the user's credentials are saved in a cookie
        if (req.cookies.user == undefined || req.cookies.pass == undefined) {
            res.render('index', { title: 'DERS' });
        } else { // appempt automatic login
            AM.autoLogin(req.cookies.user, req.cookies.pass, function(o) {
                if (o != null) {
                    req.session.user = o;
                    res.redirect('/dashboard');
                } else {
                    res.render('index', { title: 'DERS' });
                }
            });
        }
    });

    /*
     * GET TEST PAGE
     *
     * '/test'
     */

    app.get('/test', function(req, res) {
        res.render('test', {
            title: 'test',
            loggedin: false
        });
    });


    /*
     * GET dashboard
     *
     * '/dashboard'
     */

    app.get('/dashboard', function(req, res) {
        if (req.session.user == undefined) {
            if (req.cookies.user == undefined || req.cookies.pass == undefined) {
                res.redirect('/login');
            } else {
                console.log('jeg er inne i elsen');
                AM.autoLogin(req.cookies.user, req.cookies.pass, function(o) {
                    req.session.user = o;
                    console.log('DAFUQ SKJEDDE NĂ…');
                    res.render('index', { title: 'Autologin' });
                });
                res.redirect('/IJUSTAUTOLOGGEDDEGINN');
            }
           // res.redirect('/HAHAHAHAHAHA');
        } else {
            res.render('index', { title: 'kanin' });
        }
    });



    /*
     * GET login page
     *
     * '/login'
     */

    app.get('/login', function(req, res) {
        if (req.cookies.user == undefined || req.cookies.pass == undefined) {
            res.render('login', { title: 'Logg inn' });
        } else {
            AM.autoLogin(req.cookies.user, req.cookies.pass, function(o) {
                if (o != null) {
                    req.session.user = o;
                    res.redirect('/dashboard');
                } else { res.render('login', { title: 'Logg inn' }); }
            });
        }
    });


    /* POST */

    app.post('/login', function(req, res) {
        AM.manualLogin(req.param('user'), req.param('pass'), function(e, o) {
            if (!o) {
                res.send(e, 400);
            } else {
                req.session.user = o;
                if (req.param('remember-me') == 'on') {
                    res.cookie('user', o.user, { maxAge: 900000000 });
                    res.cookie('pass', o.pass, { maxAge: 900000000 });
                }
                res.redirect('/dashboard');
            }
        });
    });



    /*
     * GET signup page
     *
     * '/signup'
     */

    app.get('/signup', function(req, res) {
        res.render('signup', { title: 'Registrer deg' });
    });


    /* POST */

    app.post('/signup', function(req, res) {
        AM.addNewAccount({
            name    : req.param('name'),
            email   : req.param('email'),
            user    : req.param('user'),
            pass    : req.param('pass'),
            country : req.param('country')
        }, function(e) {
            if (e) {
                res.send(e, 400);
            } else {
                res.send('ok', 200);
            }
        });
    });





    /*
     * ERRORS
     */

    /* 404 */
    app.get('*', function(req, res) {
        res.render('error', { title: '404', text: 'Fant ikke siden' });
    });

    /* 403 on POST */
    app.post('*', function(req, res) {
        res.render('error', { title: '403', text: 'Du har ikke tilgang til denne siden' });
    });


};