Added support for using oauth token for Kafka
[nonrtric/plt/ranpm.git] / pmproducer / src / main / java / org / oran / pmproducer / Application.java
1 /*-
2  * ========================LICENSE_START=================================
3  * O-RAN-SC
4  * %%
5  * Copyright (C) 2023 Nordix Foundation
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.oran.pmproducer;
22
23
24 import org.slf4j.Logger;
25 import org.slf4j.LoggerFactory;
26 import org.springframework.boot.ApplicationArguments;
27 import org.springframework.boot.SpringApplication;
28 import org.springframework.boot.autoconfigure.SpringBootApplication;
29 import org.springframework.boot.context.properties.EnableConfigurationProperties;
30 import org.springframework.context.ConfigurableApplicationContext;
31 import org.springframework.scheduling.annotation.EnableScheduling;
32
33 @SpringBootApplication
34 @EnableConfigurationProperties
35 @EnableScheduling
36 public class Application {
37
38     private static final Logger logger = LoggerFactory.getLogger(Application.class);
39
40     private static ConfigurableApplicationContext applicationContext;
41
42     public static void main(String[] args) {
43         applicationContext = SpringApplication.run(Application.class);
44         Runtime.getRuntime().addShutdownHook(new Thread() {
45             @Override
46             public void run() {
47                 logger.warn("Shutting down, received signal SIGTERM");
48                 SpringApplication.exit(applicationContext);
49                 applicationContext = null;
50             }
51         });
52     }
53
54     private static void restartApplication() {
55         if (applicationContext == null) {
56             logger.info("Cannot restart in unittest");
57             return;
58         }
59         ApplicationArguments args = applicationContext.getBean(ApplicationArguments.class);
60
61         Thread thread = new Thread(() -> {
62             applicationContext.close();
63             applicationContext = SpringApplication.run(Application.class, args.getSourceArgs());
64         });
65
66         thread.setDaemon(false);
67         thread.start();
68     }
69
70 }