Commit ccf66078 authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gaston

Modified MemberCollection#add to remove the user from the admin/member...

Modified MemberCollection#add to remove the user from the admin/member collection if already a group user. JM-254


git-svn-id: http://svn.igniterealtime.org/svn/repos/messenger/trunk@1237 b35dd754-fafc-0310-a699-88a17e54d16e
parent 89aecbad
...@@ -267,33 +267,59 @@ public class Group implements Cacheable { ...@@ -267,33 +267,59 @@ public class Group implements Cacheable {
catch (Exception e) { catch (Exception e) {
throw new IllegalArgumentException("Invalid user.", e); throw new IllegalArgumentException("Invalid user.", e);
} }
// Find out if the user was already a group user
boolean alreadyGroupUser = false;
if (adminCollection) { if (adminCollection) {
if (members.contains(username)) { alreadyGroupUser = members.contains(username);
throw new IllegalArgumentException("The user is already a member of the group");
}
} }
else { else {
if (administrators.contains(username)) { alreadyGroupUser = administrators.contains(username);
throw new IllegalArgumentException("The user is already an admin of the group");
}
} }
if (users.add(username)) { if (users.add(username)) {
// Add the group user to the backend store. if (alreadyGroupUser) {
provider.addMember(name, username, adminCollection); // Update the group user privileges in the backend store.
provider.updateMember(name, username, adminCollection);
}
else {
// Add the group user to the backend store.
provider.addMember(name, username, adminCollection);
}
// Fire event. // Fire event.
if (adminCollection) { if (adminCollection) {
Map params = new HashMap(); Map params = new HashMap();
params.put("admin", username); params.put("admin", username);
if (alreadyGroupUser) {
GroupEventDispatcher.dispatchEvent(Group.this,
GroupEventDispatcher.EventType.member_removed, params);
}
GroupEventDispatcher.dispatchEvent(Group.this, GroupEventDispatcher.dispatchEvent(Group.this,
GroupEventDispatcher.EventType.admin_added, params); GroupEventDispatcher.EventType.admin_added, params);
} }
else { else {
Map params = new HashMap(); Map params = new HashMap();
params.put("member", username); params.put("member", username);
if (alreadyGroupUser) {
GroupEventDispatcher.dispatchEvent(Group.this,
GroupEventDispatcher.EventType.admin_removed, params);
}
GroupEventDispatcher.dispatchEvent(Group.this, GroupEventDispatcher.dispatchEvent(Group.this,
GroupEventDispatcher.EventType.member_added, params); GroupEventDispatcher.EventType.member_added, params);
} }
// If the user was a member that became an admin or vice versa then remove the
// user from the other collection
if (alreadyGroupUser) {
if (adminCollection) {
if (members.contains(username)) {
members.remove(username);
}
}
else {
if (administrators.contains(username)) {
administrators.remove(username);
}
}
}
return true; return true;
} }
return false; return false;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment