newly created groups automatically assign the creator as the owner, some tweaks to isPrivate parsing, added groups link to header, #2588

v1.18.x
Julian Lam 10 years ago
parent 65537d997f
commit 84c19921b9

@ -33,6 +33,7 @@
"header.tags": "Tags", "header.tags": "Tags",
"header.popular": "Popular", "header.popular": "Popular",
"header.users": "Users", "header.users": "Users",
"header.groups": "Groups",
"header.chats": "Chats", "header.chats": "Chats",
"header.notifications": "Notifications", "header.notifications": "Notifications",
"header.search": "Search", "header.search": "Search",

@ -49,7 +49,7 @@ define('admin/manage/groups', [
}, },
errorText; errorText;
socket.emit('admin.groups.create', submitObj, function(err, data) { socket.emit('admin.groups.create', submitObj, function(err) {
if (err) { if (err) {
switch (err) { switch (err) {
case 'group-exists': case 'group-exists':
@ -68,7 +68,7 @@ define('admin/manage/groups', [
createModalError.addClass('hide'); createModalError.addClass('hide');
createGroupName.val(''); createGroupName.val('');
createModal.on('hidden.bs.modal', function() { createModal.on('hidden.bs.modal', function() {
ajaxify.go('admin/manage/groups'); ajaxify.refresh();
}); });
createModal.modal('hide'); createModal.modal('hide');
} }

@ -204,7 +204,13 @@ var async = require('async'),
Groups.isPrivate = function(groupName, callback) { Groups.isPrivate = function(groupName, callback) {
db.getObjectField('group:' + groupName, 'private', function(err, isPrivate) { db.getObjectField('group:' + groupName, 'private', function(err, isPrivate) {
callback(err, isPrivate || isPrivate === null); // Private, if not set at all isPrivate = isPrivate || isPrivate === null;
if (typeof isPrivate === 'string') {
isPrivate = (isPrivate === '0' ? false : true);
}
callback(err, isPrivate); // Private, if not set at all
}); });
}; };
@ -358,16 +364,16 @@ var async = require('async'),
} }
}; };
Groups.create = function(name, description, callback) { Groups.create = function(data, callback) {
if (name.length === 0) { if (data.name.length === 0) {
return callback(new Error('[[error:group-name-too-short]]')); return callback(new Error('[[error:group-name-too-short]]'));
} }
if (name === 'administrators' || name === 'registered-users') { if (data.name === 'administrators' || data.name === 'registered-users') {
var system = true; var system = true;
} }
meta.userOrGroupExists(name, function (err, exists) { meta.userOrGroupExists(data.name, function (err, exists) {
if (err) { if (err) {
return callback(err); return callback(err);
} }
@ -377,24 +383,25 @@ var async = require('async'),
} }
var groupData = { var groupData = {
name: name, name: data.name,
userTitle: name, userTitle: data.name,
description: description, description: data.description,
deleted: '0', deleted: '0',
hidden: '0', hidden: '0',
system: system ? '1' : '0' system: system ? '1' : '0',
}; 'private': data.private || '1'
async.parallel([
function(next) {
db.setAdd('groups', name, next);
}, },
function(next) { tasks = [
db.setObject('group:' + name, groupData, function(err) { async.apply(db.setAdd, 'groups', data.name),
Groups.get(name, {}, next); async.apply(db.setObject, 'group:' + data.name, groupData)
}); ];
if (data.hasOwnProperty('ownerUid')) {
tasks.push(async.apply(db.setAdd, 'group:' + data.name + ':owners', data.ownerUid));
tasks.push(async.apply(db.setAdd, 'group:' + data.name + ':members', data.ownerUid));
} }
], callback);
async.parallel(tasks, callback);
}); });
}; };
@ -529,7 +536,10 @@ var async = require('async'),
uid: uid uid: uid
}); });
} else { } else {
Groups.create(groupName, '', function(err) { Groups.create({
name: groupName,
description: ''
}, function(err) {
if (err && err.message !== '[[error:group-already-exists]]') { if (err && err.message !== '[[error:group-already-exists]]') {
winston.error('[groups.join] Could not create new hidden group: ' + err.message); winston.error('[groups.join] Could not create new hidden group: ' + err.message);
return callback(err); return callback(err);

@ -8,9 +8,11 @@ Groups.create = function(socket, data, callback) {
return callback(new Error('[[error:invalid-data]]')); return callback(new Error('[[error:invalid-data]]'));
} }
groups.create(data.name, data.description, function(err, groupObj) { groups.create({
callback(err, groupObj || undefined); name: data.name,
}); description: data.description,
ownerUid: socket.uid
}, callback);
}; };
Groups.delete = function(socket, groupName, callback) { Groups.delete = function(socket, groupName, callback) {

Loading…
Cancel
Save