2 * Copyright © 2016-2018 European Support Limited
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 package org.openecomp.sdc.be.model.jsontitan.operations;
19 import fj.data.Either;
20 import org.apache.commons.collections.MapUtils;
21 import org.openecomp.sdc.be.dao.jsongraph.GraphVertex;
22 import org.openecomp.sdc.be.dao.jsongraph.types.EdgeLabelEnum;
23 import org.openecomp.sdc.be.dao.jsongraph.types.JsonParseFlagEnum;
24 import org.openecomp.sdc.be.dao.jsongraph.types.VertexTypeEnum;
25 import org.openecomp.sdc.be.datatypes.elements.CapabilityDataDefinition;
26 import org.openecomp.sdc.be.datatypes.elements.ListCapabilityDataDefinition;
27 import org.openecomp.sdc.be.datatypes.elements.MapPropertiesDataDefinition;
28 import org.openecomp.sdc.be.datatypes.elements.PropertyDataDefinition;
29 import org.openecomp.sdc.be.datatypes.enums.JsonPresentationFields;
30 import org.openecomp.sdc.be.datatypes.tosca.ToscaDataDefinition;
31 import org.openecomp.sdc.be.model.CapabilityDefinition;
32 import org.openecomp.sdc.be.model.Component;
33 import org.openecomp.sdc.be.model.ComponentParametersView;
34 import org.openecomp.sdc.be.model.jsontitan.datamodel.TopologyTemplate;
35 import org.openecomp.sdc.be.model.jsontitan.datamodel.ToscaElement;
36 import org.openecomp.sdc.be.model.operations.StorageException;
37 import org.openecomp.sdc.be.model.operations.api.StorageOperationStatus;
38 import org.slf4j.Logger;
39 import org.slf4j.LoggerFactory;
41 import java.util.ArrayList;
42 import java.util.Collections;
43 import java.util.List;
46 @org.springframework.stereotype.Component("capabilities-operation")
47 public class CapabilitiesOperation extends BaseOperation {
48 private static final Logger LOGGER = LoggerFactory.getLogger(CapabilitiesOperation.class);
50 public Either<List<CapabilityDefinition>, StorageOperationStatus> addCapabilities(String componentId,
51 List<CapabilityDefinition> capabilityDefinitions) {
52 return addOrUpdateCapabilities(componentId, capabilityDefinitions, false);
55 public Either<List<CapabilityDefinition>, StorageOperationStatus> updateCapabilities(String componentId,
56 List<CapabilityDefinition> capabilityDefinitions) {
57 return addOrUpdateCapabilities(componentId, capabilityDefinitions, true);
60 private Either<List<CapabilityDefinition>, StorageOperationStatus> addOrUpdateCapabilities(String componentId,
61 List<CapabilityDefinition> capabilityDefinitions,
62 boolean isUpdateAction) {
63 StorageOperationStatus statusRes = performUpdateToscaAction(isUpdateAction,
64 componentId, Collections.singletonList(convertToListCapabilityDataDefinition(capabilityDefinitions)));
65 if (!statusRes.equals(StorageOperationStatus.OK)) {
66 LOGGER.error("Failed to find the parent capability of capability type {}." + " status is {}", componentId,
68 return Either.right(statusRes);
70 return Either.left(capabilityDefinitions);
73 public StorageOperationStatus deleteCapabilities(Component component, String capabilityIdToDelete) {
74 return deleteToscaDataElements(component.getUniqueId(), EdgeLabelEnum.CAPABILITIES,
75 Collections.singletonList(capabilityIdToDelete));
78 public StorageOperationStatus deleteCapabilityProperties(Component component, String capabilityPropIdToDelete) {
79 return deleteToscaDataElements(component.getUniqueId(), EdgeLabelEnum.CAPABILITIES_PROPERTIES,
80 Collections.singletonList(capabilityPropIdToDelete));
83 private static ListCapabilityDataDefinition convertToListCapabilityDataDefinition(List<CapabilityDefinition> capabilities) {
84 List<CapabilityDataDefinition> capabilityDefinitions = new ArrayList<>(capabilities);
85 return new ListCapabilityDataDefinition(capabilityDefinitions);
88 private StorageOperationStatus performUpdateToscaAction(boolean isUpdate, String componentId,
89 List<ListCapabilityDataDefinition> toscaDataList) {
91 return updateToscaDataOfToscaElement(componentId, EdgeLabelEnum.CAPABILITIES,
92 VertexTypeEnum.CAPABILITIES, toscaDataList, JsonPresentationFields.TYPE);
94 return addToscaDataToToscaElement(componentId, EdgeLabelEnum.CAPABILITIES,
95 VertexTypeEnum.CAPABILITIES, toscaDataList, JsonPresentationFields.TYPE);
99 private StorageOperationStatus createOrUpdateCapabilityProperties(String componentId, TopologyTemplate toscaElement,
100 Map<String, MapPropertiesDataDefinition> propertiesMap) {
101 GraphVertex toscaElementV = titanDao.getVertexById(componentId, JsonParseFlagEnum.NoParse)
102 .left().on(this::throwStorageException);
103 Map<String, MapPropertiesDataDefinition> capabilitiesProperties = toscaElement.getCapabilitiesProperties();
104 if(MapUtils.isNotEmpty(capabilitiesProperties)) {
106 capabilitiesProperties.forEach((key, val) -> {
107 Map<String, PropertyDataDefinition> mapToscaDataDefinition = val.getMapToscaDataDefinition();
108 mapToscaDataDefinition.forEach((key1, val1) -> {
110 propertiesMap.forEach((propKey, propVal) -> {
111 Map<String, PropertyDataDefinition> propValMapToscaDataDefinition = propVal.getMapToscaDataDefinition();
112 propValMapToscaDataDefinition.forEach((propKey1, propVal1) -> {
113 if(propKey1.equals(key1) && val1.getUniqueId().equals(propVal1.getUniqueId())) {
114 ToscaDataDefinition.mergeDataMaps(mapToscaDataDefinition, propValMapToscaDataDefinition);
121 ToscaDataDefinition.mergeDataMaps(propertiesMap, capabilitiesProperties);
124 return topologyTemplateOperation.updateFullToscaData(toscaElementV,
125 EdgeLabelEnum.CAPABILITIES_PROPERTIES, VertexTypeEnum.CAPABILITIES_PROPERTIES, propertiesMap);
128 public StorageOperationStatus createOrUpdateCapabilityProperties(String componentId,
129 Map<String, MapPropertiesDataDefinition> propertiesMap) {
130 StorageOperationStatus propertiesStatusRes = null;
131 if(MapUtils.isNotEmpty(propertiesMap)) {
132 propertiesStatusRes = createOrUpdateCapabilityProperties(componentId, getTopologyTemplate(componentId),
136 return propertiesStatusRes;
139 private TopologyTemplate getTopologyTemplate(String componentId) {
140 return (TopologyTemplate)topologyTemplateOperation
141 .getToscaElement(componentId, getFilterComponentWithCapProperties())
143 .on(this::throwStorageException);
145 private ComponentParametersView getFilterComponentWithCapProperties() {
146 ComponentParametersView filter = new ComponentParametersView();
147 filter.setIgnoreCapabiltyProperties(false);
151 private ToscaElement throwStorageException(StorageOperationStatus status) {
152 throw new StorageException(status);