summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKevin Smith <git@kismith.co.uk>2011-07-01 09:19:49 (GMT)
committerKevin Smith <git@kismith.co.uk>2011-07-01 09:19:49 (GMT)
commit2da71a8a85486a494343f1662d64fb5ae5a2a44e (patch)
tree23992f9f2a00bac23b345e5c2cc9c1194efc25be /src/com/isode/stroke/parser/payloadparsers
downloadstroke-2da71a8a85486a494343f1662d64fb5ae5a2a44e.zip
stroke-2da71a8a85486a494343f1662d64fb5ae5a2a44e.tar.bz2
Initial import
Diffstat (limited to 'src/com/isode/stroke/parser/payloadparsers')
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/BodyParser.java40
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/BodyParserFactory.java19
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/FullPayloadParserFactoryCollection.java55
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/LastParser.java46
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/RawXMLPayloadParser.java45
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/RawXMLPayloadParserFactory.java26
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/ResourceBindParser.java56
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/ResourceBindParserFactory.java20
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/RosterParser.java82
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/RosterParserFactory.java19
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/SearchPayloadParser.java124
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/SearchPayloadParserFactory.java21
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/SoftwareVersionParser.java51
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/SoftwareVersionParserFactory.java20
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/StartSessionParser.java35
-rw-r--r--src/com/isode/stroke/parser/payloadparsers/StartSessionParserFactory.java19
16 files changed, 678 insertions, 0 deletions
diff --git a/src/com/isode/stroke/parser/payloadparsers/BodyParser.java b/src/com/isode/stroke/parser/payloadparsers/BodyParser.java
new file mode 100644
index 0000000..3672c56
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/BodyParser.java
@@ -0,0 +1,40 @@
+/*
+ * Copyright (c) 2010, Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, Remko Tron¨on.
+ * All rights reserved.
+ */
+
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.elements.Body;
+import com.isode.stroke.parser.AttributeMap;
+import com.isode.stroke.parser.GenericPayloadParser;
+
+public class BodyParser extends GenericPayloadParser<Body> {
+
+ private int level_ = 0;
+ private String text_ = "";
+
+ public BodyParser() {
+ super(new Body());
+ }
+
+ public void handleStartElement(String element, String ns, AttributeMap attributes) {
+ ++level_;
+ }
+
+ public void handleEndElement(String element, String ns) {
+ --level_;
+ if (level_ == 0) {
+ getPayloadInternal().setText(text_);
+ }
+ }
+
+ public void handleCharacterData(String data) {
+ text_ += data;
+ }
+
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/BodyParserFactory.java b/src/com/isode/stroke/parser/payloadparsers/BodyParserFactory.java
new file mode 100644
index 0000000..154281b
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/BodyParserFactory.java
@@ -0,0 +1,19 @@
+/*
+ * Copyright (c) 2010, 2011 Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, Remko Tron¨on.
+ * All rights reserved.
+ */
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.parser.GenericPayloadParserFactory;
+
+public class BodyParserFactory extends GenericPayloadParserFactory<BodyParser> {
+
+ public BodyParserFactory() {
+ super("body", BodyParser.class);
+ }
+
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/FullPayloadParserFactoryCollection.java b/src/com/isode/stroke/parser/payloadparsers/FullPayloadParserFactoryCollection.java
new file mode 100644
index 0000000..dfc1b61
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/FullPayloadParserFactoryCollection.java
@@ -0,0 +1,55 @@
+/*
+ * Copyright (c) 2010, Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, Remko Tron¨on.
+ * All rights reserved.
+ */
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.parser.GenericPayloadParserFactory;
+import com.isode.stroke.parser.PayloadParserFactory;
+import com.isode.stroke.parser.PayloadParserFactoryCollection;
+
+public class FullPayloadParserFactoryCollection extends PayloadParserFactoryCollection {
+ public FullPayloadParserFactoryCollection() {
+ /* TODO: Port more */
+ //addFactory(new GenericPayloadParserFactory<IBBParser>("", "http://jabber.org/protocol/ibb"));
+ //addFactory(new GenericPayloadParserFactory<StatusShowParser>("show", StatusShowParser.class));
+ //addFactory(new GenericPayloadParserFactory<StatusParser>("status", StatusParser.class));
+ //addFactory(new GenericPayloadParserFactory<ReplaceParser>("replace", "http://swift.im/protocol/replace"));
+ addFactory(new GenericPayloadParserFactory<LastParser>("query", "jabber:iq:last", LastParser.class));
+ addFactory(new GenericPayloadParserFactory<BodyParser>("body", BodyParser.class));
+ //addFactory(new GenericPayloadParserFactory<SubjectParser>("subject", SubjectParser.class));
+ //addFactory(new GenericPayloadParserFactory<PriorityParser>("priority", PriorityParser.class));
+ //addFactory(new ErrorParserFactory(this)));
+ addFactory(new SoftwareVersionParserFactory());
+ //addFactory(new StorageParserFactory());
+ addFactory(new RosterParserFactory());
+ //addFactory(new DiscoInfoParserFactory());
+ //addFactory(new DiscoItemsParserFactory());
+ //addFactory(new CapsInfoParserFactory());
+ addFactory(new ResourceBindParserFactory());
+ addFactory(new StartSessionParserFactory());
+ //addFactory(new SecurityLabelParserFactory());
+ //addFactory(new SecurityLabelsCatalogParserFactory());
+ //addFactory(new FormParserFactory());
+ //addFactory(new CommandParserFactory());
+ //addFactery(new InBandRegistrationPayloadParserFactory());
+ addFactory(new SearchPayloadParserFactory());
+ //addFactory(new StreamInitiationParserFactory());
+ //addFactory(new BytestreamsParserFactory());
+ //addFactory(new VCardUpdateParserFactory());
+ //addFactory(new VCardParserFactory());
+ //addFactory(new PrivateStorageParserFactory(this));
+ //addFactory(new ChatStateParserFactory());
+ //addFactory(new DelayParserFactory());
+ //addFactory(new MUCUserPayloadParserFactory());
+ //addFactory(new NicknameParserFactory());
+
+
+ PayloadParserFactory defaultFactory = new RawXMLPayloadParserFactory();
+ setDefaultFactory(defaultFactory);
+ }
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/LastParser.java b/src/com/isode/stroke/parser/payloadparsers/LastParser.java
new file mode 100644
index 0000000..d2c2a82
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/LastParser.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright (c) 2011, Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2011, Kevin Smith.
+ * All rights reserved.
+ */
+
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.elements.Last;
+import com.isode.stroke.parser.AttributeMap;
+import com.isode.stroke.parser.GenericPayloadParser;
+
+public class LastParser extends GenericPayloadParser<Last> {
+
+ private int level_ = 0;
+
+ public LastParser() {
+ super(new Last());
+ }
+
+ public void handleStartElement(String element, String ns, AttributeMap attributes) {
+ if (level_ == 0) {
+ int seconds = 0;
+
+ try {
+ seconds = Integer.parseInt(attributes.getAttribute("seconds"));
+ }
+ catch (NumberFormatException ex) {
+ }
+ getPayloadInternal().setSeconds(seconds);
+ }
+ ++level_;
+ }
+
+ public void handleEndElement(String element, String ns) {
+
+ }
+
+ public void handleCharacterData(String data) {
+
+ }
+
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/RawXMLPayloadParser.java b/src/com/isode/stroke/parser/payloadparsers/RawXMLPayloadParser.java
new file mode 100644
index 0000000..2a97fed
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/RawXMLPayloadParser.java
@@ -0,0 +1,45 @@
+/*
+ * Copyright (c) 2010, Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, Remko Tron¨on.
+ * All rights reserved.
+ */
+
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.elements.RawXMLPayload;
+import com.isode.stroke.parser.AttributeMap;
+import com.isode.stroke.parser.GenericPayloadParser;
+import com.isode.stroke.parser.SerializingParser;
+
+public class RawXMLPayloadParser extends GenericPayloadParser<RawXMLPayload> {
+
+ private int level_;
+ private final SerializingParser serializingParser_ = new SerializingParser();
+
+ public RawXMLPayloadParser() {
+ super(new RawXMLPayload());
+ }
+
+
+
+ public void handleStartElement(String element, String ns, AttributeMap attributes) {
+ ++level_;
+ serializingParser_.handleStartElement(element, ns, attributes);
+ }
+
+ public void handleEndElement(String element, String ns) {
+ serializingParser_.handleEndElement(element, ns);
+ --level_;
+ if (level_ == 0) {
+ getPayloadInternal().setRawXML(serializingParser_.getResult());
+ }
+ }
+
+ public void handleCharacterData(String data) {
+ serializingParser_.handleCharacterData(data);
+ }
+
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/RawXMLPayloadParserFactory.java b/src/com/isode/stroke/parser/payloadparsers/RawXMLPayloadParserFactory.java
new file mode 100644
index 0000000..e0914e1
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/RawXMLPayloadParserFactory.java
@@ -0,0 +1,26 @@
+/*
+ * Copyright (c) 2010, Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, Remko Tron¨on.
+ * All rights reserved.
+ */
+
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.parser.AttributeMap;
+import com.isode.stroke.parser.PayloadParser;
+import com.isode.stroke.parser.PayloadParserFactory;
+
+public class RawXMLPayloadParserFactory implements PayloadParserFactory {
+
+ public boolean canParse(String element, String ns, AttributeMap attributes) {
+ return true;
+ }
+
+ public PayloadParser createPayloadParser() {
+ return new RawXMLPayloadParser();
+ }
+
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/ResourceBindParser.java b/src/com/isode/stroke/parser/payloadparsers/ResourceBindParser.java
new file mode 100644
index 0000000..be409f4
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/ResourceBindParser.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright (c) 2010, 2011 Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, Remko Tron¨on.
+ * All rights reserved.
+ */
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.elements.ResourceBind;
+import com.isode.stroke.jid.JID;
+import com.isode.stroke.parser.AttributeMap;
+import com.isode.stroke.parser.GenericPayloadParser;
+
+public class ResourceBindParser extends GenericPayloadParser<ResourceBind> {
+
+ public ResourceBindParser() {
+ super(new ResourceBind());
+ level_ = 0;
+ inJID_ = false;
+ inResource_ = false;
+ }
+
+ public void handleStartElement(String element, String ns, AttributeMap attributes) {
+ if (level_ == 1) {
+ text_ = "";
+ if (element.equals("resource")) {
+ inResource_ = true;
+ }
+ if (element.equals("jid")) {
+ inJID_ = true;
+ }
+ }
+ ++level_;
+ }
+
+ public void handleEndElement(String element, String ns) {
+ --level_;
+ if (level_ == 1) {
+ if (inJID_) {
+ getPayloadInternal().setJID(JID.fromString(text_));
+ } else if (inResource_) {
+ getPayloadInternal().setResource(text_);
+ }
+ }
+ }
+
+ public void handleCharacterData(String data) {
+ text_ += data;
+ }
+ private int level_;
+ private boolean inJID_;
+ private boolean inResource_;
+ private String text_ = "";
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/ResourceBindParserFactory.java b/src/com/isode/stroke/parser/payloadparsers/ResourceBindParserFactory.java
new file mode 100644
index 0000000..a6b644d
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/ResourceBindParserFactory.java
@@ -0,0 +1,20 @@
+/*
+ * Copyright (c) 2010, 2011 Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, Remko Tron¨on.
+ * All rights reserved.
+ */
+
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.parser.GenericPayloadParserFactory;
+
+class ResourceBindParserFactory extends GenericPayloadParserFactory<ResourceBindParser> {
+
+ public ResourceBindParserFactory() {
+ super("bind", "urn:ietf:params:xml:ns:xmpp-bind", ResourceBindParser.class);
+ }
+
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/RosterParser.java b/src/com/isode/stroke/parser/payloadparsers/RosterParser.java
new file mode 100644
index 0000000..fa115c2
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/RosterParser.java
@@ -0,0 +1,82 @@
+/*
+ * Copyright (c) 2010, Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, Remko Tron¨on.
+ * All rights reserved.
+ */
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.elements.Payload;
+import com.isode.stroke.elements.RosterItemPayload;
+import com.isode.stroke.elements.RosterPayload;
+import com.isode.stroke.jid.JID;
+import com.isode.stroke.parser.AttributeMap;
+import com.isode.stroke.parser.GenericPayloadParser;
+
+public class RosterParser extends GenericPayloadParser<RosterPayload> {
+
+ public RosterParser() {
+ super(new RosterPayload());
+ }
+
+ public void handleStartElement(String element, String ns, AttributeMap attributes) {
+ if (level_ == PayloadLevel) {
+ if (element.equals("item")) {
+ inItem_ = true;
+ currentItem_ = new RosterItemPayload();
+
+ currentItem_.setJID(JID.fromString(attributes.getAttribute("jid")));
+ currentItem_.setName(attributes.getAttribute("name"));
+
+ String subscription = attributes.getAttribute("subscription");
+ if ("both".equals(subscription)) {
+ currentItem_.setSubscription(RosterItemPayload.Subscription.Both);
+ } else if ("to".equals(subscription)) {
+ currentItem_.setSubscription(RosterItemPayload.Subscription.To);
+ } else if ("frome".equals(subscription)) {
+ currentItem_.setSubscription(RosterItemPayload.Subscription.From);
+ } else if ("remove".equals(subscription)) {
+ currentItem_.setSubscription(RosterItemPayload.Subscription.Remove);
+ } else {
+ currentItem_.setSubscription(RosterItemPayload.Subscription.None);
+ }
+
+ if ("subscribe".equals(attributes.getAttribute("ask"))) {
+ currentItem_.setSubscriptionRequested();
+ }
+ }
+ } else if (level_ == ItemLevel) {
+ if (element.equals("group")) {
+ currentText_ = "";
+ }
+ }
+ ++level_;
+ }
+
+ public void handleEndElement(String element, String ns) {
+ --level_;
+ if (level_ == PayloadLevel) {
+ if (inItem_) {
+ getPayloadInternal().addItem(currentItem_);
+ inItem_ = false;
+ }
+ } else if (level_ == ItemLevel) {
+ if (element.equals("group")) {
+ currentItem_.addGroup(currentText_);
+ }
+ }
+ }
+
+ public void handleCharacterData(String data) {
+ currentText_ += data;
+ }
+ private final int TopLevel = 0;
+ private final int PayloadLevel = 1;
+ private final int ItemLevel = 2;
+ private int level_ = TopLevel;
+ private boolean inItem_ = false;
+ private RosterItemPayload currentItem_;
+ private String currentText_;
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/RosterParserFactory.java b/src/com/isode/stroke/parser/payloadparsers/RosterParserFactory.java
new file mode 100644
index 0000000..ad690e1
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/RosterParserFactory.java
@@ -0,0 +1,19 @@
+/*
+ * Copyright (c) 2010, 2011 Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, Remko Tron¨on.
+ * All rights reserved.
+ */
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.parser.GenericPayloadParserFactory;
+
+public class RosterParserFactory extends GenericPayloadParserFactory<RosterParser> {
+
+ public RosterParserFactory() {
+ super("query", "jabber:iq:roster", RosterParser.class);
+ }
+
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/SearchPayloadParser.java b/src/com/isode/stroke/parser/payloadparsers/SearchPayloadParser.java
new file mode 100644
index 0000000..0ee1499
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/SearchPayloadParser.java
@@ -0,0 +1,124 @@
+/*
+ * Copyright (c) 2010, Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, Remko Tron¨on.
+ * All rights reserved.
+ */
+
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.elements.SearchPayload;
+import com.isode.stroke.jid.JID;
+import com.isode.stroke.parser.AttributeMap;
+import com.isode.stroke.parser.GenericPayloadParser;
+
+public class SearchPayloadParser extends GenericPayloadParser<SearchPayload> {
+
+ private static final int TopLevel = 0;
+ private static final int PayloadLevel = 1;
+ private static final int ItemLevel = 2;
+
+ private int level = 0;
+ private String currentText = "";
+ //private FormParserFactory formParserFactory = new FormParserFactory(); /* Not ported yet*/
+ //private FormParser formParser;
+ SearchPayload.Item currentItem;
+
+ public SearchPayloadParser() {
+ super(new SearchPayload());
+ }
+
+ public void handleStartElement(String element, String ns, AttributeMap attributes) {
+ if (level == TopLevel) {
+ }
+ else if (level == PayloadLevel) {
+ //if (element.equals("x") && ns.equals("jabber:x:data")) {
+ // assert formParser == null;
+ // formParser = dynamic_cast<FormParser*>(formParserFactory->createPayloadParser());
+ //} /* Not ported yet */
+ //else
+ if (element.equals("item")) {
+ assert currentItem == null;
+ currentItem = new SearchPayload.Item();
+ currentItem.jid = JID.fromString(attributes.getAttribute("jid"));
+ }
+ else {
+ currentText = "";
+ }
+ }
+ else if (level == ItemLevel && currentItem != null) {
+ currentText = "";
+ }
+
+ //if (formParser) {
+ // formParser->handleStartElement(element, ns, attributes);
+ //} /* Not ported yet */
+
+ ++level;
+ }
+
+ public void handleEndElement(String element, String ns) {
+ --level;
+
+ //if (formParser) {
+ // formParser->handleEndElement(element, ns);
+ //} /*Not Ported yet*/
+
+ if (level == TopLevel) {
+ }
+ else if (level == PayloadLevel) {
+ //if (formParser) {
+ // getPayloadInternal()->setForm(formParser->getPayloadInternal());
+ // delete formParser;
+ // formParser = NULL;
+ //}
+ //else /*Not ported yet*/
+ if (element.equals("item")) {
+ assert currentItem != null;
+ getPayloadInternal().addItem(currentItem);
+ currentItem = null;
+ }
+ else if (element.equals("instructions")) {
+ getPayloadInternal().setInstructions(currentText);
+ }
+ else if (element.equals("nick")) {
+ getPayloadInternal().setNick(currentText);
+ }
+ else if (element.equals("first")) {
+ getPayloadInternal().setFirst(currentText);
+ }
+ else if (element.equals("last")) {
+ getPayloadInternal().setLast(currentText);
+ }
+ else if (element.equals("email")) {
+ getPayloadInternal().setEMail(currentText);
+ }
+ }
+ else if (level == ItemLevel && currentItem != null) {
+ if (element.equals("nick")) {
+ currentItem.nick = currentText;
+ }
+ else if (element.equals("first")) {
+ currentItem.first = currentText;
+ }
+ else if (element.equals("last")) {
+ currentItem.last = currentText;
+ }
+ else if (element.equals("email")) {
+ currentItem.email = currentText;
+ }
+ }
+ }
+
+ public void handleCharacterData(String data) {
+ //if (formParser) {
+ // formParser->handleCharacterData(data);
+ //}
+ //else { /*Not ported yet*/
+ currentText += data;
+ //}
+ }
+
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/SearchPayloadParserFactory.java b/src/com/isode/stroke/parser/payloadparsers/SearchPayloadParserFactory.java
new file mode 100644
index 0000000..4add0a1
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/SearchPayloadParserFactory.java
@@ -0,0 +1,21 @@
+/*
+ * Copyright (c) 2010 Remko Tron¨on
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, 2011 Isode Limited, London, England.
+ * All rights reserved.
+ */
+
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.parser.GenericPayloadParserFactory;
+import com.isode.stroke.parser.PayloadParser;
+
+public class SearchPayloadParserFactory extends GenericPayloadParserFactory<SearchPayloadParser> {
+
+ public SearchPayloadParserFactory() {
+ super("query", "jabber:iq:search", SearchPayloadParser.class);
+ }
+
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/SoftwareVersionParser.java b/src/com/isode/stroke/parser/payloadparsers/SoftwareVersionParser.java
new file mode 100644
index 0000000..93563a3
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/SoftwareVersionParser.java
@@ -0,0 +1,51 @@
+/*
+ * Copyright (c) 2010 Remko Tron¨on
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010 Isode Limited, London, England.
+ * All rights reserved.
+ */
+
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.elements.Version;
+import com.isode.stroke.parser.AttributeMap;
+import com.isode.stroke.parser.GenericPayloadParser;
+
+public class SoftwareVersionParser extends GenericPayloadParser<Version> {
+
+ public SoftwareVersionParser() {
+ super(new Version());
+ }
+
+ public void handleStartElement(String element, String ns, AttributeMap attributes) {
+ level_++;
+ }
+
+ public void handleEndElement(String element, String ns) {
+ --level_;
+ if (level_ == PayloadLevel) {
+ if (element.equals("name")) {
+ getPayloadInternal().setName(currentText_);
+ } else if (element.equals("version")) {
+ getPayloadInternal().setVersion(currentText_);
+ } else if (element.equals("os")) {
+ getPayloadInternal().setOS(currentText_);
+ }
+ currentText_ = "";
+ }
+
+ }
+
+ public void handleCharacterData(String data) {
+ currentText_ += data;
+ }
+
+ private static final int TopLevel = 0;
+ private static final int PayloadLevel = 1;
+ private int level_ = TopLevel;
+ private String currentText_ = "";
+
+
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/SoftwareVersionParserFactory.java b/src/com/isode/stroke/parser/payloadparsers/SoftwareVersionParserFactory.java
new file mode 100644
index 0000000..e2180f5
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/SoftwareVersionParserFactory.java
@@ -0,0 +1,20 @@
+/*
+ * Copyright (c) 2010 Remko Tron¨on
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, 2011 Isode Limited, London, England.
+ * All rights reserved.
+ */
+
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.parser.GenericPayloadParserFactory;
+
+public class SoftwareVersionParserFactory extends GenericPayloadParserFactory<SoftwareVersionParser> {
+
+ public SoftwareVersionParserFactory() {
+ super("query", "jabber:iq:version", SoftwareVersionParser.class);
+ }
+
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/StartSessionParser.java b/src/com/isode/stroke/parser/payloadparsers/StartSessionParser.java
new file mode 100644
index 0000000..ba7804c
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/StartSessionParser.java
@@ -0,0 +1,35 @@
+/*
+ * Copyright (c) 2010, 2011 Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, Remko Tron¨on.
+ * All rights reserved.
+ */
+
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.elements.StartSession;
+import com.isode.stroke.parser.AttributeMap;
+import com.isode.stroke.parser.GenericPayloadParser;
+
+public class StartSessionParser extends GenericPayloadParser<StartSession> {
+
+ public StartSessionParser() {
+ super(new StartSession());
+ }
+
+ public void handleStartElement(String element, String ns, AttributeMap attributes) {
+
+ }
+
+ public void handleEndElement(String element, String ns) {
+
+ }
+
+ public void handleCharacterData(String data) {
+
+ }
+
+
+}
diff --git a/src/com/isode/stroke/parser/payloadparsers/StartSessionParserFactory.java b/src/com/isode/stroke/parser/payloadparsers/StartSessionParserFactory.java
new file mode 100644
index 0000000..c2c9777
--- /dev/null
+++ b/src/com/isode/stroke/parser/payloadparsers/StartSessionParserFactory.java
@@ -0,0 +1,19 @@
+/*
+ * Copyright (c) 2010, 2011 Isode Limited, London, England.
+ * All rights reserved.
+ */
+/*
+ * Copyright (c) 2010, Remko Tron¨on.
+ * All rights reserved.
+ */
+package com.isode.stroke.parser.payloadparsers;
+
+import com.isode.stroke.parser.GenericPayloadParserFactory;
+
+class StartSessionParserFactory extends GenericPayloadParserFactory<StartSessionParser> {
+
+ public StartSessionParserFactory() {
+ super("session", "urn:ietf:params:xml:ns:xmpp-session", StartSessionParser.class);
+ }
+
+}