c35294db4d3bcdc0bfb9c416a9074763153b7919
[so.git] /
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP - SO
4  * ================================================================================
5  * Copyright (C) 2017 - 2018 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.adapters.requestsdb.application;
22
23
24 import org.onap.logging.filter.spring.LoggingInterceptor;
25 import org.onap.logging.filter.spring.StatusLoggingInterceptor;
26 import org.springframework.beans.factory.annotation.Autowired;
27 import org.springframework.beans.factory.annotation.Value;
28 import org.springframework.context.annotation.Bean;
29 import org.springframework.context.annotation.ComponentScan;
30 import org.springframework.context.annotation.Configuration;
31 import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
32 import org.springframework.web.servlet.handler.MappedInterceptor;
33
34 @Configuration
35 @ComponentScan(basePackages = {"org.onap.logging.filter"})
36 public class WebMvcConfig extends WebMvcConfigurerAdapter {
37
38     @Value("${logging.request-status.exclusions:}")
39     private String[] excludedPaths = new String[0];
40
41     @Autowired
42     private LoggingInterceptor loggingInterceptor;
43
44     @Autowired
45     private StatusLoggingInterceptor statusLoggingInterceptor;
46
47     @Bean
48     public MappedInterceptor mappedLoggingInterceptor() {
49         return new MappedInterceptor(new String[] {"/**"}, loggingInterceptor);
50     }
51
52     @Bean
53     public MappedInterceptor mappedStatusLoggingInterceptor() {
54         return excludedPaths != null && excludedPaths.length > 0
55                 ? new MappedInterceptor(new String[] {"/**"}, excludedPaths, statusLoggingInterceptor)
56                 : new MappedInterceptor(new String[] {"/**"}, statusLoggingInterceptor);
57     }
58 }