aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--config/middlewares/authorization.js2
-rw-r--r--controllers/users.js2
-rw-r--r--modules/account-manager.js.old196
-rw-r--r--modules/email-dispatcher.js36
-rw-r--r--modules/passport-local.js91
-rw-r--r--public/css/need.less4
-rw-r--r--views/dashboard.ejs2
7 files changed, 5 insertions, 328 deletions
diff --git a/config/middlewares/authorization.js b/config/middlewares/authorization.js
index 440f085..8d822f0 100644
--- a/config/middlewares/authorization.js
+++ b/config/middlewares/authorization.js
@@ -5,7 +5,7 @@
*/
exports.requiresLogin = function(req, res, next) {
- if (!req.isAuthenticated()) return res.redirect('/login');
+ if (!req.isAuthenticated()) return res.redirect('/test');
next();
}
diff --git a/controllers/users.js b/controllers/users.js
index d465468..6571b85 100644
--- a/controllers/users.js
+++ b/controllers/users.js
@@ -22,7 +22,7 @@ exports.login = function(req, res) {
*/
exports.logout = function(req, res) {
req.logout();
- res.resirect('/test');
+ res.redirect('/test');
}
diff --git a/modules/account-manager.js.old b/modules/account-manager.js.old
deleted file mode 100644
index b9cb1f9..0000000
--- a/modules/account-manager.js.old
+++ /dev/null
@@ -1,196 +0,0 @@
-
-var crypto = require('crypto')
-var MongoDB = require('mongodb').Db;
-var Server = require('mongodb').Server;
-var moment = require('moment');
-
-var dbPort = 27017;
-var dbHost = 'localhost';
-var dbName = 'DERStest';
-
-/* establish the database connection */
-
-var db = new MongoDB(dbName, new Server(dbHost, dbPort, {auto_reconnect: true}), {w: 1});
- db.open(function(e, d){
- if (e) {
- console.log(e);
- } else{
- console.log('connected to database :: ' + dbName);
- }
-});
-var accounts = db.collection('accounts');
-
-/* login validation methods */
-
-exports.autoLogin = function(user, pass, callback)
-{
- accounts.findOne({user:user}, function(e, o) {
- if (o){
- o.pass == pass ? callback(o) : callback(null);
- } else{
- callback(null);
- }
- });
-}
-
-exports.manualLogin = function(user, pass, callback)
-{
- accounts.findOne({user:user}, function(e, o) {
- if (o == null){
- callback('user-not-found');
- } else{
- validatePassword(pass, o.pass, function(err, res) {
- if (res){
- callback(null, o);
- } else{
- callback('invalid-password');
- }
- });
- }
- });
-}
-
-/* record insertion, update & deletion methods */
-
-exports.addNewAccount = function(newData, callback)
-{
- accounts.findOne({user:newData.user}, function(e, o) {
- if (o){
- callback('username-taken');
- } else{
- accounts.findOne({email:newData.email}, function(e, o) {
- if (o){
- callback('email-taken');
- } else{
- saltAndHash(newData.pass, function(hash){
- newData.pass = hash;
- // append date stamp when record was created //
- newData.date = moment().format('MMMM Do YYYY, h:mm:ss a');
- accounts.insert(newData, {safe: true}, callback);
- });
- }
- });
- }
- });
-}
-
-exports.updateAccount = function(newData, callback)
-{
- accounts.findOne({user:newData.user}, function(e, o){
- o.name = newData.name;
- o.email = newData.email;
- o.country = newData.country;
- if (newData.pass == ''){
- accounts.save(o, {safe: true}, callback);
- } else{
- saltAndHash(newData.pass, function(hash){
- o.pass = hash;
- accounts.save(o, {safe: true}, callback);
- });
- }
- });
-}
-
-exports.updatePassword = function(email, newPass, callback)
-{
- accounts.findOne({email:email}, function(e, o){
- if (e){
- callback(e, null);
- } else{
- saltAndHash(newPass, function(hash){
- o.pass = hash;
- accounts.save(o, {safe: true}, callback);
- });
- }
- });
-}
-
-/* account lookup methods */
-
-exports.deleteAccount = function(id, callback)
-{
- accounts.remove({_id: getObjectId(id)}, callback);
-}
-
-exports.getAccountByEmail = function(email, callback)
-{
- accounts.findOne({email:email}, function(e, o){ callback(o); });
-}
-
-exports.validateResetLink = function(email, passHash, callback)
-{
- accounts.find({ $and: [{email:email, pass:passHash}] }, function(e, o){
- callback(o ? 'ok' : null);
- });
-}
-
-exports.getAllRecords = function(callback)
-{
- accounts.find().toArray(
- function(e, res) {
- if (e) callback(e)
- else callback(null, res)
- });
-};
-
-exports.delAllRecords = function(callback)
-{
- accounts.remove({}, callback); // reset accounts collection for testing //
-}
-
-/* private encryption & validation methods */
-
-var generateSalt = function()
-{
- var set = '0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ';
- var salt = '';
- for (var i = 0; i < 10; i++) {
- var p = Math.floor(Math.random() * set.length);
- salt += set[p];
- }
- return salt;
-}
-
-var md5 = function(str) {
- return crypto.createHash('md5').update(str).digest('hex');
-}
-
-var saltAndHash = function(pass, callback)
-{
- var salt = generateSalt();
- callback(salt + md5(pass + salt));
-}
-
-var validatePassword = function(plainPass, hashedPass, callback)
-{
- var salt = hashedPass.substr(0, 10);
- var validHash = salt + md5(plainPass + salt);
- callback(null, hashedPass === validHash);
-}
-
-/* auxiliary methods */
-
-var getObjectId = function(id)
-{
- return accounts.db.bson_serializer.ObjectID.createFromHexString(id)
-}
-
-var findById = function(id, callback)
-{
- accounts.findOne({_id: getObjectId(id)},
- function(e, res) {
- if (e) callback(e)
- else callback(null, res)
- });
-};
-
-
-var findByMultipleFields = function(a, callback)
-{
-// this takes an array of name/val pairs to search against {fieldName : 'value'} //
- accounts.find( { $or : a } ).toArray(
- function(e, results) {
- if (e) callback(e)
- else callback(null, results)
- });
-}
diff --git a/modules/email-dispatcher.js b/modules/email-dispatcher.js
deleted file mode 100644
index b0c40a2..0000000
--- a/modules/email-dispatcher.js
+++ /dev/null
@@ -1,36 +0,0 @@
-
-var ES = require('../config/email-settings');
-var EM = {};
-module.exports = EM;
-
-EM.server = require("emailjs/email").server.connect({
-
- host : ES.host,
- user : ES.user,
- password : ES.password,
- ssl : true
-
-});
-
-EM.dispatchResetPasswordLink = function(account, callback)
-{
- EM.server.send({
- from : ES.sender,
- to : account.email,
- subject : 'Password Reset',
- text : 'something went wrong... :(',
- attachment : EM.composeEmail(account)
- }, callback );
-}
-
-EM.composeEmail = function(o)
-{
- var link = 'https://divid.no/reset-password?e='+o.email+'&p='+o.pass;
- var html = "<html><body>";
- html += "Hi "+o.name+",<br><br>";
- html += "Your username is :: <b>"+o.user+"</b><br><br>";
- html += "<a href='"+link+"'>Please click here to reset your password</a><br><br>";
- html += "Cheers<br>";
- html += "</body></html>";
- return [{data:html, alternative:true}];
-}
diff --git a/modules/passport-local.js b/modules/passport-local.js
deleted file mode 100644
index b269707..0000000
--- a/modules/passport-local.js
+++ /dev/null
@@ -1,91 +0,0 @@
-var mongoose = require('mongoose')
- , passport = require('passport')
- , LocalStrategy = require('passport-local').Strategy
- , SALT_WORK_FACTOR = 10;
-
-
-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 schema
-var userSchema = mongoose.Schema({
- username: { type: String, required: true, unique: true },
- email: { type: String, required: true, unique: true },
- password: { type: String, required: true, unique: true},
-});
-
-// 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) {
- if (err) return next(err);
- user.password = hash;
- next();
- });
- });
-});
-
-// Password verification
-userSchema.methods.comparePassword = function(candidatePassword, callback) {
- bcrypt.compare(candidatePassword, this.password, function(err, isMatch) {
- if (err) return callback(err);
- callback(null, isMatch);
- });
-};
-
-
-
-
-// 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.
-passport.serializeUser(function(user, done) {
- done(null, user.id);
-});
-
-passport.deserializeUser(function(id, done) {
- User.findById(id, function (err, user) {
- done(err, user);
- });
-});
-
-
-// Use the LocalStrategy within Passport.
-// Strategies in passport require a `verify` function, which accept
-// credentials (in this case, a username and password), and invoke a callback
-// with a user object. In the real world, this would query a database;
-// however, in this example we are using a baked-in set of users.
-passport.use(new LocalStrategy(function(username, password, done) {
- User.findOne({ username: username }, function(err, user) {
- if (err) return done(err);
- if (!user) { return done(null, false, { message: 'Unknown user ' + username }); }
- user.comparePassword(password, function(err, isMatch) {
- if (err) return done(err);
- if(isMatch) {
- return done(null, user);
- } else {
- return done(null, false, { message: 'Invalid password' });
- }
- });
- });
-}));
-
-
-
-
-
-
diff --git a/public/css/need.less b/public/css/need.less
index cb5fa36..478737a 100644
--- a/public/css/need.less
+++ b/public/css/need.less
@@ -1,4 +1,4 @@
-/*Temporary/*
+/* Temporary*/
.que:hover {
text-decoration: none;
-} \ No newline at end of file
+}
diff --git a/views/dashboard.ejs b/views/dashboard.ejs
index 9009686..5eca9f1 100644
--- a/views/dashboard.ejs
+++ b/views/dashboard.ejs
@@ -15,7 +15,7 @@
<section class="project">
<div class="row-fluid">
<div class="span11">
- <h1><a href="/dennisse/hyttetur">dennisse/<strong>hytteturskogentilfrank</strong></a></h1>
+ <h1><a href="/project">dennisse/<strong>hytteturskogentilfrank</strong></a></h1>
<div class="row-fluid">
<div class="span8">
<small>Meg, Robert, Turid-Laila, Kurt, Stian, Aleksander, Frank, Olav, Heidi, Anette, Kristine</small>