v1.18.x
barisusakli 11 years ago
parent f31978aa2c
commit 96b0b449b9

@ -26,7 +26,7 @@ define('forum/reset_code', function() {
password: password.val() password: password.val()
}, function(err) { }, function(err) {
if(err) { if(err) {
return app.alert(err.message); return app.alertError(err.message);
} }
$('#error').addClass('hide').hide(); $('#error').addClass('hide').hide();
$('#notice').addClass('hide').hide(); $('#notice').addClass('hide').hide();

@ -1,3 +1,5 @@
'use strict';
var db = require('../database'), var db = require('../database'),
meta = require('../meta'); meta = require('../meta');
@ -6,24 +8,35 @@ module.exports = function(User) {
User.auth.logAttempt = function(uid, callback) { User.auth.logAttempt = function(uid, callback) {
db.exists('lockout:' + uid, function(err, exists) { db.exists('lockout:' + uid, function(err, exists) {
if (!exists) { if (err) {
return callback(err);
}
if (exists) {
return callback(new Error('[[error:account-locked]]'));
}
db.increment('loginAttempts:' + uid, function(err, attempts) { db.increment('loginAttempts:' + uid, function(err, attempts) {
if (err) {
return callback(err);
}
if ((meta.config.loginAttempts || 5) < attempts) { if ((meta.config.loginAttempts || 5) < attempts) {
// Lock out the account // Lock out the account
db.set('lockout:' + uid, '', function(err) { db.set('lockout:' + uid, '', function(err) {
if (err) {
return callback(err);
}
db.delete('loginAttempts:' + uid); db.delete('loginAttempts:' + uid);
db.pexpire('lockout:' + uid, 1000*60*(meta.config.lockoutDuration || 60)); db.pexpire('lockout:' + uid, 1000 * 60 * (meta.config.lockoutDuration || 60));
callback(new Error('account-locked')); callback(new Error('account-locked'));
}); });
} else { } else {
db.pexpire('loginAttempts:' + uid, 1000*60*60); db.pexpire('loginAttempts:' + uid, 1000 * 60 * 60);
callback(); callback();
} }
}); });
} else { });
callback(new Error('[[error:account-locked]]'));
}
})
}; };
User.auth.clearLoginAttempts = function(uid) { User.auth.clearLoginAttempts = function(uid) {

@ -70,23 +70,30 @@ var async = require('async'),
return callback(err); return callback(err);
} }
if (validated) { if (!validated) {
return;
}
db.getObjectField('reset:uid', code, function(err, uid) { db.getObjectField('reset:uid', code, function(err, uid) {
if (err) { if (err) {
return callback(err); return callback(err);
} }
user.hashPassword(password, function(err, hash) { user.hashPassword(password, function(err, hash) {
if (err) {
return callback(err);
}
user.setUserField(uid, 'password', hash); user.setUserField(uid, 'password', hash);
events.logPasswordReset(uid); events.logPasswordReset(uid);
});
db.deleteObjectField('reset:uid', code); db.deleteObjectField('reset:uid', code);
db.deleteObjectField('reset:expiry', code); db.deleteObjectField('reset:expiry', code);
db.delete('lockout:' + uid);
user.auth.clearLoginAttempts(uid);
callback(null); callback();
});
}); });
}
}); });
}; };

Loading…
Cancel
Save