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
99
100
101
102
103
104
105
106
107
108
109
|
package org.onap.ccsdk.sli.core.sliapi.springboot;
import java.util.HashMap;
import java.util.Map.Entry;
import java.util.Properties;
import org.onap.ccsdk.sli.core.sli.SvcLogicException;
import org.onap.ccsdk.sli.core.sli.SvcLogicLoader;
import org.onap.ccsdk.sli.core.sli.provider.base.HashMapResolver;
import org.onap.ccsdk.sli.core.sli.provider.base.InMemorySvcLogicStore;
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.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import com.google.gson.Gson;
import com.google.gson.JsonArray;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
@Controller
@EnableAutoConfiguration
public class ExecuteGraphController {
static SvcLogicServiceBase svc;
private static final Logger LOGGER = LoggerFactory.getLogger(ExecuteGraphController.class);
@RequestMapping(value = "/executeGraph", method = RequestMethod.POST)
@ResponseBody
public HashMap<String, String> executeGraph(@RequestBody String input) {
LOGGER.error("In request");
LOGGER.error(input);
HashMap<String, String> hash = new HashMap<String, String>();
Properties parms = new Properties();
hash.put("status", "success");
JsonObject jsonInput = new Gson().fromJson(input, JsonObject.class);
JsonObject passthroughObj = jsonInput.get("input").getAsJsonObject();
writeResponseToCtx(passthroughObj.toString(), parms, "input");
JsonObject inputObject = jsonInput.get("graphDetails").getAsJsonObject();
try {
// Any of these can throw a nullpointer exception
String calledModule = inputObject.get("module").getAsString();
String calledRpc = inputObject.get("rpc").getAsString();
String modeStr = inputObject.get("mode").getAsString();
// execute should only throw a SvcLogicException
Properties respProps = svc.execute(calledModule, calledRpc, null, modeStr, parms);
for (Entry<Object, Object> prop : respProps.entrySet()) {
hash.put((String) prop.getKey(), (String) prop.getValue());
}
} catch (NullPointerException npe) {
HashMap<String, String> errorHash = new HashMap<String, String>();
errorHash.put("error-message", "check that you populated module, rpc and or mode correctly.");
return errorHash;
} catch (SvcLogicException e) {
HashMap<String, String> errorHash = new HashMap<String, String>();
errorHash.put("status", "failure");
errorHash.put("message", e.getMessage());
return errorHash;
}
return hash;
}
public static void writeResponseToCtx(String resp, Properties ctx, String prefix) {
JsonParser jp = new JsonParser();
JsonElement element = jp.parse(resp);
writeJsonObject(element.getAsJsonObject(), ctx, prefix + ".");
}
public static void writeJsonObject(JsonObject obj, Properties ctx, String root) {
for (Entry<String, JsonElement> entry : obj.entrySet()) {
if (entry.getValue().isJsonObject()) {
writeJsonObject(entry.getValue().getAsJsonObject(), ctx, root + entry.getKey() + ".");
} else if (entry.getValue().isJsonArray()) {
JsonArray array = entry.getValue().getAsJsonArray();
ctx.put(root + entry.getKey() + "_length", String.valueOf(array.size()));
Integer arrayIdx = 0;
for (JsonElement element : array) {
if (element.isJsonObject()) {
writeJsonObject(element.getAsJsonObject(), ctx, root + entry.getKey() + "[" + arrayIdx + "].");
}
arrayIdx++;
}
} else {
ctx.put(root + entry.getKey(), entry.getValue().getAsString());
}
}
}
public static void main(String[] args) throws Exception {
InMemorySvcLogicStore store = new InMemorySvcLogicStore();
SvcLogicLoader loader = new SvcLogicLoader(System.getProperty("serviceLogicDirectory"), store);
loader.loadAndActivate();
SvcLogicResolver resolver = new HashMapResolver();
svc = new SvcLogicServiceImplBase(store, resolver);
SpringApplication.run(ExecuteGraphController.class, args);
}
}
|