All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.datastax.driver.core.RemoteEndpointAwareNettySSLOptions Maven / Gradle / Ivy

/*
 * Copyright DataStax, Inc.
 *
 * This software can be used solely with DataStax Enterprise. Please consult the license at
 * http://www.datastax.com/terms/datastax-dse-driver-license-terms
 */
package com.datastax.driver.core;

import io.netty.channel.socket.SocketChannel;
import io.netty.handler.ssl.SslContext;
import io.netty.handler.ssl.SslHandler;
import java.net.InetSocketAddress;

/**
 * {@link RemoteEndpointAwareSSLOptions} implementation based on Netty's SSL context.
 *
 * 

Netty has the ability to use OpenSSL if available, instead of the JDK's built-in engine. This * yields better performance. * * @see JAVA-1364 * @since 3.2.0 */ @SuppressWarnings("deprecation") public class RemoteEndpointAwareNettySSLOptions extends NettySSLOptions implements ExtendedRemoteEndpointAwareSslOptions { /** * Create a new instance from a given context. * * @param context the Netty context. {@code SslContextBuilder.forClient()} provides a fluent API * to build it. */ public RemoteEndpointAwareNettySSLOptions(SslContext context) { super(context); } @Override public SslHandler newSSLHandler(SocketChannel channel) { throw new AssertionError( "This class implements RemoteEndpointAwareSSLOptions, this method should not be called"); } @Override public SslHandler newSSLHandler(SocketChannel channel, EndPoint remoteEndpoint) { InetSocketAddress address = remoteEndpoint.resolve(); return context.newHandler(channel.alloc(), address.getHostName(), address.getPort()); } @Override public SslHandler newSSLHandler(SocketChannel channel, InetSocketAddress remoteEndpoint) { throw new AssertionError( "The driver should never call this method on an object that implements " + this.getClass().getSimpleName()); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy