Commit 80ce9b52 authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gaston

1) A NotAllowedException is now thrown instead of sending an error as a reply.

2) Modified methods that were receiveing an Iterator to receive a Collection.


git-svn-id: http://svn.igniterealtime.org/svn/repos/messenger/trunk@495 b35dd754-fafc-0310-a699-88a17e54d16e
parent 00828f8b
...@@ -64,8 +64,10 @@ public class IQAdminHandler { ...@@ -64,8 +64,10 @@ public class IQAdminHandler {
* @throws ForbiddenException If the user is not allowed to perform his request. * @throws ForbiddenException If the user is not allowed to perform his request.
* @throws ConflictException If the desired room nickname is already reserved for the room or * @throws ConflictException If the desired room nickname is already reserved for the room or
* if the room was going to lose all of its owners. * if the room was going to lose all of its owners.
* @throws NotAllowedException Thrown if trying to ban an owner or an administrator.
*/ */
public void handleIQ(IQ packet, MUCRole role) throws ForbiddenException, ConflictException { public void handleIQ(IQ packet, MUCRole role) throws ForbiddenException, ConflictException,
NotAllowedException {
IQ reply = packet.createResult(); IQ reply = packet.createResult();
Element element = ((XMPPDOMFragment)packet.getChildFragment()).getRootElement(); Element element = ((XMPPDOMFragment)packet.getChildFragment()).getRootElement();
...@@ -99,9 +101,10 @@ public class IQAdminHandler { ...@@ -99,9 +101,10 @@ public class IQAdminHandler {
* @throws ForbiddenException If the user is not allowed to perform his request. * @throws ForbiddenException If the user is not allowed to perform his request.
* @throws ConflictException If the desired room nickname is already reserved for the room or * @throws ConflictException If the desired room nickname is already reserved for the room or
* if the room was going to lose all of its owners. * if the room was going to lose all of its owners.
* @throws NotAllowedException Thrown if trying to ban an owner or an administrator.
*/ */
private void handleItemsElement(MUCRole senderRole, List itemsList, IQ reply) private void handleItemsElement(MUCRole senderRole, List itemsList, IQ reply)
throws ForbiddenException, ConflictException { throws ForbiddenException, ConflictException, NotAllowedException {
Element item; Element item;
String affiliation = null; String affiliation = null;
String roleAttribute = null; String roleAttribute = null;
...@@ -120,16 +123,13 @@ public class IQAdminHandler { ...@@ -120,16 +123,13 @@ public class IQAdminHandler {
.get("query", "http://jabber.org/protocol/muc#admin"))); .get("query", "http://jabber.org/protocol/muc#admin")));
MetaDataFragment metaData; MetaDataFragment metaData;
MUCRole role;
if ("outcast".equals(affiliation)) { if ("outcast".equals(affiliation)) {
// The client is requesting the list of outcasts // The client is requesting the list of outcasts
if (MUCRole.ADMINISTRATOR != senderRole.getAffiliation() if (MUCRole.ADMINISTRATOR != senderRole.getAffiliation()
&& MUCRole.OWNER != senderRole.getAffiliation()) { && MUCRole.OWNER != senderRole.getAffiliation()) {
throw new ForbiddenException(); throw new ForbiddenException();
} }
String jid; for (String jid : room.getOutcasts()) {
for (Iterator<String> it = room.getOutcasts(); it.hasNext();) {
jid = it.next();
metaData = new MetaDataFragment("http://jabber.org/protocol/muc#admin", metaData = new MetaDataFragment("http://jabber.org/protocol/muc#admin",
"item"); "item");
metaData.setProperty("item:affiliation", "outcast"); metaData.setProperty("item:affiliation", "outcast");
...@@ -148,16 +148,14 @@ public class IQAdminHandler { ...@@ -148,16 +148,14 @@ public class IQAdminHandler {
&& MUCRole.OWNER != senderRole.getAffiliation()) { && MUCRole.OWNER != senderRole.getAffiliation()) {
throw new ForbiddenException(); throw new ForbiddenException();
} }
String jid; for (String jid : room.getMembers()) {
for (Iterator<String> it = room.getMembers(); it.hasNext();) {
jid = it.next();
metaData = new MetaDataFragment("http://jabber.org/protocol/muc#admin", metaData = new MetaDataFragment("http://jabber.org/protocol/muc#admin",
"item"); "item");
metaData.setProperty("item:affiliation", "member"); metaData.setProperty("item:affiliation", "member");
metaData.setProperty("item:jid", jid); metaData.setProperty("item:jid", jid);
try { try {
List<MUCRole> roles = room.getOccupantsByBareJID(jid); List<MUCRole> roles = room.getOccupantsByBareJID(jid);
role = roles.get(0); MUCRole role = roles.get(0);
metaData.setProperty("item:role", role.getRoleAsString()); metaData.setProperty("item:role", role.getRoleAsString());
metaData.setProperty("item:nick", role.getNickname()); metaData.setProperty("item:nick", role.getNickname());
} }
...@@ -176,8 +174,7 @@ public class IQAdminHandler { ...@@ -176,8 +174,7 @@ public class IQAdminHandler {
&& MUCRole.OWNER != senderRole.getAffiliation()) { && MUCRole.OWNER != senderRole.getAffiliation()) {
throw new ForbiddenException(); throw new ForbiddenException();
} }
for (Iterator<MUCRole> roles = room.getModerators(); roles.hasNext();) { for (MUCRole role : room.getModerators()) {
role = roles.next();
metaData = new MetaDataFragment("http://jabber.org/protocol/muc#admin", metaData = new MetaDataFragment("http://jabber.org/protocol/muc#admin",
"item"); "item");
metaData.setProperty("item:role", "moderator"); metaData.setProperty("item:role", "moderator");
...@@ -196,8 +193,7 @@ public class IQAdminHandler { ...@@ -196,8 +193,7 @@ public class IQAdminHandler {
if (MUCRole.MODERATOR != senderRole.getRole()) { if (MUCRole.MODERATOR != senderRole.getRole()) {
throw new ForbiddenException(); throw new ForbiddenException();
} }
for (Iterator<MUCRole> roles = room.getParticipants(); roles.hasNext();) { for (MUCRole role : room.getParticipants()) {
role = roles.next();
metaData = new MetaDataFragment("http://jabber.org/protocol/muc#admin", metaData = new MetaDataFragment("http://jabber.org/protocol/muc#admin",
"item"); "item");
metaData.setProperty("item:role", "participant"); metaData.setProperty("item:role", "participant");
...@@ -301,9 +297,6 @@ public class IQAdminHandler { ...@@ -301,9 +297,6 @@ public class IQAdminHandler {
reply.setError(XMPPError.Code.BAD_REQUEST); reply.setError(XMPPError.Code.BAD_REQUEST);
} }
} }
catch (NotAllowedException e) {
reply.setError(XMPPError.Code.NOT_ALLOWED);
}
finally { finally {
room.lock.writeLock().unlock(); room.lock.writeLock().unlock();
} }
......
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