HIGUCHI Yuta | f086d8a | 2013-06-12 15:26:35 -0700 | [diff] [blame] | 1 | package net.onrc.onos.ofcontroller.util.serializers; |
Pavlin Radoslavov | 7c15361 | 2013-02-25 19:46:08 -0800 | [diff] [blame] | 2 | |
| 3 | import java.io.IOException; |
| 4 | |
HIGUCHI Yuta | 356086e | 2013-06-12 15:21:19 -0700 | [diff] [blame] | 5 | import net.onrc.onos.ofcontroller.util.Dpid; |
Pavlin Radoslavov | 7c15361 | 2013-02-25 19:46:08 -0800 | [diff] [blame] | 6 | |
HIGUCHI Yuta | 858c1ea | 2013-06-14 13:10:06 -0700 | [diff] [blame] | 7 | import org.codehaus.jackson.JsonParser; |
| 8 | import org.codehaus.jackson.JsonProcessingException; |
| 9 | import org.codehaus.jackson.JsonToken; |
| 10 | import org.codehaus.jackson.map.DeserializationContext; |
| 11 | import org.codehaus.jackson.map.JsonDeserializer; |
Pavlin Radoslavov | 7c15361 | 2013-02-25 19:46:08 -0800 | [diff] [blame] | 12 | import org.slf4j.Logger; |
| 13 | import org.slf4j.LoggerFactory; |
| 14 | |
| 15 | /** |
| 16 | * Deserialize a DPID from a string. |
| 17 | */ |
| 18 | public class DpidDeserializer extends JsonDeserializer<Dpid> { |
| 19 | |
Yuta HIGUCHI | 6ac8d18 | 2013-10-22 15:24:56 -0700 | [diff] [blame] | 20 | protected final static Logger log = LoggerFactory.getLogger(DpidDeserializer.class); |
Pavlin Radoslavov | 7c15361 | 2013-02-25 19:46:08 -0800 | [diff] [blame] | 21 | |
| 22 | @Override |
| 23 | public Dpid deserialize(JsonParser jp, |
| 24 | DeserializationContext ctxt) |
| 25 | throws IOException, JsonProcessingException { |
| 26 | |
| 27 | Dpid dpid = 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 | dpid = new Dpid(value); |
| 36 | } |
| 37 | } |
| 38 | return dpid; |
| 39 | } |
| 40 | } |