diff options
author | Dennis Eriksen <dennis.se@gmail.com> | 2013-04-29 04:13:18 +0200 |
---|---|---|
committer | Dennis Eriksen <dennis.se@gmail.com> | 2013-04-29 04:13:18 +0200 |
commit | c1371f712789e97fac6351daee93a048b12db69b (patch) | |
tree | 0ffe7b97319018e75138646d5798039ab75f3b64 /router.js | |
parent | been cleaning a bit, moving stuff to where it belongs. signup and (diff) | |
download | Divid-c1371f712789e97fac6351daee93a048b12db69b.tar.gz |
cleaned up router.js
Diffstat (limited to '')
-rw-r--r-- | router.js | 218 |
1 files changed, 11 insertions, 207 deletions
@@ -1,118 +1,6 @@ -var mongodb = require('mongodb') - , mongoose = require('mongoose'); - -var users = require('./controllers/users'); - -// connects to mongodb -//mongoose.connect('localhost', 'test'); -var db = mongoose.connection; -db.on('error', console.error.bind(console, 'connection error:')); -db.once('open', function callback(){ - console.log('Connected to MongoDB'); -}); -/* -// user scheme -var userSchema = mongoose.Schema({ - username: { type: String, required: true, unique: true }, - email: { type: String, required: true, unique: true }, - password: { type: String, required: true }, //passwords doesn't need to be unique - accessToken:{ type: String } // used for Remember Me -}); - -// bcrypt middleware -userSchema.pre('save', function(next) { - var user = this; - - if (!user.isModified('password')) return next(); - - bcrypt.genSalt(SALT_WORK_FACTOR, function(err, salt) { - if(err) return next(err); - - bcrypt.hash(user.password, salt, function(err, hash) { - user.password = hash; - next(); - }); - }); -}); - -// password verification -userSchema.methods.comparePassword = function(candidatePassword, cb) { - bcrypt.compare(candidatePassword, this.password, function(err, isMatch) { - if (err) return cb(err); - cb(null, isMatch); - }); -}; - -// remember me implementation -userSchema.methods.generateRandomToken = function () { - var user = this, - chars = "_!abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890", - token = new Date().getTime() + '_'; - for (var x = 0; x < SALT_WORK_FACTOR; x++) { - var i = Math.floor(Math.random() * 94); - token += chars.charAt(i); - } - return token; -}; +var users = require('./controllers/users') + , system = require('./controllers/system'); -// seed a test user -var User = mongoose.model('User', userSchema); -/* -var usr = new User({ username: 'bob', email: 'bob@example.com', password: 'secret' }); -usr.save(function(err) { - if (err) { - console.log(err); - } else { - console.log('user: ' + usr.username + + 'saved.'); - } -})*/ - -// Passport session setup. -// To support persistent login sessions, Passport needs to be able to -// serialize users into and deserialize users out of the session. Typically, -// this will be as simple as storing the user ID when serializing, and finding -// the user by ID when deserializing. -// -// Both serializer and deserializer edited for Remember Me functionality -/* -passport.serializeUser( function(user, done) { - var createAccessToken = function() { - var token = user.generateRandomToken(); - User.findOne( { accessToken: token }, function (err, existingUser) { - if (err) return done(err); - if (existingUser) { - createAccessToken(); //run it again. has to be unique - } else { - user.set('accessToken', token); - user.save( function(err) { - if (err) return done(err); - return done(null, user.get('accessToken')); - }); - } - }); - } - console.log('serializing user'); - if (user._id) { createAccessToken(); } - else { done(null, user); } -}); - -passport.deserializeUser( function(token, done) { - console.log('deserializing ' + token.provider); - if (token.provider === undefined) { - User.findOne( { accessToken: token }, function(err, user) { - done(err, user); - }); - } else { done(null, token); } -}); - - -// to ensure that users are logged in -function ensureAuthenticated(req, res, next) { - console.log('checking to see if authenticated'); - if (req.isAuthenticated()) return next(); - res.redirect('/login'); -} -/* /* * ============================================================ * Routes @@ -122,82 +10,24 @@ function ensureAuthenticated(req, res, next) { module.exports = function(app, passport, auth) { - /* - * GET home page. - * - * '/' - */ + app.get('/', system.index); - app.get('/', function(req, res){ - res.render('index', { title: 'DERS' }); - }); + app.get('/test', system.test); - /* - * GET TEST PAGE - * - * '/test' - */ + app.get('/home', system.home); - app.get('/test', function(req, res) { - res.render('test', { - title: 'test', - loggedin: false - }); - }); - app.get('/home', function(req, res) { - res.render('home', { - title: 'home', - loggedin: false - }); - }); - /* - * GET dashboard - * - * '/dashboard' - */ + app.get('/dashboard', system.dashboard); - app.get('/dashboard', function(req, res) { - console.log('/dashboard - ' + req.user); - res.render('dashboard', { - title: 'kanin', - loggedin: true - }); - }); + app.get('/login', users.login); - /* - * GET login page - * - * '/login' - */ - - app.get('/login', function(req, res) { - res.render('login', { title: 'Logg inn' }); - }); + app.post('/login', users.signin); - /* POST */ - - app.post('/login', users.signin);/* function(req, res, next) { - passport.authenticate('local', function(err, user, info) { - if (err) return next(err); - if (!user) { - console.log('post/login'); - console.log(info.message); - req.session.messages = [info.message]; - return res.redirect('/login'); - } - req.logIn(user, function(err) { - if (err) return next(err); - return res.redirect('/dashboard'); - }) - })(req, res, next); - });*/ - // GET /auth/facebook // Use passport.authenticate() as route middleware to authenticate the // request. The first step in Facebook authentication will involve @@ -225,10 +55,7 @@ module.exports = function(app, passport, auth) { * * '/logout' */ - app.get('/logout', function(req, res) { - req.logout(); - res.redirect('/test'); - }); + app.get('/logout', users.logout); @@ -239,11 +66,7 @@ module.exports = function(app, passport, auth) { * '/project' */ - app.get('/project', function(req, res) { - res.render('project', { title: 'Harepus', loggedin: true }); - }) - - + app.get('/project', system.project); @@ -253,9 +76,7 @@ module.exports = function(app, passport, auth) { * '/signup' */ - app.get('/signup', function(req, res) { - res.render('signup', { title: 'Registrer deg' }); - }); + app.get('/signup', users.signup); /* POST */ @@ -263,21 +84,4 @@ module.exports = function(app, passport, auth) { app.post('/signup', users.create); - - - /* - * 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' }); - }); - - }; |