blob: 60c984dbe9eb4c9a63893c0a746b3e17ea880ae0 [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
Ray Milkey92897212014-07-21 10:33:16 -070012/**
13 * Serializes a PortEvent object as JSON.
14 */
Pavlin Radoslavov5cf1fe02014-07-03 22:52:25 -070015public class PortEventSerializer extends SerializerBase<PortEvent> {
16
Ray Milkey92897212014-07-21 10:33:16 -070017 /**
18 * Constructs a PortEvent serializer.
19 */
Pavlin Radoslavov5cf1fe02014-07-03 22:52:25 -070020 public PortEventSerializer() {
21 super(PortEvent.class);
22 }
23
24 @Override
25 public void serialize(PortEvent portEvent, JsonGenerator jsonGenerator,
26 SerializerProvider serializerProvider)
27 throws IOException {
28 //
29 // TODO: For now, the JSON format of the serialized output should
30 // be same as the JSON format of the corresponding class Port.
31 // In the future, we will use a single serializer.
32 //
33
34 jsonGenerator.writeStartObject();
Yuta HIGUCHI1222ac52014-07-09 16:50:28 -070035 jsonGenerator.writeStringField(TopologyElement.TYPE, portEvent.getType());
Pavlin Radoslavov5cf1fe02014-07-03 22:52:25 -070036 jsonGenerator.writeStringField("state", "ACTIVE");
37 jsonGenerator.writeStringField("dpid", portEvent.getDpid().toString());
Pavlin Radoslavov5cf1fe02014-07-03 22:52:25 -070038 jsonGenerator.writeNumberField("portNumber",
Yuta HIGUCHI9da3a6e2014-06-10 22:11:58 -070039 portEvent.getPortNumber().value());
Pavlin Radoslavov5cf1fe02014-07-03 22:52:25 -070040 jsonGenerator.writeStringField("desc",
41 null /* port.getDescription() */);
42 jsonGenerator.writeEndObject();
43 }
44}