* Apply now semi functional

This commit is contained in:
Bryan Ashby 2015-04-14 22:27:07 -06:00
parent 77600d3dde
commit 5eee568586
4 changed files with 119 additions and 63 deletions

View File

@ -27,6 +27,12 @@ module.exports = {
preLoginTheme : '*', preLoginTheme : '*',
users : {
usernameMin : 2,
usernameMax : 22,
passwordMin : 6,
},
paths : { paths : {
mods : paths.join(__dirname, './../mods/'), mods : paths.join(__dirname, './../mods/'),
servers : paths.join(__dirname, './servers/'), servers : paths.join(__dirname, './servers/'),

View File

@ -177,7 +177,7 @@ User.prototype.create = function(options, cb) {
); );
}, },
function genAuthCredentials(callback) { function genAuthCredentials(callback) {
generatePasswordDerivedKeySalt(options.password, function dkAndSalt(err, info) { generatePasswordDerivedKeyAndSalt(options.password, function dkAndSalt(err, info) {
if(err) { if(err) {
callback(err); callback(err);
} else { } else {
@ -188,8 +188,9 @@ User.prototype.create = function(options, cb) {
}); });
}, },
function saveAll(callback) { function saveAll(callback) {
// :TODO: persist all data - props/etc. self.persist(false, function persisted(err) {
callback(null); callback(err);
});
} }
], ],
function complete(err) { function complete(err) {
@ -211,6 +212,8 @@ User.prototype.create = function(options, cb) {
User.prototype.persist = function(useTransaction, cb) { User.prototype.persist = function(useTransaction, cb) {
assert(this.userId > 0); assert(this.userId > 0);
var self = this;
async.series( async.series(
[ [
function beginTransaction(callback) { function beginTransaction(callback) {
@ -223,7 +226,7 @@ User.prototype.persist = function(useTransaction, cb) {
} }
}, },
function saveProps(callback) { function saveProps(callback) {
persistProperties(this, function persisted(err) { persistProperties(self, function persisted(err) {
callback(err); callback(err);
}); });
} }
@ -250,6 +253,31 @@ User.prototype.persist = function(useTransaction, cb) {
); );
}; };
User.prototype.persistProperties = function(cb) {
assert(this.userId > 0);
var self = this;
var stmt = userDb.prepare(
'REPLACE INTO user_property (user_id, prop_name, prop_value) ' +
'VALUES (?, ?, ?);');
async.each(Object.keys(this.properties), function property(propName, callback) {
stmt.run(self.userId, propName, self.properties[propName], function onRun(err) {
callback(err);
});
}, function complete(err) {
if(err) {
cb(err);
} else {
stmt.finalize(function finalized() {
cb(null);
});
}
});
};
function createNew(user, cb) { function createNew(user, cb) {
assert(user.username && user.username.length > 1, 'Invalid userName'); assert(user.username && user.username.length > 1, 'Invalid userName');

View File

@ -8,6 +8,9 @@ var theme = require('../core/theme.js');
var Log = require('../core/logger.js').log; var Log = require('../core/logger.js').log;
var MenuModule = require('../core/menu_module.js').MenuModule; var MenuModule = require('../core/menu_module.js').MenuModule;
var ViewController = require('../core/view_controller.js').ViewController; var ViewController = require('../core/view_controller.js').ViewController;
var Config = require('../core/config.js').config;
var util = require('util');
//var async = require('async'); //var async = require('async');
@ -28,11 +31,81 @@ function ApplyModule(menuConfig) {
var self = this; var self = this;
this.menuMethods.submitApplication = function(args) { this.menuMethods.submitApplication = function(args) {
console.log('do submit') var usernameView = self.viewController.getView(1);
var passwordView = self.viewController.getView(9);
var pwConfirmView = self.viewController.getView(10);
var statusView = self.viewController.getView(11);
self.validateApplication(args, function validated(errString, clearFields) {
if(errString) {
statusView.setText(errString);
clearFields.forEach(function formId(id) {
self.viewController.getView(id).setText('');
});
self.viewController.switchFocus(clearFields[0]);
} else {
var newUser = new user.User();
newUser.username = args.username;
newUser.properties = {
real_name : args.realName,
age : args.age,
sex : args.sex,
location : args.location,
affiliation : args.affils,
email_address : args.email,
web_address : args.web,
// :TODO: Other defaults
// :TODO: should probably have a place to create defaults/etc.
// :TODO: set account_status to default based on Config.user...
};
newUser.create({ password : args.pw }, function created(err) {
if(err) {
console.log(err)
} else {
Log.info( { username : args.username, userId : newUser.userId }, 'New user created');
}
});
}
});
};
this.validateApplication = function(args, cb) {
if(args.username.length < Config.users.usernameMin) {
cb('Handle too short!', [ 1 ]);
return;
}
if(args.username.length > Config.users.usernameMax) {
cb('Handle too long!', [ 1 ]);
return;
}
if(args.pw.length < Config.users.passwordMin) {
cb('Password too short!', [ 9, 10 ]);
return;
}
if(args.pw !== args.pwConfirm) {
cb('Passwords do not match!', [ 9, 10 ]);
return;
}
user.getUserIdAndName(args.username, function userIdAndName(err) {
var alreadyExists = !err;
if(alreadyExists) {
cb('Username unavailable!', [ 1 ] );
} else {
cb(null);
}
});
}; };
} }
require('util').inherits(ApplyModule, MenuModule); util.inherits(ApplyModule, MenuModule);
ApplyModule.prototype.enter = function(client) { ApplyModule.prototype.enter = function(client) {
ApplyModule.super_.prototype.enter.call(this, client); ApplyModule.super_.prototype.enter.call(this, client);
@ -49,61 +122,6 @@ ApplyModule.prototype.mciReady = function(mciMap) {
self.viewController = self.addViewController(new ViewController({ client : self.client } )); self.viewController = self.addViewController(new ViewController({ client : self.client } ));
self.viewController.loadFromMCIMapAndConfig( { mciMap : mciMap, menuConfig : self.menuConfig }, function onViewReady(err) { self.viewController.loadFromMCIMapAndConfig( { mciMap : mciMap, menuConfig : self.menuConfig }, function onViewReady(err) {
var usernameView = self.viewController.getView(1);
var passwordView = self.viewController.getView(9);
var pwConfirmView = self.viewController.getView(10);
var statusView = self.viewController.getView(11);
self.viewController.on('leave', function leaveView(view) {
switch(view.getId()) {
case 1 :
user.getUserIdAndName(view.getViewData(), function userIdAndName(err) {
var alreadyExists = !err;
if(alreadyExists) {
statusView.setText('Username unavailable!');
self.viewController.switchFocus(1); // don't allow to leave
} else {
statusView.setText('');
self.viewController.switchFocus(2);
}
});
break;
}
});
/*
usernameView.on('leave', function leaveUsername() {
user.getUserIdAndName(usernameView.getViewData(), function userIdAndName(err) {
var alreadyExists = !err;
if(alreadyExists) {
statusView.setText('Username unavailable!');
self.viewController.switchFocus(1); // don't allow to leave
} else {
statusView.setText('');
self.viewController.switchFocus(2);
}
});
});
passwordView.on('leave', function leavePw() {
if(passwordView.getViewData().length < 3) {
statusView.setText('Password too short!');
self.viewController.switchFocus(9);
} else {
statusView.setText('');
}
});
pwConfirmView.on('leave', function leavePwConfirm() {
if(passwordView.getViewData() !== pwConfirmView.getViewData()) {
statusView.setText('Passwords must match!');
self.viewController.switchFocus(9);
} else {
statusView.setText('');
}
});
*/
}); });
}; };

View File

@ -124,6 +124,9 @@
{ {
"value" : { "12" : null }, "value" : { "12" : null },
"action" : "@method:submitApplication", "action" : "@method:submitApplication",
// :TODO: Need a way to supply next menu based on data from @method
// @method:submitApplication|nextMenu1|nextMenu2|nextMenu3 ? method could cb(indexValue)
"args" : { "args" : {
"username" : "{1}", "username" : "{1}",
"realName" : "{2}", "realName" : "{2}",
@ -133,7 +136,8 @@
"affils" : "{6}", "affils" : "{6}",
"email" : "{7}", "email" : "{7}",
"web" : "{8}", "web" : "{8}",
"password" : "{9}" "pw" : "{9}",
"pwConfirm" : "{10}"
} }
} }
], ],