1453adb9904b786bbaa3f4a1e9e77dde149b6988
[dcaegen2/services/sdk.git] / rest-services / http-client / src / main / java / org / onap / dcaegen2 / services / sdk / rest / services / adapters / http / RxHttpClientFactory.java
1 /*
2  * ============LICENSE_START====================================
3  * DCAEGEN2-SERVICES-SDK
4  * =========================================================
5  * Copyright (C) 2019 Nokia. All rights reserved.
6  * =========================================================
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  *       http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ============LICENSE_END=====================================
19  */
20
21 package org.onap.dcaegen2.services.sdk.rest.services.adapters.http;
22
23 import io.netty.handler.ssl.SslContext;
24 import org.jetbrains.annotations.NotNull;
25 import org.onap.dcaegen2.services.sdk.security.ssl.SecurityKeys;
26 import org.onap.dcaegen2.services.sdk.security.ssl.SslFactory;
27 import reactor.netty.http.client.HttpClient;
28
29 /**
30  * @author <a href="mailto:piotr.jaszczyk@nokia.com">Piotr Jaszczyk</a>
31  * @since May 2019
32  */
33 public final class RxHttpClientFactory {
34
35     private static final SslFactory SSL_FACTORY = new SslFactory();
36
37     private RxHttpClientFactory() {
38     }
39
40     public static RxHttpClient create() {
41         return new RxHttpClient(HttpClient.create());
42     }
43
44
45     public static RxHttpClient create(SecurityKeys securityKeys) {
46         final SslContext context = SSL_FACTORY.createSecureClientContext(securityKeys);
47         return create(context);
48     }
49
50     public static RxHttpClient createInsecure() {
51         final SslContext context = SSL_FACTORY.createInsecureClientContext();
52         return create(context);
53     }
54
55     private static RxHttpClient create(@NotNull SslContext sslContext) {
56         return new RxHttpClient(HttpClient.create().secure(sslContextSpec -> sslContextSpec.sslContext(sslContext)));
57     }
58 }