X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=influxlogger%2Fsrc%2Fmain%2Fjava%2Forg%2Foran%2Fpmlog%2Fconfiguration%2FApplicationConfig.java;fp=influxlogger%2Fsrc%2Fmain%2Fjava%2Forg%2Foran%2Fpmlog%2Fconfiguration%2FApplicationConfig.java;h=84c50836225c65daa1380ba0ab9d778172d9abe2;hb=9e3ded97088f197b335d060e1c9ddf7d6c0ecd89;hp=0000000000000000000000000000000000000000;hpb=7c434fcb459c84543cdb0ad14aa59391c60d16d4;p=nonrtric%2Fplt%2Franpm.git diff --git a/influxlogger/src/main/java/org/oran/pmlog/configuration/ApplicationConfig.java b/influxlogger/src/main/java/org/oran/pmlog/configuration/ApplicationConfig.java new file mode 100644 index 0000000..84c5083 --- /dev/null +++ b/influxlogger/src/main/java/org/oran/pmlog/configuration/ApplicationConfig.java @@ -0,0 +1,192 @@ +/*- + * ========================LICENSE_START================================= + * O-RAN-SC + * %% + * Copyright (C) 2023 Nordix Foundation + * %% + * 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 + * + * http://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. + * ========================LICENSE_END=================================== + */ + +package org.oran.pmlog.configuration; + +import java.lang.invoke.MethodHandles; +import java.nio.charset.Charset; +import java.nio.file.Files; + +import lombok.Getter; +import lombok.ToString; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.boot.context.properties.EnableConfigurationProperties; + +@EnableConfigurationProperties +@ToString +public class ApplicationConfig { + + private static final Logger logger = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass()); + private static com.google.gson.Gson gson = new com.google.gson.GsonBuilder().disableHtmlEscaping().create(); + private static final String JOB_DEFINITION_PATH = "./config/jobDefinition.json"; + + @Value("${server.ssl.key-store-type}") + private String sslKeyStoreType = ""; + + @Value("${server.ssl.key-store-password}") + private String sslKeyStorePassword = ""; + + @Value("${server.ssl.key-store}") + private String sslKeyStore = ""; + + @Value("${server.ssl.key-password}") + private String sslKeyPassword = ""; + + @Value("${app.webclient.trust-store-used}") + private boolean sslTrustStoreUsed = false; + + @Value("${app.webclient.trust-store-password}") + private String sslTrustStorePassword = ""; + + @Value("${app.webclient.trust-store}") + private String sslTrustStore = ""; + + @Value("${app.webclient.http.proxy-host:}") + private String httpProxyHost = ""; + + @Value("${app.webclient.http.proxy-port:0}") + private int httpProxyPort = 0; + + @Getter + @Value("${server.port}") + private int localServerHttpsPort; + + @Getter + @Value("${app.kafka.max-poll-records:300}") + private int kafkaMaxPollRecords; + + @Getter + @Value("${app.kafka.group-id}") + private String kafkaGroupId; + + @Getter + @Value("${app.kafka.client-id}") + private String kafkaClientId; + + @Value("${app.kafka.bootstrap-servers}") + private String kafkaBootstrapServers; + + @Value("${app.kafka.input-topic}") + private String kafkaInputTopic; + + @Getter + @Value("${app.influx.url}") + private String influxUrl; + + @Getter + @Value("${app.influx.access-token}") + private String influxAccessToken; + + @Getter + @Value("${app.ics-base-url}") + private String icsBaseUrl; + + @Getter + @Value("${app.consumer-job-id:shouldHaveBeenDefinedInYaml}") + private String consumerJobId; + + @Getter + @Value("${app.influx.user}") + private String influxUser; + + @Getter + @Value("${app.influx.password}") + private String influxPassword; + + @Getter + @Value("${app.influx.database}") + private String influxDatabase; + + @Getter + @Value("${app.influx.bucket}") + private String influxBucket; + + @Getter + @Value("${app.influx.org}") + private String influxOrg; + + private WebClientConfig webClientConfig = null; + + public WebClientConfig getWebClientConfig() { + if (this.webClientConfig == null) { + WebClientConfig.HttpProxyConfig httpProxyConfig = WebClientConfig.HttpProxyConfig.builder() // + .httpProxyHost(this.httpProxyHost) // + .httpProxyPort(this.httpProxyPort) // + .build(); + + this.webClientConfig = WebClientConfig.builder() // + .keyStoreType(this.sslKeyStoreType) // + .keyStorePassword(this.sslKeyStorePassword) // + .keyStore(this.sslKeyStore) // + .keyPassword(this.sslKeyPassword) // + .isTrustStoreUsed(this.sslTrustStoreUsed) // + .trustStore(this.sslTrustStore) // + .trustStorePassword(this.sslTrustStorePassword) // + .httpProxyConfig(httpProxyConfig) // + .build(); + } + return this.webClientConfig; + } + + public String getConsumerJobInfo() { + + try { + return Files.readString(java.nio.file.Path.of(JOB_DEFINITION_PATH), Charset.defaultCharset()); + } catch (Exception e) { + logger.error("Could not load configuration file: {}, reason: {}", JOB_DEFINITION_PATH, e.getMessage()); + return "{}"; + } + } + + private ConsumerJobInfo.KafkaDeliveryInfo getKafkaDeliveryInfoFromAplicationYaml() { + return ConsumerJobInfo.KafkaDeliveryInfo.builder() // + .bootStrapServers(this.kafkaBootstrapServers) // + .topic(kafkaInputTopic) // + .build(); + } + + private ConsumerJobInfo.KafkaDeliveryInfo getKafkaDeliveryInfo() { + try { + ConsumerJobInfo infoFromFile = gson.fromJson(getConsumerJobInfo(), ConsumerJobInfo.class); + if (infoFromFile != null && infoFromFile.jobDefinition != null + && infoFromFile.jobDefinition.getDeliveryInfo() != null) { + return infoFromFile.jobDefinition.getDeliveryInfo(); + } + + } catch (Exception e) { + logger.warn("Could not parse file: {}, reason: {}, falling back to parameters in Application.yaml", + JOB_DEFINITION_PATH, e.getMessage()); + } + return getKafkaDeliveryInfoFromAplicationYaml(); + + } + + public String getKafkaInputTopic() { + return getKafkaDeliveryInfo().getTopic(); + } + + public String getKafkaBootStrapServers() { + return getKafkaDeliveryInfo().getBootStrapServers(); + } + +}