summaryrefslogtreecommitdiffstats
path: root/ms/gra/gra-app/src/main/java/org/onap/sdnc/apps/ms/gra/FilterConfiguration.java
blob: fb09cf8a1513109284c5f747a6ccfc6f432ebe46 (plain)
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;
	}



}