mirror of
https://github.com/vanitasvitae/Smack.git
synced 2024-11-23 04:22:05 +01:00
Added a first version of Personal Event Publishing.
git-svn-id: http://svn.igniterealtime.org/svn/repos/smack/trunk@10853 b35dd754-fafc-0310-a699-88a17e54d16e
This commit is contained in:
parent
84fcf53512
commit
4a917320aa
6 changed files with 585 additions and 0 deletions
42
source/org/jivesoftware/smackx/PEPListener.java
Normal file
42
source/org/jivesoftware/smackx/PEPListener.java
Normal file
|
@ -0,0 +1,42 @@
|
|||
/**
|
||||
* $RCSfile: PEPListener.java,v $
|
||||
* $Revision: 1.1 $
|
||||
* $Date: 2007/11/03 00:14:32 $
|
||||
*
|
||||
* Copyright 2003-2007 Jive Software.
|
||||
*
|
||||
* All rights reserved. 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;
|
||||
|
||||
import org.jivesoftware.smackx.packet.PEPEvent;
|
||||
|
||||
|
||||
/**
|
||||
*
|
||||
* A listener that is fired anytime a PEP event message is received.
|
||||
*
|
||||
* @author Jeff Williams
|
||||
*/
|
||||
public interface PEPListener {
|
||||
|
||||
/**
|
||||
* Called when PEP events are received as part of a presence subscribe or message filter.
|
||||
*
|
||||
* @param from the user that sent the entries.
|
||||
* @param event the event contained in the message.
|
||||
*/
|
||||
public void eventReceived(String from, PEPEvent event);
|
||||
|
||||
}
|
158
source/org/jivesoftware/smackx/PEPManager.java
Normal file
158
source/org/jivesoftware/smackx/PEPManager.java
Normal file
|
@ -0,0 +1,158 @@
|
|||
/**
|
||||
* $RCSfile: PEPManager.java,v $
|
||||
* $Revision: 1.4 $
|
||||
* $Date: 2007/11/06 21:43:40 $
|
||||
*
|
||||
* Copyright 2003-2007 Jive Software.
|
||||
*
|
||||
* All rights reserved. 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;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import org.jivesoftware.smack.PacketListener;
|
||||
import org.jivesoftware.smack.XMPPConnection;
|
||||
import org.jivesoftware.smack.filter.PacketExtensionFilter;
|
||||
import org.jivesoftware.smack.filter.PacketFilter;
|
||||
import org.jivesoftware.smack.packet.Message;
|
||||
import org.jivesoftware.smack.packet.Packet;
|
||||
import org.jivesoftware.smack.packet.IQ.Type;
|
||||
import org.jivesoftware.smackx.packet.PEPEvent;
|
||||
import org.jivesoftware.smackx.packet.PEPItem;
|
||||
import org.jivesoftware.smackx.packet.PEPPubSub;
|
||||
|
||||
/**
|
||||
*
|
||||
* Manages Personal Event Publishing (XEP-163). A PEPManager provides a high level access to
|
||||
* pubsub personal events. It also provides an easy way
|
||||
* to hook up custom logic when events are received from another XMPP client through PEPListeners.
|
||||
*
|
||||
* Use example:
|
||||
*
|
||||
* PEPManager pepManager = new PEPManager(smackConnection);
|
||||
* pepManager.addPEPListener(new PEPListener() {
|
||||
* public void eventReceived(String inFrom, PEPEvent inEvent) {
|
||||
* LOGGER.debug("Event received: " + inEvent);
|
||||
* }
|
||||
* });
|
||||
*
|
||||
* PEPProvider pepProvider = new PEPProvider();
|
||||
* pepProvider.registerPEPParserExtension("http://jabber.org/protocol/tune", new TuneProvider());
|
||||
* ProviderManager.getInstance().addExtensionProvider("event", "http://jabber.org/protocol/pubsub#event", pepProvider);
|
||||
*
|
||||
* Tune tune = new Tune("jeff", "1", "CD", "My Title", "My Track");
|
||||
* pepManager.publish(tune);
|
||||
*
|
||||
* @author Jeff Williams
|
||||
*/
|
||||
public class PEPManager {
|
||||
|
||||
private List<PEPListener> pepListeners = new ArrayList<PEPListener>();
|
||||
|
||||
private XMPPConnection connection;
|
||||
|
||||
private PacketFilter packetFilter = new PacketExtensionFilter("event", "http://jabber.org/protocol/pubsub#event");
|
||||
private PacketListener packetListener;
|
||||
|
||||
/**
|
||||
* Creates a new PEP exchange manager.
|
||||
*
|
||||
* @param con an XMPPConnection.
|
||||
*/
|
||||
public PEPManager(XMPPConnection connection) {
|
||||
this.connection = connection;
|
||||
init();
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds a listener to PEPs. The listener will be fired anytime PEP events
|
||||
* are received from remote XMPP clients.
|
||||
*
|
||||
* @param pepListener a roster exchange listener.
|
||||
*/
|
||||
public void addPEPListener(PEPListener pepListener) {
|
||||
synchronized (pepListeners) {
|
||||
if (!pepListeners.contains(pepListener)) {
|
||||
pepListeners.add(pepListener);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Removes a listener from PEP events.
|
||||
*
|
||||
* @param pepListener a roster exchange listener..
|
||||
*/
|
||||
public void removePEPListener(PEPListener pepListener) {
|
||||
synchronized (pepListeners) {
|
||||
pepListeners.remove(pepListener);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Publish an event.
|
||||
*
|
||||
* @param roster the roster to send
|
||||
* @param targetUserID the user that will receive the roster entries
|
||||
*/
|
||||
public void publish(PEPItem item) {
|
||||
// Create a new message to publish the event.
|
||||
PEPPubSub pubSub = new PEPPubSub(item);
|
||||
pubSub.setType(Type.SET);
|
||||
//pubSub.setFrom(connection.getUser());
|
||||
|
||||
// Send the message that contains the roster
|
||||
connection.sendPacket(pubSub);
|
||||
}
|
||||
|
||||
/**
|
||||
* Fires roster exchange listeners.
|
||||
*/
|
||||
private void firePEPListeners(String from, PEPEvent event) {
|
||||
PEPListener[] listeners = null;
|
||||
synchronized (pepListeners) {
|
||||
listeners = new PEPListener[pepListeners.size()];
|
||||
pepListeners.toArray(listeners);
|
||||
}
|
||||
for (int i = 0; i < listeners.length; i++) {
|
||||
listeners[i].eventReceived(from, event);
|
||||
}
|
||||
}
|
||||
|
||||
private void init() {
|
||||
// Listens for all roster exchange packets and fire the roster exchange listeners.
|
||||
packetListener = new PacketListener() {
|
||||
public void processPacket(Packet packet) {
|
||||
Message message = (Message) packet;
|
||||
PEPEvent event = (PEPEvent) message.getExtension("event", "http://jabber.org/protocol/pubsub#event");
|
||||
// Fire event for roster exchange listeners
|
||||
firePEPListeners(message.getFrom(), event);
|
||||
};
|
||||
|
||||
};
|
||||
connection.addPacketListener(packetListener, packetFilter);
|
||||
}
|
||||
|
||||
public void destroy() {
|
||||
if (connection != null)
|
||||
connection.removePacketListener(packetListener);
|
||||
|
||||
}
|
||||
|
||||
public void finalize() {
|
||||
destroy();
|
||||
}
|
||||
}
|
105
source/org/jivesoftware/smackx/packet/PEPEvent.java
Normal file
105
source/org/jivesoftware/smackx/packet/PEPEvent.java
Normal file
|
@ -0,0 +1,105 @@
|
|||
/**
|
||||
* $RCSfile: PEPEvent.java,v $
|
||||
* $Revision: 1.1 $
|
||||
* $Date: 2007/11/03 00:14:32 $
|
||||
*
|
||||
* Copyright 2003-2007 Jive Software.
|
||||
*
|
||||
* All rights reserved. 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.packet;
|
||||
|
||||
import org.jivesoftware.smack.packet.PacketExtension;
|
||||
|
||||
/**
|
||||
* Represents XMPP Personal Event Protocol packets.<p>
|
||||
*
|
||||
* The 'http://jabber.org/protocol/pubsub#event' namespace is used to publish personal events items from one client
|
||||
* to subscribed clients (See XEP-163).
|
||||
*
|
||||
* @author Jeff Williams
|
||||
*/
|
||||
public class PEPEvent implements PacketExtension {
|
||||
|
||||
PEPItem item;
|
||||
|
||||
/**
|
||||
* Creates a new empty roster exchange package.
|
||||
*
|
||||
*/
|
||||
public PEPEvent() {
|
||||
super();
|
||||
}
|
||||
|
||||
/**
|
||||
* Creates a new empty roster exchange package.
|
||||
*
|
||||
*/
|
||||
public PEPEvent(PEPItem item) {
|
||||
super();
|
||||
|
||||
this.item = item;
|
||||
}
|
||||
|
||||
public void addPEPItem(PEPItem item) {
|
||||
this.item = item;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the XML element name of the extension sub-packet root element.
|
||||
* Always returns "x"
|
||||
*
|
||||
* @return the XML element name of the packet extension.
|
||||
*/
|
||||
public String getElementName() {
|
||||
return "event";
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the XML namespace of the extension sub-packet root element.
|
||||
* According the specification the namespace is always "jabber:x:roster"
|
||||
* (which is not to be confused with the 'jabber:iq:roster' namespace
|
||||
*
|
||||
* @return the XML namespace of the packet extension.
|
||||
*/
|
||||
public String getNamespace() {
|
||||
return "http://jabber.org/protocol/pubsub";
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the XML representation of a Personal Event Publish according the specification.
|
||||
*
|
||||
* Usually the XML representation will be inside of a Message XML representation like
|
||||
* in the following example:
|
||||
* <pre>
|
||||
* <message id="MlIpV-4" to="gato1@gato.home" from="gato3@gato.home/Smack">
|
||||
* <subject>Any subject you want</subject>
|
||||
* <body>This message contains roster items.</body>
|
||||
* <x xmlns="jabber:x:roster">
|
||||
* <item jid="gato1@gato.home"/>
|
||||
* <item jid="gato2@gato.home"/>
|
||||
* </x>
|
||||
* </message>
|
||||
* </pre>
|
||||
*
|
||||
*/
|
||||
public String toXML() {
|
||||
StringBuilder buf = new StringBuilder();
|
||||
buf.append("<").append(getElementName()).append(" xmlns=\"").append(getNamespace()).append("\">");
|
||||
buf.append(item.toXML());
|
||||
buf.append("</").append(getElementName()).append(">");
|
||||
return buf.toString();
|
||||
}
|
||||
|
||||
}
|
92
source/org/jivesoftware/smackx/packet/PEPItem.java
Normal file
92
source/org/jivesoftware/smackx/packet/PEPItem.java
Normal file
|
@ -0,0 +1,92 @@
|
|||
/**
|
||||
* $RCSfile: PEPItem.java,v $
|
||||
* $Revision: 1.2 $
|
||||
* $Date: 2007/11/06 02:05:09 $
|
||||
*
|
||||
* Copyright 2003-2007 Jive Software.
|
||||
*
|
||||
* All rights reserved. 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.packet;
|
||||
|
||||
import org.jivesoftware.smack.packet.PacketExtension;
|
||||
|
||||
/**
|
||||
* Represents XMPP Personal Event Protocol packets.<p>
|
||||
*
|
||||
* The 'http://jabber.org/protocol/pubsub#event' namespace is used to publish personal events items from one client
|
||||
* to subscribed clients (See XEP-163).
|
||||
*
|
||||
* @author Jeff Williams
|
||||
*/
|
||||
public abstract class PEPItem implements PacketExtension {
|
||||
|
||||
String id;
|
||||
abstract String getNode();
|
||||
abstract String getItemDetailsXML();
|
||||
|
||||
/**
|
||||
* Creates a new PEPItem.
|
||||
*
|
||||
*/
|
||||
public PEPItem(String id) {
|
||||
super();
|
||||
this.id = id;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the XML element name of the extension sub-packet root element.
|
||||
* Always returns "x"
|
||||
*
|
||||
* @return the XML element name of the packet extension.
|
||||
*/
|
||||
public String getElementName() {
|
||||
return "item";
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the XML namespace of the extension sub-packet root element.
|
||||
*
|
||||
* @return the XML namespace of the packet extension.
|
||||
*/
|
||||
public String getNamespace() {
|
||||
return "http://jabber.org/protocol/pubsub";
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the XML representation of a Personal Event Publish according the specification.
|
||||
*
|
||||
* Usually the XML representation will be inside of a Message XML representation like
|
||||
* in the following example:
|
||||
* <pre>
|
||||
* <message id="MlIpV-4" to="gato1@gato.home" from="gato3@gato.home/Smack">
|
||||
* <subject>Any subject you want</subject>
|
||||
* <body>This message contains roster items.</body>
|
||||
* <x xmlns="jabber:x:roster">
|
||||
* <item jid="gato1@gato.home"/>
|
||||
* <item jid="gato2@gato.home"/>
|
||||
* </x>
|
||||
* </message>
|
||||
* </pre>
|
||||
*
|
||||
*/
|
||||
public String toXML() {
|
||||
StringBuilder buf = new StringBuilder();
|
||||
buf.append("<").append(getElementName()).append(" id=\"").append(id).append("\">");
|
||||
buf.append(getItemDetailsXML());
|
||||
buf.append("</").append(getElementName()).append(">");
|
||||
return buf.toString();
|
||||
}
|
||||
|
||||
}
|
95
source/org/jivesoftware/smackx/packet/PEPPubSub.java
Normal file
95
source/org/jivesoftware/smackx/packet/PEPPubSub.java
Normal file
|
@ -0,0 +1,95 @@
|
|||
/**
|
||||
* $RCSfile: PEPPubSub.java,v $
|
||||
* $Revision: 1.2 $
|
||||
* $Date: 2007/11/03 04:46:52 $
|
||||
*
|
||||
* Copyright 2003-2007 Jive Software.
|
||||
*
|
||||
* All rights reserved. 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.packet;
|
||||
|
||||
import org.jivesoftware.smack.packet.IQ;
|
||||
|
||||
/**
|
||||
* Represents XMPP PEP/XEP-163 pubsub packets.<p>
|
||||
*
|
||||
* The 'http://jabber.org/protocol/pubsub' namespace is used to publish personal events items from one client
|
||||
* to subscribed clients (See XEP-163).
|
||||
*
|
||||
* @author Jeff Williams
|
||||
*/
|
||||
public class PEPPubSub extends IQ {
|
||||
|
||||
PEPItem item;
|
||||
|
||||
/**
|
||||
* Creates a new PubSub.
|
||||
*
|
||||
*/
|
||||
public PEPPubSub(PEPItem item) {
|
||||
super();
|
||||
|
||||
this.item = item;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the XML element name of the extension sub-packet root element.
|
||||
* Always returns "x"
|
||||
*
|
||||
* @return the XML element name of the packet extension.
|
||||
*/
|
||||
public String getElementName() {
|
||||
return "pubsub";
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the XML namespace of the extension sub-packet root element.
|
||||
* According the specification the namespace is always "jabber:x:roster"
|
||||
* (which is not to be confused with the 'jabber:iq:roster' namespace
|
||||
*
|
||||
* @return the XML namespace of the packet extension.
|
||||
*/
|
||||
public String getNamespace() {
|
||||
return "http://jabber.org/protocol/pubsub";
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the XML representation of a Personal Event Publish according the specification.
|
||||
*
|
||||
* Usually the XML representation will be inside of a Message XML representation like
|
||||
* in the following example:
|
||||
* <pre>
|
||||
* <message id="MlIpV-4" to="gato1@gato.home" from="gato3@gato.home/Smack">
|
||||
* <subject>Any subject you want</subject>
|
||||
* <body>This message contains roster items.</body>
|
||||
* <x xmlns="jabber:x:roster">
|
||||
* <item jid="gato1@gato.home"/>
|
||||
* <item jid="gato2@gato.home"/>
|
||||
* </x>
|
||||
* </message>
|
||||
* </pre>
|
||||
*
|
||||
*/
|
||||
public String getChildElementXML() {
|
||||
StringBuilder buf = new StringBuilder();
|
||||
buf.append("<").append(getElementName()).append(" xmlns=\"").append(getNamespace()).append("\">");
|
||||
buf.append("<publish node=\"").append(item.getNode()).append("\">");
|
||||
buf.append(item.toXML());
|
||||
buf.append("</publish>");
|
||||
buf.append("</").append(getElementName()).append(">");
|
||||
return buf.toString();
|
||||
}
|
||||
|
||||
}
|
93
source/org/jivesoftware/smackx/provider/PEPProvider.java
Normal file
93
source/org/jivesoftware/smackx/provider/PEPProvider.java
Normal file
|
@ -0,0 +1,93 @@
|
|||
/**
|
||||
* $RCSfile: PEPProvider.java,v $
|
||||
* $Revision: 1.2 $
|
||||
* $Date: 2007/11/06 02:05:09 $
|
||||
*
|
||||
* Copyright 2003-2007 Jive Software.
|
||||
*
|
||||
* All rights reserved. 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.provider;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
import org.jivesoftware.smack.packet.PacketExtension;
|
||||
import org.jivesoftware.smack.provider.PacketExtensionProvider;
|
||||
import org.xmlpull.v1.XmlPullParser;
|
||||
|
||||
/**
|
||||
*
|
||||
* The PEPProvider parses incoming PEPEvent packets.
|
||||
* (XEP-163 has a weird asymmetric deal: outbound PEP are <iq> + <pubsub> and inbound are <message> + <event>.
|
||||
* The provider only deals with inbound, and so it only deals with <message>.
|
||||
*
|
||||
* Anyhoo...
|
||||
*
|
||||
* The way this works is that PEPxxx classes are generic <pubsub> and <message> providers, and anyone who
|
||||
* wants to publish/receive PEPs, such as <tune>, <geoloc>, etc., simply need to extend PEPItem and register (here)
|
||||
* a PacketExtensionProvider that knows how to parse that PEPItem extension.
|
||||
*
|
||||
* @author Jeff Williams
|
||||
*/
|
||||
public class PEPProvider implements PacketExtensionProvider {
|
||||
|
||||
Map<String, PacketExtensionProvider> nodeParsers = new HashMap<String, PacketExtensionProvider>();
|
||||
PacketExtension pepItem;
|
||||
|
||||
/**
|
||||
* Creates a new PEPProvider.
|
||||
* ProviderManager requires that every PacketExtensionProvider has a public, no-argument constructor
|
||||
*/
|
||||
public PEPProvider() {
|
||||
}
|
||||
|
||||
public void registerPEPParserExtension(String node, PacketExtensionProvider pepItemParser) {
|
||||
nodeParsers.put(node, pepItemParser);
|
||||
}
|
||||
|
||||
/**
|
||||
* Parses a PEPEvent packet and extracts a PEPItem from it.
|
||||
* (There is only one per <event>.)
|
||||
*
|
||||
* @param parser the XML parser, positioned at the starting element of the extension.
|
||||
* @return a PacketExtension.
|
||||
* @throws Exception if a parsing error occurs.
|
||||
*/
|
||||
public PacketExtension parseExtension(XmlPullParser parser) throws Exception {
|
||||
|
||||
boolean done = false;
|
||||
while (!done) {
|
||||
int eventType = parser.next();
|
||||
if (eventType == XmlPullParser.START_TAG) {
|
||||
if (parser.getName().equals("event")) {
|
||||
} else if (parser.getName().equals("items")) {
|
||||
// Figure out the node for this event.
|
||||
String node = parser.getAttributeValue("", "node");
|
||||
// Get the parser for this kind of node, and if found then parse the node.
|
||||
PacketExtensionProvider nodeParser = nodeParsers.get(node);
|
||||
if (nodeParser != null) {
|
||||
pepItem = nodeParser.parseExtension(parser);
|
||||
}
|
||||
}
|
||||
} else if (eventType == XmlPullParser.END_TAG) {
|
||||
if (parser.getName().equals("event")) {
|
||||
done = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return pepItem;
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue