Fix VES problem with subsequent fetching from CBS
[dcaegen2/collectors/ves.git] / src / main / java / org / onap / dcae / configuration / cbs / CbsClientConfigurationResolver.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * org.onap.dcaegen2.collectors.ves
4  * ================================================================================
5  * Copyright (C) 2020 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 package org.onap.dcae.configuration.cbs;
21
22 import org.onap.dcaegen2.services.sdk.rest.services.cbs.client.model.CbsClientConfiguration;
23 import org.onap.dcaegen2.services.sdk.rest.services.cbs.client.model.ImmutableCbsClientConfiguration;
24 import org.slf4j.Logger;
25 import org.slf4j.LoggerFactory;
26
27 class CbsClientConfigurationResolver {
28
29     private static final Logger LOGGER = LoggerFactory.getLogger(CbsClientConfigurationResolver.class);
30
31     private final String defaultProtocol = "http";
32     private final String defaultHostname = "config-binding-service";
33     private final int defaultPort = 10000;
34     private final String defaultAppName = "dcae-ves-collector";
35
36     CbsClientConfiguration resolveCbsClientConfiguration() {
37         try {
38             return CbsClientConfiguration.fromEnvironment();
39         } catch (Exception e) {
40             LOGGER.warn("Failed resolving CBS client configuration from system environments: " + e);
41         }
42         LOGGER.info("Falling back to use default CBS client configuration properties");
43         return getFallbackConfiguration();
44     }
45
46     private ImmutableCbsClientConfiguration getFallbackConfiguration() {
47         LOGGER.info("Falling back to use default CBS client configuration");
48         return createCbsClientConfiguration(defaultProtocol, defaultHostname, defaultAppName, defaultPort);
49     }
50
51     private ImmutableCbsClientConfiguration createCbsClientConfiguration(String protocol, String hostname,
52         String appName, Integer port) {
53         return ImmutableCbsClientConfiguration.builder()
54             .protocol(protocol)
55             .hostname(hostname)
56             .port(port)
57             .appName(appName)
58             .build();
59     }
60 }