diff options
author | JvD_Ericsson <jeff.van.dam@est.tech> | 2023-09-01 11:50:31 +0100 |
---|---|---|
committer | Vasyl Razinkov <vasyl.razinkov@est.tech> | 2023-09-04 11:31:56 +0000 |
commit | b945edb543cc7283908a019bd8859ad936572e86 (patch) | |
tree | edbf11a7747e453e0dfbf82a0a4145f00352f7ef /catalog-be/src/main | |
parent | db7c4875fb9336088b9a74f34f6f539950cdb344 (diff) |
Import service with outputs mapped to implicit attributes
Issue-ID: SDC-4613
Signed-off-by: JvD_Ericsson <jeff.van.dam@est.tech>
Change-Id: Icd02e0ee1e9f4d649db25b36077cfffb94e4d562
Diffstat (limited to 'catalog-be/src/main')
-rw-r--r-- | catalog-be/src/main/java/org/openecomp/sdc/be/components/impl/OutputsBusinessLogic.java | 31 |
1 files changed, 30 insertions, 1 deletions
diff --git a/catalog-be/src/main/java/org/openecomp/sdc/be/components/impl/OutputsBusinessLogic.java b/catalog-be/src/main/java/org/openecomp/sdc/be/components/impl/OutputsBusinessLogic.java index a5f819d9b0..62ef98b985 100644 --- a/catalog-be/src/main/java/org/openecomp/sdc/be/components/impl/OutputsBusinessLogic.java +++ b/catalog-be/src/main/java/org/openecomp/sdc/be/components/impl/OutputsBusinessLogic.java @@ -17,6 +17,7 @@ * limitations under the License. * ============LICENSE_END========================================================= */ + package org.openecomp.sdc.be.components.impl; import fj.data.Either; @@ -26,6 +27,7 @@ import java.util.List; import java.util.Map; import java.util.Optional; import org.apache.commons.collections4.CollectionUtils; +import org.jetbrains.annotations.NotNull; import org.openecomp.sdc.be.components.attribute.AttributeDeclarationOrchestrator; import org.openecomp.sdc.be.components.impl.exceptions.ByActionStatusComponentException; import org.openecomp.sdc.be.components.impl.exceptions.ByResponseFormatComponentException; @@ -43,6 +45,7 @@ import org.openecomp.sdc.be.model.ComponentInstanceAttribute; import org.openecomp.sdc.be.model.ComponentInstanceOutput; import org.openecomp.sdc.be.model.ComponentParametersView; import org.openecomp.sdc.be.model.OutputDefinition; +import org.openecomp.sdc.be.model.PropertyDefinition; import org.openecomp.sdc.be.model.jsonjanusgraph.operations.ArtifactsOperations; import org.openecomp.sdc.be.model.jsonjanusgraph.operations.InterfaceOperation; import org.openecomp.sdc.be.model.operations.api.IElementOperation; @@ -68,7 +71,8 @@ public class OutputsBusinessLogic extends BaseBusinessLogic { private static final String GOING_TO_EXECUTE_ROLLBACK_ON_CREATE_OUTPUTS = "Going to execute rollback on create outputs."; private static final String GOING_TO_EXECUTE_COMMIT_ON_CREATE_OUTPUTS = "Going to execute commit on create outputs."; private static final LoggerSupportability loggerSupportability = LoggerSupportability.getLogger(OutputsBusinessLogic.class); - private static final String FAILED_TO_FOUND_COMPONENT_INSTANCE_OUTPUTS_COMPONENT_INSTANCE_ID = "Failed to found component instance outputs componentInstanceId: {}"; + private static final String FAILED_TO_FOUND_COMPONENT_INSTANCE_OUTPUTS_COMPONENT_INSTANCE_ID = + "Failed to found component instance outputs componentInstanceId: {}"; private static final String FAILED_TO_FOUND_COMPONENT_INSTANCE_OUTPUTS_ERROR = "Failed to found component instance outputs {}, error: {}"; private final AttributeDeclarationOrchestrator attributeDeclarationOrchestrator; @@ -301,7 +305,32 @@ public class OutputsBusinessLogic extends BaseBusinessLogic { result.addAll(createdOutputs.left().value()); } } + final List<PropertyDefinition> componentInstanceProperties = componentInstance.getProperties(); + if (CollectionUtils.isNotEmpty(componentInstanceProperties)) { + final Optional<PropertyDefinition> componentInstancePropertyOptional = componentInstanceProperties.stream() + .filter(prop -> prop.getName().equals(attributeName)).findFirst(); + if (componentInstancePropertyOptional.isPresent()) { + PropertyDefinition propertyDefinition = componentInstancePropertyOptional.get(); + final ComponentInstOutputsMap componentInstOutputsMap = new ComponentInstOutputsMap(); + ComponentInstanceAttribOutput attribute = getComponentInstanceAttribOutput(propertyDefinition); + componentInstOutputsMap.setComponentInstanceAttributes(Collections.singletonMap(componentInstance.getUniqueId(), + Collections.singletonList(new ComponentInstanceAttribOutput(attribute)))); + return createMultipleOutputs(userId, componentUniqueId, ComponentTypeEnum.SERVICE, componentInstOutputsMap, true, false); + } + } return Either.left(result); } + @NotNull + private ComponentInstanceAttribOutput getComponentInstanceAttribOutput(PropertyDefinition propertyDefinition) { + ComponentInstanceAttribOutput attribute = new ComponentInstanceAttribOutput(); + attribute.setParentUniqueId(propertyDefinition.getParentUniqueId()); + attribute.setName(propertyDefinition.getName()); + attribute.setOwnerId(propertyDefinition.getOwnerId()); + attribute.setType(propertyDefinition.getType()); + attribute.setSchema(propertyDefinition.getSchema()); + attribute.setUniqueId(propertyDefinition.getUniqueId()); + return attribute; + } + } |