/*
* Copyright (c) 2011-2019 Contributors to the Eclipse Foundation
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
* which is available at https://www.apache.org/licenses/LICENSE-2.0.
*
* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
*/
package io.vertx.core.net;
import io.vertx.codegen.annotations.DataObject;
import io.vertx.core.json.JsonObject;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLEngine;
Configures a TCPSSLOptions
to use the JDK ssl engine implementation. Author: Julien Viet
/**
* Configures a {@link TCPSSLOptions} to use the JDK ssl engine implementation.
*
* @author <a href="mailto:julien@julienviet.com">Julien Viet</a>
*/
@DataObject
public class JdkSSLEngineOptions extends SSLEngineOptions {
private static Boolean jdkAlpnAvailable;
Returns: if alpn support is available via the JDK SSL engine
/**
* @return if alpn support is available via the JDK SSL engine
*/
public static synchronized boolean isAlpnAvailable() {
if (jdkAlpnAvailable == null) {
boolean available = false;
try {
// Public method on SSLEngine
SSLEngine.class.getDeclaredMethod("getApplicationProtocol");
available = true;
} catch (Exception ignore1) {
// JDK provides ALPN
try {
// Always use bootstrap class loader.
JdkSSLEngineOptions.class.getClassLoader().loadClass("sun.security.ssl.ALPNExtension");
available = true;
} catch (Exception ignore2) {
// alpn-boot was not loaded.
}
} finally {
jdkAlpnAvailable = available;
}
}
return jdkAlpnAvailable;
}
public JdkSSLEngineOptions() {
}
public JdkSSLEngineOptions(JsonObject json) {
}
public JdkSSLEngineOptions(JdkSSLEngineOptions that) {
}
public JsonObject toJson() {
return new JsonObject();
}
@Override
public JdkSSLEngineOptions copy() {
return new JdkSSLEngineOptions();
}
}