Commit 234b838b authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

Process all room invitations that a message may contain. JM-464

git-svn-id: http://svn.igniterealtime.org/svn/repos/messenger/trunk@3084 b35dd754-fafc-0310-a699-88a17e54d16e
parent defcbb3e
...@@ -228,8 +228,17 @@ public class MUCUserImpl implements MUCUser { ...@@ -228,8 +228,17 @@ public class MUCUserImpl implements MUCUser {
// persistence will be added. Replace locking with transactions! // persistence will be added. Replace locking with transactions!
MUCRoomImpl room = (MUCRoomImpl) role.getChatRoom(); MUCRoomImpl room = (MUCRoomImpl) role.getChatRoom();
if (userInfo != null && userInfo.element("invite") != null) { if (userInfo != null && userInfo.element("invite") != null) {
// An occupant is sending an invitation // An occupant is sending invitations
Element info = userInfo.element("invite");
// Try to keep the list of extensions sent together with the
// message invitation. These extensions will be sent to the
// invitees.
List<Element> extensions = new ArrayList<Element>(packet
.getElement().elements());
extensions.remove(userInfo);
// Send invitations to invitees
for (Iterator it=userInfo.elementIterator("invite");it.hasNext();) {
Element info = (Element) it.next();
// Add the user as a member of the room if the room is // Add the user as a member of the room if the room is
// members only // members only
...@@ -242,17 +251,12 @@ public class MUCUserImpl implements MUCUser { ...@@ -242,17 +251,12 @@ public class MUCUserImpl implements MUCUser {
room.lock.writeLock().unlock(); room.lock.writeLock().unlock();
} }
} }
// Try to keep the list of extensions sent together with the
// message invitation. These extensions will be sent to the
// invitee.
List<Element> extensions = new ArrayList<Element>(packet
.getElement().elements());
extensions.remove(userInfo);
// Send the invitation to the user // Send the invitation to the invitee
room.sendInvitation(new JID(info.attributeValue("to")), room.sendInvitation(new JID(info.attributeValue("to")),
info.elementTextTrim("reason"), role, extensions); info.elementTextTrim("reason"), role, extensions);
} }
}
else if (userInfo != null else if (userInfo != null
&& userInfo.element("decline") != null) { && userInfo.element("decline") != null) {
// An occupant has declined an invitation // An occupant has declined an invitation
......
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