blob: f3410270abfe17b21434b216b0b27665cc4f7853 [file] [log] [blame]
HIGUCHI Yutaf086d8a2013-06-12 15:26:35 -07001package net.onrc.onos.ofcontroller.util.serializers;
Pavlin Radoslavov7c153612013-02-25 19:46:08 -08002
3import java.io.IOException;
4
HIGUCHI Yuta356086e2013-06-12 15:21:19 -07005import net.onrc.onos.ofcontroller.util.FlowId;
Pavlin Radoslavov7c153612013-02-25 19:46:08 -08006
HIGUCHI Yuta858c1ea2013-06-14 13:10:06 -07007import org.codehaus.jackson.JsonParser;
8import org.codehaus.jackson.JsonProcessingException;
9import org.codehaus.jackson.JsonToken;
10import org.codehaus.jackson.map.DeserializationContext;
11import org.codehaus.jackson.map.JsonDeserializer;
Pavlin Radoslavov7c153612013-02-25 19:46:08 -080012import org.slf4j.Logger;
13import org.slf4j.LoggerFactory;
14
15/**
16 * Deserialize a Flow ID from a string.
17 */
18public class FlowIdDeserializer extends JsonDeserializer<FlowId> {
19
Yuta HIGUCHI6ac8d182013-10-22 15:24:56 -070020 protected final static Logger log = LoggerFactory.getLogger(FlowIdDeserializer.class);
Pavlin Radoslavov7c153612013-02-25 19:46:08 -080021
22 @Override
23 public FlowId deserialize(JsonParser jp,
24 DeserializationContext ctxt)
25 throws IOException, JsonProcessingException {
26
27 FlowId flowId = null;
28
29 jp.nextToken(); // Move to JsonToken.START_OBJECT
30 while (jp.nextToken() != JsonToken.END_OBJECT) {
31 String fieldname = jp.getCurrentName();
32 if ("value".equals(fieldname)) {
33 String value = jp.getText();
34 log.debug("Fieldname: " + fieldname + " Value: " + value);
35 flowId = new FlowId(value);
36 }
37 }
38 return flowId;
39 }
40}