ephemeral groups - guests

v1.18.x
Julian Lam 11 years ago
parent 118723e185
commit c297e2f2f8

@ -7,32 +7,49 @@
db = require('./database'), db = require('./database'),
utils = require('../public/src/utils'), utils = require('../public/src/utils'),
filterGroups = function(groups, options) { ephemeralGroups = ['guests'],
// Remove system, hidden, or deleted groups from this list
if (groups && !options.showAllGroups) { internals = {
return groups.filter(function (group) { filterGroups: function(groups, options) {
if (group.deleted || (group.hidden && !group.system) || (!options.showSystemGroups && group.system)) { // Remove system, hidden, or deleted groups from this list
return false; if (groups && !options.showAllGroups) {
return groups.filter(function (group) {
if (group.deleted || (group.hidden && !group.system) || (!options.showSystemGroups && group.system)) {
return false;
} else {
return true;
}
});
} else {
return groups;
}
},
getEphemeralGroup: function(groupName, options, callback) {
Groups.exists(groupName, function(err, exists) {
if (!err && exists) {
Groups.get.apply(null, arguments);
} else { } else {
return true; callback(null, {
name: groupName,
description: '',
deleted: '0',
hidden: '0',
system: '1'
});
} }
}); });
} else {
return groups;
} }
}; };
Groups.list = function(options, callback) { Groups.list = function(options, callback) {
db.getSetMembers('groups', function (err, groupNames) { db.getSetMembers('groups', function (err, groupNames) {
if (groupNames.length > 0) { groupNames = groupNames.concat(ephemeralGroups);
async.map(groupNames, function (groupName, next) {
Groups.get(groupName, options, next); async.map(groupNames, function (groupName, next) {
}, function (err, groups) { Groups.get(groupName, options, next);
callback(err, filterGroups(groups, options)); }, function (err, groups) {
}); callback(err, internals.filterGroups(groups, options));
} else { });
callback(null, []);
}
}); });
}; };
@ -42,15 +59,19 @@
async.parallel({ async.parallel({
base: function (next) { base: function (next) {
db.getObject('group:' + groupName, function(err, groupObj) { if (ephemeralGroups.indexOf(groupName) === -1) {
if (err) { db.getObject('group:' + groupName, function(err, groupObj) {
next(err); if (err) {
} else if (!groupObj) { next(err);
next('group-not-found'); } else if (!groupObj) {
} else { next('group-not-found');
next(err, groupObj); } else {
} next(err, groupObj);
}); }
});
} else {
internals.getEphemeralGroup(groupName, options, next);
}
}, },
users: function (next) { users: function (next) {
db.getSetMembers('group:' + groupName + ':members', function (err, uids) { db.getSetMembers('group:' + groupName + ':members', function (err, uids) {
@ -103,7 +124,7 @@
async.map(groups, function(groupName, next) { async.map(groups, function(groupName, next) {
Groups.get(groupName, options, next); Groups.get(groupName, options, next);
}, function(err, groups) { }, function(err, groups) {
callback(err, filterGroups(groups, options)); callback(err, internals.filterGroups(groups, options));
}); });
}); });
} else { } else {

Loading…
Cancel
Save