mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-11 08:25:46 +01:00
admins can create users from admin/users panel
This commit is contained in:
@@ -64,6 +64,39 @@ define(function() {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function handleUserCreate() {
|
||||||
|
$('#createUser').on('click', function() {
|
||||||
|
$('#create-modal').modal('show');
|
||||||
|
});
|
||||||
|
|
||||||
|
$('#create-modal-go').on('click', function() {
|
||||||
|
var username = $('#create-user-name').val(),
|
||||||
|
email = $('#create-user-email').val(),
|
||||||
|
password = $('#create-user-password').val(),
|
||||||
|
passwordAgain = $('#create-user-password-again').val(),
|
||||||
|
errorEl = $('#create-modal-error');
|
||||||
|
|
||||||
|
if(password !== passwordAgain) {
|
||||||
|
return errorEl.html('<strong>Error</strong><p>Passwords must match!</p>').removeClass('hide');
|
||||||
|
}
|
||||||
|
|
||||||
|
var user = {
|
||||||
|
username: username,
|
||||||
|
email: email,
|
||||||
|
password: password
|
||||||
|
};
|
||||||
|
|
||||||
|
socket.emit('api:admin.user.createUser', user, function(err, data) {
|
||||||
|
if(err) {
|
||||||
|
return errorEl.html('<strong>Error</strong><p>' + err + '</p>').removeClass('hide');
|
||||||
|
}
|
||||||
|
$('#create-modal').modal('hide');
|
||||||
|
app.alert();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
jQuery('document').ready(function() {
|
jQuery('document').ready(function() {
|
||||||
|
|
||||||
@@ -99,6 +132,8 @@ define(function() {
|
|||||||
|
|
||||||
initUsers();
|
initUsers();
|
||||||
|
|
||||||
|
handleUserCreate();
|
||||||
|
|
||||||
socket.removeAllListeners('api:admin.user.search');
|
socket.removeAllListeners('api:admin.user.search');
|
||||||
|
|
||||||
socket.on('api:admin.user.search', function(data) {
|
socket.on('api:admin.user.search', function(data) {
|
||||||
|
|||||||
@@ -41,10 +41,11 @@ define(function() {
|
|||||||
|
|
||||||
if (!utils.isEmailValid(emailEl.val())) {
|
if (!utils.isEmailValid(emailEl.val())) {
|
||||||
showError(email_notify, 'Invalid email address.');
|
showError(email_notify, 'Invalid email address.');
|
||||||
} else
|
} else {
|
||||||
socket.emit('user.email.exists', {
|
socket.emit('user.email.exists', {
|
||||||
email: emailEl.val()
|
email: emailEl.val()
|
||||||
});
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
emailEl.on('blur', function() {
|
emailEl.on('blur', function() {
|
||||||
|
|||||||
@@ -1,4 +1,6 @@
|
|||||||
<h1>Users</h1>
|
<h1>Users</h1>
|
||||||
|
|
||||||
|
<button id="createUser" class="btn btn-primary">Create User</button>
|
||||||
<hr />
|
<hr />
|
||||||
<ul class="nav nav-pills">
|
<ul class="nav nav-pills">
|
||||||
<li class='active'><a href='/admin/users/latest'>Latest Users</a></li>
|
<li class='active'><a href='/admin/users/latest'>Latest Users</a></li>
|
||||||
@@ -38,6 +40,47 @@
|
|||||||
<!-- END users -->
|
<!-- END users -->
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
|
<div class="modal fade" id="create-modal">
|
||||||
|
<div class="modal-dialog">
|
||||||
|
<div class="modal-content">
|
||||||
|
<div class="modal-header">
|
||||||
|
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
|
||||||
|
<h4 class="modal-title">Create User</h4>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
<div class="alert alert-danger hide" id="create-modal-error"></div>
|
||||||
|
<form>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="group-name">User Name</label>
|
||||||
|
<input type="text" class="form-control" id="create-user-name" placeholder="User Name" />
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="group-name">Email</label>
|
||||||
|
<input type="text" class="form-control" id="create-user-email" placeholder="Email of this user" />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="group-name">Password</label>
|
||||||
|
<input type="password" class="form-control" id="create-user-password" placeholder="Password" />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="group-name">Password Confirm</label>
|
||||||
|
<input type="password" class="form-control" id="create-user-password-again" placeholder="Password" />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
|
||||||
|
<button type="button" class="btn btn-primary" id="create-modal-go">Create</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<div class="text-center {loadmore_display}">
|
<div class="text-center {loadmore_display}">
|
||||||
<button id="load-more-users-btn" class="btn btn-primary">Load More</button>
|
<button id="load-more-users-btn" class="btn btn-primary">Load More</button>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -4,6 +4,21 @@ var utils = require('../../public/src/utils'),
|
|||||||
|
|
||||||
(function(UserAdmin) {
|
(function(UserAdmin) {
|
||||||
|
|
||||||
|
UserAdmin.createUser = function(uid, userData, callback) {
|
||||||
|
user.isAdministrator(uid, function(err, isAdmin) {
|
||||||
|
if (isAdmin) {
|
||||||
|
user.create(userData.username, userData.password, userData.email, function(err) {
|
||||||
|
if(err) {
|
||||||
|
return callback(err.message);
|
||||||
|
}
|
||||||
|
callback(null);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
callback(new Error('You are not an administrator'));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
UserAdmin.makeAdmin = function(uid, theirid, socket) {
|
UserAdmin.makeAdmin = function(uid, theirid, socket) {
|
||||||
user.isAdministrator(uid, function(err, isAdmin) {
|
user.isAdministrator(uid, function(err, isAdmin) {
|
||||||
if (isAdmin) {
|
if (isAdmin) {
|
||||||
|
|||||||
@@ -960,9 +960,10 @@ websockets.init = function(io) {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
socket.on('api:admin.user.deleteUser', function(theirid) {
|
socket.on('api:admin.user.createUser', function(user, callback) {
|
||||||
|
console.log('heeerp');
|
||||||
if (uid && uid > 0) {
|
if (uid && uid > 0) {
|
||||||
admin.user.deleteUser(uid, theirid, socket);
|
admin.user.createUser(uid, user, callback);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user