blob: 5319adfd345ea1fae4c59e3583aeded3d0e735f2 [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 {
TeruU65bc5ff2014-04-23 22:22:32 -070021 jsonGenerator.writeStartObject();
TeruU1c072a62014-04-28 14:49:25 -070022 jsonGenerator.writeStringField("mac", dev.getMacAddress().toString());
TeruU65bc5ff2014-04-23 22:22:32 -070023 jsonGenerator.writeFieldName("attachmentPoints");
24 jsonGenerator.writeStartArray();
25 for (Port port : dev.getAttachmentPoints()) {
TeruU1c072a62014-04-28 14:49:25 -070026 jsonGenerator.writeStartObject();
Yuta HIGUCHI8f3dfa32014-06-25 00:14:25 -070027 jsonGenerator.writeStringField("dpid", port.getDpid().toString());
28 // XXX Should port number be treated as unsigned?
29 jsonGenerator.writeNumberField("port", port.getNumber().value());
TeruU1c072a62014-04-28 14:49:25 -070030 jsonGenerator.writeEndObject();
TeruU65bc5ff2014-04-23 22:22:32 -070031 }
32 jsonGenerator.writeEndArray();
33 jsonGenerator.writeEndObject();
34 }
TeruU65bc5ff2014-04-23 22:22:32 -070035}