01206d4e4b91bcbd6416c8d80f3cdc94fb8cb4df
[openflowjava.git] / openflow-protocol-impl / src / main / java / org / opendaylight / openflowjava / protocol / impl / core / OF13Decoder.java
1 /* Copyright (C)2013 Pantheon Technologies, s.r.o. All rights reserved. */\r
2 package org.opendaylight.openflowjava.protocol.impl.core;\r
3 \r
4 import io.netty.channel.ChannelHandlerContext;\r
5 import io.netty.handler.codec.MessageToMessageDecoder;\r
6 \r
7 import java.util.List;\r
8 \r
9 import org.opendaylight.openflowjava.protocol.impl.deserialization.DeserializationFactory;\r
10 import org.opendaylight.yangtools.yang.binding.DataObject;\r
11 import org.slf4j.Logger;\r
12 import org.slf4j.LoggerFactory;\r
13 \r
14 /**\r
15  * Transforms OpenFlow Protocol messages to POJOs\r
16  *\r
17  * @author michal.polkorab\r
18  */\r
19 public class OF13Decoder extends MessageToMessageDecoder<VersionMessageWrapper> {\r
20 \r
21     private static final Logger LOGGER = LoggerFactory.getLogger(OF13Decoder.class);\r
22 \r
23     /**\r
24      * Constructor of class\r
25      */\r
26     public OF13Decoder() {\r
27         LOGGER.info("Creating OF 1.3 Decoder");\r
28     }\r
29 \r
30     @Override\r
31     protected void decode(ChannelHandlerContext ctx, VersionMessageWrapper msg,\r
32             List<Object> out) throws Exception {\r
33         LOGGER.debug("VersionMessageWrapper received");\r
34         DataObject dataObject = DeserializationFactory.bufferToMessage(msg.getMessageBuffer(),\r
35                 msg.getVersion());\r
36         if (dataObject == null) {\r
37             LOGGER.warn("Translated POJO is null");\r
38             return;\r
39         }\r
40         out.add(dataObject);\r
41     }\r
42 }\r