Merge "Resolve Bug:445 Remove freemarker from config code generator."
[controller.git] / opendaylight / netconf / netconf-impl / src / main / java / org / opendaylight / controller / netconf / impl / NetconfServerSessionNegotiator.java
1 /*
2  * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
3  *
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
7  */
8
9 package org.opendaylight.controller.netconf.impl;
10
11 import com.google.common.base.Optional;
12 import io.netty.channel.Channel;
13 import io.netty.util.Timer;
14 import io.netty.util.concurrent.Promise;
15 import org.opendaylight.controller.netconf.api.NetconfServerSessionPreferences;
16 import org.opendaylight.controller.netconf.util.AbstractNetconfSessionNegotiator;
17 import org.opendaylight.controller.netconf.util.messages.NetconfHelloMessage;
18 import org.opendaylight.controller.netconf.util.messages.NetconfHelloMessageAdditionalHeader;
19 import org.slf4j.Logger;
20 import org.slf4j.LoggerFactory;
21
22 import java.net.InetSocketAddress;
23
24 public class NetconfServerSessionNegotiator extends
25         AbstractNetconfSessionNegotiator<NetconfServerSessionPreferences, NetconfServerSession, NetconfServerSessionListener> {
26
27     static final Logger logger = LoggerFactory.getLogger(NetconfServerSessionNegotiator.class);
28
29     protected NetconfServerSessionNegotiator(NetconfServerSessionPreferences sessionPreferences,
30             Promise<NetconfServerSession> promise, Channel channel, Timer timer, NetconfServerSessionListener sessionListener,
31             long connectionTimeoutMillis) {
32         super(sessionPreferences, promise, channel, timer, sessionListener, connectionTimeoutMillis);
33     }
34
35     @Override
36     protected NetconfServerSession getSession(NetconfServerSessionListener sessionListener, Channel channel, NetconfHelloMessage message) {
37         Optional<NetconfHelloMessageAdditionalHeader> additionalHeader = message.getAdditionalHeader();
38
39         NetconfHelloMessageAdditionalHeader parsedHeader;
40         if (additionalHeader.isPresent()) {
41             parsedHeader = additionalHeader.get();
42         } else {
43             InetSocketAddress inetSocketAddress = (InetSocketAddress) channel.localAddress();
44             parsedHeader = new NetconfHelloMessageAdditionalHeader("unknown", inetSocketAddress.getHostString(), Integer.toString(inetSocketAddress.getPort()),
45                     "tcp", "client");
46         }
47
48         logger.debug("Additional header from hello parsed as {} from {}", parsedHeader, additionalHeader);
49
50         return new NetconfServerSession(sessionListener, channel, getSessionPreferences().getSessionId(), parsedHeader);
51     }
52
53 }