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

reactor.netty.http.Http3SslContextSpec Maven / Gradle / Ivy

/*
 * Copyright (c) 2024 VMware, Inc. or its affiliates, All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package reactor.netty.http;

import io.netty.handler.ssl.SslContext;
import io.netty.incubator.codec.quic.QuicSslContext;
import io.netty.incubator.codec.quic.QuicSslContextBuilder;
import io.netty.util.DomainWildcardMappingBuilder;
import reactor.netty.tcp.SslProvider;
import reactor.util.annotation.Incubating;
import reactor.util.annotation.Nullable;

import javax.net.ssl.KeyManager;
import javax.net.ssl.KeyManagerFactory;
import javax.net.ssl.SSLException;
import java.io.File;
import java.security.PrivateKey;
import java.security.cert.X509Certificate;
import java.util.Map;
import java.util.Objects;
import java.util.function.Consumer;

import static io.netty.incubator.codec.http3.Http3.supportedApplicationProtocols;
import static io.netty.incubator.codec.quic.QuicSslContextBuilder.buildForServerWithSni;

/**
 * SslContext builder that provides default configuration specific to HTTP/3 as follows:
 * 
    *
  • Supported application protocols
  • *
*

The default configuration is applied prior any other custom configuration.

* * @author Violeta Georgieva * @since 1.2.0 * @see io.netty.incubator.codec.http3.Http3#supportedApplicationProtocols() */ @Incubating public final class Http3SslContextSpec implements SslProvider.GenericSslContextSpecWithSniSupport { /** * Creates a builder for new client-side {@link SslContext}. * * @see QuicSslContextBuilder#forClient() */ public static Http3SslContextSpec forClient() { return new Http3SslContextSpec(QuicSslContextBuilder.forClient()); } /** * Creates a builder for new server-side {@link SslContext}. * * @see QuicSslContextBuilder#forServer(File, String, File) */ public static Http3SslContextSpec forServer(File keyFile, @Nullable String keyPassword, File certChainFile) { return new Http3SslContextSpec(QuicSslContextBuilder.forServer(keyFile, keyPassword, certChainFile)); } /** * Creates a builder for new server-side {@link SslContext}. * * @see QuicSslContextBuilder#forServer(KeyManager, String) */ public static Http3SslContextSpec forServer(KeyManager keyManager, @Nullable String keyPassword) { return new Http3SslContextSpec(QuicSslContextBuilder.forServer(keyManager, keyPassword)); } /** * Creates a builder for new server-side {@link SslContext}. * * @see QuicSslContextBuilder#forServer(KeyManagerFactory, String) */ public static Http3SslContextSpec forServer(KeyManagerFactory keyManagerFactory, @Nullable String password) { return new Http3SslContextSpec(QuicSslContextBuilder.forServer(keyManagerFactory, password)); } /** * Creates a builder for new server-side {@link SslContext}. * * @see QuicSslContextBuilder#forServer(PrivateKey, String, X509Certificate...) */ public static Http3SslContextSpec forServer(PrivateKey key, @Nullable String keyPassword, X509Certificate... certChain) { return new Http3SslContextSpec(QuicSslContextBuilder.forServer(key, keyPassword, certChain)); } @Override public Http3SslContextSpec configure(Consumer sslCtxBuilder) { Objects.requireNonNull(sslCtxBuilder, "sslCtxBuilder"); sslCtxBuilder.accept(sslContextBuilder); return this; } @Override public SslContext sslContext() throws SSLException { return sslContextBuilder.build(); } @Override public SslContext sslContext(Map sniMappings) throws SSLException { DomainWildcardMappingBuilder mappingsSslProviderBuilder = new DomainWildcardMappingBuilder<>((QuicSslContext) sslContext()); sniMappings.forEach((s, sslProvider) -> mappingsSslProviderBuilder.add(s, (QuicSslContext) sslProvider.getSslContext())); return buildForServerWithSni(mappingsSslProviderBuilder.build()); } final QuicSslContextBuilder sslContextBuilder; Http3SslContextSpec(QuicSslContextBuilder sslContextBuilder) { this.sslContextBuilder = sslContextBuilder; configure(DEFAULT_CONFIGURATOR); } static final Consumer DEFAULT_CONFIGURATOR = sslCtxBuilder -> sslCtxBuilder.applicationProtocols(supportedApplicationProtocols()); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy