re base code
[sdc.git] / catalog-be / src / main / java / org / openecomp / sdc / be / components / property / ComponentInstanceInputPropertyDeclarator.java
@@ -1,38 +1,35 @@
 package org.openecomp.sdc.be.components.property;
 
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.List;
-import java.util.Map;
-import java.util.Optional;
-
-import org.apache.commons.collections.CollectionUtils;
+import fj.data.Either;
 import org.openecomp.sdc.be.components.impl.ComponentInstanceBusinessLogic;
+import org.openecomp.sdc.be.components.impl.utils.ExceptionUtils;
+import org.openecomp.sdc.be.datatypes.elements.Annotation;
 import org.openecomp.sdc.be.datatypes.elements.PropertyDataDefinition;
 import org.openecomp.sdc.be.impl.ComponentsUtils;
-import org.openecomp.sdc.be.model.Component;
-import org.openecomp.sdc.be.model.ComponentInstance;
-import org.openecomp.sdc.be.model.ComponentInstanceInput;
-import org.openecomp.sdc.be.model.InputDefinition;
+import org.openecomp.sdc.be.model.*;
 import org.openecomp.sdc.be.model.jsontitan.operations.ToscaOperationFacade;
 import org.openecomp.sdc.be.model.operations.api.StorageOperationStatus;
 import org.openecomp.sdc.be.model.operations.impl.PropertyOperation;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
+import org.openecomp.sdc.common.log.wrappers.Logger;
 
-import fj.data.Either;
+import java.util.*;
+
+import static org.apache.commons.collections.CollectionUtils.isEmpty;
+import static org.openecomp.sdc.be.model.utils.ComponentUtilities.getInputAnnotations;
 
 @org.springframework.stereotype.Component
-public class ComponentInstanceInputPropertyDecelerator extends DefaultPropertyDecelerator<ComponentInstance, ComponentInstanceInput> {
+public class ComponentInstanceInputPropertyDeclarator extends DefaultPropertyDeclarator<ComponentInstance, ComponentInstanceInput> {
 
-    private static final Logger log = LoggerFactory.getLogger(ComponentInstanceInputPropertyDecelerator.class);
-    private ToscaOperationFacade toscaOperationFacade;
-    private ComponentInstanceBusinessLogic componentInstanceBusinessLogic;
+    private static final Logger log = Logger.getLogger(ComponentInstanceInputPropertyDeclarator.class);
+    private final ToscaOperationFacade toscaOperationFacade;
+    private final ComponentInstanceBusinessLogic componentInstanceBusinessLogic;
+    private final ExceptionUtils exceptionUtils;
 
-    public ComponentInstanceInputPropertyDecelerator(ComponentsUtils componentsUtils, PropertyOperation propertyOperation, ToscaOperationFacade toscaOperationFacade, ComponentInstanceBusinessLogic componentInstanceBusinessLogic) {
+    public ComponentInstanceInputPropertyDeclarator(ComponentsUtils componentsUtils, PropertyOperation propertyOperation, ToscaOperationFacade toscaOperationFacade, ComponentInstanceBusinessLogic componentInstanceBusinessLogic, ExceptionUtils exceptionUtils) {
         super(componentsUtils, propertyOperation);
         this.toscaOperationFacade = toscaOperationFacade;
         this.componentInstanceBusinessLogic = componentInstanceBusinessLogic;
+        this.exceptionUtils = exceptionUtils;
     }
 
     @Override
@@ -54,7 +51,7 @@ public class ComponentInstanceInputPropertyDecelerator extends DefaultPropertyDe
     }
 
     @Override
-    void addPropertiesListToInput(ComponentInstanceInput declaredProp, PropertyDataDefinition originalProp, InputDefinition input) {
+    void addPropertiesListToInput(ComponentInstanceInput declaredProp, InputDefinition input) {
         List<ComponentInstanceInput> inputsValueList = input.getInputs();
         if(inputsValueList == null) {
             inputsValueList = new ArrayList<>(); // adding the property with the new value for UI
@@ -66,11 +63,37 @@ public class ComponentInstanceInputPropertyDecelerator extends DefaultPropertyDe
     @Override
     public StorageOperationStatus unDeclarePropertiesAsInputs(Component component, InputDefinition input) {
         List<ComponentInstanceInput> componentInstanceInputsByInputId = componentInstanceBusinessLogic.getComponentInstanceInputsByInputId(component, input.getUniqueId());
-        if (CollectionUtils.isEmpty(componentInstanceInputsByInputId)) {
+        if (isEmpty(componentInstanceInputsByInputId)) {
             return StorageOperationStatus.OK;
         }
         componentInstanceInputsByInputId.forEach(cmptInstanceInput -> prepareValueBeforeDelete(input, cmptInstanceInput, cmptInstanceInput.getPath()));
         return toscaOperationFacade.updateComponentInstanceInputs(component, componentInstanceInputsByInputId.get(0).getComponentInstanceId(), componentInstanceInputsByInputId);
     }
 
+    @Override
+    InputDefinition createInputFromProperty(String componentId, ComponentInstance propertiesOwner, String inputName, ComponentInstancePropInput propInput, PropertyDataDefinition prop) {
+        InputDefinition inputFromProperty = super.createInputFromProperty(componentId, propertiesOwner, inputName, propInput, prop);
+        Component propertiesOwnerNodeType = getInstanceOriginType(propertiesOwner);
+        enrichInputWithAnnotations(prop, inputFromProperty, propertiesOwnerNodeType);
+        return inputFromProperty;
+    }
+
+    private void enrichInputWithAnnotations(PropertyDataDefinition prop, InputDefinition inputFromProperty, Component propertiesOwnerNodeType) {
+        List<Annotation> inputAnnotations = getInputAnnotations(propertiesOwnerNodeType, prop.getName());
+        if(!isEmpty(inputAnnotations)){
+            inputFromProperty.setAnnotations(inputAnnotations);
+        }
+    }
+
+    private Component getInstanceOriginType(ComponentInstance propertiesOwner) {
+        return toscaOperationFacade.getToscaElement(propertiesOwner.getActualComponentUid(), getFilterComponentInputs())
+                    .left()
+                    .on(err -> exceptionUtils.rollBackAndThrow(err, propertiesOwner.getActualComponentUid()));
+    }
+
+    private ComponentParametersView getFilterComponentInputs() {
+        ComponentParametersView filterInputs = new ComponentParametersView(true);
+        filterInputs.setIgnoreInputs(false);
+        return filterInputs;
+    }
 }