2 * Copyright (c) 2014 Cisco Systems, Inc. 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
8 package org.opendaylight.netconf.client.conf;
10 import static java.util.Objects.requireNonNull;
12 import com.google.common.base.MoreObjects;
13 import com.google.common.base.MoreObjects.ToStringHelper;
14 import java.net.InetSocketAddress;
15 import java.util.List;
16 import java.util.Optional;
17 import org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader;
18 import org.opendaylight.netconf.client.NetconfClientSessionListener;
19 import org.opendaylight.netconf.client.SslHandlerFactory;
20 import org.opendaylight.netconf.nettyutil.ReconnectStrategy;
21 import org.opendaylight.netconf.nettyutil.handler.ssh.authentication.AuthenticationHandler;
22 import org.opendaylight.netconf.nettyutil.handler.ssh.client.NetconfSshClient;
23 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Uri;
24 import org.slf4j.Logger;
25 import org.slf4j.LoggerFactory;
27 public class NetconfClientConfiguration {
29 private static final Logger LOG = LoggerFactory.getLogger(NetconfClientConfiguration.class);
31 private final NetconfClientProtocol clientProtocol;
32 private final InetSocketAddress address;
33 private final Long connectionTimeoutMillis;
35 private final NetconfHelloMessageAdditionalHeader additionalHeader;
36 private final NetconfClientSessionListener sessionListener;
38 private final ReconnectStrategy reconnectStrategy;
40 private final AuthenticationHandler authHandler;
41 private final SslHandlerFactory sslHandlerFactory;
42 private final NetconfSshClient sshClient;
44 private final List<Uri> odlHelloCapabilities;
46 NetconfClientConfiguration(final NetconfClientProtocol protocol, final InetSocketAddress address,
47 final Long connectionTimeoutMillis,
48 final NetconfHelloMessageAdditionalHeader additionalHeader,
49 final NetconfClientSessionListener sessionListener,
50 final ReconnectStrategy reconnectStrategy, final AuthenticationHandler authHandler,
51 final SslHandlerFactory sslHandlerFactory, final NetconfSshClient sshClient,
52 final List<Uri> odlHelloCapabilities) {
53 this.address = address;
54 this.connectionTimeoutMillis = connectionTimeoutMillis;
55 this.additionalHeader = additionalHeader;
56 this.sessionListener = sessionListener;
57 this.clientProtocol = protocol;
58 this.reconnectStrategy = reconnectStrategy;
59 this.authHandler = authHandler;
60 this.sslHandlerFactory = sslHandlerFactory;
61 this.sshClient = sshClient;
62 this.odlHelloCapabilities = odlHelloCapabilities;
63 validateConfiguration();
66 public final InetSocketAddress getAddress() {
70 public final Long getConnectionTimeoutMillis() {
71 return connectionTimeoutMillis;
74 public final Optional<NetconfHelloMessageAdditionalHeader> getAdditionalHeader() {
75 return Optional.ofNullable(additionalHeader);
78 public final NetconfClientSessionListener getSessionListener() {
79 return sessionListener;
82 public final ReconnectStrategy getReconnectStrategy() {
83 return reconnectStrategy;
86 public final AuthenticationHandler getAuthHandler() {
90 public NetconfClientProtocol getProtocol() {
91 return clientProtocol;
94 public SslHandlerFactory getSslHandlerFactory() {
95 return sslHandlerFactory;
98 public NetconfSshClient getSshClient() {
102 public List<Uri> getOdlHelloCapabilities() {
103 return odlHelloCapabilities;
106 private void validateConfiguration() {
107 switch (requireNonNull(clientProtocol)) {
109 validateTlsConfiguration();
110 validateTcpConfiguration();
113 validateSshConfiguration();
114 validateTcpConfiguration();
117 validateTcpConfiguration();
120 LOG.warn("Unexpected protocol: {} in netconf client configuration.", clientProtocol);
124 protected void validateTlsConfiguration() {
125 requireNonNull(sslHandlerFactory, "sslHandlerFactory");
128 protected void validateSshConfiguration() {
129 requireNonNull(authHandler, "authHandler");
132 protected void validateTcpConfiguration() {
133 requireNonNull(address, "address");
134 requireNonNull(clientProtocol, "clientProtocol");
135 requireNonNull(connectionTimeoutMillis, "connectionTimeoutMillis");
136 requireNonNull(sessionListener, "sessionListener");
137 requireNonNull(reconnectStrategy, "reconnectStrategy");
141 public final String toString() {
142 return buildToStringHelper().toString();
145 protected ToStringHelper buildToStringHelper() {
146 return MoreObjects.toStringHelper(this)
147 .add("address", address)
148 .add("connectionTimeoutMillis", connectionTimeoutMillis)
149 .add("additionalHeader", additionalHeader)
150 .add("sessionListener", sessionListener)
151 .add("reconnectStrategy", reconnectStrategy)
152 .add("clientProtocol", clientProtocol)
153 .add("authHandler", authHandler)
154 .add("sslHandlerFactory", sslHandlerFactory);
157 public enum NetconfClientProtocol {