summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'src/com/isode/stroke/serializer/payloadserializers/MAMFinSerializer.java')
-rw-r--r--src/com/isode/stroke/serializer/payloadserializers/MAMFinSerializer.java44
1 files changed, 44 insertions, 0 deletions
diff --git a/src/com/isode/stroke/serializer/payloadserializers/MAMFinSerializer.java b/src/com/isode/stroke/serializer/payloadserializers/MAMFinSerializer.java
new file mode 100644
index 0000000..3fcbc1d
--- /dev/null
+++ b/src/com/isode/stroke/serializer/payloadserializers/MAMFinSerializer.java
@@ -0,0 +1,44 @@
+package com.isode.stroke.serializer.payloadserializers;
+
+import com.isode.stroke.elements.MAMFin;
+import com.isode.stroke.elements.ResultSet;
+import com.isode.stroke.serializer.GenericPayloadSerializer;
+import com.isode.stroke.serializer.xml.XMLElement;
+import com.isode.stroke.serializer.xml.XMLRawTextNode;
+
+public class MAMFinSerializer extends GenericPayloadSerializer<MAMFin> {
+
+ public MAMFinSerializer() {
+ super(MAMFin.class);
+ }
+
+ @Override
+ protected String serializePayload(MAMFin payload) {
+ if (payload == null) {
+ return "";
+ }
+
+ XMLElement element = new XMLElement("fin","urn:xmpp:mam:0");
+
+ if (payload.isComplete()) {
+ element.setAttribute("complete", "true");
+ }
+ if (!payload.isStable()) {
+ element.setAttribute("stable", "false");
+ }
+ String queryIDValue = payload.getQueryID();
+ if (queryIDValue != null) {
+ element.setAttribute("queryid", queryIDValue);
+ }
+ ResultSet resultSet = payload.getResultSet();
+ if (resultSet != null) {
+ ResultSetSerializer resultSetSerialized = new ResultSetSerializer();
+ String serializedResultSet = resultSetSerialized.serialize(resultSet);
+ XMLRawTextNode rawTextNode = new XMLRawTextNode(serializedResultSet);
+ element.addNode(rawTextNode);
+ }
+
+ return element.serialize();
+ }
+
+}