mirror of
https://github.com/vanitasvitae/Smack.git
synced 2024-06-29 14:54:50 +02:00
3d4e7938a7
ExtensionElement is now a marker interface that requires all implementation non-abstract classes to carry a static final QNAME field (of type QName). This is verified by a new unit test. Also FullyQualifiedElement is renamed to simply XmlElement. XmlElement is used over ExtensionElement when implementing classes do not statically know the qualified name of the XML elements they represent. In general, XmlElement should be used sparingly, and every XML element should be modeled by its own Java class (implementing ExtensionElement).
81 lines
3.2 KiB
Java
81 lines
3.2 KiB
Java
/**
|
|
*
|
|
* Copyright 2003-2007 Jive Software.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
package org.jivesoftware.smackx.iqregister.provider;
|
|
|
|
import java.io.IOException;
|
|
import java.util.HashMap;
|
|
import java.util.LinkedList;
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
|
|
import org.jivesoftware.smack.packet.IQ;
|
|
import org.jivesoftware.smack.packet.XmlElement;
|
|
import org.jivesoftware.smack.packet.XmlEnvironment;
|
|
import org.jivesoftware.smack.parsing.SmackParsingException;
|
|
import org.jivesoftware.smack.provider.IQProvider;
|
|
import org.jivesoftware.smack.util.PacketParserUtils;
|
|
import org.jivesoftware.smack.xml.XmlPullParser;
|
|
import org.jivesoftware.smack.xml.XmlPullParserException;
|
|
|
|
import org.jivesoftware.smackx.iqregister.packet.Registration;
|
|
|
|
public class RegistrationProvider extends IQProvider<Registration> {
|
|
|
|
@Override
|
|
public Registration parse(XmlPullParser parser, int initialDepth, XmlEnvironment xmlEnvironment) throws XmlPullParserException, IOException, SmackParsingException {
|
|
String instruction = null;
|
|
Map<String, String> fields = new HashMap<>();
|
|
List<XmlElement> packetExtensions = new LinkedList<>();
|
|
outerloop:
|
|
while (true) {
|
|
XmlPullParser.Event eventType = parser.next();
|
|
if (eventType == XmlPullParser.Event.START_ELEMENT) {
|
|
// Any element that's in the jabber:iq:register namespace,
|
|
// attempt to parse it if it's in the form <name>value</name>.
|
|
if (parser.getNamespace().equals(Registration.NAMESPACE)) {
|
|
String name = parser.getName();
|
|
String value = "";
|
|
|
|
if (parser.next() == XmlPullParser.Event.TEXT_CHARACTERS) {
|
|
value = parser.getText();
|
|
}
|
|
// Ignore instructions, but anything else should be added to the map.
|
|
if (!name.equals("instructions")) {
|
|
fields.put(name, value);
|
|
}
|
|
else {
|
|
instruction = value;
|
|
}
|
|
}
|
|
// Otherwise, it must be a packet extension.
|
|
else {
|
|
PacketParserUtils.addExtensionElement(packetExtensions, parser, xmlEnvironment);
|
|
}
|
|
}
|
|
else if (eventType == XmlPullParser.Event.END_ELEMENT) {
|
|
if (parser.getName().equals(IQ.QUERY_ELEMENT)) {
|
|
break outerloop;
|
|
}
|
|
}
|
|
}
|
|
Registration registration = new Registration(instruction, fields);
|
|
registration.addExtensions(packetExtensions);
|
|
return registration;
|
|
}
|
|
|
|
}
|