This commit is contained in:
2013-01-14 19:48:40 -05:00
parent 9c33416a92
commit ef1226aef6
3 changed files with 53 additions and 39 deletions

View File

@@ -7,6 +7,8 @@ var express = require('express')
, routes = require('./routes'); , routes = require('./routes');
var async = require('async'); var async = require('async');
var app = module.exports = express.createServer(); var app = module.exports = express.createServer();
var dbURL = 'mongodb://localhost/database';
var db = require('mongoose').connect(dbURL);
// Configuration // Configuration

View File

@@ -1,12 +1,10 @@
/* /*
* Session Routes * Session Routes
*/ */
var User = require('../data/models/user');
var users = require('../data/users'); var notLoggedIn = require('./middleware/not_logged_in');
var notLoggedIn = require('./middleware/not_logged_in');
module.exports = function(app) { module.exports = function(app) {
app.dynamicHelpers({ app.dynamicHelpers({
session: function(req, res) { session: function(req, res) {
return req.session; return req.session;
@@ -15,21 +13,25 @@ module.exports = function(app) {
app.get('/session/new', notLoggedIn, function(req, res) { app.get('/session/new', notLoggedIn, function(req, res) {
res.render('session/new', {title: "Log in"}); res.render('session/new', {title: "Log in"});
});
app.post('/session', notLoggedIn, function(req, res) {
if (users[req.body.username] &&
users[req.body.username].password === req.body.password) {
req.session.user = users[req.body.username];
res.redirect('/users');
} else {
res.redirect('/session/new');
}
}); });
app.del('/session', function(req, res, next) { app.post('/session', notLoggedIn, function(req, res) {
req.session.destroy(); User.findOne({username: req.body.username, password: req.body.password},
res.redirect('/users'); function(err, user) {
if (err) {
return next(err);
}
if (user) {
req.session.user = user;
res.redirect('/users');
} else {
res.redirect('/session/new');
}
});
}); });
app.del('/session', function(req, res, next) {
req.session.destroy();
res.redirect('/users');
});
}; };

View File

@@ -10,17 +10,30 @@ var maxUsersPerPage = 5;
module.exports = function(app) { module.exports = function(app) {
app.get('/users', function(req, res,next){ app.get('/users', function(req, res, next){
var page = req.query.page && parseInt(req.query.page, 10) || 0; var page = req.query.page && parseInt(req.query.page, 10) || 0;
User.find({})
.sort('name', 1) User.count(function(err, count) {
.skip(page * maxUsersPerPage)
.limit(maxUsersPerPage)
.exec(function(err, users) {
if (err) { if (err) {
return next(err); return next(err);
} }
res.render('users/index', {title: 'Users', users: users}); var lastPage = (page + 1) * maxUsersPerPage >= count;
User.find({})
.sort('name')
.skip(page * maxUsersPerPage)
.limit(maxUsersPerPage)
.exec(function(err, users) {
if (err) {
return next(err);
}
res.render('users/index', {
title: 'Users',
users: users,
page: page,
lastPage: lastPage
});
});
}); });
}); });
@@ -33,19 +46,16 @@ module.exports = function(app) {
}); });
app.post('/users', notLoggedIn, function(req, res, next) { app.post('/users', notLoggedIn, function(req, res, next) {
User.findOne({username: req.body.username}, function(err, user) { User.create(req.body, function(err) {
if (err) {
return next(err);
}
if (user) {
return res.send('Conflict', 409);
}
User.create(req.body, function(err) {
if (err) { if (err) {
return next(err); if (err.code === 11000) {
res.send('Conflict', 409);
} else {
next(err);
} }
res.redirect('/users'); return;
}); }
res.redirect('/users');
}); });
}); });