blob: 1f8676ae3372987bad3821dd528c062eae8f6284 [file] [log] [blame]
Yuta HIGUCHIa7f1cdd2014-06-09 15:05:20 -07001package net.onrc.onos.core.topology.web.serializers;
TeruU65bc5ff2014-04-23 22:22:32 -07002
3import java.io.IOException;
4
5import net.onrc.onos.core.topology.Device;
6import net.onrc.onos.core.topology.Port;
TeruU65bc5ff2014-04-23 22:22:32 -07007
TeruU65bc5ff2014-04-23 22:22:32 -07008import org.codehaus.jackson.JsonGenerator;
9import org.codehaus.jackson.map.SerializerProvider;
10import org.codehaus.jackson.map.ser.std.SerializerBase;
11
12public class DeviceSerializer extends SerializerBase<Device> {
13
14 public DeviceSerializer() {
15 super(Device.class);
16 }
17
18 @Override
19 public void serialize(Device dev, JsonGenerator jsonGenerator,
Ray Milkey7d7f0a02014-06-18 12:52:13 -070020 SerializerProvider serializerProvider) throws IOException {
Pavlin Radoslavov5cf1fe02014-07-03 22:52:25 -070021
22 //
23 // TODO: For now, the JSON format of the serialized output should
24 // be same as the JSON format of the corresponding class DeviceEvent.
25 // In the future, we will use a single serializer.
26 //
27
TeruU65bc5ff2014-04-23 22:22:32 -070028 jsonGenerator.writeStartObject();
TeruU1c072a62014-04-28 14:49:25 -070029 jsonGenerator.writeStringField("mac", dev.getMacAddress().toString());
TeruU65bc5ff2014-04-23 22:22:32 -070030 jsonGenerator.writeFieldName("attachmentPoints");
31 jsonGenerator.writeStartArray();
32 for (Port port : dev.getAttachmentPoints()) {
Pavlin Radoslavov5cf1fe02014-07-03 22:52:25 -070033 jsonGenerator.writeObject(port.asSwitchPort());
TeruU65bc5ff2014-04-23 22:22:32 -070034 }
35 jsonGenerator.writeEndArray();
36 jsonGenerator.writeEndObject();
37 }
TeruU65bc5ff2014-04-23 22:22:32 -070038}