Update Logging
[so.git] / mso-api-handlers / mso-api-handler-infra / src / main / java / org / onap / so / apihandlerinfra / ApiHandlerApplication.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP - SO
4  * ================================================================================
5  * Copyright (C) 2017 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.onap.so.apihandlerinfra;
22
23 import java.util.concurrent.Executor;
24
25 import org.springframework.beans.factory.annotation.Autowired;
26 import org.springframework.beans.factory.annotation.Value;
27 import org.springframework.boot.SpringApplication;
28 import org.springframework.boot.autoconfigure.SpringBootApplication;
29 import org.springframework.context.annotation.Bean;
30 import org.springframework.scheduling.annotation.EnableAsync;
31 import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
32 import org.onap.so.logging.jaxrs.filter.MDCTaskDecorator;
33
34 @SpringBootApplication(scanBasePackages = { "org.onap"})
35 @EnableAsync
36 public class ApiHandlerApplication {
37         
38         @Value("${mso.async.core-pool-size}")
39         private int corePoolSize;
40
41         @Value("${mso.async.max-pool-size}")
42         private int maxPoolSize;
43
44         @Value("${mso.async.queue-capacity}")
45         private int queueCapacity;
46
47         private static final String LOGS_DIR = "logs_dir";
48
49         private static void setLogsDir() {
50                 if (System.getProperty(LOGS_DIR) == null) {
51                         System.getProperties().setProperty(LOGS_DIR, "./logs/apih/");
52                 }
53         }
54
55         public static void main(String[] args) {
56                 SpringApplication.run(ApiHandlerApplication.class, args);
57                 System.getProperties().setProperty("mso.db", "MARIADB");
58                 System.getProperties().setProperty("server.name", "Springboot");
59                 setLogsDir();
60         }
61
62         @Bean
63         public Executor asyncExecutor() {
64                 ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
65                 executor.setCorePoolSize(corePoolSize);
66                 executor.setMaxPoolSize(maxPoolSize);
67                 executor.setQueueCapacity(queueCapacity);
68                 executor.setThreadNamePrefix("mso-apihandler-infra-");
69                 executor.setTaskDecorator(new MDCTaskDecorator());
70                 executor.initialize();
71                 return executor;
72         }
73 }