Catalog alignment
[sdc.git] / common-app-api / src / main / java / org / openecomp / sdc / common / http / client / api / HttpClientFactory.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * SDC
4  * ================================================================================
5  * Copyright (C) 2019 AT&T Intellectual Property. 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.openecomp.sdc.common.http.client.api;
22
23 import org.apache.http.client.HttpRequestRetryHandler;
24 import org.apache.http.client.UserTokenHandler;
25 import org.apache.http.client.config.RequestConfig;
26 import org.apache.http.conn.HttpClientConnectionManager;
27 import org.apache.http.impl.client.CloseableHttpClient;
28 import org.apache.http.impl.client.HttpClientBuilder;
29 import org.apache.http.impl.client.HttpClients;
30 import org.openecomp.sdc.common.api.Constants;
31 import org.openecomp.sdc.common.http.config.ClientCertificate;
32 import org.openecomp.sdc.common.log.interceptors.ApacheClientLogRequestInterceptor;
33 import org.openecomp.sdc.common.log.interceptors.ApacheClientLogResponseInterceptor;
34 import org.openecomp.sdc.common.log.wrappers.Logger;
35
36 public class HttpClientFactory {
37
38     private static final Logger logger = Logger.getLogger(HttpClientFactory.class.getName());
39     private static final UserTokenHandler userTokenHandler = context -> null;
40     private final HttpConnectionMngFactory connectionMngFactory;
41     
42     HttpClientFactory(HttpConnectionMngFactory connectionMngFactory) {
43         this.connectionMngFactory = connectionMngFactory;
44     }
45
46     HttpClient createClient(String protocol, HttpClientConfigImmutable config) {
47         logger.debug("Create {} client based on {}", protocol, config);
48
49         ClientCertificate clientCertificate = Constants.HTTPS.equals(protocol) ? config.getClientCertificate() : null; 
50         HttpClientConnectionManager connectionManager = connectionMngFactory.getOrCreate(clientCertificate);
51         RequestConfig requestConfig = createClientTimeoutConfiguration(config);
52         CloseableHttpClient client = HttpClients.custom()
53                     .setDefaultRequestConfig(requestConfig)
54                     .setConnectionManager(connectionManager)
55                     .setUserTokenHandler(userTokenHandler)
56                     .setRetryHandler(resolveRetryHandler(config))
57                     .build();
58
59         return new HttpClient(client, config);
60     }
61
62     private HttpRequestRetryHandler resolveRetryHandler(HttpClientConfigImmutable config) {
63         return config.getNumOfRetries() > 0 ? config.getRetryHandler() : null;
64     }
65         
66     private RequestConfig createClientTimeoutConfiguration(HttpClientConfigImmutable config) {
67         return RequestConfig.custom()
68                 .setConnectTimeout(config.getConnectTimeoutMs())
69                 .setSocketTimeout(config.getReadTimeoutMs())
70                 .setConnectionRequestTimeout(config.getConnectPoolTimeoutMs())
71                 .build();
72     }
73 }