blob: 69d710e8743765c31eb0221b1f10c75b9debb413 [file] [log] [blame]
Yuta HIGUCHIa7f1cdd2014-06-09 15:05:20 -07001package net.onrc.onos.core.topology.web.serializers;
Jonathan Hart891d0502014-02-10 10:04:08 -08002
3import java.io.IOException;
Yuta HIGUCHId830aad2014-07-06 15:02:01 -07004import java.util.Map.Entry;
Jonathan Hart891d0502014-02-10 10:04:08 -08005
Jonathan Hart472062d2014-04-03 10:56:48 -07006import net.onrc.onos.core.topology.Port;
Jonathan Hart891d0502014-02-10 10:04:08 -08007
8import org.codehaus.jackson.JsonGenerator;
Jonathan Hart891d0502014-02-10 10:04:08 -08009import org.codehaus.jackson.map.SerializerProvider;
10import org.codehaus.jackson.map.ser.std.SerializerBase;
11
12public class PortSerializer extends SerializerBase<Port> {
13
Ray Milkey269ffb92014-04-03 14:43:30 -070014 public PortSerializer() {
15 super(Port.class);
16 }
Jonathan Hart891d0502014-02-10 10:04:08 -080017
Ray Milkey269ffb92014-04-03 14:43:30 -070018 @Override
19 public void serialize(Port port, JsonGenerator jsonGenerator,
20 SerializerProvider serializerProvider)
Ray Milkey7d7f0a02014-06-18 12:52:13 -070021 throws IOException {
Pavlin Radoslavov5cf1fe02014-07-03 22:52:25 -070022 //
23 // TODO: For now, the JSON format of the serialized output should
24 // be same as the JSON format of the corresponding class PortEvent.
25 // In the future, we will use a single serializer.
26 //
27
Ray Milkey269ffb92014-04-03 14:43:30 -070028 jsonGenerator.writeStartObject();
29 jsonGenerator.writeStringField("state", "ACTIVE");
Yuta HIGUCHI8f3dfa32014-06-25 00:14:25 -070030 jsonGenerator.writeStringField("dpid", port.getDpid().toString());
Pavlin Radoslavov5cf1fe02014-07-03 22:52:25 -070031 //
32 // FIXME: The solution below to preresent the "short" port number
33 // as an unsigned value is a hack. The fix should be elsewhere
34 // (e.g., in class PortNumber itself).
35 //
36 jsonGenerator.writeNumberField("portNumber",
37 (0xffff & port.getNumber().value()));
Ray Milkey269ffb92014-04-03 14:43:30 -070038 jsonGenerator.writeStringField("desc", port.getDescription());
Yuta HIGUCHId830aad2014-07-06 15:02:01 -070039 jsonGenerator.writeObjectFieldStart("stringAttributes");
40 for (Entry<String, String> entry : port.getAllStringAttributes().entrySet()) {
41 jsonGenerator.writeStringField(entry.getKey(), entry.getValue());
42 }
43 jsonGenerator.writeEndObject(); // stringAttributes
Ray Milkey269ffb92014-04-03 14:43:30 -070044 jsonGenerator.writeEndObject();
45 }
Jonathan Hart891d0502014-02-10 10:04:08 -080046}