|
|
@ -43,20 +43,14 @@ var async = require('async'),
|
|
|
|
return groups;
|
|
|
|
return groups;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
getEphemeralGroup: function(groupName, options, callback) {
|
|
|
|
getEphemeralGroup: function(groupName) {
|
|
|
|
Groups.exists(groupName, function(err, exists) {
|
|
|
|
return {
|
|
|
|
if (!err && exists) {
|
|
|
|
name: groupName,
|
|
|
|
Groups.get.apply(null, arguments);
|
|
|
|
description: '',
|
|
|
|
} else {
|
|
|
|
deleted: '0',
|
|
|
|
callback(null, {
|
|
|
|
hidden: '0',
|
|
|
|
name: groupName,
|
|
|
|
system: '1'
|
|
|
|
description: '',
|
|
|
|
};
|
|
|
|
deleted: '0',
|
|
|
|
|
|
|
|
hidden: '0',
|
|
|
|
|
|
|
|
system: '1'
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
},
|
|
|
|
},
|
|
|
|
removeEphemeralGroups: function(groups) {
|
|
|
|
removeEphemeralGroups: function(groups) {
|
|
|
|
var x = groups.length;
|
|
|
|
var x = groups.length;
|
|
|
@ -95,6 +89,9 @@ var async = require('async'),
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
Groups.get = function(groupName, options, callback) {
|
|
|
|
Groups.get = function(groupName, options, callback) {
|
|
|
|
|
|
|
|
if (!arguments[0]) {
|
|
|
|
|
|
|
|
console.log(new Error.stack);
|
|
|
|
|
|
|
|
}
|
|
|
|
var truncated = false,
|
|
|
|
var truncated = false,
|
|
|
|
numUsers;
|
|
|
|
numUsers;
|
|
|
|
|
|
|
|
|
|
|
@ -103,7 +100,7 @@ var async = require('async'),
|
|
|
|
if (ephemeralGroups.indexOf(groupName) === -1) {
|
|
|
|
if (ephemeralGroups.indexOf(groupName) === -1) {
|
|
|
|
db.getObject('group:' + groupName, next);
|
|
|
|
db.getObject('group:' + groupName, next);
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
internals.getEphemeralGroup(groupName, options, next);
|
|
|
|
next(null, internals.getEphemeralGroup(groupName));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
users: function (next) {
|
|
|
|
users: function (next) {
|
|
|
@ -400,6 +397,11 @@ var async = require('async'),
|
|
|
|
return utils.slugify(groupName);
|
|
|
|
return utils.slugify(groupName);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
async.parallel([
|
|
|
|
async.parallel([
|
|
|
|
|
|
|
|
function(next) {
|
|
|
|
|
|
|
|
callback(null, slugs.map(function(slug) {
|
|
|
|
|
|
|
|
return ephemeralGroups.indexOf(slug) !== -1;
|
|
|
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
},
|
|
|
|
async.apply(db.isObjectFields, 'groupslug:groupname', slugs),
|
|
|
|
async.apply(db.isObjectFields, 'groupslug:groupname', slugs),
|
|
|
|
async.apply(db.isSortedSetMembers, 'groups:createtime', name)
|
|
|
|
async.apply(db.isSortedSetMembers, 'groups:createtime', name)
|
|
|
|
], function(err, results) {
|
|
|
|
], function(err, results) {
|
|
|
@ -407,17 +409,20 @@ var async = require('async'),
|
|
|
|
return callback(err);
|
|
|
|
return callback(err);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
callback(null, results.map(function(pair) {
|
|
|
|
callback(null, results.map(function(result) {
|
|
|
|
return pair[0] || pair[1];
|
|
|
|
return result[0] || result[1] || result[2];
|
|
|
|
}));
|
|
|
|
}));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
var slug = utils.slugify(name);
|
|
|
|
var slug = utils.slugify(name);
|
|
|
|
async.parallel([
|
|
|
|
async.parallel([
|
|
|
|
|
|
|
|
function(next) {
|
|
|
|
|
|
|
|
next(null, ephemeralGroups.indexOf(slug) !== -1);
|
|
|
|
|
|
|
|
},
|
|
|
|
async.apply(db.isObjectField, 'groupslug:groupname', slug),
|
|
|
|
async.apply(db.isObjectField, 'groupslug:groupname', slug),
|
|
|
|
async.apply(db.isSortedSetMember, 'groups:createtime', name)
|
|
|
|
async.apply(db.isSortedSetMember, 'groups:createtime', name)
|
|
|
|
], function(err, results) {
|
|
|
|
], function(err, results) {
|
|
|
|
callback(err, !err ? (results[0] || results[1]) : null);
|
|
|
|
callback(err, !err ? (results[0] || results[1] || results[2]) : null);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
|