package org.oransc.policyagent.configuration;
-import com.google.gson.Gson;
-import com.google.gson.GsonBuilder;
import com.google.gson.JsonArray;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
-import java.net.MalformedURLException;
-import java.net.URL;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
import java.util.Map.Entry;
-import java.util.Properties;
import java.util.Set;
-import java.util.Vector;
+
import javax.validation.constraints.NotNull;
-import lombok.Getter;
-import org.onap.dmaap.mr.test.clients.ProtocolTypeConstants;
+
+import org.immutables.gson.Gson;
+import org.immutables.value.Value;
import org.oransc.policyagent.exceptions.ServiceException;
-import org.springframework.http.MediaType;
+/**
+ * Parser for the Json representing of the component configuration.
+ */
public class ApplicationConfigParser {
private static final String CONFIG = "config";
+ private static final String CONTROLLER = "controller";
+
+ @Value.Immutable
+ @Gson.TypeAdapters
+ public interface ConfigParserResult {
+ List<RicConfig> ricConfigs();
+
+ Map<String, ControllerConfig> controllerConfigs();
- private static Gson gson = new GsonBuilder() //
- .serializeNulls() //
- .create(); //
+ String dmaapConsumerTopicUrl();
- @Getter
- private Vector<RicConfig> ricConfigs;
- @Getter
- private Properties dmaapPublisherConfig;
- @Getter
- private Properties dmaapConsumerConfig;
+ String dmaapProducerTopicUrl();
+
+ }
+
+ public ConfigParserResult parse(JsonObject root) throws ServiceException {
+
+ String dmaapProducerTopicUrl = "";
+ String dmaapConsumerTopicUrl = "";
- public void parse(JsonObject root) throws ServiceException {
JsonObject agentConfigJson = root.getAsJsonObject(CONFIG);
- ricConfigs = parseRics(agentConfigJson);
- JsonObject dmaapPublisherConfigJson = agentConfigJson.getAsJsonObject("streams_publishes");
- if (dmaapPublisherConfigJson == null) {
- dmaapPublisherConfig = new Properties();
- } else {
- dmaapPublisherConfig = parseDmaapConfig(dmaapPublisherConfigJson);
+
+ if (agentConfigJson == null) {
+ throw new ServiceException("Missing root configuration \"" + CONFIG + "\" in JSON: " + root);
}
- JsonObject dmaapConsumerConfigJson = agentConfigJson.getAsJsonObject("streams_subscribes");
- if (dmaapConsumerConfigJson == null) {
- dmaapConsumerConfig = new Properties();
- } else {
- dmaapConsumerConfig = parseDmaapConfig(dmaapConsumerConfigJson);
+
+ JsonObject json = agentConfigJson.getAsJsonObject("streams_publishes");
+ if (json != null) {
+ dmaapProducerTopicUrl = parseDmaapConfig(json);
+ }
+
+ json = agentConfigJson.getAsJsonObject("streams_subscribes");
+ if (json != null) {
+ dmaapConsumerTopicUrl = parseDmaapConfig(json);
+ }
+
+ List<RicConfig> ricConfigs = parseRics(agentConfigJson);
+ Map<String, ControllerConfig> controllerConfigs = parseControllerConfigs(agentConfigJson);
+ checkConfigurationConsistency(ricConfigs, controllerConfigs);
+
+ return ImmutableConfigParserResult.builder() //
+ .dmaapConsumerTopicUrl(dmaapConsumerTopicUrl) //
+ .dmaapProducerTopicUrl(dmaapProducerTopicUrl) //
+ .ricConfigs(ricConfigs) //
+ .controllerConfigs(controllerConfigs) //
+ .build();
+ }
+
+ private void checkConfigurationConsistency(List<RicConfig> ricConfigs,
+ Map<String, ControllerConfig> controllerConfigs) throws ServiceException {
+ Set<String> ricUrls = new HashSet<>();
+ Set<String> ricNames = new HashSet<>();
+ for (RicConfig ric : ricConfigs) {
+ if (!ricUrls.add(ric.baseUrl())) {
+ throw new ServiceException("Configuration error, more than one RIC URL: " + ric.baseUrl());
+ }
+ if (!ricNames.add(ric.name())) {
+ throw new ServiceException("Configuration error, more than one RIC with name: " + ric.name());
+ }
+ if (!ric.controllerName().isEmpty() && controllerConfigs.get(ric.controllerName()) == null) {
+ throw new ServiceException(
+ "Configuration error, controller configuration not found: " + ric.controllerName());
+ }
+
}
}
- private Vector<RicConfig> parseRics(JsonObject config) throws ServiceException {
- Vector<RicConfig> result = new Vector<RicConfig>();
+ private List<RicConfig> parseRics(JsonObject config) throws ServiceException {
+ List<RicConfig> result = new ArrayList<>();
for (JsonElement ricElem : getAsJsonArray(config, "ric")) {
- result.add(gson.fromJson(ricElem.getAsJsonObject(), ImmutableRicConfig.class));
+ JsonObject ricAsJson = ricElem.getAsJsonObject();
+ JsonElement controllerNameElement = ricAsJson.get(CONTROLLER);
+ ImmutableRicConfig ricConfig = ImmutableRicConfig.builder() //
+ .name(get(ricAsJson, "name").getAsString()) //
+ .baseUrl(get(ricAsJson, "baseUrl").getAsString()) //
+ .managedElementIds(parseManagedElementIds(get(ricAsJson, "managedElementIds").getAsJsonArray())) //
+ .controllerName(controllerNameElement != null ? controllerNameElement.getAsString() : "") //
+ .build();
+ result.add(ricConfig);
}
return result;
}
+ Map<String, ControllerConfig> parseControllerConfigs(JsonObject config) throws ServiceException {
+ if (config.get(CONTROLLER) == null) {
+ return new HashMap<>();
+ }
+ Map<String, ControllerConfig> result = new HashMap<>();
+ for (JsonElement element : getAsJsonArray(config, CONTROLLER)) {
+ JsonObject controllerAsJson = element.getAsJsonObject();
+ ImmutableControllerConfig controllerConfig = ImmutableControllerConfig.builder() //
+ .name(get(controllerAsJson, "name").getAsString()) //
+ .baseUrl(get(controllerAsJson, "baseUrl").getAsString()) //
+ .password(get(controllerAsJson, "password").getAsString()) //
+ .userName(get(controllerAsJson, "userName").getAsString()) // )
+ .build();
+
+ if (result.put(controllerConfig.name(), controllerConfig) != null) {
+ throw new ServiceException(
+ "Configuration error, more than one controller with name: " + controllerConfig.name());
+ }
+ }
+ return result;
+ }
+
+ private List<String> parseManagedElementIds(JsonArray asJsonObject) {
+ Iterator<JsonElement> iterator = asJsonObject.iterator();
+ List<String> managedElementIds = new ArrayList<>();
+ while (iterator.hasNext()) {
+ managedElementIds.add(iterator.next().getAsString());
+
+ }
+ return managedElementIds;
+ }
+
private static JsonElement get(JsonObject obj, String memberName) throws ServiceException {
JsonElement elem = obj.get(memberName);
if (elem == null) {
- throw new ServiceException("Could not find member: " + memberName + " in: " + obj);
+ throw new ServiceException("Could not find member: '" + memberName + "' in: " + obj);
}
return elem;
}
return get(obj, memberName).getAsJsonArray();
}
- private Properties parseDmaapConfig(JsonObject streamCfg) throws ServiceException {
+ private String parseDmaapConfig(JsonObject streamCfg) throws ServiceException {
Set<Entry<String, JsonElement>> streamConfigEntries = streamCfg.entrySet();
if (streamConfigEntries.size() != 1) {
throw new ServiceException(
}
JsonObject streamConfigEntry = streamConfigEntries.iterator().next().getValue().getAsJsonObject();
JsonObject dmaapInfo = get(streamConfigEntry, "dmaap_info").getAsJsonObject();
- String topicUrl = getAsString(dmaapInfo, "topic_url");
-
- Properties dmaapProps = new Properties();
- try {
- URL url = new URL(topicUrl);
- String passwd = "";
- String userName = "";
- if (url.getUserInfo() != null) {
- String[] userInfo = url.getUserInfo().split(":");
- userName = userInfo[0];
- passwd = userInfo[1];
- }
- String urlPath = url.getPath();
- DmaapUrlPath path = parseDmaapUrlPath(urlPath);
-
- dmaapProps.put("ServiceName", url.getHost() + ":" + url.getPort() + "/events");
- dmaapProps.put("topic", path.dmaapTopicName);
- dmaapProps.put("host", url.getHost() + ":" + url.getPort());
- dmaapProps.put("contenttype", MediaType.APPLICATION_JSON.toString());
- dmaapProps.put("userName", userName);
- dmaapProps.put("password", passwd);
- dmaapProps.put("group", path.consumerGroup);
- dmaapProps.put("id", path.consumerId);
- dmaapProps.put("TransportType", ProtocolTypeConstants.HTTPNOAUTH.toString());
- dmaapProps.put("timeout", 15000);
- dmaapProps.put("limit", 100);
- dmaapProps.put("maxBatchSize", "10");
- dmaapProps.put("maxAgeMs", "10000");
- dmaapProps.put("compress", true);
- dmaapProps.put("MessageSentThreadOccurance", "2");
- } catch (MalformedURLException e) {
- throw new ServiceException("Could not parse the URL", e);
- }
-
- return dmaapProps;
+ return getAsString(dmaapInfo, "topic_url");
}
private static @NotNull String getAsString(JsonObject obj, String memberName) throws ServiceException {
return get(obj, memberName).getAsString();
}
-
- private class DmaapUrlPath {
- final String dmaapTopicName;
- final String consumerGroup;
- final String consumerId;
-
- DmaapUrlPath(String dmaapTopicName, String consumerGroup, String consumerId) {
- this.dmaapTopicName = dmaapTopicName;
- this.consumerGroup = consumerGroup;
- this.consumerId = consumerId;
- }
- }
-
- private DmaapUrlPath parseDmaapUrlPath(String urlPath) throws ServiceException {
- String[] tokens = urlPath.split("/"); // /events/A1-P/users/sdnc1
- if (!(tokens.length == 3 ^ tokens.length == 5)) {
- throw new ServiceException("The path has incorrect syntax: " + urlPath);
- }
-
- final String dmaapTopicName = tokens[2]; // /events/A1-P
- String consumerGroup = ""; // users
- String consumerId = ""; // sdnc1
- if (tokens.length == 5) {
- consumerGroup = tokens[3];
- consumerId = tokens[4];
- }
- return new DmaapUrlPath(dmaapTopicName, consumerGroup, consumerId);
- }
}