diff options
author | Tarun Gupta <tarun1995gupta@gmail.com> | 2015-06-11 20:23:56 (GMT) |
---|---|---|
committer | Tarun Gupta <tarun1995gupta@gmail.com> | 2015-06-16 19:14:39 (GMT) |
commit | e868c966e23716d8a0261b222cccbeb04616e235 (patch) | |
tree | 2e26cc205e671f54bc5de527917913f8de47e0f4 /src/com/isode/stroke/serializer | |
parent | b2a8ac9a0387a9a5e75e31f7704e62ac077faba4 (diff) | |
download | stroke-e868c966e23716d8a0261b222cccbeb04616e235.zip stroke-e868c966e23716d8a0261b222cccbeb04616e235.tar.bz2 |
Add the UserLocation Element.
Adds UserLocation Element, its parser and Serializer.
License:
This patch is BSD-licensed, see Documentation/Licenses/BSD-simplified.txt for details.
Test-Information:
Tests added for UserLocation Parser and UserLocation Serializer, which passes.
Change-Id: Ia1d57f4233351e755770f06fdc8e292db1acf521
Diffstat (limited to 'src/com/isode/stroke/serializer')
-rw-r--r-- | src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java | 1 | ||||
-rw-r--r-- | src/com/isode/stroke/serializer/payloadserializers/UserLocationSerializer.java | 105 |
2 files changed, 106 insertions, 0 deletions
diff --git a/src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java b/src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java index bdb57cc..c25ac12 100644 --- a/src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java +++ b/src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java @@ -69,6 +69,7 @@ public class FullPayloadSerializerCollection extends PayloadSerializerCollection addSerializer(new MAMQuerySerializer()); addSerializer(new MAMFinSerializer()); addSerializer(new UserTuneSerializer(this)); + addSerializer(new UserLocationSerializer(this)); } } diff --git a/src/com/isode/stroke/serializer/payloadserializers/UserLocationSerializer.java b/src/com/isode/stroke/serializer/payloadserializers/UserLocationSerializer.java new file mode 100644 index 0000000..233886e --- /dev/null +++ b/src/com/isode/stroke/serializer/payloadserializers/UserLocationSerializer.java @@ -0,0 +1,105 @@ +/* + * Copyright (c) 2013 Isode Limited. + * All rights reserved. + * See the COPYING file for more information. + */ +/* + * Copyright (c) 2015 Tarun Gupta. + * Licensed under the simplified BSD license. + * See Documentation/Licenses/BSD-simplified.txt for more information. + */ + +package com.isode.stroke.serializer.payloadserializers; + +import com.isode.stroke.serializer.GenericPayloadSerializer; +import com.isode.stroke.serializer.xml.XMLTextNode; +import com.isode.stroke.serializer.xml.XMLElement; +import com.isode.stroke.serializer.PayloadSerializerCollection; +import com.isode.stroke.elements.UserLocation; +import com.isode.stroke.base.NotNull; +import com.isode.stroke.base.DateTime; + +public class UserLocationSerializer extends GenericPayloadSerializer<UserLocation> { + + private PayloadSerializerCollection serializers; + + public UserLocationSerializer(PayloadSerializerCollection serializers) { + super(UserLocation.class); + this.serializers = serializers; + } + + public String serializePayload(UserLocation payload) { + if (payload == null) { + return ""; + } + + XMLElement element = new XMLElement("geoloc", "http://jabber.org/protocol/geoloc"); + if (payload.getArea() != null) { + element.addNode(new XMLElement("area", "", payload.getArea())); + } + if (payload.getAltitude() != null) { + element.addNode(new XMLElement("alt", "", Float.toString(payload.getAltitude()))); + } + if (payload.getLocality() != null) { + element.addNode(new XMLElement("locality", "", payload.getLocality())); + } + if (payload.getLatitude() != null) { + element.addNode(new XMLElement("lat", "", Float.toString(payload.getLatitude()))); + } + if (payload.getAccuracy() != null) { + element.addNode(new XMLElement("accuracy", "", Float.toString(payload.getAccuracy()))); + } + if (payload.getDescription() != null) { + element.addNode(new XMLElement("description", "", payload.getDescription())); + } + if (payload.getCountryCode() != null) { + element.addNode(new XMLElement("countrycode", "", payload.getCountryCode())); + } + if (payload.getTimestamp() != null) { + element.addNode(new XMLElement("timestamp", "", DateTime.dateToString(payload.getTimestamp()))); + } + if (payload.getFloor() != null) { + element.addNode(new XMLElement("floor", "", payload.getFloor())); + } + if (payload.getBuilding() != null) { + element.addNode(new XMLElement("building", "", payload.getBuilding())); + } + if (payload.getRoom() != null) { + element.addNode(new XMLElement("room", "", payload.getRoom())); + } + if (payload.getCountry() != null) { + element.addNode(new XMLElement("country", "", payload.getCountry())); + } + if (payload.getRegion() != null) { + element.addNode(new XMLElement("region", "", payload.getRegion())); + } + if (payload.getURI() != null) { + element.addNode(new XMLElement("uri", "", payload.getURI())); + } + if (payload.getLongitude() != null) { + element.addNode(new XMLElement("lon", "", Float.toString(payload.getLongitude()))); + } + if (payload.getError() != null) { + element.addNode(new XMLElement("error", "", Float.toString(payload.getError()))); + } + if (payload.getPostalCode() != null) { + element.addNode(new XMLElement("postalcode", "", payload.getPostalCode())); + } + if (payload.getBearing() != null) { + element.addNode(new XMLElement("bearing", "", Float.toString(payload.getBearing()))); + } + if (payload.getText() != null) { + element.addNode(new XMLElement("text", "", payload.getText())); + } + if (payload.getDatum() != null) { + element.addNode(new XMLElement("datum", "", payload.getDatum())); + } + if (payload.getStreet() != null) { + element.addNode(new XMLElement("street", "", payload.getStreet())); + } + if (payload.getSpeed() != null) { + element.addNode(new XMLElement("speed", "", Float.toString(payload.getSpeed()))); + } + return element.serialize(); + } +}
\ No newline at end of file |