refactor groups.invite request member ship

v1.18.x
barisusakli 10 years ago
parent dc351fa320
commit c81d6f8b57

@ -66,26 +66,7 @@ module.exports = function(Groups) {
}; };
Groups.requestMembership = function(groupName, uid, callback) { Groups.requestMembership = function(groupName, uid, callback) {
async.parallel({ inviteOrRequestMembership(groupName, uid, 'request', callback);
exists: async.apply(Groups.exists, groupName),
isMember: async.apply(Groups.isMember, uid, groupName)
}, function(err, checks) {
if (!checks.exists) {
return callback(new Error('[[error:no-group]]'));
} else if (checks.isMember) {
return callback(new Error('[[error:group-already-member]]'));
}
if (parseInt(uid, 10) > 0) {
db.setAdd('group:' + groupName + ':pending', uid, callback);
plugins.fireHook('action:group.requestMembership', {
groupName: groupName,
uid: uid
});
} else {
callback(new Error('[[error:not-logged-in]]'));
}
});
}; };
Groups.acceptMembership = function(groupName, uid, callback) { Groups.acceptMembership = function(groupName, uid, callback) {
@ -106,27 +87,41 @@ module.exports = function(Groups) {
}; };
Groups.invite = function(groupName, uid, callback) { Groups.invite = function(groupName, uid, callback) {
async.parallel({ inviteOrRequestMembership(groupName, uid, 'invite', callback);
exists: async.apply(Groups.exists, groupName), };
isMember: async.apply(Groups.isMember, uid, groupName)
}, function(err, checks) { function inviteOrRequestMembership(groupName, uid, type, callback) {
if (!checks.exists) { if (!parseInt(uid, 10)) {
return callback(new Error('[[error:no-group]]')); return callback(new Error('[[error:not-logged-in]]'));
} else if (checks.isMember) { }
return callback(new Error('[[error:group-already-member]]')); var hookName = type === 'invite' ? 'action:group.inviteMember' : 'action:group.requestMembership';
} var set = type === 'invite' ? 'group:' + groupName + ':invited' : 'group:' + groupName + ':pending';
if (parseInt(uid, 10) > 0) { async.waterfall([
db.setAdd('group:' + groupName + ':invited', uid, callback); function(next) {
async.parallel({
exists: async.apply(Groups.exists, groupName),
isMember: async.apply(Groups.isMember, uid, groupName)
}, next);
},
function(checks, next) {
if (!checks.exists) {
return next(new Error('[[error:no-group]]'));
} else if (checks.isMember) {
return next(new Error('[[error:group-already-member]]'));
}
db.setAdd('group:' + groupName + ':invited', uid, next);
},
function(next) {
plugins.fireHook('action:group.inviteMember', { plugins.fireHook('action:group.inviteMember', {
groupName: groupName, groupName: groupName,
uid: uid uid: uid
}); });
} else { next();
callback(new Error('[[error:not-logged-in]]'));
} }
}); ], callback);
}; }
Groups.leave = function(groupName, uid, callback) { Groups.leave = function(groupName, uid, callback) {
callback = callback || function() {}; callback = callback || function() {};

Loading…
Cancel
Save