2 * ========================LICENSE_START=================================
5 * Copyright (C) 2023 Nordix Foundation
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
11 * http://www.apache.org/licenses/LICENSE-2.0
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===================================
21 package org.oran.pmlog;
23 import org.apache.catalina.connector.Connector;
24 import org.oran.pmlog.configuration.ApplicationConfig;
25 import org.springframework.beans.factory.annotation.Autowired;
26 import org.springframework.beans.factory.annotation.Value;
27 import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory;
28 import org.springframework.boot.web.servlet.server.ServletWebServerFactory;
29 import org.springframework.context.annotation.Bean;
30 import org.springframework.context.annotation.Configuration;
33 public class BeanFactory {
35 @Value("${server.http-port}")
36 private int httpPort = 0;
39 public ApplicationConfig getApplicationConfig() {
40 return new ApplicationConfig();
44 public ServletWebServerFactory servletContainer() {
45 TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory();
47 tomcat.addAdditionalTomcatConnectors(getHttpConnector(httpPort));
52 private static Connector getHttpConnector(int httpPort) {
53 Connector connector = new Connector(TomcatServletWebServerFactory.DEFAULT_PROTOCOL);
54 connector.setScheme("http");
55 connector.setPort(httpPort);
56 connector.setSecure(false);
61 public KafkaTopicListener getKafkaTopicListener(@Autowired ApplicationConfig appConfig) {
62 return new KafkaTopicListener(appConfig);
66 public InfluxStore getInfluxStore(@Autowired ApplicationConfig appConfig, @Autowired KafkaTopicListener listener) {
68 InfluxStore distr = new InfluxStore(appConfig);
69 distr.start(listener.getFlux());