aboutsummaryrefslogtreecommitdiffstats
path: root/sliapi/springboot/src/main/java/org/onap/ccsdk/sli/core/sliapi/springboot/core/SvcLogicFactory.java
blob: f39fc229c9f757fab2faab7f9f0f2811d84f4bfb (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
package org.onap.ccsdk.sli.core.sliapi.springboot.core;

import java.io.FileInputStream;
import java.io.IOException;
import java.util.Properties;
import org.onap.ccsdk.sli.core.sli.ConfigurationException;
import org.onap.ccsdk.sli.core.sli.SvcLogicLoader;
import org.onap.ccsdk.sli.core.sli.SvcLogicStore;
import org.onap.ccsdk.sli.core.sli.SvcLogicStoreFactory;
import org.onap.ccsdk.sli.core.sli.provider.base.HashMapResolver;
import org.onap.ccsdk.sli.core.sli.provider.base.SvcLogicPropertiesProvider;
import org.onap.ccsdk.sli.core.sli.provider.base.SvcLogicResolver;
import org.onap.ccsdk.sli.core.sli.provider.base.SvcLogicServiceBase;
import org.onap.ccsdk.sli.core.sli.provider.base.SvcLogicServiceImplBase;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class SvcLogicFactory {
  private static final Logger log = LoggerFactory.getLogger(SvcLogicFactory.class);

  @Bean
  public SvcLogicStore getStore() throws Exception {
    SvcLogicPropertiesProvider propProvider = new SvcLogicPropertiesProvider() {

      @Override
      public Properties getProperties() {
        Properties props = new Properties();
        String propPath = "src/main/resources/svclogic.properties";
        System.out.println(propPath);
        try (FileInputStream fileInputStream = new FileInputStream(propPath)) {
          props = new Properties();
          props.load(fileInputStream);
        } catch (final IOException e) {
          log.error("Failed to load properties for file: {}", propPath,
              new ConfigurationException("Failed to load properties for file: " + propPath, e));
        }
        return props;
      }
    };
    SvcLogicStore store = SvcLogicStoreFactory.getSvcLogicStore(propProvider.getProperties());
    return store;
  }

  @Bean
  public SvcLogicLoader createLoader() throws Exception {
    String serviceLogicDirectory = System.getProperty("serviceLogicDirectory");
    if (serviceLogicDirectory == null) {
      serviceLogicDirectory = "src/main/resources";
    }

    System.out.println("serviceLogicDirectory is " + serviceLogicDirectory);
    SvcLogicLoader loader = new SvcLogicLoader(serviceLogicDirectory, getStore());

    try {
      loader.loadAndActivate();
    } catch (IOException e) {
      log.error("Cannot load directed graphs", e);
    }
    return loader;
  }

  @Bean
  public SvcLogicServiceBase createService() throws Exception {
    SvcLogicResolver resolver = new HashMapResolver();
    return new SvcLogicServiceImplBase(getStore(), resolver);
  }

}