1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
|
package org.onap.sdnc.apps.ms.gra;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.util.Properties;
import org.onap.aaf.cadi.filter.CadiFilter;
import org.onap.ccsdk.apps.filters.AuditLogFilter;
import org.onap.ccsdk.apps.filters.PayloadLoggingFilter;
import org.onap.ccsdk.sli.core.utils.common.EnvProperties;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.annotation.Order;
@Configuration
public class FilterConfiguration {
private static final Logger log = LoggerFactory.getLogger(FilterConfiguration.class);
// Explicitly add CadiFilter to filter chain. Note: autowiring already
// adds the filters defined in org.onap.ccsdk.apps.filters package, so do
// not need to explicitly insert them here.
@Value("${cadi.properties.path:none}")
private String cadiPropFile;
@Bean
@Order(1)
public FilterRegistrationBean<PayloadLoggingFilter> loggingFilter() {
FilterRegistrationBean<PayloadLoggingFilter> registrationBean = new FilterRegistrationBean<>();
registrationBean.setFilter(new PayloadLoggingFilter());
registrationBean.addUrlPatterns("/config/*", "/operational/*", "/operations/*");
return registrationBean;
}
@Bean
@Order(2)
public FilterRegistrationBean<AuditLogFilter> auditFilter() {
FilterRegistrationBean<AuditLogFilter> registrationBean = new FilterRegistrationBean<>();
registrationBean.setFilter(new AuditLogFilter());
registrationBean.addUrlPatterns("/config/*", "/operational/*", "/operations/*");
return registrationBean;
}
@Bean
@Order(3)
public FilterRegistrationBean<CadiFilter> cadiFilter() {
CadiFilter filter = new CadiFilter();
FilterRegistrationBean<CadiFilter> registrationBean = new FilterRegistrationBean<>();
registrationBean.setFilter(filter);
if ("none".equals(cadiPropFile)){
log.info(" AAF CADI disabled");
registrationBean.setEnabled(false);
registrationBean.addUrlPatterns("/xxxx/*");
} else {
// Note: assume that cadi.properties.path specifies full path to properties file
File cadiFile = new File(cadiPropFile);
if (!cadiFile.exists()) {
log.info("cadi properties file {} not found, AAF CADI disabled", cadiPropFile);
registrationBean.setEnabled(false);
registrationBean.addUrlPatterns("/xxxx/*");
} else {
Properties cadiProperties = new EnvProperties();
try {
cadiProperties.load(new FileReader(cadiFile));
cadiProperties.forEach((k, v) -> {
registrationBean.addInitParameter((String) k, cadiProperties.getProperty((String) k));
});
registrationBean.addUrlPatterns("/*");
log.info("Installed and configured CADI filter");
} catch (IOException e) {
log.info("Caught exception loading cadi properties file {}, AAF CADI disabled", cadiPropFile, e);
registrationBean.setEnabled(false);
registrationBean.addUrlPatterns("/xxxx/*");
}
}
}
return registrationBean;
}
}
|