mirror of
https://github.com/vanitasvitae/Smack.git
synced 2024-06-28 14:24:49 +02:00
6980c8e63d
this is the first stop towards fixing "SMACK-65: parsing should look for depth", by providing the initial parsing depth to the provider. Some methods (.e.g parseMessage) now use the depth as abort condition, instead of a unclean String equals check. parseIQ() and parseExtension() where both renamed to parse. This also restricts the Exceptions thrown by the parse method, to just XmlPullParserException, IOException and SmackException (not really a big victory, but nevertheless a slight improvement). StreamFeatureProvider is now gone, we simply use PacketExtensionProvider for stream features.
73 lines
2.8 KiB
Java
73 lines
2.8 KiB
Java
/**
|
|
*
|
|
* Copyright the original author or authors
|
|
*
|
|
* 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.pubsub.provider;
|
|
|
|
import java.io.IOException;
|
|
|
|
import org.jivesoftware.smack.SmackException;
|
|
import org.jivesoftware.smack.packet.PacketExtension;
|
|
import org.jivesoftware.smack.provider.PacketExtensionProvider;
|
|
import org.jivesoftware.smack.provider.ProviderManager;
|
|
import org.jivesoftware.smack.util.PacketParserUtils;
|
|
import org.jivesoftware.smackx.pubsub.Item;
|
|
import org.jivesoftware.smackx.pubsub.PayloadItem;
|
|
import org.jivesoftware.smackx.pubsub.SimplePayload;
|
|
import org.jivesoftware.smackx.pubsub.packet.PubSubNamespace;
|
|
import org.xmlpull.v1.XmlPullParser;
|
|
import org.xmlpull.v1.XmlPullParserException;
|
|
|
|
/**
|
|
* Parses an <b>item</b> element as is defined in both the {@link PubSubNamespace#BASIC} and
|
|
* {@link PubSubNamespace#EVENT} namespaces. To parse the item contents, it will use whatever
|
|
* {@link PacketExtensionProvider} is registered in <b>smack.providers</b> for its element name and namespace. If no
|
|
* provider is registered, it will return a {@link SimplePayload}.
|
|
*
|
|
* @author Robin Collier
|
|
*/
|
|
public class ItemProvider extends PacketExtensionProvider<Item>
|
|
{
|
|
@Override
|
|
public Item parse(XmlPullParser parser, int initialDepth)
|
|
throws XmlPullParserException, IOException, SmackException {
|
|
String id = parser.getAttributeValue(null, "id");
|
|
String node = parser.getAttributeValue(null, "node");
|
|
|
|
int tag = parser.next();
|
|
|
|
if (tag == XmlPullParser.END_TAG)
|
|
{
|
|
return new Item(id, node);
|
|
}
|
|
else
|
|
{
|
|
String payloadElemName = parser.getName();
|
|
String payloadNS = parser.getNamespace();
|
|
|
|
if (ProviderManager.getExtensionProvider(payloadElemName, payloadNS) == null)
|
|
{
|
|
CharSequence payloadText = PacketParserUtils.parseElement(parser, true);
|
|
return new PayloadItem<SimplePayload>(id, node, new SimplePayload(payloadElemName, payloadNS, payloadText));
|
|
}
|
|
else
|
|
{
|
|
return new PayloadItem<PacketExtension>(id, node, PacketParserUtils.parsePacketExtension(payloadElemName, payloadNS, parser));
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|