<enforcer.version>1.3.1</enforcer.version>
<bundle.plugin.version>2.3.7</bundle.plugin.version>
<junit.version>4.8.1</junit.version>
- <bgpcep.version>0.2.0-SNAPSHOT</bgpcep.version>
+ <bgpcep.version>0.3.0-SNAPSHOT</bgpcep.version>
<yangtools.version>0.5.9-SNAPSHOT</yangtools.version>
<yangtools.binding.version>0.6.0-SNAPSHOT</yangtools.binding.version>
<!--versions for bits of the controller -->
<groupId>com.google.code.findbugs</groupId>
<artifactId>jsr305</artifactId>
</dependency>
- <dependency>
- <groupId>org.opendaylight.bgpcep</groupId>
- <artifactId>concepts</artifactId>
- <version>0.2.0-SNAPSHOT</version>
- </dependency>
<dependency>
<groupId>org.osgi</groupId>
<artifactId>org.osgi.core</artifactId>
*/
package org.opendaylight.controller.config.api;
-import org.opendaylight.protocol.concepts.Identifier;
-
-public class ModuleIdentifier implements Identifier {
+public class ModuleIdentifier {
private static final long serialVersionUID = 1L;
private final String factoryName, instanceName;
import org.opendaylight.controller.config.api.ModuleIdentifier;
import org.opendaylight.controller.config.api.annotations.RequireInterface;
-import org.opendaylight.protocol.concepts.NamedObject;
+
/**
* Represents one service that is to be configured. These methods need to be
* </p>
*/
@NotThreadSafe
-public interface Module extends NamedObject<ModuleIdentifier> {
+public interface Module {
/**
* This method will be called as first phase in two phase commit. Instance
* can check attributes, but is not allowed to do any kind of work that
*/
AutoCloseable getInstance();
+ ModuleIdentifier getName();
+
}
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>mockito-configuration</artifactId>
- <version>0.2.0-SNAPSHOT</version>
+ <version>${bgpcep.version}</version>
<scope>test</scope>
</dependency>
<dependency>
import org.opendaylight.controller.config.manager.impl.util.LookupBeansUtil;
import org.opendaylight.controller.config.spi.Module;
import org.opendaylight.controller.config.spi.ModuleFactory;
-import org.opendaylight.protocol.concepts.NamedObject;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
*/
class ConfigTransactionControllerImpl implements
ConfigTransactionControllerInternal,
- ConfigTransactionControllerImplMXBean,
- NamedObject<TransactionIdentifier> {
+ ConfigTransactionControllerImplMXBean {
private static final Logger logger = LoggerFactory
.getLogger(ConfigTransactionControllerImpl.class);
return txModuleJMXRegistrator;
}
- @Override
public TransactionIdentifier getName() {
return transactionIdentifier;
}
import org.opendaylight.controller.config.api.ModuleIdentifier;
import org.opendaylight.controller.config.manager.impl.jmx.ModuleJMXRegistrator;
import org.opendaylight.controller.config.manager.impl.osgi.BeanToOsgiServiceManager.OsgiRegistration;
-import org.opendaylight.protocol.concepts.NamedObject;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
* were created. Module instances should be closed in order defined by the
* compareTo method.
*/
-public class DestroyedModule implements NamedObject<ModuleIdentifier>,
- AutoCloseable, Comparable<DestroyedModule> {
+public class DestroyedModule implements AutoCloseable,
+ Comparable<DestroyedModule> {
private static final Logger logger = LoggerFactory
.getLogger(DestroyedModule.class);
this.orderingIdx = orderingIdx;
}
- @Override
public ModuleIdentifier getName() {
return name;
}
import org.opendaylight.controller.config.manager.impl.jmx.ModuleJMXRegistrator;
import org.opendaylight.controller.config.manager.impl.jmx.RootRuntimeBeanRegistratorImpl;
import org.opendaylight.controller.config.manager.impl.osgi.BeanToOsgiServiceManager.OsgiRegistration;
-import org.opendaylight.protocol.concepts.NamedObject;
/**
* Provides metadata about Module from controller to registry.
*/
-public class ModuleInternalInfo implements NamedObject<ModuleIdentifier>,
- Comparable<ModuleInternalInfo> {
+public class ModuleInternalInfo implements Comparable<ModuleInternalInfo> {
private final ModuleIdentifier name;
// this registrator is passed to runtime bean registrator and config
return osgiRegistration;
}
- @Override
public ModuleIdentifier getName() {
return name;
}
.TransactionModuleJMXRegistration;
import org.opendaylight.controller.config.spi.Module;
import org.opendaylight.controller.config.spi.ModuleFactory;
-import org.opendaylight.protocol.concepts.NamedObject;
-public class ModuleInternalTransactionalInfo implements
- NamedObject<ModuleIdentifier> {
+public class ModuleInternalTransactionalInfo {
private final ModuleIdentifier name;
private final Module module;
private final ModuleFactory moduleFactory;
this.transactionModuleJMXRegistration = transactionModuleJMXRegistration;
}
- @Override
public ModuleIdentifier getName() {
return name;
}
*/
package org.opendaylight.controller.config.manager.impl;
-import org.opendaylight.protocol.concepts.Identifier;
-
-public class TransactionIdentifier implements Identifier {
+public class TransactionIdentifier {
private final String name;
public TransactionIdentifier(String name) {
import org.opendaylight.controller.config.manager.impl.TransactionStatus;
import org.opendaylight.controller.config.spi.Module;
import org.opendaylight.controller.config.spi.ModuleFactory;
-import org.opendaylight.protocol.concepts.NamedObject;
/**
* Protect {@link org.opendaylight.controller.config.spi.Module#getInstance()}
* during validation. Tracks dependencies for ordering purposes.
*/
final class DependencyResolverImpl implements DependencyResolver,
- NamedObject<ModuleIdentifier>, Comparable<DependencyResolverImpl> {
+ Comparable<DependencyResolverImpl> {
private final ModulesHolder modulesHolder;
private final ModuleIdentifier name;
private final TransactionStatus transactionStatus;
this.modulesHolder = modulesHolder;
}
- @Override
public ModuleIdentifier getName() {
return name;
}
@Test
public void testGetAllInterfaces() {
Set<Class<?>> expected = Sets.<Class<?>> newHashSet(SuperA.class, SuperBMXBean.class, SuperC.class,
- SubA.class, Module.class, org.opendaylight.protocol.concepts.NamedObject.class);
+ SubA.class, Module.class);
assertEquals(expected,
InterfacesHelper.getAllInterfaces(SubClass.class));
}
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>mockito-configuration</artifactId>
- <version>0.2.0-SNAPSHOT</version>
+ <version>${bgpcep.version}</version>
<scope>test</scope>
</dependency>
</dependencies>
<artifactId>config-api</artifactId>
<version>0.2.1-SNAPSHOT</version>
</dependency>
- <dependency>
- <groupId>org.opendaylight.bgpcep</groupId>
- <artifactId>concepts</artifactId>
- <version>0.2.0-SNAPSHOT</version>
- </dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>mockito-configuration</artifactId>
- <version>0.2.0-SNAPSHOT</version>
+ <version>${bgpcep.version}</version>
<scope>test</scope>
</dependency>
<dependency>
ch.qos.logback.core.status,
ch.qos.logback.core.encoder,
ch.qos.logback.core.rolling,
- org.opendaylight.protocol.concepts,
org.opendaylight.controller.config.api,
org.opendaylight.controller.config.api.runtime,
org.opendaylight.controller.config.api.annotations,
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>mockito-configuration</artifactId>
- <version>0.2.0-SNAPSHOT</version>
+ <version>${bgpcep.version}</version>
<scope>test</scope>
</dependency>
</dependencies>
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>mockito-configuration</artifactId>
- <version>0.2.0-SNAPSHOT</version>
+ <version>${bgpcep.version}</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>mockito-configuration</artifactId>
- <version>0.2.0-SNAPSHOT</version>
+ <version>${bgpcep.version}</version>
<scope>test</scope>
</dependency>
<dependency>
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>mockito-configuration</artifactId>
- <version>0.2.0-SNAPSHOT</version>
+ <version>${bgpcep.version}</version>
<scope>test</scope>
</dependency>
</dependencies>
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>mockito-configuration</artifactId>
+ <version>${bgpcep.version}</version>
<scope>test</scope>
</dependency>
</dependencies>
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>mockito-configuration</artifactId>
+ <version>${bgpcep.version}</version>
<scope>test</scope>
</dependency>
</dependencies>
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>framework</artifactId>
+ <version>${bgpcep.version}</version>
</dependency>
</dependencies>
package org.opendaylight.controller.netconf.api;
-import org.opendaylight.protocol.framework.ProtocolMessage;
import org.w3c.dom.Document;
/**
* NetconfMessage represents a wrapper around org.w3c.dom.Document. Needed for
* implementing ProtocolMessage interface.
*/
-public final class NetconfMessage implements ProtocolMessage {
+public final class NetconfMessage {
private static final long serialVersionUID = 462175939836367285L;
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>framework</artifactId>
+ <version>${bgpcep.version}</version>
</dependency>
<dependency>
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>util</artifactId>
+ <version>${bgpcep.version}</version>
</dependency>
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>framework</artifactId>
+ <version>${bgpcep.version}</version>
</dependency>
<dependency>
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>mockito-configuration</artifactId>
+ <version>${bgpcep.version}</version>
<scope>test</scope>
</dependency>
<dependency>
import static org.junit.Assert.assertArrayEquals;
import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertNotNull;
-import static org.junit.Assert.assertTrue;
-import java.util.Queue;
+import java.io.IOException;
-import io.netty.buffer.ByteBuf;
-import io.netty.channel.embedded.EmbeddedChannel;
+import javax.xml.parsers.ParserConfigurationException;
+import org.custommonkey.xmlunit.XMLAssert;
import org.junit.Before;
+import org.junit.Ignore;
import org.junit.Test;
import org.opendaylight.controller.netconf.api.NetconfMessage;
-import org.opendaylight.controller.netconf.util.handler.FramingMechanismHandlerFactory;
-import org.opendaylight.controller.netconf.util.handler.NetconfMessageAggregator;
-import org.opendaylight.controller.netconf.util.handler.NetconfMessageChunkDecoder;
import org.opendaylight.controller.netconf.util.messages.FramingMechanism;
import org.opendaylight.controller.netconf.util.messages.NetconfMessageFactory;
-import org.opendaylight.controller.netconf.util.messages.NetconfMessageHeader;
import org.opendaylight.controller.netconf.util.test.XmlFileLoader;
-import org.opendaylight.protocol.framework.ProtocolMessageDecoder;
-import org.opendaylight.protocol.framework.ProtocolMessageEncoder;
+import org.opendaylight.controller.netconf.util.xml.XmlUtil;
+import org.opendaylight.protocol.framework.DeserializerException;
+import org.opendaylight.protocol.framework.DocumentedException;
+import org.opendaylight.protocol.util.ByteArray;
+import org.w3c.dom.Document;
+import org.xml.sax.SAXException;
public class MessageParserTest {
- private NetconfMessage msg;
- private NetconfMessageFactory msgFactory = new NetconfMessageFactory();
+ private NetconfMessageFactory parser = null;
@Before
- public void setUp() throws Exception {
- this.msg = XmlFileLoader.xmlFileToNetconfMessage("netconfMessages/getConfig.xml");
+ public void setUp() {
+ this.parser = new NetconfMessageFactory();
}
@Test
- public void testChunkedFramingMechanismOnPipeline() throws Exception {
- EmbeddedChannel testChunkChannel = new EmbeddedChannel(
- FramingMechanismHandlerFactory.createHandler(FramingMechanism.CHUNK),
- new ProtocolMessageEncoder<NetconfMessage>(msgFactory),
-
- new NetconfMessageAggregator(FramingMechanism.CHUNK), new NetconfMessageChunkDecoder(),
- new ProtocolMessageDecoder<NetconfMessage>(msgFactory));
-
- testChunkChannel.writeOutbound(this.msg);
- Queue<Object> messages = testChunkChannel.outboundMessages();
- assertFalse(messages.isEmpty());
-
- int msgLength = msgFactory.put(this.msg).length;
- int chunkCount = msgLength / NetconfMessageFactory.MAX_CHUNK_SIZE;
- if ((msgLength % NetconfMessageFactory.MAX_CHUNK_SIZE) != 0) {
- chunkCount++;
- }
- for (int i = 1; i <= chunkCount; i++) {
- ByteBuf recievedOutbound = (ByteBuf) messages.poll();
- int exptHeaderLength = NetconfMessageFactory.MAX_CHUNK_SIZE;
- if (i == chunkCount) {
- exptHeaderLength = msgLength - (NetconfMessageFactory.MAX_CHUNK_SIZE * (i - 1));
- byte[] eom = new byte[NetconfMessageFactory.endOfChunk.length];
- recievedOutbound.getBytes(recievedOutbound.readableBytes() - NetconfMessageFactory.endOfChunk.length,
- eom);
- assertArrayEquals(NetconfMessageFactory.endOfChunk, eom);
- }
-
- byte[] header = new byte[String.valueOf(exptHeaderLength).length() + NetconfMessageHeader.MIN_HEADER_LENGTH
- - 1];
- recievedOutbound.getBytes(0, header);
- NetconfMessageHeader messageHeader = new NetconfMessageHeader();
- messageHeader.fromBytes(header);
- assertEquals(exptHeaderLength, messageHeader.getLength());
-
- testChunkChannel.writeInbound(recievedOutbound);
- }
- assertTrue(messages.isEmpty());
-
- NetconfMessage receivedMessage = (NetconfMessage) testChunkChannel.readInbound();
- assertNotNull(receivedMessage);
- assertTrue(this.msg.getDocument().isEqualNode(receivedMessage.getDocument()));
+ public void testPutEOM() throws IOException, SAXException, ParserConfigurationException {
+ final NetconfMessage msg = XmlFileLoader.xmlFileToNetconfMessage("netconfMessages/client_hello.xml");
+ final byte[] bytes = this.parser.put(msg);
+ assertArrayEquals(NetconfMessageFactory.endOfMessage, ByteArray.subByte(bytes, bytes.length
+ - NetconfMessageFactory.endOfMessage.length, NetconfMessageFactory.endOfMessage.length));
}
+ @Ignore
@Test
- public void testEOMFramingMechanismOnPipeline() throws Exception {
- EmbeddedChannel testChunkChannel = new EmbeddedChannel(
- FramingMechanismHandlerFactory.createHandler(FramingMechanism.EOM),
- new ProtocolMessageEncoder<NetconfMessage>(msgFactory), new NetconfMessageAggregator(
- FramingMechanism.EOM), new ProtocolMessageDecoder<NetconfMessage>(msgFactory));
-
- testChunkChannel.writeOutbound(this.msg);
- ByteBuf recievedOutbound = (ByteBuf) testChunkChannel.readOutbound();
+ // TODO not working on WINDOWS
+ // arrays first differed at element [4]; expected:<49> but was:<53>
+ // at
+ // org.junit.internal.ComparisonCriteria.arrayEquals(ComparisonCriteria.java:52)
+ public void testPutChunk() throws IOException, SAXException, ParserConfigurationException {
+ final NetconfMessage msg = XmlFileLoader.xmlFileToNetconfMessage("netconfMessages/client_hello.xml");
+ this.parser.setFramingMechanism(FramingMechanism.CHUNK);
+ final byte[] bytes = this.parser.put(msg);
+ final byte[] header = new byte[] { (byte) 0x0a, (byte) 0x23 , (byte) 0x32, (byte) 0x31, (byte) 0x31, (byte) 0x0a};
+ assertArrayEquals(header, ByteArray.subByte(bytes, 0, header.length));
+ assertArrayEquals(NetconfMessageFactory.endOfChunk, ByteArray.subByte(bytes, bytes.length
+ - NetconfMessageFactory.endOfChunk.length, NetconfMessageFactory.endOfChunk.length));
+ }
- byte[] eom = new byte[NetconfMessageFactory.endOfMessage.length];
- recievedOutbound.getBytes(recievedOutbound.readableBytes() - NetconfMessageFactory.endOfMessage.length, eom);
- assertArrayEquals(NetconfMessageFactory.endOfMessage, eom);
+ @Test
+ public void testParseEOM() throws IOException, SAXException, DeserializerException, DocumentedException,
+ ParserConfigurationException {
+ final Document msg = XmlFileLoader.xmlFileToDocument("netconfMessages/client_hello.xml");
+ final byte[] bytes = this.parser.put(new NetconfMessage(msg));
+ final Document doc = this.parser
+ .parse(ByteArray.subByte(bytes, 0, bytes.length - NetconfMessageFactory.endOfMessage.length))
+ .getDocument();
+ assertEquals(XmlUtil.toString(msg), XmlUtil.toString(doc));
+ XMLAssert.assertXMLEqual(msg, doc);
+ }
- testChunkChannel.writeInbound(recievedOutbound);
- NetconfMessage receivedMessage = (NetconfMessage) testChunkChannel.readInbound();
- assertNotNull(receivedMessage);
- assertTrue(this.msg.getDocument().isEqualNode(receivedMessage.getDocument()));
+ @Test
+ public void testParseChunk() throws IOException, SAXException, DeserializerException, DocumentedException,
+ ParserConfigurationException {
+ final Document msg = XmlFileLoader.xmlFileToDocument("netconfMessages/client_hello.xml");
+ this.parser.setFramingMechanism(FramingMechanism.CHUNK);
+ final byte[] bytes = this.parser.put(new NetconfMessage(msg));
+ final Document doc = this.parser
+ .parse(ByteArray.subByte(bytes, 6, bytes.length - NetconfMessageFactory.endOfChunk.length - 6))
+ .getDocument();
+ assertEquals(XmlUtil.toString(msg), XmlUtil.toString(doc));
+ XMLAssert.assertXMLEqual(msg, doc);
}
+
}
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>util</artifactId>
+ <version>${bgpcep.version}</version>
<scope>test</scope>
</dependency>
<dependency>
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>mockito-configuration</artifactId>
+ <version>${bgpcep.version}</version>
<scope>test</scope>
</dependency>
</dependencies>
protected List<ModuleFactory> getModuleFactories() {
return getModuleFactoriesS();
}
-
static List<ModuleFactory> getModuleFactoriesS() {
return Lists.newArrayList(new TestImplModuleFactory(), new DepTestImplModuleFactory(),
new NetconfTestImplModuleFactory());
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>framework</artifactId>
+ <version>${bgpcep.version}</version>
</dependency>
<dependency>
<groupId>org.opendaylight.bgpcep</groupId>
<artifactId>util</artifactId>
+ <version>${bgpcep.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</dependency>
+ <dependency>
+ <groupId>io.netty</groupId>
+ <artifactId>netty-handler</artifactId>
+ <version>${netconf.netty.version}</version>
+ </dependency>
</dependencies>
<build>
import com.google.common.base.Charsets;
import com.google.common.base.Optional;
-import com.google.common.collect.Lists;
+import io.netty.buffer.Unpooled;
+import io.netty.channel.ChannelHandler;
+import io.netty.handler.codec.DelimiterBasedFrameDecoder;
import org.opendaylight.controller.netconf.api.NetconfDeserializerException;
import org.opendaylight.controller.netconf.api.NetconfMessage;
import org.opendaylight.controller.netconf.util.xml.XmlUtil;
public static final int MAX_CHUNK_SIZE = 1024; // Bytes
+ private FramingMechanism framing = FramingMechanism.EOM;
+
private final Optional<String> clientId;
public NetconfMessageFactory() {
this.clientId = clientId;
}
+ public static ChannelHandler getDelimiterFrameDecoder() {
+ return new DelimiterBasedFrameDecoder(Integer.MAX_VALUE, Unpooled.copiedBuffer(endOfMessage));
+ }
+
@Override
- public List<NetconfMessage> parse(byte[] bytes) throws DeserializerException, DocumentedException {
+ public NetconfMessage parse(byte[] bytes) throws DeserializerException, DocumentedException {
String s = Charsets.UTF_8.decode(ByteBuffer.wrap(bytes)).toString();
logger.debug("Parsing message \n{}", s);
if (bytes[0] == '[') {
bytes = Arrays.copyOfRange(bytes, endOfAuthHeader + 2, bytes.length);
}
}
- List<NetconfMessage> messages = Lists.newArrayList();
+ NetconfMessage message = null;
try {
Document doc = XmlUtil.readXmlToDocument(new ByteArrayInputStream(bytes));
- messages.add(new NetconfMessage(doc));
+ message = new NetconfMessage(doc);
} catch (final SAXException | IOException | IllegalStateException e) {
throw new NetconfDeserializerException("Could not parse message from " + new String(bytes), e);
}
- return messages;
+ return message;
}
@Override
Comment comment = netconfMessage.getDocument().createComment("clientId:" + clientId.get());
netconfMessage.getDocument().appendChild(comment);
}
- final ByteBuffer msgBytes = Charsets.UTF_8.encode(xmlToString(netconfMessage.getDocument()));
+ byte[] bytes = (this.framing == FramingMechanism.EOM) ? this.putEOM(netconfMessage) : this
+ .putChunked(netconfMessage);
String content = xmlToString(netconfMessage.getDocument());
logger.trace("Putting message \n{}", content);
- byte[] b = new byte[msgBytes.remaining()];
- msgBytes.get(b);
- return b;
+ return bytes;
+ }
+
+ private byte[] putEOM(NetconfMessage msg) {
+ // create byte buffer from the String XML
+ // all Netconf messages are encoded using UTF-8
+ final ByteBuffer msgBytes = Charsets.UTF_8.encode(xmlToString(msg.getDocument()));
+ final ByteBuffer result = ByteBuffer.allocate(msgBytes.limit() + endOfMessage.length);
+ result.put(msgBytes);
+ // put end of message
+ result.put(endOfMessage);
+ return result.array();
+ }
+
+ private byte[] putChunked(NetconfMessage msg) {
+ final ByteBuffer msgBytes = Charsets.UTF_8.encode(xmlToString(msg.getDocument()));
+ final NetconfMessageHeader h = new NetconfMessageHeader();
+ if (msgBytes.limit() > MAX_CHUNK_SIZE)
+ logger.warn("Netconf message too long, should be split.");
+ h.setLength(msgBytes.limit());
+ final byte[] headerBytes = h.toBytes();
+ final ByteBuffer result = ByteBuffer.allocate(headerBytes.length + msgBytes.limit() + endOfChunk.length);
+ result.put(headerBytes);
+ result.put(msgBytes);
+ result.put(endOfChunk);
+ return result.array();
}
private String xmlToString(Document doc) {
return XmlUtil.toString(doc, false);
}
+
+ /**
+ * For Hello message the framing is always EOM, but the framing mechanism
+ * may change.
+ *
+ * @param fm
+ * new framing mechanism
+ */
+ public void setFramingMechanism(final FramingMechanism fm) {
+ logger.debug("Framing mechanism changed to {}", fm);
+ this.framing = fm;
+ }
}
<slf4j.version>1.7.2</slf4j.version>
<java.version.source>1.7</java.version.source>
<java.version.target>1.7</java.version.target>
+ <netconf.netty.version>4.0.10.Final</netconf.netty.version>
</properties>
<dependencies>