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.checkerframework.checker.index.qual.NonNegative;
18 import org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader;
19 import org.opendaylight.netconf.client.NetconfClientSessionListener;
20 import org.opendaylight.netconf.client.SslHandlerFactory;
21 import org.opendaylight.netconf.nettyutil.ReconnectStrategy;
22 import org.opendaylight.netconf.nettyutil.handler.ssh.authentication.AuthenticationHandler;
23 import org.opendaylight.netconf.nettyutil.handler.ssh.client.NetconfSshClient;
24 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Uri;
25 import org.slf4j.Logger;
26 import org.slf4j.LoggerFactory;
28 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;
45 private final @NonNegative int maximumIncomingChunkSize;
47 NetconfClientConfiguration(final NetconfClientProtocol protocol, final InetSocketAddress address,
48 final Long connectionTimeoutMillis,
49 final NetconfHelloMessageAdditionalHeader additionalHeader,
50 final NetconfClientSessionListener sessionListener,
51 final ReconnectStrategy reconnectStrategy, final AuthenticationHandler authHandler,
52 final SslHandlerFactory sslHandlerFactory, final NetconfSshClient sshClient,
53 final List<Uri> odlHelloCapabilities, final @NonNegative int maximumIncomingChunkSize) {
54 this.address = address;
55 this.connectionTimeoutMillis = connectionTimeoutMillis;
56 this.additionalHeader = additionalHeader;
57 this.sessionListener = sessionListener;
58 clientProtocol = protocol;
59 this.reconnectStrategy = reconnectStrategy;
60 this.authHandler = authHandler;
61 this.sslHandlerFactory = sslHandlerFactory;
62 this.sshClient = sshClient;
63 this.odlHelloCapabilities = odlHelloCapabilities;
64 this.maximumIncomingChunkSize = maximumIncomingChunkSize;
65 validateConfiguration();
68 public final InetSocketAddress getAddress() {
72 public final Long getConnectionTimeoutMillis() {
73 return connectionTimeoutMillis;
76 public final Optional<NetconfHelloMessageAdditionalHeader> getAdditionalHeader() {
77 return Optional.ofNullable(additionalHeader);
80 public final NetconfClientSessionListener getSessionListener() {
81 return sessionListener;
84 @Deprecated(forRemoval = true)
85 public final ReconnectStrategy getReconnectStrategy() {
86 return reconnectStrategy;
89 public final AuthenticationHandler getAuthHandler() {
93 public NetconfClientProtocol getProtocol() {
94 return clientProtocol;
97 public SslHandlerFactory getSslHandlerFactory() {
98 return sslHandlerFactory;
101 public NetconfSshClient getSshClient() {
105 public List<Uri> getOdlHelloCapabilities() {
106 return odlHelloCapabilities;
109 public @NonNegative int getMaximumIncomingChunkSize() {
110 return maximumIncomingChunkSize;
113 private void validateConfiguration() {
114 switch (requireNonNull(clientProtocol)) {
116 validateTlsConfiguration();
117 validateTcpConfiguration();
120 validateSshConfiguration();
121 validateTcpConfiguration();
124 validateTcpConfiguration();
127 LOG.warn("Unexpected protocol: {} in netconf client configuration.", clientProtocol);
131 protected final void validateTlsConfiguration() {
132 requireNonNull(sslHandlerFactory, "sslHandlerFactory");
135 protected final void validateSshConfiguration() {
136 requireNonNull(authHandler, "authHandler");
139 protected final void validateTcpConfiguration() {
140 requireNonNull(address, "address");
141 requireNonNull(clientProtocol, "clientProtocol");
142 requireNonNull(connectionTimeoutMillis, "connectionTimeoutMillis");
143 requireNonNull(sessionListener, "sessionListener");
144 requireNonNull(reconnectStrategy, "reconnectStrategy");
148 public final String toString() {
149 return buildToStringHelper().toString();
152 protected ToStringHelper buildToStringHelper() {
153 return MoreObjects.toStringHelper(this)
154 .add("address", address)
155 .add("connectionTimeoutMillis", connectionTimeoutMillis)
156 .add("additionalHeader", additionalHeader)
157 .add("sessionListener", sessionListener)
158 .add("reconnectStrategy", reconnectStrategy)
159 .add("clientProtocol", clientProtocol)
160 .add("authHandler", authHandler)
161 .add("sslHandlerFactory", sslHandlerFactory);
164 public enum NetconfClientProtocol {