This directory contains a demo springboot implementation of the SLI-API healthcheck method.
-To start this server, run:
+To start this server with out AAF authentication, run:
mvn -DserviceLogicDirectory=src/main/resources spring-boot:run
+To start this server with AAF authentication, run:
+mvn spring-boot:run -Dspring-boot.run.jvmArguments="-Dcadi_prop_files=/opt/onap/sdnc/data/properties/org.onap.sdnc.props -DserviceLogicDirectory=src/main/resources"
+
+
This will start a servlet on port 8080. To test to that servlet, post a blank
message to that port:
"mixed": "cAsE"
}
}
-```
\ No newline at end of file
+```
<properties>
<start-class>org.onap.ccsdk.sli.core.sliapi.springboot.App</start-class>
+ <shiro.version>1.5.0</shiro.version>
+ <aaf-shiro-bundle.version>2.1.13</aaf-shiro-bundle.version>
</properties>
<dependencies>
<artifactId>swagger-annotations</artifactId>
</dependency>
<dependency>
- <groupId>org.springframework.boot</groupId>
- <artifactId>spring-boot-starter-web</artifactId>
+ <groupId>org.apache.shiro</groupId>
+ <artifactId>shiro-spring-boot-web-starter</artifactId>
+ <version>${shiro.version}</version>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
+ <dependency>
+ <groupId>org.onap.aaf.cadi</groupId>
+ <artifactId>aaf-cadi-shiro</artifactId>
+ <version>${aaf-shiro-bundle.version}</version>
+ </dependency>
+
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
import org.springframework.boot.autoconfigure.SpringBootApplication;\r
import org.springframework.context.annotation.ComponentScan;\r
import springfox.documentation.swagger2.annotations.EnableSwagger2;\r
+import org.apache.shiro.realm.Realm;\r
+import org.apache.shiro.realm.text.PropertiesRealm;\r
+import org.apache.shiro.realm.text.TextConfigurationRealm;\r
+import org.apache.shiro.spring.web.config.DefaultShiroFilterChainDefinition;\r
+import org.apache.shiro.spring.web.config.ShiroFilterChainDefinition;\r
+import org.springframework.context.annotation.Bean;\r
+import org.onap.aaf.cadi.shiro.AAFRealm;\r
\r
@SpringBootApplication\r
@EnableSwagger2\r
public static void main(String[] args) throws Exception {\r
SpringApplication.run(App.class, args);\r
}\r
+\r
+ @Bean\r
+ public Realm realm() {\r
+\r
+ // If cadi prop files is not defined use local properties realm\r
+ // src/main/resources/shiro-users.properties\r
+ if ("none".equals(System.getProperty("cadi_prop_files", "none"))) {\r
+ PropertiesRealm realm = new PropertiesRealm();\r
+ return realm;\r
+ } else {\r
+ AAFRealm realm = new AAFRealm();\r
+ return realm;\r
+ }\r
+\r
+ }\r
+\r
+ @Bean\r
+ public ShiroFilterChainDefinition shiroFilterChainDefinition() {\r
+ DefaultShiroFilterChainDefinition chainDefinition = new DefaultShiroFilterChainDefinition();\r
+\r
+ // if cadi prop files is not set disable authentication\r
+ if ("none".equals(System.getProperty("cadi_prop_files", "none"))) {\r
+ chainDefinition.addPathDefinition("/**", "anon");\r
+ } else {\r
+ chainDefinition.addPathDefinition("/**", "authcBasic, rest[org.onap.sdnc:odl-api]");\r
+ }\r
+\r
+ return chainDefinition;\r
+ }\r
+\r
}\r
--- /dev/null
+user.admin = Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U,service
+role.service = odl-api:*
+
--- /dev/null
+package org.onap.ccsdk.sli.core.sliapi.springboot;
+
+import org.apache.shiro.realm.Realm;
+import org.apache.shiro.realm.text.PropertiesRealm;
+import org.apache.shiro.spring.web.config.ShiroFilterChainDefinition;
+import org.junit.Before;
+import org.junit.Test;
+import org.onap.aaf.cadi.shiro.AAFRealm;
+
+import java.util.Map;
+
+import static org.junit.Assert.*;
+
+public class AppTest {
+
+ App app;
+
+ @Before
+ public void setUp() throws Exception {
+ app = new App();
+ }
+
+ @Test
+ public void realm() {
+ Realm realm = app.realm();
+ assertTrue(realm instanceof PropertiesRealm);
+
+
+ }
+
+ @Test
+ public void shiroFilterChainDefinition() {
+ ShiroFilterChainDefinition chainDefinition = app.shiroFilterChainDefinition();
+ Map<String, String> chainMap = chainDefinition.getFilterChainMap();
+ assertEquals("anon", chainMap.get("/**"));
+
+
+ }
+}
\ No newline at end of file