2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
21 package org.openecomp.sdc.be.model.operations.impl;
23 import fj.data.Either;
24 import org.apache.commons.lang3.tuple.ImmutablePair;
25 import org.openecomp.sdc.be.config.BeEcompErrorManager;
26 import org.openecomp.sdc.be.dao.graph.datatype.GraphEdge;
27 import org.openecomp.sdc.be.dao.graph.datatype.GraphRelation;
28 import org.openecomp.sdc.be.dao.janusgraph.JanusGraphOperationStatus;
29 import org.openecomp.sdc.be.dao.jsongraph.GraphVertex;
30 import org.openecomp.sdc.be.dao.jsongraph.JanusGraphDao;
31 import org.openecomp.sdc.be.dao.jsongraph.types.JsonParseFlagEnum;
32 import org.openecomp.sdc.be.dao.neo4j.GraphEdgeLabels;
33 import org.openecomp.sdc.be.dao.neo4j.GraphPropertiesDictionary;
34 import org.openecomp.sdc.be.dao.utils.MapUtil;
35 import org.openecomp.sdc.be.datatypes.elements.GroupDataDefinition;
36 import org.openecomp.sdc.be.datatypes.elements.PropertyDataDefinition;
37 import org.openecomp.sdc.be.datatypes.enums.NodeTypeEnum;
38 import org.openecomp.sdc.be.model.*;
39 import org.openecomp.sdc.be.model.cache.ApplicationDataTypeCache;
40 import org.openecomp.sdc.be.model.jsonjanusgraph.operations.TopologyTemplateOperation;
41 import org.openecomp.sdc.be.model.operations.StorageException;
42 import org.openecomp.sdc.be.model.operations.api.IGroupOperation;
43 import org.openecomp.sdc.be.model.operations.api.StorageOperationStatus;
44 import org.openecomp.sdc.be.resources.data.*;
45 import org.openecomp.sdc.common.log.wrappers.Logger;
46 import org.springframework.stereotype.Component;
49 import java.util.function.Function;
50 import java.util.stream.Collectors;
52 import static org.apache.commons.collections.CollectionUtils.isNotEmpty;
53 import static org.springframework.util.CollectionUtils.isEmpty;
57 public class GroupOperation extends AbstractOperation implements IGroupOperation {
60 private static final Logger log = Logger.getLogger(GroupOperation.class.getName());
61 private final JanusGraphDao janusGraphDao;
62 private final TopologyTemplateOperation topologyTemplateOperation;
63 private final PropertyOperation propertyOperation;
64 private final GroupTypeOperation groupTypeOperation;
65 private final ApplicationDataTypeCache dataTypeCache;
67 public GroupOperation(JanusGraphDao janusGraphDao, TopologyTemplateOperation topologyTemplateOperation, PropertyOperation propertyOperation, GroupTypeOperation groupTypeOperation, ApplicationDataTypeCache dataTypeCache) {
68 this.janusGraphDao = janusGraphDao;
69 this.topologyTemplateOperation = topologyTemplateOperation;
70 this.propertyOperation = propertyOperation;
71 this.groupTypeOperation = groupTypeOperation;
72 this.dataTypeCache = dataTypeCache;
75 private GroupDefinition convertGroupDataToGroupDefinition(GroupData groupData) {
76 return new GroupDefinition(groupData.getGroupDataDefinition());
81 * get members of group
83 * @param groupUniqueId
86 private Either<Map<String, String>, JanusGraphOperationStatus> getGroupMembers(String groupUniqueId) {
88 Either<Map<String, String>, JanusGraphOperationStatus> result = null;
90 Either<List<ImmutablePair<ComponentInstanceData, GraphEdge>>, JanusGraphOperationStatus> childrenNodes = janusGraphGenericDao
91 .getChildrenNodes(UniqueIdBuilder.getKeyByNodeType(NodeTypeEnum.Group), groupUniqueId, GraphEdgeLabels.GROUP_MEMBER,
92 NodeTypeEnum.ResourceInstance, ComponentInstanceData.class);
94 if (childrenNodes.isRight()) {
95 JanusGraphOperationStatus status = childrenNodes.right().value();
96 if (status == JanusGraphOperationStatus.NOT_FOUND) {
97 status = JanusGraphOperationStatus.OK;
99 result = Either.right(status);
103 Map<String, String> compInstaMap = new HashMap<>();
104 List<ImmutablePair<ComponentInstanceData, GraphEdge>> list = childrenNodes.left().value();
106 for (ImmutablePair<ComponentInstanceData, GraphEdge> pair : list) {
107 ComponentInstanceData componentInstanceData = pair.getKey();
109 String compInstUniqueId = componentInstanceData.getComponentInstDataDefinition().getUniqueId();
110 String compInstName = componentInstanceData.getName();
111 compInstaMap.put(compInstName, compInstUniqueId);
115 result = Either.left(compInstaMap);
121 private Either<GroupTypeDefinition, StorageOperationStatus> getGroupTypeOfGroup(String groupUniqueId) {
123 Either<ImmutablePair<GroupTypeData, GraphEdge>, StorageOperationStatus> groupTypeRes = janusGraphGenericDao
124 .getChild(UniqueIdBuilder.getKeyByNodeType(NodeTypeEnum.Group), groupUniqueId, GraphEdgeLabels.TYPE_OF, NodeTypeEnum.GroupType,
127 .map(DaoStatusConverter::convertJanusGraphStatusToStorageStatus);
129 if (groupTypeRes.isRight()) {
130 StorageOperationStatus status = groupTypeRes.right().value();
131 log.debug("Cannot find group type associated with capability {}. Status is {}", groupUniqueId, status);
133 BeEcompErrorManager.getInstance().logBeFailedFindAssociationError("Fetch Group type", NodeTypeEnum.GroupType.getName(), groupUniqueId, String.valueOf(status));
134 return Either.right(groupTypeRes.right().value());
137 GroupTypeData groupTypeData = groupTypeRes.left().value().getKey();
139 return groupTypeOperation.getGroupTypeByUid(groupTypeData.getGroupTypeDataDefinition().getUniqueId());
144 * get all properties of the group.
146 * the propert definition is taken from the group type.
151 private Either<List<GroupProperty>, StorageOperationStatus> getGroupProperties(String groupUid) {
153 List<GroupProperty> groupPropertiesList = new ArrayList<>();
155 Either<GroupTypeDefinition, StorageOperationStatus> groupTypeOfGroupRes = getGroupTypeOfGroup(groupUid);
157 if (groupTypeOfGroupRes.isRight()) {
158 StorageOperationStatus status = groupTypeOfGroupRes.right().value();
159 return Either.right(status);
162 GroupTypeDefinition groupTypeDefinition = groupTypeOfGroupRes.left().value();
164 // Get the properties on the group type of this group
165 List<PropertyDefinition> groupTypeProperties = groupTypeDefinition.getProperties();
167 if (isEmpty(groupTypeProperties)) {
168 return Either.right(StorageOperationStatus.OK);
171 Map<String, PropertyDefinition> uidToPropDefMap = groupTypeProperties.stream().collect(Collectors.toMap(PropertyDefinition::getUniqueId, Function.identity()));
173 // Find all properties values on the group
174 Either<List<ImmutablePair<PropertyValueData, GraphEdge>>, StorageOperationStatus> propertyImplNodes = janusGraphGenericDao
175 .getChildrenNodes(UniqueIdBuilder.getKeyByNodeType(NodeTypeEnum.Group), groupUid, GraphEdgeLabels.PROPERTY_VALUE,
176 NodeTypeEnum.PropertyValue, PropertyValueData.class)
178 .map(DaoStatusConverter::convertJanusGraphStatusToStorageStatus);
180 if (propertyImplNodes.isRight()) {
181 StorageOperationStatus status = propertyImplNodes.right().value();
182 if (status == StorageOperationStatus.NOT_FOUND) {
183 groupPropertiesList = groupTypeProperties.stream().map(p -> new GroupProperty(p, p.getDefaultValue(), null)).collect(Collectors.toList());
184 return Either.left(groupPropertiesList);
186 return Either.right(status);
190 List<ImmutablePair<PropertyValueData, GraphEdge>> list = propertyImplNodes.left().value();
192 return Either.right(StorageOperationStatus.OK);
195 List<String> processedProps = new ArrayList<>();
197 for (ImmutablePair<PropertyValueData, GraphEdge> propertyValue : list) {
199 PropertyValueData propertyValueData = propertyValue.getLeft();
200 String propertyValueUid = propertyValueData.getUniqueId();
201 String value = propertyValueData.getValue();
203 Either<ImmutablePair<PropertyData, GraphEdge>, StorageOperationStatus> propertyDefRes = janusGraphGenericDao
204 .getChild(UniqueIdBuilder.getKeyByNodeType(NodeTypeEnum.PropertyValue), propertyValueUid, GraphEdgeLabels.PROPERTY_IMPL,
205 NodeTypeEnum.Property, PropertyData.class)
207 .map(DaoStatusConverter::convertJanusGraphStatusToStorageStatus);
208 if (propertyDefRes.isRight()) {
209 StorageOperationStatus status = propertyDefRes.right().value();
210 if (status == StorageOperationStatus.NOT_FOUND) {
211 status = StorageOperationStatus.INVALID_ID;
213 return Either.right(status);
216 ImmutablePair<PropertyData, GraphEdge> propertyDefPair = propertyDefRes.left().value();
218 PropertyData propertyData = propertyDefPair.left;
219 String propertyUniqueId = propertyData.getPropertyDataDefinition().getUniqueId();
221 PropertyDefinition propertyDefinition = uidToPropDefMap.get(propertyUniqueId);
222 GroupProperty groupProperty = new GroupProperty(propertyDefinition, value, propertyValueUid);
224 processedProps.add(propertyUniqueId);
226 groupPropertiesList.add(groupProperty);
230 // Find all properties which does not have property value on the group.
231 List<GroupProperty> leftProps = groupTypeProperties.stream()
232 // filter out the group type properties which already processed
233 .filter(p -> !processedProps.contains(p.getUniqueId()))
234 .map(p -> new GroupProperty(p, p.getDefaultValue(), null))
235 .collect(Collectors.toList());
236 if (leftProps != null) {
237 groupPropertiesList.addAll(leftProps);
240 return Either.left(groupPropertiesList);
244 public Either<List<GraphRelation>, StorageOperationStatus> dissociateAllGroupsFromArtifactOnGraph(String componentId, NodeTypeEnum componentTypeEnum, String artifactId) {
246 List<GraphRelation> relations = new ArrayList<>();
247 Either<List<GraphRelation>, StorageOperationStatus> result = Either.left(relations);
249 Either<List<GroupDefinition>, StorageOperationStatus> allGroupsFromGraph = getAllGroupsFromGraph(componentId, componentTypeEnum, true, true, false);
250 if (allGroupsFromGraph.isRight()) {
251 StorageOperationStatus status = allGroupsFromGraph.right().value();
252 return Either.right(status);
255 List<GroupDefinition> allGroups = allGroupsFromGraph.left().value();
256 if (isEmpty(allGroups)) {
257 return Either.right(StorageOperationStatus.OK);
260 // Find all groups which contains this artifact id
261 List<GroupDefinition> associatedGroups = allGroups.stream().filter(p -> p.getArtifacts() != null && p.getArtifacts().contains(artifactId)).collect(Collectors.toList());
263 if (isNotEmpty(associatedGroups)) {
264 log.debug("The groups {} contains the artifact {}", associatedGroups.stream().map(GroupDataDefinition::getName).collect(Collectors.toList()), artifactId);
266 UniqueIdData artifactData = new UniqueIdData(NodeTypeEnum.ArtifactRef, artifactId);
267 for (GroupDefinition groupDefinition : associatedGroups) {
268 UniqueIdData groupData = new UniqueIdData(NodeTypeEnum.Group, groupDefinition.getUniqueId());
269 Either<GraphRelation, StorageOperationStatus> deleteRelation = janusGraphGenericDao
270 .deleteRelation(groupData, artifactData, GraphEdgeLabels.GROUP_ARTIFACT_REF)
272 .map(DaoStatusConverter::convertJanusGraphStatusToStorageStatus);
273 if (deleteRelation.isRight()) {
274 StorageOperationStatus status = deleteRelation.right().value();
275 if (status == StorageOperationStatus.NOT_FOUND) {
276 status = StorageOperationStatus.INVALID_ID;
278 return Either.right(status);
281 relations.add(deleteRelation.left().value());
287 log.debug("No group under component id {} is associated to artifact {}", componentId, artifactId);
288 return Either.right(StorageOperationStatus.OK);
293 public Either<GroupDefinition, StorageOperationStatus> getGroupFromGraph(String uniqueId, boolean skipProperties, boolean skipMembers, boolean skipArtifacts) {
295 Either<GroupDefinition, StorageOperationStatus> result = null;
297 Either<GroupData, StorageOperationStatus> groupRes = janusGraphGenericDao
298 .getNode(UniqueIdBuilder.getKeyByNodeType(NodeTypeEnum.Group), uniqueId, GroupData.class)
300 .map(DaoStatusConverter::convertJanusGraphStatusToStorageStatus);
301 if (groupRes.isRight()) {
302 StorageOperationStatus status = groupRes.right().value();
303 log.debug("Failed to retrieve group {} from graph. Status is {}", uniqueId, status);
304 BeEcompErrorManager.getInstance().logBeFailedRetrieveNodeError("Fetch Group", uniqueId, String.valueOf(status));
305 result = Either.right(status);
309 GroupData groupData = groupRes.left().value();
311 GroupDefinition groupDefinition = convertGroupDataToGroupDefinition(groupData);
313 Either<GroupTypeDefinition, StorageOperationStatus> groupTypeOfGroup = getGroupTypeOfGroup(uniqueId);
315 if (groupTypeOfGroup.isRight()) {
316 StorageOperationStatus status = groupTypeOfGroup.right().value();
317 log.debug("Failed to retrieve capability type of capability {}. Status is {}", uniqueId, status);
319 result = Either.right(status);
323 GroupTypeDefinition groupTypeDefinition = groupTypeOfGroup.left().value();
325 groupDefinition.setTypeUid(groupTypeDefinition.getUniqueId());
328 Either<Map<String, String>, StorageOperationStatus> membersRes = getGroupMembers(uniqueId)
330 .map(DaoStatusConverter::convertJanusGraphStatusToStorageStatus);
331 if (membersRes.isRight()) {
332 StorageOperationStatus status = membersRes.right().value();
333 if (status != StorageOperationStatus.OK) {
334 result = Either.right(status);
338 Map<String, String> members = membersRes.left().value();
339 groupDefinition.setMembers(members);
343 if (!skipProperties) {
344 Either<List<GroupProperty>, StorageOperationStatus> propertiesRes = getGroupProperties(uniqueId);
345 if (propertiesRes.isRight()) {
346 StorageOperationStatus status = propertiesRes.right().value();
347 if (status != StorageOperationStatus.OK) {
348 result = Either.right(status);
352 List<GroupProperty> properties = propertiesRes.left().value();
353 groupDefinition.convertFromGroupProperties(properties);
357 if (!skipArtifacts) {
358 Either<List<ImmutablePair<String, String>>, StorageOperationStatus> artifactsRes = getGroupArtifactsPairs(uniqueId)
360 .map(DaoStatusConverter::convertJanusGraphStatusToStorageStatus);
361 if (artifactsRes.isRight()) {
362 StorageOperationStatus status = artifactsRes.right().value();
363 if (status != StorageOperationStatus.OK) {
364 result = Either.right(status);
368 List<String> artifactsUid = new ArrayList<>();
369 List<String> artifactsUUID = new ArrayList<>();
371 List<ImmutablePair<String, String>> list = artifactsRes.left().value();
373 for (ImmutablePair<String, String> pair : list) {
374 String uid = pair.left;
375 String UUID = pair.right;
376 artifactsUid.add(uid);
377 artifactsUUID.add(UUID);
379 groupDefinition.setArtifacts(artifactsUid);
380 groupDefinition.setArtifactsUuid(artifactsUUID);
384 result = Either.left(groupDefinition);
391 public boolean isGroupExist(String groupName, boolean inTransaction) {
393 Either<List<GroupData>, JanusGraphOperationStatus> eitherGroup = null;
395 Map<String, Object> properties = new HashMap<>();
396 properties.put(GraphPropertiesDictionary.NAME.getProperty(), groupName);
398 eitherGroup = janusGraphGenericDao
399 .getByCriteria(NodeTypeEnum.Group, properties, GroupData.class);
400 return eitherGroup.isLeft() && !eitherGroup.left().value().isEmpty();
403 handleTransactionCommitRollback(inTransaction, eitherGroup);
407 protected Either<List<GroupDefinition>, StorageOperationStatus> getAllGroupsFromGraph(String componentId, NodeTypeEnum componentTypeEnum, boolean skipProperties, boolean skipMembers, boolean skipArtifacts) {
409 List<GroupDefinition> groups = new ArrayList<>();
411 Either<List<ImmutablePair<GroupData, GraphEdge>>, StorageOperationStatus> childrenNodes = janusGraphGenericDao
412 .getChildrenNodes(UniqueIdBuilder.getKeyByNodeType(componentTypeEnum), componentId, GraphEdgeLabels.GROUP, NodeTypeEnum.Group,
415 .map(DaoStatusConverter::convertJanusGraphStatusToStorageStatus);
417 if (childrenNodes.isRight()) {
418 StorageOperationStatus status = childrenNodes.right().value();
419 return Either.right(status);
422 List<ImmutablePair<GroupData, GraphEdge>> graphGroups = childrenNodes.left().value();
424 if (isEmpty(graphGroups)) {
425 return Either.right(StorageOperationStatus.NOT_FOUND);
430 for (ImmutablePair<GroupData, GraphEdge> pair : graphGroups) {
432 String groupUniqueId = pair.left.getGroupDataDefinition().getUniqueId();
433 Either<GroupDefinition, StorageOperationStatus> groupRes = this.getGroupFromGraph(groupUniqueId, skipProperties, skipMembers, skipArtifacts);
435 if (groupRes.isRight()) {
436 StorageOperationStatus status = groupRes.right().value();
437 if (status == StorageOperationStatus.NOT_FOUND) {
438 status = StorageOperationStatus.INVALID_ID;
440 return Either.right(status);
442 groups.add(groupRes.left().value());
447 return Either.left(groups);
450 private StorageOperationStatus dissociateAndAssociateGroupsFromArtifactOnGraph(String componentId, NodeTypeEnum componentTypeEnum, String oldArtifactId, ArtifactData newArtifact) {
452 Either<List<GroupDefinition>, StorageOperationStatus> allGroupsFromGraph = getAllGroupsFromGraph(componentId, componentTypeEnum, true, true, false);
453 if (allGroupsFromGraph.isRight()) {
454 return allGroupsFromGraph.right().value();
458 List<GroupDefinition> allGroups = allGroupsFromGraph.left().value();
459 if (isEmpty(allGroups)) {
460 return StorageOperationStatus.OK;
463 // Find all groups which contains this artifact id
464 List<GroupDefinition> associatedGroups = allGroups.stream().filter(p -> p.getArtifacts() != null && p.getArtifacts().contains(oldArtifactId)).collect(Collectors.toList());
466 if (isNotEmpty(associatedGroups)) {
468 log.debug("The groups {} contains the artifact {}", associatedGroups.stream().map(GroupDataDefinition::getName).collect(Collectors.toList()), oldArtifactId);
470 UniqueIdData oldArtifactData = new UniqueIdData(NodeTypeEnum.ArtifactRef, oldArtifactId);
471 UniqueIdData newArtifactData = new UniqueIdData(NodeTypeEnum.ArtifactRef, newArtifact.getArtifactDataDefinition().getUniqueId());
472 Map<String, Object> props = new HashMap<>();
473 props.put(GraphPropertiesDictionary.NAME.getProperty(), newArtifactData.getLabel());
475 for (GroupDefinition groupDefinition : associatedGroups) {
476 UniqueIdData groupData = new UniqueIdData(NodeTypeEnum.Group, groupDefinition.getUniqueId());
478 Either<GraphRelation, StorageOperationStatus> deleteRelation = janusGraphGenericDao
479 .deleteRelation(groupData, oldArtifactData, GraphEdgeLabels.GROUP_ARTIFACT_REF)
481 .map(DaoStatusConverter::convertJanusGraphStatusToStorageStatus);
482 log.trace("After dissociate group {} from artifact {}" , groupDefinition.getName(), oldArtifactId);
483 if (deleteRelation.isRight()) {
484 StorageOperationStatus status = deleteRelation.right().value();
485 if (status == StorageOperationStatus.NOT_FOUND) {
486 status = StorageOperationStatus.INVALID_ID;
491 Either<GraphRelation, StorageOperationStatus> createRelation = janusGraphGenericDao
492 .createRelation(groupData, newArtifactData, GraphEdgeLabels.GROUP_ARTIFACT_REF, props)
494 .map(DaoStatusConverter::convertJanusGraphStatusToStorageStatus);
495 log.trace("After associate group {} to artifact {}" , groupDefinition.getName(), newArtifact.getUniqueIdKey());
496 if (createRelation.isRight()) {
497 StorageOperationStatus status = createRelation.right().value();
498 if (status == StorageOperationStatus.NOT_FOUND) {
499 status = StorageOperationStatus.INVALID_ID;
506 return StorageOperationStatus.OK;
510 public StorageOperationStatus dissociateAndAssociateGroupsFromArtifact(String componentId, NodeTypeEnum componentTypeEnum, String oldArtifactId, ArtifactData newArtifact, boolean inTransaction) {
512 StorageOperationStatus result = null;
515 StorageOperationStatus status = this.dissociateAndAssociateGroupsFromArtifactOnGraph(componentId, componentTypeEnum, oldArtifactId, newArtifact);
517 if (status != StorageOperationStatus.OK && status != StorageOperationStatus.NOT_FOUND) {
521 result = StorageOperationStatus.OK;
525 if (!inTransaction) {
526 if (result == null || result != StorageOperationStatus.OK) {
527 log.debug("Going to execute rollback on graph.");
528 BeEcompErrorManager.getInstance().logBeExecuteRollbackError("Rollback on graph");
529 janusGraphGenericDao.rollback();
531 log.debug("Going to execute commit on graph.");
532 janusGraphGenericDao.commit();
538 private Either<List<ImmutablePair<String, String>>, JanusGraphOperationStatus> getGroupArtifactsPairs(String groupUniqueId) {
540 Either<List<ImmutablePair<String, String>>, JanusGraphOperationStatus> result = null;
542 Either<List<ImmutablePair<ArtifactData, GraphEdge>>, JanusGraphOperationStatus> childrenNodes = janusGraphGenericDao
543 .getChildrenNodes(UniqueIdBuilder.getKeyByNodeType(NodeTypeEnum.Group), groupUniqueId, GraphEdgeLabels.GROUP_ARTIFACT_REF,
544 NodeTypeEnum.ArtifactRef, ArtifactData.class);
545 if (childrenNodes.isRight()) {
546 JanusGraphOperationStatus status = childrenNodes.right().value();
547 if (status == JanusGraphOperationStatus.NOT_FOUND) {
548 status = JanusGraphOperationStatus.OK;
550 result = Either.right(status);
554 List<ImmutablePair<String, String>> artifactsList = new ArrayList<>();
555 List<ImmutablePair<ArtifactData, GraphEdge>> list = childrenNodes.left().value();
557 for (ImmutablePair<ArtifactData, GraphEdge> pair : list) {
558 ArtifactData artifactData = pair.getKey();
559 String uniqueId = artifactData.getArtifactDataDefinition().getUniqueId();
560 String UUID = artifactData.getArtifactDataDefinition().getArtifactUUID();
561 ImmutablePair<String, String> artifact = new ImmutablePair<>(uniqueId, UUID);
562 artifactsList.add(artifact);
566 log.debug("The artifacts list related to group {} is {}", groupUniqueId, artifactsList);
567 result = Either.left(artifactsList);
575 public StorageOperationStatus validateAndUpdatePropertyValue(GroupProperty property) {
577 StorageOperationStatus result = null;
578 String innerType = property.getSchema() == null ? null : property.getSchema().getProperty() == null ? null : property.getSchema().getProperty().getType();
579 Either<Map<String, DataTypeDefinition>, JanusGraphOperationStatus> allDataTypes = dataTypeCache.getAll();
580 Either<Object, Boolean> isValid = null;
581 if (allDataTypes.isRight()) {
582 JanusGraphOperationStatus status = allDataTypes.right().value();
583 log.debug("Failed to fetch data types from cache. Status is {}. ", status);
584 result = DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status);
587 isValid = propertyOperation.validateAndUpdatePropertyValue(property.getType(), property.getValue(), innerType, allDataTypes.left().value());
588 if(isValid.isRight()){
589 log.debug("Failed to validate property value {}. Status is {}. ", property.getValue(), StorageOperationStatus.INVALID_PROPERTY);
590 result = StorageOperationStatus.INVALID_PROPERTY;
594 String validValue = String.valueOf(isValid.left().value());
595 property.setValue(validValue);
596 result = StorageOperationStatus.OK;
601 public StorageOperationStatus updateGroupProperties(org.openecomp.sdc.be.model.Component containerComponent, String groupId, List<PropertyDataDefinition> propertiesToUpdate) {
602 log.debug("#updateGroupProperties - updating the properties of group {} in component {}", groupId, containerComponent.getUniqueId());
603 Optional<GroupDefinition> group = containerComponent.getGroupById(groupId);
604 if (group.isPresent()){
605 return janusGraphDao.getVertexById(containerComponent.getUniqueId(), JsonParseFlagEnum.NoParse)
606 .either(containerVertex -> updateGroupProperties(containerVertex, group.get(), propertiesToUpdate),
607 DaoStatusConverter::convertJanusGraphStatusToStorageStatus);
609 throw new StorageException(StorageOperationStatus.NOT_FOUND, groupId);
613 private StorageOperationStatus updateGroupProperties(GraphVertex container, GroupDefinition group, List<PropertyDataDefinition> propertiesToUpdate) {
614 List<PropertyDataDefinition> groupProperties = group.getProperties();
615 List<PropertyDataDefinition> updatedGroupProperties = updateGroupProperties(groupProperties, propertiesToUpdate);
616 group.setProperties(updatedGroupProperties);
617 return topologyTemplateOperation.updateGroupOfToscaElement(container, group);
620 private List<PropertyDataDefinition> updateGroupProperties(List<PropertyDataDefinition> currentGroupProperties, List<PropertyDataDefinition> toBeUpdatedProperties) {
621 Map<String, PropertyDataDefinition> currPropsByName = MapUtil.toMap(currentGroupProperties, PropertyDataDefinition::getName);
622 overrideCurrentPropertiesWithUpdatedProperties(currPropsByName, toBeUpdatedProperties);
623 return new ArrayList<>(currPropsByName.values());
626 private void overrideCurrentPropertiesWithUpdatedProperties(Map<String, PropertyDataDefinition> currPropsByName, List<PropertyDataDefinition> toBeUpdatedProperties) {
627 toBeUpdatedProperties.forEach(prop -> currPropsByName.put(prop.getName(), prop));