Fix CsarInstaller 31/43731/1
authorDeterme, Sebastien (sd378r) <sd378r@intl.att.com>
Thu, 19 Apr 2018 12:21:24 +0000 (14:21 +0200)
committerDeterme, Sebastien (sd378r) <sd378r@intl.att.com>
Thu, 19 Apr 2018 12:21:24 +0000 (14:21 +0200)
Fix the CsarInstaller for policy input when deploying to DCAE, and fix
UI so that default value is well displayed

Issue-ID: CLAMP-153
Change-Id: I307d24782e6482590e709affe59bff84fb8a8526
Signed-off-by: Determe, Sebastien (sd378r) <sd378r@intl.att.com>
src/main/java/org/onap/clamp/clds/model/properties/ModelProperties.java
src/main/java/org/onap/clamp/clds/sdc/controller/installer/CsarInstallerImpl.java
src/main/resources/META-INF/resources/designer/partials/portfolios/deploy_parameters.html
src/main/resources/META-INF/resources/designer/scripts/DeploymentCtrl.js
src/main/resources/clds/templates/dcae-template.json
src/test/java/org/onap/clamp/clds/it/sdc/controller/installer/CsarInstallerItCase.java
src/test/resources/clds/templates/dcae-template.json
src/test/resources/clds/templates/tca-template.json

index cc6f02d..c840bd1 100644 (file)
@@ -36,6 +36,8 @@ import java.util.Set;
 import java.util.concurrent.ConcurrentHashMap;
 
 import org.apache.camel.Exchange;
+import org.onap.clamp.clds.client.req.policy.PolicyClient;
+import org.onap.clamp.clds.config.ClampProperties;
 import org.onap.clamp.clds.exception.ModelBpmnException;
 import org.onap.clamp.clds.model.CldsEvent;
 import org.onap.clamp.clds.model.CldsModel;
@@ -222,6 +224,15 @@ public class ModelProperties {
         return normalizePolicyScopeName(modelName + "." + getCurrentPolicyName());
     }
 
+    /**
+     * @return The policyName that wil be used in input parameters of DCAE
+     *         deploy
+     */
+    public String getPolicyNameForDcaeDeploy(ClampProperties refProp) {
+        return normalizePolicyScopeName(modelName + "."
+                + refProp.getStringValue(PolicyClient.POLICY_MS_NAME_PREFIX_PROPERTY_NAME) + getCurrentPolicyName());
+    }
+
     /**
      * @return the policyScopeAndNameWithUniqueId
      */
index 10a7cd5..4acbdee 100644 (file)
@@ -35,17 +35,21 @@ import java.util.Map;
 import java.util.Map.Entry;
 
 import javax.annotation.PostConstruct;
+import javax.xml.transform.TransformerException;
 
 import org.json.simple.parser.ParseException;
 import org.onap.clamp.clds.client.DcaeInventoryServices;
+import org.onap.clamp.clds.config.ClampProperties;
 import org.onap.clamp.clds.config.sdc.BlueprintParserFilesConfiguration;
 import org.onap.clamp.clds.config.sdc.BlueprintParserMappingConfiguration;
 import org.onap.clamp.clds.dao.CldsDao;
 import org.onap.clamp.clds.exception.sdc.controller.SdcArtifactInstallerException;
 import org.onap.clamp.clds.model.CldsModel;
 import org.onap.clamp.clds.model.CldsTemplate;
+import org.onap.clamp.clds.model.properties.ModelProperties;
 import org.onap.clamp.clds.service.CldsService;
 import org.onap.clamp.clds.service.CldsTemplateService;
+import org.onap.clamp.clds.transform.XslTransformer;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.context.ApplicationContext;
@@ -81,6 +85,10 @@ public class CsarInstallerImpl implements CsarInstaller {
     CldsService cldsService;
     @Autowired
     DcaeInventoryServices dcaeInventoryService;
+    @Autowired
+    private XslTransformer cldsBpmnTransformer;
+    @Autowired
+    private ClampProperties refProp;
 
     @PostConstruct
     public void loadConfiguration() throws IOException {
@@ -197,28 +205,37 @@ public class CsarInstallerImpl implements CsarInstaller {
 
     private CldsModel createFakeCldsModel(CsarHandler csar, BlueprintArtifact blueprintArtifact,
             CldsTemplate cldsTemplate, String serviceTypeId) throws SdcArtifactInstallerException {
-        CldsModel cldsModel = new CldsModel();
-        String policyName = searchForPolicyName(blueprintArtifact);
-        if (policyName.contains("*")) {
-            // It's a filter must add a specific prefix
-            cldsModel.setControlNamePrefix(policyName);
-        } else {
-            cldsModel.setControlNamePrefix(CONTROL_NAME_PREFIX);
+        try {
+            CldsModel cldsModel = new CldsModel();
+            cldsModel.setName(buildModelName(csar));
+            cldsModel.setBlueprintText(blueprintArtifact.getDcaeBlueprint());
+            cldsModel.setTemplateName(cldsTemplate.getName());
+            cldsModel.setTemplateId(cldsTemplate.getId());
+            cldsModel.setBpmnText(cldsTemplate.getBpmnText());
+            cldsModel.setTypeId(serviceTypeId);
+            ModelProperties modelProp = new ModelProperties(cldsModel.getName(), "test", "PUT", false,
+                    cldsBpmnTransformer.doXslTransformToString(cldsTemplate.getBpmnText()), "{}");
+            String policyName = searchForPolicyName(blueprintArtifact);
+            String inputParams = "";
+            if (policyName.contains("*")) {
+                // It's a filter must add a specific prefix
+                cldsModel.setControlNamePrefix(policyName);
+            } else {
+                cldsModel.setControlNamePrefix(CONTROL_NAME_PREFIX);
+                inputParams = "{\"name\":\"deployParameters\",\"value\":{\n" + "\"policy_id\": \""
+                        + modelProp.getPolicyNameForDcaeDeploy(refProp) + "\"" + "}}";
+            }
+            cldsModel.setPropText("{\"global\":[{\"name\":\"service\",\"value\":[\""
+                    + blueprintArtifact.getBlueprintInvariantServiceUuid() + "\"]},{\"name\":\"vf\",\"value\":[\""
+                    + blueprintArtifact.getResourceAttached().getResourceInvariantUUID()
+                    + "\"]},{\"name\":\"actionSet\",\"value\":[\"vnfRecipe\"]},{\"name\":\"location\",\"value\":[\"DC1\"]},"
+                    + inputParams + "]}");
+            cldsModel.save(cldsDao, null);
+            logger.info("Fake Clds Model created for blueprint " + blueprintArtifact.getBlueprintArtifactName()
+                    + " with name " + cldsModel.getName());
+            return cldsModel;
+        } catch (TransformerException e) {
+            throw new SdcArtifactInstallerException("TransformerException when decoding the BpmnText", e);
         }
-        cldsModel.setName(buildModelName(csar));
-        cldsModel.setBlueprintText(blueprintArtifact.getDcaeBlueprint());
-        cldsModel.setTemplateName(cldsTemplate.getName());
-        cldsModel.setTemplateId(cldsTemplate.getId());
-        cldsModel.setPropText("{\"global\":[{\"name\":\"service\",\"value\":[\""
-                + blueprintArtifact.getBlueprintInvariantServiceUuid() + "\"]},{\"name\":\"vf\",\"value\":[\""
-                + blueprintArtifact.getResourceAttached().getResourceInvariantUUID()
-                + "\"]},{\"name\":\"actionSet\",\"value\":[\"vnfRecipe\"]},{\"name\":\"location\",\"value\":[\"DC1\"]},{\"name\":\"deployParameters\",\"value\":{\n"
-                + "        \"policy_id\": \"" + "test" + "\"" + "      }}]}");
-        cldsModel.setBpmnText(cldsTemplate.getBpmnText());
-        cldsModel.setTypeId(serviceTypeId);
-        cldsModel.save(cldsDao, null);
-        logger.info("Fake Clds Model created for blueprint " + blueprintArtifact.getBlueprintArtifactName()
-                + " with name " + cldsModel.getName());
-        return cldsModel;
     }
 }
index c0cd6c9..ecb0af4 100644 (file)
@@ -30,7 +30,7 @@
                  <div style="height: 30px">
         Deployment parameters as JSON.
       </div>
-      <textarea class="form-control" focus="true" name="deployProperties"  id="deployProperties" />
+      <textarea class="form-control" focus="true" name="deployProperties" id="deployProperties" ng-init="load_deploy_parameters()"/>
        </div>
        <div class="modal-footer">
       <button ng-click="deploy()"  class="btn btn-primary">Deploy</button>
index 04ba83a..4259e66 100644 (file)
@@ -25,6 +25,16 @@ app.controller('DeploymentCtrl',
                ['$scope','$rootScope','$modalInstance','data','dialogs', 'cldsModelService',
        function( $scope,  $rootScope,  $modalInstance,  data,  dialogs,   cldsModelService) {
 
+           function validate_and_set_deploy_parameters () {
+                  var parameters = $("#deployProperties").val();
+               try {
+                   parameters = JSON.parse(parameters);
+                   set_deploy_parameters(parameters);
+               } catch (e) {
+                   console.error("Couldn't parse deploy parameters json");
+               }
+           }
+
            function set_deploy_parameters(parameters) {
                if (!'global' in elementMap) {
                    elementMap["global"] = [];
@@ -38,15 +48,16 @@ app.controller('DeploymentCtrl',
                }
            }
 
-           $scope.deploy = function() {
-               var parameters = $("#deployProperties").val();
-               try {
-                   parameters = JSON.parse(parameters);
-                   set_deploy_parameters(parameters);
-                   $modalInstance.close();
-               } catch (e) {
-                   console.error("Couldn't parse deploy parameters json");
+           $scope.load_deploy_parameters = function () {
+                  var index = elementMap["global"].findIndex(function (e) { return (typeof e == "object" && !(e instanceof Array)) && "deployParameters" == e["name"]; }); 
+               if (index != -1) { 
+                  $('#deployProperties').val(JSON.stringify(elementMap["global"][index]["value"]))
                }
+           }
+
+           $scope.deploy = function() {
+                  validate_and_set_deploy_parameters ();
+               $modalInstance.close();
            };
 
            $scope.close = function() {
index 3316297..b76baf2 100644 (file)
@@ -16,7 +16,7 @@
                                "closedLoopControlName": "",
                                "closedLoopEventClient": "configuration.dcae.microservice.tca.xml",
                                "policyName": "",
-                               "policyScope": "CLAMP",
+                               "policyScope": "DCAE",
                                "policyVersion": "v0.0.1",
                                "serviceConfigurations": {
                                }
index 9009d37..c3ebb5b 100644 (file)
@@ -155,6 +155,6 @@ public class CsarInstallerItCase {
         assertNotNull(modelFromDb.getImageText());
         assertNotNull(modelFromDb.getPropText());
         assertEquals(CsarInstallerImpl.buildModelName(csar), modelFromDb.getName());
-        assertEquals(CsarInstallerImpl.MODEL_NAME_PREFIX, modelFromDb.getControlNamePrefix());
+        assertEquals(CsarInstallerImpl.CONTROL_NAME_PREFIX, modelFromDb.getControlNamePrefix());
     }
 }
index 3316297..b76baf2 100644 (file)
@@ -16,7 +16,7 @@
                                "closedLoopControlName": "",
                                "closedLoopEventClient": "configuration.dcae.microservice.tca.xml",
                                "policyName": "",
-                               "policyScope": "CLAMP",
+                               "policyScope": "DCAE",
                                "policyVersion": "v0.0.1",
                                "serviceConfigurations": {
                                }
index d2c04bf..892fc0d 100644 (file)
@@ -4,7 +4,7 @@
                {
                        "eventName": "???",
                        "controlLoopSchemaType": "VNF",
-                       "policyScope": "CLAMP",
+                       "policyScope": "DCAE",
                        "policyName": "???",
                        "policyVersion": "v0.0.1",
                        "thresholds": [