diff options
author | zhaoxiangjun666 <xjzhaop@isoftstone.com> | 2020-10-30 09:20:53 +0800 |
---|---|---|
committer | Xue Gao <xg353y@intl.att.com> | 2020-11-06 12:59:36 +0000 |
commit | c3f6bfa35f80d17e93ba83f4cfb65aa6f0dd8f5d (patch) | |
tree | 5a52881faba5b23731b6a638c417cb34f977122d /catalog-be | |
parent | 29bc8aa56fb17a6ada9866a0c97df077d63c05e4 (diff) |
Modify the get service Abstract status interface and add the tonode judgment
Issue-ID: SDC-3346
Change-Id: Ib61d54394d6c4f0d20c39824e9265fc4bff995c1
Signed-off-by: zhaoxiangjun666 <xjzhaop@isoftstone.com>
(cherry picked from commit d21377fed2d4622f52f52ed4f7a71dc1f671acfc)
Signed-off-by: sebdet <sebastien.determe@intl.att.com>
Diffstat (limited to 'catalog-be')
-rw-r--r-- | catalog-be/src/main/java/org/openecomp/sdc/be/components/impl/AbstractTemplateBusinessLogic.java | 43 |
1 files changed, 21 insertions, 22 deletions
diff --git a/catalog-be/src/main/java/org/openecomp/sdc/be/components/impl/AbstractTemplateBusinessLogic.java b/catalog-be/src/main/java/org/openecomp/sdc/be/components/impl/AbstractTemplateBusinessLogic.java index 95422f4cfc..9206dcb52e 100644 --- a/catalog-be/src/main/java/org/openecomp/sdc/be/components/impl/AbstractTemplateBusinessLogic.java +++ b/catalog-be/src/main/java/org/openecomp/sdc/be/components/impl/AbstractTemplateBusinessLogic.java @@ -16,9 +16,10 @@ package org.openecomp.sdc.be.components.impl; import fj.data.Either; +import lombok.Getter; +import lombok.Setter; import org.apache.commons.lang3.tuple.ImmutablePair; import org.openecomp.sdc.be.components.validation.ServiceDistributionValidation; -import org.openecomp.sdc.be.dao.janusgraph.JanusGraphOperationStatus; import org.openecomp.sdc.be.externalapi.servlet.representation.AbstractResourceInfo; import org.openecomp.sdc.be.externalapi.servlet.representation.AbstractTemplateInfo; import org.openecomp.sdc.be.model.*; @@ -27,7 +28,6 @@ import org.openecomp.sdc.be.model.category.SubCategoryDefinition; 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.*; -import org.openecomp.sdc.be.model.operations.impl.DaoStatusConverter; import org.openecomp.sdc.be.model.operations.impl.InterfaceLifecycleOperation; import org.openecomp.sdc.common.log.wrappers.Logger; import org.openecomp.sdc.exception.ResponseFormat; @@ -38,7 +38,8 @@ import java.util.HashMap; import java.util.List; import java.util.Map; - +@Getter +@Setter @org.springframework.stereotype.Component("abstractTemplateBusinessLogic") public class AbstractTemplateBusinessLogic extends BaseBusinessLogic { @@ -110,12 +111,7 @@ public class AbstractTemplateBusinessLogic extends BaseBusinessLogic { invariantUUID); uuidDuplicatesMap.put(componentUid, uuidInvariantUUIDPair); - Either<List<AbstractResourceInfo>, ResponseFormat> abstractResourceEither = getAbstractResourceInfoList(resource, componentInstancesRelations, serviceUniqueId); - if (abstractResourceEither.isRight()) { - return Either.right(abstractResourceEither.right().value()); - } - abstractResourceInfoList = abstractResourceEither.left().value(); - isContainAbstractResource = true; + isContainAbstractResource = getResourceAbstractStatus(resource, isContainAbstractResource, componentInstancesRelations, serviceUniqueId,abstractResourceInfoList); } } } @@ -124,20 +120,21 @@ public class AbstractTemplateBusinessLogic extends BaseBusinessLogic { return Either.left(isContainAbstractResource); } - private Either<List<AbstractResourceInfo>, ResponseFormat> getAbstractResourceInfoList(Resource resource, List<RequirementCapabilityRelDef> componentInstancesRelations, String serviceUniqueId) { - List<AbstractResourceInfo> abstractResourceInfoList = new ArrayList<>(); + private boolean getResourceAbstractStatus(Resource resource,Boolean isContainAbstractResource, List<RequirementCapabilityRelDef> componentInstancesRelations, + String serviceUniqueId,List<AbstractResourceInfo> abstractResourceInfoList) { boolean isAbstract = getIsAbstract(resource.getCategories()); log.debug("before if isAbstract,get resource:{}", resource); - if (!isAbstract) { - log.debug("getAbstractResourceInfoList:Resource is not Abstract"); - ResponseFormat responseFormat = componentsUtils.getResponseFormat(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(JanusGraphOperationStatus.NOT_FOUND)); - return Either.right(responseFormat); + if (isAbstract) { + log.debug("getResourceAbstractStatus: resource {} with id {} ,NormalizedName:{},isAbstract{} is abstract resource", + resource.getName(), resource.getUUID(), resource.getNormalizedName(), true); + isContainAbstractResource = true; + AbstractResourceInfo abstractResourceInfo = getAbstractResourceInfo(resource, componentInstancesRelations, serviceUniqueId); + abstractResourceInfoList.add(abstractResourceInfo); + } else { + log.debug("getResourceAbstractStatus:resource {} ,with id {} isAbstract{} is missing the isAbstract parameter", + resource.getName(), resource.getUUID(),false); } - log.debug("getAbstractResourceInfoList:Resource is Abstract"); - - AbstractResourceInfo abstractResourceInfo = getAbstractResourceInfo(resource, componentInstancesRelations, serviceUniqueId); - abstractResourceInfoList.add(abstractResourceInfo); - return Either.left(abstractResourceInfoList); + return isContainAbstractResource; } private AbstractResourceInfo getAbstractResourceInfo(Resource resource,List<RequirementCapabilityRelDef> componentInstancesRelations,String serviceUniqueId){ @@ -153,9 +150,11 @@ public class AbstractTemplateBusinessLogic extends BaseBusinessLogic { log.debug("get is Abstract,componentInstancesRelations:{}", componentInstancesRelations); for (RequirementCapabilityRelDef componentInstancesRelation : componentInstancesRelations) { log.debug("for componentInstancesRelation,get componentInstancesRelation:{}", componentInstancesRelation); + String toNode = componentInstancesRelation.getToNode(); String fromNode = componentInstancesRelation.getFromNode(); - log.debug("for componentInstancesRelation,get fromNode:{},uniqueId:{}", fromNode,uniqueId); - if (fromNode.toUpperCase().contains(uniqueId.toUpperCase())) { + log.debug("for componentInstancesRelation,get fromNode:{},uniqueId:{},ToNode:{},Relationships:{}", + fromNode,uniqueId,toNode,componentInstancesRelation.getRelationships()); + if (toNode.toUpperCase().contains(uniqueId.toUpperCase()) || fromNode.toUpperCase().contains(uniqueId.toUpperCase())) { RequirementCapabilityRelDef resourceComponentInstancesRelation = new RequirementCapabilityRelDef(); log.debug("fromNode contains name,get componentInstancesRelation:{}", componentInstancesRelation); resourceComponentInstancesRelation.setFromNode(componentInstancesRelation.getFromNode()); |