blob: 4f2d5bf008480cc25bd5591e24fdf19b02760217 [file] [log] [blame]
Pavlin Radoslavov5cf1fe02014-07-03 22:52:25 -07001package net.onrc.onos.core.topology.web.serializers;
2
3import java.io.IOException;
4
5import net.onrc.onos.core.topology.PortEvent;
Yuta HIGUCHI1222ac52014-07-09 16:50:28 -07006import net.onrc.onos.core.topology.TopologyElement;
Pavlin Radoslavov5cf1fe02014-07-03 22:52:25 -07007
8import org.codehaus.jackson.JsonGenerator;
9import org.codehaus.jackson.map.SerializerProvider;
10import org.codehaus.jackson.map.ser.std.SerializerBase;
11
12public class PortEventSerializer extends SerializerBase<PortEvent> {
13
14 public PortEventSerializer() {
15 super(PortEvent.class);
16 }
17
18 @Override
19 public void serialize(PortEvent portEvent, JsonGenerator jsonGenerator,
20 SerializerProvider serializerProvider)
21 throws IOException {
22 //
23 // TODO: For now, the JSON format of the serialized output should
24 // be same as the JSON format of the corresponding class Port.
25 // In the future, we will use a single serializer.
26 //
27
28 jsonGenerator.writeStartObject();
Yuta HIGUCHI1222ac52014-07-09 16:50:28 -070029 jsonGenerator.writeStringField(TopologyElement.TYPE, portEvent.getType());
Pavlin Radoslavov5cf1fe02014-07-03 22:52:25 -070030 jsonGenerator.writeStringField("state", "ACTIVE");
31 jsonGenerator.writeStringField("dpid", portEvent.getDpid().toString());
32 //
33 // FIXME: The solution below to preresent the "short" port number
34 // as an unsigned value is a hack. The fix should be elsewhere
35 // (e.g., in class PortNumber itself).
36 //
37 jsonGenerator.writeNumberField("portNumber",
38 (0xffff & portEvent.getPortNumber().value()));
39 jsonGenerator.writeStringField("desc",
40 null /* port.getDescription() */);
41 jsonGenerator.writeEndObject();
42 }
43}