Format java POLICY-SDK-APP
[policy/engine.git] / POLICY-SDK-APP / src / main / java / org / onap / policy / controller / CreateBRMSParamController.java
index 8c14048..33b7803 100644 (file)
@@ -2,7 +2,7 @@
  * ============LICENSE_START=======================================================
  * ONAP Policy Engine
  * ================================================================================
- * Copyright (C) 2017-2018 AT&T Intellectual Property. All rights reserved.
+ * Copyright (C) 2017-2019 AT&T Intellectual Property. All rights reserved.
  * Modified Copyright (C) 2018 Samsung Electronics Co., Ltd.
  * Modifications Copyright (C) 2019 Bell Canada
  * ================================================================================
 
 package org.onap.policy.controller;
 
+import com.fasterxml.jackson.databind.DeserializationFeature;
+import com.fasterxml.jackson.databind.JsonNode;
+import com.fasterxml.jackson.databind.ObjectMapper;
+
 import java.io.PrintWriter;
 import java.util.ArrayList;
 import java.util.Arrays;
@@ -36,12 +40,23 @@ import java.util.Objects;
 import java.util.Set;
 import java.util.regex.Matcher;
 import java.util.regex.Pattern;
-
 import java.util.stream.Collectors;
+
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 import javax.xml.bind.JAXBElement;
 
+import oasis.names.tc.xacml._3_0.core.schema.wd_17.AdviceExpressionType;
+import oasis.names.tc.xacml._3_0.core.schema.wd_17.AdviceExpressionsType;
+import oasis.names.tc.xacml._3_0.core.schema.wd_17.AnyOfType;
+import oasis.names.tc.xacml._3_0.core.schema.wd_17.AttributeAssignmentExpressionType;
+import oasis.names.tc.xacml._3_0.core.schema.wd_17.AttributeDesignatorType;
+import oasis.names.tc.xacml._3_0.core.schema.wd_17.AttributeValueType;
+import oasis.names.tc.xacml._3_0.core.schema.wd_17.MatchType;
+import oasis.names.tc.xacml._3_0.core.schema.wd_17.PolicyType;
+import oasis.names.tc.xacml._3_0.core.schema.wd_17.RuleType;
+import oasis.names.tc.xacml._3_0.core.schema.wd_17.TargetType;
+
 import org.apache.commons.collections.CollectionUtils;
 import org.json.JSONObject;
 import org.onap.policy.common.logging.flexlogger.FlexLogger;
@@ -57,21 +72,6 @@ import org.springframework.stereotype.Controller;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RequestMethod;
 
-import com.fasterxml.jackson.databind.DeserializationFeature;
-import com.fasterxml.jackson.databind.JsonNode;
-import com.fasterxml.jackson.databind.ObjectMapper;
-
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.AdviceExpressionType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.AdviceExpressionsType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.AnyOfType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.AttributeAssignmentExpressionType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.AttributeDesignatorType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.AttributeValueType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.MatchType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.PolicyType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.RuleType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.TargetType;
-
 @Controller
 @RequestMapping("/")
 public class CreateBRMSParamController extends RestrictedBaseController {
@@ -104,8 +104,7 @@ public class CreateBRMSParamController extends RestrictedBaseController {
     private static String brmsTemplateVlaue = "<$%BRMSParamTemplate=";
     private static String string = "String";
 
-
-    @RequestMapping(value = {"/policyController/getBRMSTemplateData.htm"}, method = { RequestMethod.POST})
+    @RequestMapping(value = {"/policyController/getBRMSTemplateData.htm"}, method = {RequestMethod.POST})
     public void getBRMSParamPolicyRuleData(HttpServletRequest request, HttpServletResponse response) {
         try {
             dynamicLayoutMap = new HashMap<>();
@@ -129,7 +128,7 @@ public class CreateBRMSParamController extends RestrictedBaseController {
 
     private String findRule(String ruleTemplate) {
         List<Object> datas = commonClassDao.getDataById(BRMSParamTemplate.class, "ruleName", ruleTemplate);
-        if(CollectionUtils.isNotEmpty(datas)){
+        if (CollectionUtils.isNotEmpty(datas)) {
             BRMSParamTemplate bRMSParamTemplate = (BRMSParamTemplate) datas.get(0);
             return bRMSParamTemplate.getRule();
         }
@@ -151,7 +150,7 @@ public class CreateBRMSParamController extends RestrictedBaseController {
     private void processRule(String rule) {
         StringBuilder params = getParamsBuilderFromRule(rule);
         params = new StringBuilder(
-            params.toString().replace("declare Params", "").replace("end", "").replaceAll("\\s+", ""));
+                params.toString().replace("declare Params", "").replace("end", "").replaceAll("\\s+", ""));
         String[] components = params.toString().split(":");
         String caption = "";
         for (int i = 0; i < components.length; i++) {
@@ -244,7 +243,8 @@ public class CreateBRMSParamController extends RestrictedBaseController {
     }
 
     /*
-     * When the User Click Edit or View Policy the following method will get invoked for setting the data to PolicyRestAdapter.
+     * When the User Click Edit or View Policy the following method will get invoked for setting the data to
+     * PolicyRestAdapter.
      * Which is used to bind the data in GUI
      */
     public void prePopulateBRMSParamPolicyData(PolicyRestAdapter policyAdapter, PolicyEntity entity) {
@@ -254,11 +254,11 @@ public class CreateBRMSParamController extends RestrictedBaseController {
             policyAdapter.setOldPolicyFileName(policyAdapter.getPolicyName());
             // policy name value is the policy name without any prefix and
             // Extensions.
-            String policyNameValue = policyAdapter.getPolicyName()
-                .substring(policyAdapter.getPolicyName().indexOf("BRMS_Param_") + 11);
+            String policyNameValue =
+                    policyAdapter.getPolicyName().substring(policyAdapter.getPolicyName().indexOf("BRMS_Param_") + 11);
             if (policyLogger.isDebugEnabled()) {
                 policyLogger
-                    .debug("Prepopulating form data for BRMS RAW Policy selected:" + policyAdapter.getPolicyName());
+                        .debug("Prepopulating form data for BRMS RAW Policy selected:" + policyAdapter.getPolicyName());
             }
             policyAdapter.setPolicyName(policyNameValue);
             String description;
@@ -281,11 +281,10 @@ public class CreateBRMSParamController extends RestrictedBaseController {
             // Get the target data under policy.
             policyAdapter.setDynamicLayoutMap(dynamicLayoutMap);
             if (policyAdapter.getDynamicLayoutMap().size() > 0) {
-                LinkedHashMap<String, String> drlRule = policyAdapter.getDynamicLayoutMap()
-                    .keySet().stream()
-                    .collect(Collectors
-                        .toMap(String::toString, keyValue -> policyAdapter.getDynamicLayoutMap().get(keyValue),
-                            (a, b) -> b, LinkedHashMap::new));
+                LinkedHashMap<String, String> drlRule = policyAdapter.getDynamicLayoutMap().keySet().stream()
+                        .collect(Collectors.toMap(String::toString,
+                                keyValue -> policyAdapter.getDynamicLayoutMap().get(keyValue), (a, b) -> b,
+                                LinkedHashMap::new));
                 policyAdapter.setRuleData(drlRule);
             }
             TargetType target = policy.getTarget();
@@ -298,24 +297,25 @@ public class CreateBRMSParamController extends RestrictedBaseController {
     private void setDataAdapterFromAdviceExpressions(PolicyType policy, PolicyRestAdapter policyAdapter) {
         ArrayList<Object> attributeList = new ArrayList<>();
         // Set Attributes.
-        AdviceExpressionsType expressionTypes = ((RuleType) policy
-            .getCombinerParametersOrRuleCombinerParametersOrVariableDefinition().get(0)).getAdviceExpressions();
+        AdviceExpressionsType expressionTypes =
+                ((RuleType) policy.getCombinerParametersOrRuleCombinerParametersOrVariableDefinition().get(0))
+                        .getAdviceExpressions();
         for (AdviceExpressionType adviceExpression : expressionTypes.getAdviceExpression()) {
             for (AttributeAssignmentExpressionType attributeAssignment : adviceExpression
-                .getAttributeAssignmentExpression()) {
+                    .getAttributeAssignmentExpression()) {
                 if (attributeAssignment.getAttributeId().startsWith("key:")) {
                     Map<String, String> attribute = new HashMap<>();
                     String key = attributeAssignment.getAttributeId().replace("key:", "");
                     attribute.put("key", key);
                     @SuppressWarnings("unchecked")
-                    JAXBElement<AttributeValueType> attributeValue = (JAXBElement<AttributeValueType>) attributeAssignment
-                        .getExpression();
+                    JAXBElement<AttributeValueType> attributeValue =
+                            (JAXBElement<AttributeValueType>) attributeAssignment.getExpression();
                     String value = (String) attributeValue.getValue().getContent().get(0);
                     attribute.put("value", value);
                     attributeList.add(attribute);
                 } else if (attributeAssignment.getAttributeId().startsWith("dependencies:")) {
-                    ArrayList<String> dependencies = new ArrayList<>(
-                        Arrays.asList(attributeAssignment.getAttributeId().replace("dependencies:", "").split(",")));
+                    ArrayList<String> dependencies = new ArrayList<>(Arrays
+                            .asList(attributeAssignment.getAttributeId().replace("dependencies:", "").split(",")));
                     dependencies.remove("");
                     policyAdapter.setBrmsDependency(dependencies);
                 } else if (attributeAssignment.getAttributeId().startsWith("controller:")) {
@@ -332,10 +332,8 @@ public class CreateBRMSParamController extends RestrictedBaseController {
         if (anyOfList == null) {
             return;
         }
-        anyOfList.stream().map(AnyOfType::getAllOf)
-            .filter(Objects::nonNull)
-            .flatMap(Collection::stream)
-            .forEach(allOf -> setDataToAdapterFromMatchList(allOf.getMatch(), policyAdapter));
+        anyOfList.stream().map(AnyOfType::getAllOf).filter(Objects::nonNull).flatMap(Collection::stream)
+                .forEach(allOf -> setDataToAdapterFromMatchList(allOf.getMatch(), policyAdapter));
     }
 
     private void setDataToAdapterFromMatchList(List<MatchType> matchList, PolicyRestAdapter policyAdapter) {
@@ -390,8 +388,8 @@ public class CreateBRMSParamController extends RestrictedBaseController {
                 String value = line.substring(line.indexOf("<%$"), line.indexOf("$%>"));
                 value = value.replaceAll("<%\\$Values=", "");
                 Arrays.stream(value.split(":\\|:")).map(keyValue -> keyValue.split(":-:"))
-                    .filter(pair -> pair.length > 0)
-                    .forEach(pair -> dynamicLayoutMap.put(pair[0], (pair.length > 1) ? pair[1] : ""));
+                        .filter(pair -> pair.length > 0)
+                        .forEach(pair -> dynamicLayoutMap.put(pair[0], (pair.length > 1) ? pair[1] : ""));
                 return;
             }
             if (line.startsWith("/*")) {
@@ -429,32 +427,26 @@ public class CreateBRMSParamController extends RestrictedBaseController {
             }
         }
         params = new StringBuilder(params.substring(params.indexOf(".Params\"") + 11));
-        params = new StringBuilder(params.toString().replaceAll("\\s+", "")
-            .replace("salience1000whenthenParamsparams=newParams();", "")
-            .replace("insert(params);end", "")
-            .replace("params.set", ""));
+        params = new StringBuilder(
+                params.toString().replaceAll("\\s+", "").replace("salience1000whenthenParamsparams=newParams();", "")
+                        .replace("insert(params);end", "").replace("params.set", ""));
         updateCaptionToDynamicLayoutMap(params);
     }
 
     private void updateCaptionToDynamicLayoutMap(final StringBuilder params) {
         String[] components = params.toString().split("\\);");
-        if(components.length > 0){
+        if (components.length > 0) {
             for (int i = 0; i < components.length; i++) {
                 String value;
                 components[i] = components[i] + ")";
-                String caption = components[i].substring(0,
-                    components[i].indexOf('('));
+                String caption = components[i].substring(0, components[i].indexOf('('));
                 caption = caption.substring(0, 1).toLowerCase() + caption.substring(1);
                 if (components[i].contains("(\"")) {
-                    value = components[i]
-                        .substring(components[i].indexOf("(\""),
-                            components[i].indexOf("\")"))
-                        .replace("(\"", "").replace("\")", "");
+                    value = components[i].substring(components[i].indexOf("(\""), components[i].indexOf("\")"))
+                            .replace("(\"", "").replace("\")", "");
                 } else {
-                    value = components[i]
-                        .substring(components[i].indexOf('('),
-                            components[i].indexOf(')'))
-                        .replace("(", "").replace(")", "");
+                    value = components[i].substring(components[i].indexOf('('), components[i].indexOf(')'))
+                            .replace("(", "").replace(")", "");
                 }
                 dynamicLayoutMap.put(caption, value);
             }
@@ -473,8 +465,7 @@ public class CreateBRMSParamController extends RestrictedBaseController {
 
     private String processMultiLineFullComment(String line) {
         try {
-            line = splitMultiLineStartComment(line)
-                + splitMultiLineEndComment(line);
+            line = splitMultiLineStartComment(line) + splitMultiLineEndComment(line);
         } catch (Exception e) {
             policyLogger.info("Just for Logging" + e);
             line = splitMultiLineStartComment(line);
@@ -484,26 +475,25 @@ public class CreateBRMSParamController extends RestrictedBaseController {
 
     // set View Rule
     @SuppressWarnings("unchecked")
-    @RequestMapping(value = {"/policyController/ViewBRMSParamPolicyRule.htm"}, method = { RequestMethod.POST})
+    @RequestMapping(value = {"/policyController/ViewBRMSParamPolicyRule.htm"}, method = {RequestMethod.POST})
     public void setViewRule(HttpServletRequest request, HttpServletResponse response) {
         try {
             ObjectMapper mapper = new ObjectMapper();
             mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
             JsonNode root = mapper.readTree(request.getReader());
-            PolicyRestAdapter policyData = mapper
-                .readValue(root.get(PolicyController.getPolicydata()).get("policy").toString(),
-                    PolicyRestAdapter.class);
+            PolicyRestAdapter policyData = mapper.readValue(
+                    root.get(PolicyController.getPolicydata()).get("policy").toString(), PolicyRestAdapter.class);
             policyData.setDomainDir(
-                root.get(PolicyController.getPolicydata()).get("model").get("name").toString().replace("\"", ""));
+                    root.get(PolicyController.getPolicydata()).get("model").get("name").toString().replace("\"", ""));
             if (root.get(PolicyController.getPolicydata()).get("model").get("type").toString().replace("\"", "")
-                .equals(PolicyController.getFile())) {
+                    .equals(PolicyController.getFile())) {
                 policyData.setEditPolicy(true);
             }
 
             String body = findRule(policyData.getRuleName()) + "\n";
             StringBuilder generatedMetadata = new StringBuilder().append(
-                "/* Autogenerated Code Please Don't change/remove this comment section. This is for the UI purpose. \n\t ")
-                .append(brmsTemplateVlaue).append(policyData.getRuleName()).append("%$> \n */ \n");
+                    "/* Autogenerated Code Please Don't change/remove this comment section. This is for the UI purpose. \n\t ")
+                    .append(brmsTemplateVlaue).append(policyData.getRuleName()).append("%$> \n */ \n");
 
             if (policyData.getDynamicLayoutMap().size() > 0) {
                 generatedMetadata.append("/* <%$Values=");
@@ -518,26 +508,25 @@ public class CreateBRMSParamController extends RestrictedBaseController {
             policyLogger.info("Metadata generated with :" + generatedMetadata.toString());
             body = generatedMetadata.toString() + body;
             // Expand the body.
-            Map<String, String> copyMap = new HashMap<>(
-                (Map<? extends String, ? extends String>) policyData.getRuleData());
+            Map<String, String> copyMap =
+                    new HashMap<>((Map<? extends String, ? extends String>) policyData.getRuleData());
             copyMap.put("policyName",
-                policyData.getDomainDir().replace("\\", ".") + ".Config_BRMS_Param_" + policyData.getPolicyName());
+                    policyData.getDomainDir().replace("\\", ".") + ".Config_BRMS_Param_" + policyData.getPolicyName());
             copyMap.put("policyScope", policyData.getDomainDir().replace("\\", "."));
             copyMap.put("policyVersion", "1");
-            //Finding all the keys in the Map data-structure.
+            // Finding all the keys in the Map data-structure.
             Set<String> keySet = copyMap.keySet();
             Iterator<String> iterator = keySet.iterator();
             Pattern p;
             Matcher m;
             while (iterator.hasNext()) {
-                //Converting the first character of the key into a lower case.
+                // Converting the first character of the key into a lower case.
                 String input = iterator.next();
-                String output = Character.toLowerCase(input.charAt(0)) +
-                    (input.length() > 1 ? input.substring(1) : "");
-                //Searching for a pattern in the String using the key.
+                String output = Character.toLowerCase(input.charAt(0)) + (input.length() > 1 ? input.substring(1) : "");
+                // Searching for a pattern in the String using the key.
                 p = Pattern.compile("\\$\\{" + output + "\\}");
                 m = p.matcher(body);
-                //Replacing the value with the inputs provided by the user in the editor.
+                // Replacing the value with the inputs provided by the user in the editor.
                 body = m.replaceAll(copyMap.get(input));
             }
             response.setCharacterEncoding("UTF-8");