2 * Copyright (c) 2014 Pantheon Technologies s.r.o. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
9 package org.opendaylight.openflowjava.protocol.impl.core;
11 import io.netty.channel.ChannelHandlerContext;
12 import io.netty.channel.SimpleChannelInboundHandler;
14 import org.opendaylight.openflowjava.protocol.impl.core.connection.MessageConsumer;
15 import org.opendaylight.openflowjava.protocol.impl.deserialization.DeserializationFactory;
16 import org.opendaylight.openflowjava.util.ByteBufUtils;
17 import org.opendaylight.yangtools.yang.binding.DataObject;
18 import org.slf4j.Logger;
19 import org.slf4j.LoggerFactory;
22 * @author michal.polkorab
25 public class OFDatagramPacketDecoder extends SimpleChannelInboundHandler<VersionMessageUdpWrapper>{
27 private static final Logger LOGGER = LoggerFactory.getLogger(OFDatagramPacketDecoder.class);
28 private DeserializationFactory deserializationFactory;
31 public void channelRead0(ChannelHandlerContext ctx, VersionMessageUdpWrapper msg)
33 if (LOGGER.isDebugEnabled()) {
34 LOGGER.debug("UdpVersionMessageWrapper received");
35 LOGGER.debug("<< " + ByteBufUtils.byteBufToHexString(msg.getMessageBuffer()));
37 DataObject dataObject = null;
39 dataObject = deserializationFactory.deserialize(msg.getMessageBuffer(),msg.getVersion());
40 if (dataObject == null) {
41 LOGGER.warn("Translated POJO is null");
43 MessageConsumer consumer = UdpConnectionMap.getMessageConsumer(msg.getAddress());
44 consumer.consume(dataObject);
46 } catch(Exception e) {
47 LOGGER.warn("Message deserialization failed");
48 LOGGER.warn(e.getMessage(), e);
49 // TODO: delegate exception to allow easier deserialization
50 // debugging / deserialization problem awareness
52 msg.getMessageBuffer().release();
57 * @param deserializationFactory
59 public void setDeserializationFactory(DeserializationFactory deserializationFactory) {
60 this.deserializationFactory = deserializationFactory;