--- /dev/null
+/* Copyright (c) 2019 AT&T Intellectual Property. #\r
+# #\r
+# Licensed under the Apache License, Version 2.0 (the "License"); #\r
+# you may not use this file except in compliance with the License. #\r
+# You may obtain a copy of the License at #\r
+# #\r
+# http://www.apache.org/licenses/LICENSE-2.0 #\r
+# #\r
+# Unless required by applicable law or agreed to in writing, software #\r
+# distributed under the License is distributed on an "AS IS" BASIS, #\r
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. #\r
+# See the License for the specific language governing permissions and #\r
+# limitations under the License. #\r
+##############################################################################*/\r
+\r
+\r
+package org.oran.otf.api.config;\r
+\r
+import javax.servlet.Filter;\r
+import org.onap.aaf.cadi.Access;\r
+import org.onap.aaf.cadi.config.Config;\r
+import org.onap.aaf.cadi.filter.CadiFilter;\r
+import org.springframework.beans.factory.annotation.Value;\r
+import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;\r
+import org.springframework.boot.web.servlet.FilterRegistrationBean;\r
+import org.springframework.context.annotation.Bean;\r
+import org.springframework.context.annotation.Conditional;\r
+import org.springframework.context.annotation.PropertySource;\r
+import org.springframework.stereotype.Component;\r
+\r
+@PropertySource("classpath:application.properties")\r
+@Component\r
+@ConditionalOnProperty(prefix = "aaf",name ="enabled",havingValue = "true",matchIfMissing = true)\r
+public class CadiFilterConfiguration {\r
+\r
+ @Value("${aaf.call-timeout}")\r
+ private String AAF_CALL_TIMEOUT;\r
+\r
+ @Value("${aaf.conn-timeout}")\r
+ private String AAF_CONN_TIMEOUT;\r
+\r
+ @Value("${aaf.default-realm}")\r
+ private String AAF_DEFAULT_REALM;\r
+\r
+ @Value("${aaf.env}")\r
+ private String AAF_ENV;\r
+\r
+ @Value("${aaf.locate-url}")\r
+ private String AAF_LOCATE_URL;\r
+\r
+ @Value("${aaf.lur-class}")\r
+ private String AAF_LUR_CLASS;\r
+\r
+ @Value("${aaf.url}")\r
+ private String AAF_URL;\r
+\r
+ @Value("${basic-realm}")\r
+ private String BASIC_REALM;\r
+\r
+ @Value("${basic-warn}")\r
+ private String BASIC_WARN;\r
+\r
+ @Value("${cadi-latitude}")\r
+ private String CADI_LATITUDE;\r
+\r
+ @Value("${cadi-longitude}")\r
+ private String CADI_LONGITUDE;\r
+\r
+ @Value("${cadi-protocols}")\r
+ private String CADI_PROTOCOLS;\r
+\r
+ @Value("${cadi-noauthn}")\r
+ private String CADI_NOAUTHN;\r
+\r
+ @Bean(name = "cadiFilterRegistrationBean")\r
+ @ConditionalOnProperty(prefix = "aaf",name ="enabled",havingValue = "true",matchIfMissing = true)\r
+ public FilterRegistrationBean<Filter> cadiFilterRegistration() {\r
+ FilterRegistrationBean<Filter> registration = new FilterRegistrationBean<>();\r
+ // set cadi configuration properties\r
+ initCadiProperties(registration);\r
+\r
+ registration.addUrlPatterns("/otf/api/testInstance/*", "/otf/api/testExecution/*", "/otf/api/testStrategy/*", "/otf/api/virtualTestHead/*");\r
+ registration.setFilter(cadiFilter());\r
+ registration.setName("otfCadiFilter");\r
+ registration.setOrder(0);\r
+ return registration;\r
+ }\r
+\r
+ public Filter cadiFilter() {\r
+ return new CadiFilter();\r
+ }\r
+\r
+ private void initCadiProperties(FilterRegistrationBean<Filter> registration) {\r
+ registration.addInitParameter(Config.AAF_APPID, System.getenv("AAF_ID"));\r
+ registration.addInitParameter(Config.AAF_APPPASS, System.getenv("AAF_PASSWORD"));\r
+ registration.addInitParameter(Config.AAF_CALL_TIMEOUT, AAF_CALL_TIMEOUT);\r
+ registration.addInitParameter(Config.AAF_CONN_TIMEOUT, AAF_CONN_TIMEOUT);\r
+ registration.addInitParameter(Config.AAF_DEFAULT_REALM, AAF_DEFAULT_REALM);\r
+ registration.addInitParameter(Config.AAF_ENV, AAF_ENV);\r
+ registration.addInitParameter(Config.AAF_LOCATE_URL, AAF_LOCATE_URL);\r
+ registration.addInitParameter(Config.AAF_LUR_CLASS, AAF_LUR_CLASS);\r
+ registration.addInitParameter(\r
+ Config.AAF_URL, AAF_URL);\r
+\r
+ registration.addInitParameter(Config.BASIC_REALM, BASIC_REALM);\r
+ registration.addInitParameter(Config.BASIC_WARN, BASIC_WARN);\r
+\r
+ registration.addInitParameter(Config.CADI_KEYFILE, System.getenv("CADI_KEYFILE"));\r
+ registration.addInitParameter(Config.CADI_LATITUDE, CADI_LATITUDE);\r
+ //registration.addInitParameter(Config.CADI_LOGLEVEL, Access.Level.DEBUG.name());\r
+ registration.addInitParameter(Config.CADI_LONGITUDE, CADI_LONGITUDE);\r
+ registration.addInitParameter(Config.CADI_NOAUTHN, CADI_NOAUTHN);\r
+ registration.addInitParameter(Config.CADI_PROTOCOLS, CADI_PROTOCOLS);\r
+ registration.addInitParameter(Config.CADI_KEYSTORE, System.getenv("OTF_CERT_PATH"));\r
+ registration.addInitParameter(Config.CADI_KEYSTORE_PASSWORD, System.getenv("OTF_CERT_PASS"));\r
+\r
+ registration.addInitParameter(Config.HOSTNAME, System.getenv("CADI_HOSTNAME"));\r
+ }\r
+}\r