Commit 45dfa4c9 authored by Daniel Henninger's avatar Daniel Henninger Committed by dhenninger

Fixed as per Guus's patches.

git-svn-id: http://svn.igniterealtime.org/svn/repos/wildfire/trunk/src/plugins/gateway@7037 b35dd754-fafc-0310-a699-88a17e54d16e
parent 8a5d2b0a
...@@ -554,6 +554,12 @@ public abstract class BaseTransport implements Component, RosterEventListener { ...@@ -554,6 +554,12 @@ public abstract class BaseTransport implements Component, RosterEventListener {
// this.convinceNotToLeave() ... kidding. // this.convinceNotToLeave() ... kidding.
IQ result = IQ.createResultIQ(packet); IQ result = IQ.createResultIQ(packet);
if (packet.getChildElement().elements().size() != 1) {
result.setError(Condition.bad_request);
reply.add(result);
return reply;
}
// Tell the end user the transport went byebye. // Tell the end user the transport went byebye.
Presence unavailable = new Presence(Presence.Type.unavailable); Presence unavailable = new Presence(Presence.Type.unavailable);
unavailable.setTo(from); unavailable.setTo(from);
...@@ -565,7 +571,7 @@ public abstract class BaseTransport implements Component, RosterEventListener { ...@@ -565,7 +571,7 @@ public abstract class BaseTransport implements Component, RosterEventListener {
} }
catch (UserNotFoundException e) { catch (UserNotFoundException e) {
Log.error("Error cleaning up contact list of: " + from); Log.error("Error cleaning up contact list of: " + from);
result.setError(Condition.bad_request); result.setError(Condition.registration_required);
} }
reply.add(result); reply.add(result);
...@@ -1331,6 +1337,9 @@ public abstract class BaseTransport implements Component, RosterEventListener { ...@@ -1331,6 +1337,9 @@ public abstract class BaseTransport implements Component, RosterEventListener {
*/ */
public void deleteRegistration(JID jid) throws UserNotFoundException { public void deleteRegistration(JID jid) throws UserNotFoundException {
Collection<Registration> registrations = registrationManager.getRegistrations(jid, this.transportType); Collection<Registration> registrations = registrationManager.getRegistrations(jid, this.transportType);
if (registrations.isEmpty()) {
throw new UserNotFoundException("User was not registered.");
}
// For now, we're going to have to just nuke all of these. Sorry. // For now, we're going to have to just nuke all of these. Sorry.
for (Registration reg : registrations) { for (Registration reg : registrations) {
registrationManager.deleteRegistration(reg); registrationManager.deleteRegistration(reg);
......
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