2 * Copyright (c) 2013 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.Channel;
12 import io.netty.channel.group.DefaultChannelGroup;
13 import io.netty.channel.socket.SocketChannel;
14 import io.netty.handler.ssl.SslHandler;
16 import java.net.InetAddress;
17 import java.util.Iterator;
18 import java.util.concurrent.TimeUnit;
20 import javax.net.ssl.SSLEngine;
22 import org.opendaylight.openflowjava.protocol.impl.core.connection.ConnectionAdapterFactory;
23 import org.opendaylight.openflowjava.protocol.impl.core.connection.ConnectionAdapterFactoryImpl;
24 import org.opendaylight.openflowjava.protocol.impl.core.connection.ConnectionFacade;
25 import org.slf4j.Logger;
26 import org.slf4j.LoggerFactory;
29 * Initializes TCP / TLS channel
30 * @author michal.polkorab
32 public class TcpChannelInitializer extends ProtocolChannelInitializer<SocketChannel> {
34 private static final Logger LOGGER = LoggerFactory
35 .getLogger(TcpChannelInitializer.class);
36 private final DefaultChannelGroup allChannels;
37 private ConnectionAdapterFactory connectionAdapterFactory;
42 public TcpChannelInitializer() {
43 this( new DefaultChannelGroup("netty-receiver", null), new ConnectionAdapterFactoryImpl() );
50 protected TcpChannelInitializer( DefaultChannelGroup channelGroup, ConnectionAdapterFactory connAdaptorFactory ) {
51 allChannels = channelGroup ;
52 connectionAdapterFactory = connAdaptorFactory ;
56 protected void initChannel(final SocketChannel ch) {
57 if (ch.remoteAddress() != null) {
58 InetAddress switchAddress = ch.remoteAddress().getAddress();
59 int port = ch.localAddress().getPort();
60 int remotePort = ch.remoteAddress().getPort();
61 LOGGER.debug("Incoming connection from (remote address): " + switchAddress.toString()
62 + ":" + remotePort + " --> :" + port);
64 if (!getSwitchConnectionHandler().accept(switchAddress)) {
66 LOGGER.debug("Incoming connection rejected");
70 LOGGER.debug("Incoming connection accepted - building pipeline");
72 ConnectionFacade connectionFacade = null;
73 connectionFacade = connectionAdapterFactory.createConnectionFacade(ch, null);
75 LOGGER.debug("calling plugin: " + getSwitchConnectionHandler());
76 getSwitchConnectionHandler().onSwitchConnected(connectionFacade);
77 connectionFacade.checkListeners();
78 ch.pipeline().addLast(PipelineHandlers.IDLE_HANDLER.name(), new IdleHandler(getSwitchIdleTimeout(), TimeUnit.MILLISECONDS));
79 boolean tlsPresent = false;
81 // If this channel is configured to support SSL it will only support SSL
82 if (getTlsConfiguration() != null) {
84 SslContextFactory sslFactory = new SslContextFactory(getTlsConfiguration());
85 SSLEngine engine = sslFactory.getServerContext().createSSLEngine();
86 engine.setNeedClientAuth(true);
87 engine.setUseClientMode(false);
88 ch.pipeline().addLast(PipelineHandlers.SSL_HANDLER.name(), new SslHandler(engine));
90 ch.pipeline().addLast(PipelineHandlers.OF_FRAME_DECODER.name(),
91 new OFFrameDecoder(connectionFacade, tlsPresent));
92 ch.pipeline().addLast(PipelineHandlers.OF_VERSION_DETECTOR.name(), new OFVersionDetector());
93 OFDecoder ofDecoder = new OFDecoder();
94 ofDecoder.setDeserializationFactory(getDeserializationFactory());
95 ch.pipeline().addLast(PipelineHandlers.OF_DECODER.name(), ofDecoder);
96 OFEncoder ofEncoder = new OFEncoder();
97 ofEncoder.setSerializationFactory(getSerializationFactory());
98 ch.pipeline().addLast(PipelineHandlers.OF_ENCODER.name(), ofEncoder);
99 ch.pipeline().addLast(PipelineHandlers.DELEGATING_INBOUND_HANDLER.name(), new DelegatingInboundHandler(connectionFacade));
101 connectionFacade.fireConnectionReadyNotification();
103 } catch (Exception e) {
104 LOGGER.warn("Failed to initialize channel", e);
110 * @return iterator through active connections
112 public Iterator<Channel> getConnectionIterator() {
113 return allChannels.iterator();
117 * @return amount of active channels
120 return allChannels.size();