admin.js socket fixes

v1.18.x
Baris Soner Usakli 11 years ago
parent 13ae2e9401
commit a802dc4b68

@ -87,7 +87,10 @@ define(['uploader'], function(uploader) {
}; };
socket.emit('admin.categories.create', category, function(err, data) { socket.emit('admin.categories.create', category, function(err, data) {
if (!err) { if(err) {
return app.alertError(err.message);
}
app.alert({ app.alert({
alert_id: 'category_created', alert_id: 'category_created',
title: 'Created', title: 'Created',
@ -99,10 +102,10 @@ define(['uploader'], function(uploader) {
var html = templates.prepare(templates['admin/categories'].blocks['categories']).parse({ var html = templates.prepare(templates['admin/categories'].blocks['categories']).parse({
categories: [data] categories: [data]
}); });
$('#entry-container').append(html);
$('#entry-container').append(html);
$('#new-category-modal').modal('hide'); $('#new-category-modal').modal('hide');
}
}); });
} }
@ -227,6 +230,10 @@ define(['uploader'], function(uploader) {
username: searchEl.value, username: searchEl.value,
cid: cid cid: cid
}, function(err, results) { }, function(err, results) {
if(err) {
return app.alertError(err.message);
}
var numResults = results.length, var numResults = results.length,
resultObj; resultObj;
for(var x=0;x<numResults;x++) { for(var x=0;x<numResults;x++) {
@ -276,6 +283,9 @@ define(['uploader'], function(uploader) {
// User Groups and privileges // User Groups and privileges
socket.emit('admin.categories.groupsList', cid, function(err, results) { socket.emit('admin.categories.groupsList', cid, function(err, results) {
if(err) {
return app.alertError(err.message);
}
var groupsFrag = document.createDocumentFragment(), var groupsFrag = document.createDocumentFragment(),
numResults = results.length, numResults = results.length,
trEl = document.createElement('tr'), trEl = document.createElement('tr'),

@ -64,7 +64,12 @@ define(function() {
bootbox.confirm('Are you sure you wish to delete this group?', function(confirm) { bootbox.confirm('Are you sure you wish to delete this group?', function(confirm) {
if (confirm) { if (confirm) {
socket.emit('admin.groups.delete', gid, function(err, data) { socket.emit('admin.groups.delete', gid, function(err, data) {
if (data === 'OK') ajaxify.go('admin/groups'); console.log(err, data);
if(err) {
return app.alertError(err.message);
}
ajaxify.go('admin/groups');
}); });
} }
}); });

@ -64,7 +64,11 @@ define(function() {
}, false); }, false);
// Installed Themes // Installed Themes
socket.emit('admin.themes.getInstalled', function(themes) { socket.emit('admin.themes.getInstalled', function(err, themes) {
if(err) {
return app.alertError(err.message);
}
var instListEl = document.getElementById('installed_themes'), var instListEl = document.getElementById('installed_themes'),
themeFrag = document.createDocumentFragment(), themeFrag = document.createDocumentFragment(),
liEl = document.createElement('li'); liEl = document.createElement('li');

@ -54,10 +54,13 @@ define(function() {
socket.emit('admin.topics.getMore', { socket.emit('admin.topics.getMore', {
limit: 10, limit: 10,
after: lastTid after: lastTid
}, function(topics) { }, function(err, topics) {
if(err) {
return app.alertError(err.message);
}
var btnEl = document.getElementById('topics_loadmore'); var btnEl = document.getElementById('topics_loadmore');
topics = JSON.parse(topics);
if (topics.length > 0) { if (topics.length > 0) {
var html = templates.prepare(templates['admin/topics'].blocks['topics']).parse({ var html = templates.prepare(templates['admin/topics'].blocks['topics']).parse({
topics: topics topics: topics

@ -126,16 +126,19 @@ define(function() {
} }
function handleUserCreate() { function handleUserCreate() {
var errorEl = $('#create-modal-error');
$('#createUser').on('click', function() { $('#createUser').on('click', function() {
$('#create-modal').modal('show'); $('#create-modal').modal('show');
$('#create-modal form')[0].reset();
errorEl.addClass('hide');
}); });
$('#create-modal-go').on('click', function() { $('#create-modal-go').on('click', function() {
var username = $('#create-user-name').val(), var username = $('#create-user-name').val(),
email = $('#create-user-email').val(), email = $('#create-user-email').val(),
password = $('#create-user-password').val(), password = $('#create-user-password').val(),
passwordAgain = $('#create-user-password-again').val(), passwordAgain = $('#create-user-password-again').val();
errorEl = $('#create-modal-error');
if(password !== passwordAgain) { if(password !== passwordAgain) {
return errorEl.html('<strong>Error</strong><p>Passwords must match!</p>').removeClass('hide'); return errorEl.html('<strong>Error</strong><p>Passwords must match!</p>').removeClass('hide');
@ -147,14 +150,16 @@ define(function() {
password: password password: password
}; };
socket.emit('admin.user.createUser', user, function(err, data) { socket.emit('admin.user.createUser', user, function(err) {
if(err) { if(err) {
return errorEl.html('<strong>Error</strong><p>' + err + '</p>').removeClass('hide'); return errorEl.html('<strong>Error</strong><p>' + err.message + '</p>').removeClass('hide');
} }
$('#create-modal').modal('hide'); $('#create-modal').modal('hide');
app.alertSuccess('User created!'); $('#create-modal').on('hidden.bs.modal', function() {
ajaxify.go('admin/users'); ajaxify.go('admin/users');
}); });
app.alertSuccess('User created!');
});
}); });
} }
@ -191,7 +196,7 @@ define(function() {
socket.emit('admin.user.search', username, function(err, data) { socket.emit('admin.user.search', username, function(err, data) {
if(err) { if(err) {
return app.alertError(err.message); return app.alertError(err.message);
} }console.log(data)
var html = templates.prepare(templates['admin/users'].blocks['users']).parse({ var html = templates.prepare(templates['admin/users'].blocks['users']).parse({
users: data users: data

@ -6,11 +6,16 @@ var utils = require('../../public/src/utils'),
UserAdmin.createUser = function(uid, userData, callback) { UserAdmin.createUser = function(uid, userData, callback) {
user.isAdministrator(uid, function(err, isAdmin) { user.isAdministrator(uid, function(err, isAdmin) {
if(err) {
return callback(err);
}
if (isAdmin) { if (isAdmin) {
user.create(userData.username, userData.password, userData.email, function(err) { user.create(userData.username, userData.password, userData.email, function(err) {
if(err) { if(err) {
return callback(err.message); return callback(err);
} }
callback(null); callback(null);
}); });
} else { } else {

@ -122,7 +122,7 @@ var fs = require('fs'),
'theme:templates': '', 'theme:templates': '',
'theme:src': '' 'theme:src': ''
}; };
console.log(themeData);
switch(data.type) { switch(data.type) {
case 'local': case 'local':
async.waterfall([ async.waterfall([

@ -35,9 +35,11 @@ SocketAdmin.before = function(socket, next) {
SocketAdmin.topics = {}; SocketAdmin.topics = {};
SocketAdmin.topics.getMore = function(socket, data, callback) { SocketAdmin.topics.getMore = function(socket, data, callback) {
topics.getAllTopics(data.limit, data.after, function(err, topics) { if(!data) {
callback(JSON.stringify(topics)); return callback(new Error('invalid data'));
}); }
topics.getAllTopics(data.limit, data.after, callback);
}; };
/* User */ /* User */
@ -53,15 +55,18 @@ SocketAdmin.user.removeAdmin = function(socket, theirid) {
}; };
SocketAdmin.user.createUser = function(socket, user, callback) { SocketAdmin.user.createUser = function(socket, user, callback) {
if(!user) {
return callback(new Error('invalid data'));
}
admin.user.createUser(socket.uid, user, callback); admin.user.createUser(socket.uid, user, callback);
}; };
SocketAdmin.user.banUser = function(socket, theirid) { SocketAdmin.user.banUser = function(socket, theirid) {
admin.user.banUser(socket.uid, theirid, socket, function(isBanned) { admin.user.banUser(socket.uid, theirid, socket, function(isBanned) {
if(isBanned) { if(isBanned) {
if(socket.userSockets[theirid]) { if(index.userSockets[theirid]) {
for(var i=0; i<socket.userSockets[theirid].length; ++i) { for(var i=0; i<index.userSockets[theirid].length; ++i) {
socket.userSockets[theirid][i].emit('event:banned'); index.userSockets[theirid][i].emit('event:banned');
} }
} }
module.parent.exports.logoutUser(theirid); module.parent.exports.logoutUser(theirid);
@ -97,46 +102,56 @@ SocketAdmin.user.search = function(socket, username, callback) {
SocketAdmin.categories = {}; SocketAdmin.categories = {};
SocketAdmin.categories.create = function(socket, data, callback) { SocketAdmin.categories.create = function(socket, data, callback) {
categories.create(data, function(err, data) { if(!data) {
callback(err, data); return callback(new Error('invalid data'));
}); }
categories.create(data, callback);
}; };
SocketAdmin.categories.update = function(socket, data) { SocketAdmin.categories.update = function(socket, data) {
if(!data) {
return callback(new Error('invalid data'));
}
admin.categories.update(data, socket); admin.categories.update(data, socket);
}; };
SocketAdmin.categories.search = function(socket, data, callback) { SocketAdmin.categories.search = function(socket, data, callback) {
if(!data) {
return callback(new Error('invalid data'));
}
var username = data.username, var username = data.username,
cid = data.cid; cid = data.cid;
user.search(username, function(data) { user.search(username, function(data) {
async.map(data, function(userObj, next) { async.map(data, function(userObj, next) {
CategoryTools.privileges(cid, userObj.uid, function(err, privileges) { CategoryTools.privileges(cid, userObj.uid, function(err, privileges) {
if (!err) { if(err) {
userObj.privileges = privileges; return next(err);
} else {
winston.error('[socket admin.categories.search] Could not retrieve permissions');
} }
userObj.privileges = privileges;
next(null, userObj); next(null, userObj);
}); });
}, function(err, data) { }, callback);
if (!callback) {
socket.emit('admin.categories.search', data);
} else {
callback(null, data);
}
});
}); });
}; };
SocketAdmin.categories.setPrivilege = function(socket, data, callback) { SocketAdmin.categories.setPrivilege = function(socket, data, callback) {
if(!data) {
return callback(new Error('invalid data'));
}
var cid = data.cid, var cid = data.cid,
uid = data.uid, uid = data.uid,
privilege = data.privilege, privilege = data.privilege,
set = data.set, set = data.set,
cb = function(err) { cb = function(err) {
if(err) {
return callback(err);
}
CategoryTools.privileges(cid, uid, callback); CategoryTools.privileges(cid, uid, callback);
}; };
@ -172,6 +187,10 @@ SocketAdmin.categories.getPrivilegeSettings = function(socket, cid, callback) {
}); });
} }
}, function(err, data) { }, function(err, data) {
if(err) {
return callback(err);
}
callback(null, { callback(null, {
"+r": data['+r'].members, "+r": data['+r'].members,
"+w": data['+w'].members "+w": data['+w'].members
@ -180,6 +199,10 @@ SocketAdmin.categories.getPrivilegeSettings = function(socket, cid, callback) {
}; };
SocketAdmin.categories.setGroupPrivilege = function(socket, data, callback) { SocketAdmin.categories.setGroupPrivilege = function(socket, data, callback) {
if(!data) {
return callback(new Error('invalid data'));
}
if (data.set) { if (data.set) {
groups.joinByGroupName('cid:' + data.cid + ':privileges:' + data.privilege, data.gid, callback); groups.joinByGroupName('cid:' + data.cid + ':privileges:' + data.privilege, data.gid, callback);
} else { } else {
@ -189,19 +212,20 @@ SocketAdmin.categories.setGroupPrivilege = function(socket, data, callback) {
SocketAdmin.categories.groupsList = function(socket, cid, callback) { SocketAdmin.categories.groupsList = function(socket, cid, callback) {
groups.list({expand:false}, function(err, data){ groups.list({expand:false}, function(err, data){
if(err) {
return callback(err);
}
async.map(data, function(groupObj, next) { async.map(data, function(groupObj, next) {
CategoryTools.groupPrivileges(cid, groupObj.gid, function(err, privileges) { CategoryTools.groupPrivileges(cid, groupObj.gid, function(err, privileges) {
if (!err) { if(err) {
groupObj.privileges = privileges; return next(err);
} else {
winston.error('[socket admin.categories.groupsList] Could not retrieve permissions');
} }
groupObj.privileges = privileges;
next(null, groupObj); next(null, groupObj);
}); });
}, function(err, data) { }, callback);
callback(null, data);
});
}); });
}; };
@ -211,12 +235,15 @@ SocketAdmin.themes = {};
SocketAdmin.plugins = {}; SocketAdmin.plugins = {};
SocketAdmin.themes.getInstalled = function(socket, data, callback) { SocketAdmin.themes.getInstalled = function(socket, data, callback) {
meta.themes.get(function(err, themeArr) { meta.themes.get(callback);
callback(themeArr);
});
}; };
SocketAdmin.themes.set = meta.themes.set; SocketAdmin.themes.set = function(socket, data, callback) {
if(!data) {
return callback(new Error('invalid data'));
}
meta.themes.set(data, callback);
}
SocketAdmin.plugins.toggle = function(socket, plugin_id) { SocketAdmin.plugins.toggle = function(socket, plugin_id) {
plugins.toggleActive(plugin_id, function(status) { plugins.toggleActive(plugin_id, function(status) {
@ -233,6 +260,10 @@ SocketAdmin.config.get = function(socket, data, callback) {
}; };
SocketAdmin.config.set = function(socket, data, callback) { SocketAdmin.config.set = function(socket, data, callback) {
if(!data) {
return callback(new Error('invalid data'));
}
meta.configs.set(data.key, data.value, function(err) { meta.configs.set(data.key, data.value, function(err) {
if(err) { if(err) {
return callback(err); return callback(err);
@ -258,34 +289,48 @@ SocketAdmin.config.remove = function(socket, key) {
SocketAdmin.groups = {}; SocketAdmin.groups = {};
SocketAdmin.groups.create = function(socket, data, callback) { SocketAdmin.groups.create = function(socket, data, callback) {
if(!data) {
return callback(new Error('invalid data'));
}
groups.create(data.name, data.description, function(err, groupObj) { groups.create(data.name, data.description, function(err, groupObj) {
callback(err ? err.message : null, groupObj || undefined); callback(err, groupObj || undefined);
}); });
}; };
SocketAdmin.groups.delete = function(socket, gid, callback) { SocketAdmin.groups.delete = function(socket, gid, callback) {
groups.destroy(gid, function(err) { groups.destroy(gid, callback);
callback(err ? err.message : null, err ? null : 'OK');
});
}; };
SocketAdmin.groups.get = function(socket, gid, callback) { SocketAdmin.groups.get = function(socket, gid, callback) {
groups.get(gid, { groups.get(gid, {
expand: true expand: true
}, function(err, groupObj) { }, function(err, groupObj) {
callback(err ? err.message : null, groupObj || undefined); callback(err, groupObj || undefined);
}); });
}; };
SocketAdmin.groups.join = function(socket, data, callback) { SocketAdmin.groups.join = function(socket, data, callback) {
if(!data) {
return callback(new Error('invalid data'));
}
groups.join(data.gid, data.uid, callback); groups.join(data.gid, data.uid, callback);
}; };
SocketAdmin.groups.leave = function(socket, data, callback) { SocketAdmin.groups.leave = function(socket, data, callback) {
if(!data) {
return callback(new Error('invalid data'));
}
groups.leave(data.gid, data.uid, callback); groups.leave(data.gid, data.uid, callback);
}; };
SocketAdmin.groups.update = function(socket, data, callback) { SocketAdmin.groups.update = function(socket, data, callback) {
if(!data) {
return callback(new Error('invalid data'));
}
groups.update(data.gid, data.values, function(err) { groups.update(data.gid, data.values, function(err) {
callback(err ? err.message : null); callback(err ? err.message : null);
}); });

Loading…
Cancel
Save