Files
NodeBB/src/socket.io/admin/user.js

259 lines
6.0 KiB
JavaScript
Raw Normal View History

2014-04-15 02:25:42 -04:00
"use strict";
2016-01-25 13:36:10 +02:00
var async = require('async');
2016-09-27 13:31:50 +03:00
var validator = require('validator');
2016-01-25 13:36:10 +02:00
var db = require('../../database');
var groups = require('../../groups');
var user = require('../../user');
var events = require('../../events');
var meta = require('../../meta');
2014-04-15 02:25:42 -04:00
2016-01-25 13:36:10 +02:00
var User = {};
2014-04-15 02:25:42 -04:00
User.makeAdmins = function (socket, uids, callback) {
if(!Array.isArray(uids)) {
return callback(new Error('[[error:invalid-data]]'));
}
2014-04-15 02:25:42 -04:00
user.getUsersFields(uids, ['banned'], function (err, userData) {
2014-10-06 12:41:56 -04:00
if (err) {
return callback(err);
}
2016-10-13 11:42:29 +02:00
for(var i = 0; i < userData.length; i++) {
2014-10-06 12:41:56 -04:00
if (userData[i] && parseInt(userData[i].banned, 10) === 1) {
return callback(new Error('[[error:cant-make-banned-users-admin]]'));
}
}
async.each(uids, function (uid, next) {
2014-10-06 12:41:56 -04:00
groups.join('administrators', uid, next);
}, callback);
});
2014-04-15 02:25:42 -04:00
};
User.removeAdmins = function (socket, uids, callback) {
if(!Array.isArray(uids)) {
return callback(new Error('[[error:invalid-data]]'));
}
async.eachSeries(uids, function (uid, next) {
groups.getMemberCount('administrators', function (err, count) {
if (err) {
return next(err);
}
if (count === 1) {
return next(new Error('[[error:cant-remove-last-admin]]'));
}
groups.leave('administrators', uid, next);
});
}, callback);
};
User.createUser = function (socket, userData, callback) {
2014-04-15 02:25:42 -04:00
if (!userData) {
return callback(new Error('[[error:invalid-data]]'));
}
user.create(userData, callback);
};
User.resetLockouts = function (socket, uids, callback) {
2014-08-14 08:34:38 -04:00
if (!Array.isArray(uids)) {
return callback(new Error('[[error:invalid-data]]'));
}
async.each(uids, user.auth.resetLockout, callback);
};
User.resetFlags = function (socket, uids, callback) {
2014-12-21 16:29:32 -05:00
if (!Array.isArray(uids)) {
return callback(new Error('[[error:invalid-data]]'));
}
user.resetFlags(uids, callback);
};
User.validateEmail = function (socket, uids, callback) {
2014-10-06 13:11:12 -04:00
if (!Array.isArray(uids)) {
return callback(new Error('[[error:invalid-data]]'));
}
uids = uids.filter(function (uid) {
2014-10-06 13:11:12 -04:00
return parseInt(uid, 10);
});
async.each(uids, function (uid, next) {
2014-10-06 13:11:12 -04:00
user.setUserField(uid, 'email:confirmed', 1, next);
}, function (err) {
2016-01-20 16:12:57 +02:00
if (err) {
return callback(err);
}
db.sortedSetRemove('users:notvalidated', uids, callback);
});
2014-11-03 15:31:41 -05:00
};
User.sendValidationEmail = function (socket, uids, callback) {
2015-02-11 14:44:56 -05:00
if (!Array.isArray(uids)) {
return callback(new Error('[[error:invalid-data]]'));
}
2015-04-13 17:29:43 -04:00
2015-02-11 14:44:56 -05:00
if (parseInt(meta.config.requireEmailConfirmation, 10) !== 1) {
return callback(new Error('[[error:email-confirmations-are-disabled]]'));
}
user.getUsersFields(uids, ['uid', 'email'], function (err, usersData) {
2015-02-11 14:44:56 -05:00
if (err) {
return callback(err);
}
async.eachLimit(usersData, 50, function (userData, next) {
2015-02-11 14:44:56 -05:00
if (userData.email && userData.uid) {
2015-04-13 17:29:43 -04:00
user.email.sendValidationEmail(userData.uid, userData.email, next);
2015-02-11 14:44:56 -05:00
} else {
next();
}
}, callback);
});
};
User.sendPasswordResetEmail = function (socket, uids, callback) {
2014-11-03 15:31:41 -05:00
if (!Array.isArray(uids)) {
return callback(new Error('[[error:invalid-data]]'));
}
uids = uids.filter(function (uid) {
2014-11-03 15:31:41 -05:00
return parseInt(uid, 10);
});
async.each(uids, function (uid, next) {
user.getUserFields(uid, ['email', 'username'], function (err, userData) {
2014-11-03 15:31:41 -05:00
if (err) {
return next(err);
}
if (!userData.email) {
return next(new Error('[[error:user-doesnt-have-email, ' + userData.username + ']]'));
}
user.reset.send(userData.email, next);
});
2014-10-06 13:11:12 -04:00
}, callback);
};
User.deleteUsers = function (socket, uids, callback) {
deleteUsers(socket, uids, function (uid, next) {
2016-08-12 01:55:38 +03:00
user.deleteAccount(uid, next);
}, callback);
};
User.deleteUsersAndContent = function (socket, uids, callback) {
deleteUsers(socket, uids, function (uid, next) {
2016-08-12 01:55:38 +03:00
user.delete(socket.uid, uid, next);
}, callback);
};
function deleteUsers(socket, uids, method, callback) {
if (!Array.isArray(uids)) {
return callback(new Error('[[error:invalid-data]]'));
}
2014-04-15 02:25:42 -04:00
async.each(uids, function (uid, next) {
async.waterfall([
function (next) {
user.isAdministrator(uid, next);
},
function (isAdmin, next) {
if (isAdmin) {
return next(new Error('[[error:cant-delete-other-admins]]'));
}
2016-08-12 01:55:38 +03:00
method(uid, next);
},
function (next) {
2015-02-01 19:11:58 -05:00
events.log({
type: 'user-delete',
uid: socket.uid,
targetUid: uid,
ip: socket.ip
});
next();
}
], next);
}, callback);
2016-08-12 01:55:38 +03:00
}
2014-04-15 02:25:42 -04:00
User.search = function (socket, data, callback) {
user.search({query: data.query, searchBy: data.searchBy, uid: socket.uid}, function (err, searchData) {
2014-04-15 02:25:42 -04:00
if (err) {
return callback(err);
}
2014-12-21 16:29:32 -05:00
if (!searchData.users.length) {
return callback(null, searchData);
}
var userData = searchData.users;
var uids = userData.map(function (user) {
2014-12-21 16:29:32 -05:00
return user && user.uid;
});
user.getUsersFields(uids, ['email', 'flags', 'lastonline', 'joindate'], function (err, userInfo) {
2014-12-21 16:29:32 -05:00
if (err) {
return callback(err);
}
userData.forEach(function (user, index) {
2016-07-04 17:49:02 +03:00
if (user && userInfo[index]) {
2016-09-27 13:31:50 +03:00
user.email = validator.escape(String(userInfo[index].email || ''));
2016-07-04 17:49:02 +03:00
user.flags = userInfo[index].flags || 0;
2016-10-07 17:35:24 +03:00
user.lastonlineISO = userInfo[index].lastonlineISO;
user.joindateISO = userInfo[index].joindateISO;
2014-12-21 16:29:32 -05:00
}
});
2014-04-15 02:25:42 -04:00
2014-12-21 16:29:32 -05:00
callback(null, searchData);
2014-04-15 02:25:42 -04:00
});
});
};
User.deleteInvitation = function (socket, data, callback) {
user.deleteInvitation(data.invitedBy, data.email, callback);
};
User.acceptRegistration = function (socket, data, callback) {
2016-10-24 14:39:17 +03:00
user.acceptRegistration(data.username, function (err, uid) {
if (err) {
return callback(err);
}
events.log({
type: 'registration-approved',
uid: socket.uid,
ip: socket.ip,
targetUid: uid,
});
callback();
});
2015-06-27 21:26:19 -04:00
};
User.rejectRegistration = function (socket, data, callback) {
2016-10-24 14:39:17 +03:00
user.rejectRegistration(data.username, function (err) {
if (err) {
return callback(err);
}
events.log({
type: 'registration-rejected',
uid: socket.uid,
ip: socket.ip,
username: data.username,
});
callback();
});
2015-06-27 21:26:19 -04:00
};
User.restartJobs = function (socket, data, callback) {
2016-08-26 10:04:38 -04:00
user.startJobs(callback);
};
2015-06-27 21:26:19 -04:00
module.exports = User;