summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'src/com/isode/stroke/serializer/payloadserializers')
-rw-r--r--src/com/isode/stroke/serializer/payloadserializers/DelaySerializer.java3
-rw-r--r--src/com/isode/stroke/serializer/payloadserializers/ErrorSerializer.java14
-rw-r--r--src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java2
3 files changed, 16 insertions, 3 deletions
diff --git a/src/com/isode/stroke/serializer/payloadserializers/DelaySerializer.java b/src/com/isode/stroke/serializer/payloadserializers/DelaySerializer.java
index f54f38f..38e1eba 100644
--- a/src/com/isode/stroke/serializer/payloadserializers/DelaySerializer.java
+++ b/src/com/isode/stroke/serializer/payloadserializers/DelaySerializer.java
@@ -25,7 +25,8 @@ public class DelaySerializer extends GenericPayloadSerializer<Delay> {
if (delay.getFrom() != null && delay.getFrom().isValid()) {
delayElement.setAttribute("from", delay.getFrom().toString());
}
- delayElement.setAttribute("stamp", DateTime.dateToString(delay.getStamp()));
+ if(delay.getStamp() != null)
+ delayElement.setAttribute("stamp", DateTime.dateToString(delay.getStamp()));
return delayElement.serialize();
}
}
diff --git a/src/com/isode/stroke/serializer/payloadserializers/ErrorSerializer.java b/src/com/isode/stroke/serializer/payloadserializers/ErrorSerializer.java
index 33d064d..47373f8 100644
--- a/src/com/isode/stroke/serializer/payloadserializers/ErrorSerializer.java
+++ b/src/com/isode/stroke/serializer/payloadserializers/ErrorSerializer.java
@@ -12,11 +12,16 @@ package com.isode.stroke.serializer.payloadserializers;
import com.isode.stroke.elements.ErrorPayload;
import com.isode.stroke.serializer.GenericPayloadSerializer;
import com.isode.stroke.serializer.xml.XMLTextNode;
+import com.isode.stroke.serializer.PayloadSerializerCollection;
+import com.isode.stroke.serializer.PayloadSerializer;
class ErrorSerializer extends GenericPayloadSerializer<ErrorPayload> {
- public ErrorSerializer() {
+ private PayloadSerializerCollection serializers;
+
+ public ErrorSerializer(PayloadSerializerCollection serializers) {
super(ErrorPayload.class);
+ this.serializers = serializers;
}
@Override
@@ -63,6 +68,13 @@ class ErrorSerializer extends GenericPayloadSerializer<ErrorPayload> {
result += "<text xmlns=\"urn:ietf:params:xml:ns:xmpp-stanzas\">" + textNode.serialize() + "</text>";
}
+ if (error.getPayload() != null) {
+ PayloadSerializer serializer = serializers.getPayloadSerializer(error.getPayload());
+ if (serializer != null) {
+ result += serializer.serialize(error.getPayload());
+ }
+ }
+
result += "</error>";
return result;
}
diff --git a/src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java b/src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java
index 001d126..ac093c0 100644
--- a/src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java
+++ b/src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java
@@ -26,7 +26,7 @@ public class FullPayloadSerializerCollection extends PayloadSerializerCollection
addSerializer(new CarbonsReceivedSerializer(this));
addSerializer(new CarbonsSentSerializer(this));
addSerializer(new PrioritySerializer());
- addSerializer(new ErrorSerializer());
+ addSerializer(new ErrorSerializer(this));
addSerializer(new InBandRegistrationPayloadSerializer());
addSerializer(new IBBSerializer());
addSerializer(new JingleIBBTransportPayloadSerializer());