update sliapi-springboot
[ccsdk/sli/core.git] / sliapi / springboot / src / main / java / org / onap / ccsdk / sli / core / sliapi / springboot / core / SvcLogicFactory.java
diff --git a/sliapi/springboot/src/main/java/org/onap/ccsdk/sli/core/sliapi/springboot/core/SvcLogicFactory.java b/sliapi/springboot/src/main/java/org/onap/ccsdk/sli/core/sliapi/springboot/core/SvcLogicFactory.java
new file mode 100644 (file)
index 0000000..f39fc22
--- /dev/null
@@ -0,0 +1,71 @@
+package org.onap.ccsdk.sli.core.sliapi.springboot.core;\r
+\r
+import java.io.FileInputStream;\r
+import java.io.IOException;\r
+import java.util.Properties;\r
+import org.onap.ccsdk.sli.core.sli.ConfigurationException;\r
+import org.onap.ccsdk.sli.core.sli.SvcLogicLoader;\r
+import org.onap.ccsdk.sli.core.sli.SvcLogicStore;\r
+import org.onap.ccsdk.sli.core.sli.SvcLogicStoreFactory;\r
+import org.onap.ccsdk.sli.core.sli.provider.base.HashMapResolver;\r
+import org.onap.ccsdk.sli.core.sli.provider.base.SvcLogicPropertiesProvider;\r
+import org.onap.ccsdk.sli.core.sli.provider.base.SvcLogicResolver;\r
+import org.onap.ccsdk.sli.core.sli.provider.base.SvcLogicServiceBase;\r
+import org.onap.ccsdk.sli.core.sli.provider.base.SvcLogicServiceImplBase;\r
+import org.slf4j.Logger;\r
+import org.slf4j.LoggerFactory;\r
+import org.springframework.context.annotation.Bean;\r
+import org.springframework.context.annotation.Configuration;\r
+\r
+@Configuration\r
+public class SvcLogicFactory {\r
+  private static final Logger log = LoggerFactory.getLogger(SvcLogicFactory.class);\r
+\r
+  @Bean\r
+  public SvcLogicStore getStore() throws Exception {\r
+    SvcLogicPropertiesProvider propProvider = new SvcLogicPropertiesProvider() {\r
+\r
+      @Override\r
+      public Properties getProperties() {\r
+        Properties props = new Properties();\r
+        String propPath = "src/main/resources/svclogic.properties";\r
+        System.out.println(propPath);\r
+        try (FileInputStream fileInputStream = new FileInputStream(propPath)) {\r
+          props = new Properties();\r
+          props.load(fileInputStream);\r
+        } catch (final IOException e) {\r
+          log.error("Failed to load properties for file: {}", propPath,\r
+              new ConfigurationException("Failed to load properties for file: " + propPath, e));\r
+        }\r
+        return props;\r
+      }\r
+    };\r
+    SvcLogicStore store = SvcLogicStoreFactory.getSvcLogicStore(propProvider.getProperties());\r
+    return store;\r
+  }\r
+\r
+  @Bean\r
+  public SvcLogicLoader createLoader() throws Exception {\r
+    String serviceLogicDirectory = System.getProperty("serviceLogicDirectory");\r
+    if (serviceLogicDirectory == null) {\r
+      serviceLogicDirectory = "src/main/resources";\r
+    }\r
+\r
+    System.out.println("serviceLogicDirectory is " + serviceLogicDirectory);\r
+    SvcLogicLoader loader = new SvcLogicLoader(serviceLogicDirectory, getStore());\r
+\r
+    try {\r
+      loader.loadAndActivate();\r
+    } catch (IOException e) {\r
+      log.error("Cannot load directed graphs", e);\r
+    }\r
+    return loader;\r
+  }\r
+\r
+  @Bean\r
+  public SvcLogicServiceBase createService() throws Exception {\r
+    SvcLogicResolver resolver = new HashMapResolver();\r
+    return new SvcLogicServiceImplBase(getStore(), resolver);\r
+  }\r
+\r
+}\r