summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'src/com/isode/stroke/serializer/payloadserializers/MAMResultSerializer.java')
-rw-r--r--src/com/isode/stroke/serializer/payloadserializers/MAMResultSerializer.java44
1 files changed, 44 insertions, 0 deletions
diff --git a/src/com/isode/stroke/serializer/payloadserializers/MAMResultSerializer.java b/src/com/isode/stroke/serializer/payloadserializers/MAMResultSerializer.java
new file mode 100644
index 0000000..532e93f
--- /dev/null
+++ b/src/com/isode/stroke/serializer/payloadserializers/MAMResultSerializer.java
@@ -0,0 +1,44 @@
+/*
+* Copyright (c) 2014 Kevin Smith and Remko Tronçon
+* All rights reserved.
+*/
+
+/*
+* Copyright (c) 2014, Isode Limited, London, England.
+* All rights reserved.
+*/
+
+package com.isode.stroke.serializer.payloadserializers;
+
+import com.isode.stroke.elements.MAMResult;
+import com.isode.stroke.serializer.GenericPayloadSerializer;
+import com.isode.stroke.serializer.PayloadSerializerCollection;
+import com.isode.stroke.serializer.xml.XMLElement;
+import com.isode.stroke.serializer.xml.XMLRawTextNode;
+
+public class MAMResultSerializer extends GenericPayloadSerializer<MAMResult> {
+ public MAMResultSerializer(PayloadSerializerCollection serializers) {
+ super(MAMResult.class);
+ serializers_ = serializers;
+ }
+
+ public String serializePayload(MAMResult payload) {
+ if (payload == null) {
+ return "";
+ }
+
+ XMLElement element = new XMLElement("result", "urn:xmpp:mam:0");
+
+ element.setAttribute("id", payload.getID());
+
+ if (payload.getQueryID() != null) {
+ element.setAttribute("queryid", payload.getQueryID());
+ }
+
+ element.addNode(new XMLRawTextNode((new ForwardedSerializer(serializers_)).serialize(payload.getPayload())));
+
+ return element.serialize();
+ }
+
+ PayloadSerializerCollection serializers_;
+}