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=========================================================
20 package org.openecomp.sdc.be.model.jsonjanusgraph.operations;
22 import static java.util.Objects.requireNonNull;
23 import static org.apache.commons.collections.CollectionUtils.isEmpty;
24 import static org.apache.commons.collections.CollectionUtils.isNotEmpty;
25 import static org.janusgraph.core.attribute.Text.REGEX;
27 import com.vdurmont.semver4j.Semver;
28 import com.vdurmont.semver4j.Semver.SemverType;
29 import fj.data.Either;
30 import java.util.ArrayList;
31 import java.util.Arrays;
32 import java.util.Collection;
33 import java.util.Collections;
34 import java.util.EnumMap;
35 import java.util.HashMap;
36 import java.util.HashSet;
37 import java.util.Iterator;
38 import java.util.LinkedList;
39 import java.util.List;
41 import java.util.Map.Entry;
42 import java.util.Objects;
43 import java.util.Optional;
45 import java.util.function.BiPredicate;
46 import java.util.function.Predicate;
47 import java.util.stream.Collectors;
48 import java.util.stream.StreamSupport;
49 import org.apache.commons.collections.CollectionUtils;
50 import org.apache.commons.collections.MapUtils;
51 import org.apache.commons.lang3.StringUtils;
52 import org.apache.commons.lang3.tuple.ImmutablePair;
53 import org.apache.tinkerpop.gremlin.structure.Direction;
54 import org.apache.tinkerpop.gremlin.structure.Edge;
55 import org.janusgraph.graphdb.query.JanusGraphPredicate;
56 import org.openecomp.sdc.be.config.Configuration;
57 import org.openecomp.sdc.be.config.ConfigurationManager;
58 import org.openecomp.sdc.be.dao.janusgraph.JanusGraphOperationStatus;
59 import org.openecomp.sdc.be.dao.jsongraph.GraphVertex;
60 import org.openecomp.sdc.be.dao.janusgraph.HealingJanusGraphDao;
61 import org.openecomp.sdc.be.dao.jsongraph.types.EdgeLabelEnum;
62 import org.openecomp.sdc.be.dao.jsongraph.types.JsonParseFlagEnum;
63 import org.openecomp.sdc.be.dao.jsongraph.types.VertexTypeEnum;
64 import org.openecomp.sdc.be.datatypes.elements.ArtifactDataDefinition;
65 import org.openecomp.sdc.be.datatypes.elements.AttributeDataDefinition;
66 import org.openecomp.sdc.be.datatypes.elements.CapabilityDataDefinition;
67 import org.openecomp.sdc.be.datatypes.elements.ComponentInstanceDataDefinition;
68 import org.openecomp.sdc.be.datatypes.elements.DataTypeDataDefinition;
69 import org.openecomp.sdc.be.datatypes.elements.GroupDataDefinition;
70 import org.openecomp.sdc.be.datatypes.elements.ListCapabilityDataDefinition;
71 import org.openecomp.sdc.be.datatypes.elements.ListRequirementDataDefinition;
72 import org.openecomp.sdc.be.datatypes.elements.MapArtifactDataDefinition;
73 import org.openecomp.sdc.be.datatypes.elements.MapAttributesDataDefinition;
74 import org.openecomp.sdc.be.datatypes.elements.MapCapabilityProperty;
75 import org.openecomp.sdc.be.datatypes.elements.MapInterfaceDataDefinition;
76 import org.openecomp.sdc.be.datatypes.elements.MapListCapabilityDataDefinition;
77 import org.openecomp.sdc.be.datatypes.elements.MapListRequirementDataDefinition;
78 import org.openecomp.sdc.be.datatypes.elements.MapPropertiesDataDefinition;
79 import org.openecomp.sdc.be.datatypes.elements.PropertyDataDefinition;
80 import org.openecomp.sdc.be.datatypes.elements.RequirementDataDefinition;
81 import org.openecomp.sdc.be.datatypes.enums.ComponentTypeEnum;
82 import org.openecomp.sdc.be.datatypes.enums.GraphPropertyEnum;
83 import org.openecomp.sdc.be.datatypes.enums.JsonPresentationFields;
84 import org.openecomp.sdc.be.datatypes.enums.OriginTypeEnum;
85 import org.openecomp.sdc.be.datatypes.enums.PromoteVersionEnum;
86 import org.openecomp.sdc.be.datatypes.enums.ResourceTypeEnum;
87 import org.openecomp.sdc.be.model.ArtifactDefinition;
88 import org.openecomp.sdc.be.model.AttributeDefinition;
89 import org.openecomp.sdc.be.model.CapabilityDefinition;
90 import org.openecomp.sdc.be.model.CatalogUpdateTimestamp;
91 import org.openecomp.sdc.be.model.Component;
92 import org.openecomp.sdc.be.model.ComponentInstance;
93 import org.openecomp.sdc.be.model.ComponentInstanceAttribute;
94 import org.openecomp.sdc.be.model.ComponentInstanceInput;
95 import org.openecomp.sdc.be.model.ComponentInstanceInterface;
96 import org.openecomp.sdc.be.model.ComponentInstanceOutput;
97 import org.openecomp.sdc.be.model.ComponentInstanceProperty;
98 import org.openecomp.sdc.be.model.ComponentParametersView;
99 import org.openecomp.sdc.be.model.DataTypeDefinition;
100 import org.openecomp.sdc.be.model.DistributionStatusEnum;
101 import org.openecomp.sdc.be.model.GroupDefinition;
102 import org.openecomp.sdc.be.model.GroupInstance;
103 import org.openecomp.sdc.be.model.InputDefinition;
104 import org.openecomp.sdc.be.model.LifecycleStateEnum;
105 import org.openecomp.sdc.be.model.OutputDefinition;
106 import org.openecomp.sdc.be.model.PolicyDefinition;
107 import org.openecomp.sdc.be.model.PropertyDefinition;
108 import org.openecomp.sdc.be.model.RelationshipInfo;
109 import org.openecomp.sdc.be.model.RequirementCapabilityRelDef;
110 import org.openecomp.sdc.be.model.RequirementDefinition;
111 import org.openecomp.sdc.be.model.Resource;
112 import org.openecomp.sdc.be.model.Service;
113 import org.openecomp.sdc.be.model.User;
114 import org.openecomp.sdc.be.model.catalog.CatalogComponent;
115 import org.openecomp.sdc.be.model.jsonjanusgraph.config.ContainerInstanceTypesData;
116 import org.openecomp.sdc.be.model.jsonjanusgraph.datamodel.TopologyTemplate;
117 import org.openecomp.sdc.be.model.jsonjanusgraph.datamodel.ToscaElement;
118 import org.openecomp.sdc.be.model.jsonjanusgraph.utils.ModelConverter;
119 import org.openecomp.sdc.be.model.operations.StorageException;
120 import org.openecomp.sdc.be.model.operations.api.StorageOperationStatus;
121 import org.openecomp.sdc.be.model.operations.impl.DaoStatusConverter;
122 import org.openecomp.sdc.be.model.operations.impl.UniqueIdBuilder;
123 import org.openecomp.sdc.be.model.utils.GroupUtils;
124 import org.openecomp.sdc.be.resources.data.ComponentMetadataData;
125 import org.openecomp.sdc.common.jsongraph.util.CommonUtility;
126 import org.openecomp.sdc.common.jsongraph.util.CommonUtility.LogLevelEnum;
127 import org.openecomp.sdc.common.log.wrappers.Logger;
128 import org.openecomp.sdc.common.util.ValidationUtils;
129 import org.springframework.beans.factory.annotation.Autowired;
131 @org.springframework.stereotype.Component("tosca-operation-facade")
132 public class ToscaOperationFacade {
134 // region - ToscaElement - GetById
135 public static final String PROXY_SUFFIX = "_proxy";
137 private static final String COULDNT_FETCH_A_COMPONENT_WITH_AND_UNIQUE_ID_ERROR = "Couldn't fetch a component with and UniqueId {}, error: {}";
138 private static final String FAILED_TO_FIND_RECENTLY_ADDED_PROPERTY_ON_THE_RESOURCE_STATUS_IS = "Failed to find recently added property {} on the resource {}. Status is {}. ";
139 private static final String FAILED_TO_GET_UPDATED_RESOURCE_STATUS_IS = "Failed to get updated resource {}. Status is {}. ";
140 private static final String FAILED_TO_ADD_THE_PROPERTY_TO_THE_RESOURCE_STATUS_IS = "Failed to add the property {} to the resource {}. Status is {}. ";
141 private static final String SERVICE = "service";
142 private static final String NOT_SUPPORTED_COMPONENT_TYPE = "Not supported component type {}";
143 private static final String COMPONENT_CREATED_SUCCESSFULLY = "Component created successfully!!!";
144 private static final String COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR = "Couldn't fetch component with and unique id {}, error: {}";
145 private static final Logger log = Logger.getLogger(ToscaOperationFacade.class.getName());
147 private NodeTypeOperation nodeTypeOperation;
149 private TopologyTemplateOperation topologyTemplateOperation;
151 private NodeTemplateOperation nodeTemplateOperation;
153 private GroupsOperation groupsOperation;
155 private HealingJanusGraphDao janusGraphDao;
158 private ContainerInstanceTypesData containerInstanceTypesData;
160 private static Optional<CapabilityDefinition> getPropertyCapability(String propertyParentUniqueId, Component containerComponent) {
161 Map<String, List<CapabilityDefinition>> componentCapabilities = containerComponent.getCapabilities();
162 if (MapUtils.isEmpty(componentCapabilities)) {
163 return Optional.empty();
165 List<CapabilityDefinition> capabilityDefinitionList = componentCapabilities.values().stream().flatMap(Collection::stream)
166 .collect(Collectors.toList());
167 if (CollectionUtils.isEmpty(capabilityDefinitionList)) {
168 return Optional.empty();
170 return capabilityDefinitionList.stream().filter(capabilityDefinition -> capabilityDefinition.getUniqueId().equals(propertyParentUniqueId))
174 public <T extends Component> Either<T, StorageOperationStatus> getToscaFullElement(String componentId) {
175 ComponentParametersView filters = new ComponentParametersView();
176 filters.setIgnoreCapabiltyProperties(false);
177 filters.setIgnoreServicePath(false);
178 return getToscaElement(componentId, filters);
181 public <T extends Component> Either<T, StorageOperationStatus> getToscaElement(String componentId) {
182 return getToscaElement(componentId, JsonParseFlagEnum.ParseAll);
185 public <T extends Component> Either<T, StorageOperationStatus> getToscaElement(String componentId, ComponentParametersView filters) {
186 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, filters.detectParseFlag());
187 if (getVertexEither.isRight()) {
188 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
189 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
191 return getToscaElementByOperation(getVertexEither.left().value(), filters);
194 public <T extends Component> Either<T, StorageOperationStatus> getToscaElement(String componentId, JsonParseFlagEnum parseFlag) {
195 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, parseFlag);
196 if (getVertexEither.isRight()) {
197 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
198 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
200 return getToscaElementByOperation(getVertexEither.left().value());
203 public <T extends Component> Either<T, StorageOperationStatus> getToscaElement(GraphVertex componentVertex) {
204 return getToscaElementByOperation(componentVertex);
207 public Either<Boolean, StorageOperationStatus> validateComponentExists(String componentId) {
208 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
209 if (getVertexEither.isRight()) {
210 JanusGraphOperationStatus status = getVertexEither.right().value();
211 if (status == JanusGraphOperationStatus.NOT_FOUND) {
212 return Either.left(false);
214 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
215 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
218 return Either.left(true);
222 public <T extends Component> Either<T, StorageOperationStatus> findLastCertifiedToscaElementByUUID(T component) {
223 Map<GraphPropertyEnum, Object> props = new EnumMap<>(GraphPropertyEnum.class);
224 props.put(GraphPropertyEnum.UUID, component.getUUID());
225 props.put(GraphPropertyEnum.STATE, LifecycleStateEnum.CERTIFIED.name());
226 props.put(GraphPropertyEnum.IS_HIGHEST_VERSION, true);
227 Either<List<GraphVertex>, JanusGraphOperationStatus> getVertexEither = janusGraphDao
228 .getByCriteria(ModelConverter.getVertexType(component), props);
229 if (getVertexEither.isRight()) {
230 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, component.getUniqueId(), getVertexEither.right().value());
231 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
233 return getToscaElementByOperation(getVertexEither.left().value().get(0));
236 // region - ToscaElement - GetByOperation
237 private <T extends Component> Either<T, StorageOperationStatus> getToscaElementByOperation(GraphVertex componentV) {
238 return getToscaElementByOperation(componentV, new ComponentParametersView());
241 private <T extends Component> Either<T, StorageOperationStatus> getToscaElementByOperation(GraphVertex componentV,
242 ComponentParametersView filters) {
243 if (componentV == null) {
244 log.debug("Unexpected null value for `componentV`");
245 return Either.right(StorageOperationStatus.GENERAL_ERROR);
247 VertexTypeEnum label = componentV.getLabel();
248 ToscaElementOperation toscaOperation = getToscaElementOperation(componentV);
249 if (toscaOperation != null) {
250 log.debug("getToscaElementByOperation: toscaOperation={}", toscaOperation.getClass());
252 Either<ToscaElement, StorageOperationStatus> toscaElement;
253 String componentId = componentV.getUniqueId();
254 if (toscaOperation != null) {
255 log.debug("Need to fetch tosca element for id {}", componentId);
256 toscaElement = toscaOperation.getToscaElement(componentV, filters);
258 log.debug("not supported tosca type {} for id {}", label, componentId);
259 toscaElement = Either.right(StorageOperationStatus.BAD_REQUEST);
261 return toscaElement.left().map(ModelConverter::convertFromToscaElement);
266 private ToscaElementOperation getToscaElementOperation(GraphVertex componentV) {
267 VertexTypeEnum label = componentV.getLabel();
270 return nodeTypeOperation;
271 case TOPOLOGY_TEMPLATE:
272 return topologyTemplateOperation;
278 public <T extends Component> Either<T, StorageOperationStatus> createToscaComponent(T resource) {
279 ToscaElement toscaElement = ModelConverter.convertToToscaElement(resource);
280 ToscaElementOperation toscaElementOperation = getToscaElementOperation(resource);
281 Either<ToscaElement, StorageOperationStatus> createToscaElement = toscaElementOperation.createToscaElement(toscaElement);
282 if (createToscaElement.isLeft()) {
283 log.debug(COMPONENT_CREATED_SUCCESSFULLY);
284 T dataModel = ModelConverter.convertFromToscaElement(createToscaElement.left().value());
285 return Either.left(dataModel);
287 return Either.right(createToscaElement.right().value());
290 // region - ToscaElement Delete
291 public StorageOperationStatus markComponentToDelete(Component componentToDelete) {
292 if (Boolean.TRUE.equals(componentToDelete.getIsDeleted()) && Boolean.FALSE.equals(componentToDelete.isHighestVersion())) {
293 // component already marked for delete
294 return StorageOperationStatus.OK;
296 Either<GraphVertex, JanusGraphOperationStatus> getResponse = janusGraphDao
297 .getVertexById(componentToDelete.getUniqueId(), JsonParseFlagEnum.ParseAll);
298 if (getResponse.isRight()) {
299 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentToDelete.getUniqueId(), getResponse.right().value());
300 return DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getResponse.right().value());
302 GraphVertex componentV = getResponse.left().value();
303 // same operation for node type and topology template operations
304 Either<GraphVertex, StorageOperationStatus> result = nodeTypeOperation.markComponentToDelete(componentV);
305 if (result.isRight()) {
306 return result.right().value();
308 return StorageOperationStatus.OK;
312 public <T extends Component> Either<T, StorageOperationStatus> deleteToscaComponent(String componentId) {
313 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.ParseAll);
314 if (getVertexEither.isRight()) {
315 log.debug("Couldn't fetch component vertex with and unique id {}, error: {}", componentId, getVertexEither.right().value());
316 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
318 Either<ToscaElement, StorageOperationStatus> deleteElement = deleteToscaElement(getVertexEither.left().value());
319 if (deleteElement.isRight()) {
320 log.debug("Failed to delete component with and unique id {}, error: {}", componentId, deleteElement.right().value());
321 return Either.right(deleteElement.right().value());
323 T dataModel = ModelConverter.convertFromToscaElement(deleteElement.left().value());
324 return Either.left(dataModel);
327 private Either<ToscaElement, StorageOperationStatus> deleteToscaElement(GraphVertex componentV) {
328 VertexTypeEnum label = componentV.getLabel();
329 Either<ToscaElement, StorageOperationStatus> toscaElement;
330 Object componentId = componentV.getUniqueId();
333 log.debug("Need to fetch node type for id {}", componentId);
334 toscaElement = nodeTypeOperation.deleteToscaElement(componentV);
336 case TOPOLOGY_TEMPLATE:
337 log.debug("Need to fetch topology template for id {}", componentId);
338 toscaElement = topologyTemplateOperation.deleteToscaElement(componentV);
341 log.debug("not supported tosca type {} for id {}", label, componentId);
342 toscaElement = Either.right(StorageOperationStatus.BAD_REQUEST);
349 private ToscaElementOperation getToscaElementOperation(Component component) {
350 return ModelConverter.isAtomicComponent(component) ? nodeTypeOperation : topologyTemplateOperation;
353 public <T extends Component> Either<T, StorageOperationStatus> getLatestByToscaResourceNameAndModel(final String toscaResourceName,
354 final String model) {
355 return getLatestByNameAndModel(toscaResourceName, JsonParseFlagEnum.ParseMetadata, new ComponentParametersView(), model);
358 private <T extends Component> Either<T, StorageOperationStatus> getLatestByNameAndModel(final String nodeName,
359 final JsonParseFlagEnum parseFlag,
360 final ComponentParametersView filter,
361 final String model) {
362 Either<T, StorageOperationStatus> result;
363 final Map<GraphPropertyEnum, Object> propertiesToMatch = new EnumMap<>(GraphPropertyEnum.class);
364 final Map<GraphPropertyEnum, Object> propertiesNotToMatch = new EnumMap<>(GraphPropertyEnum.class);
365 propertiesToMatch.put(GraphPropertyEnum.TOSCA_RESOURCE_NAME, nodeName);
366 propertiesToMatch.put(GraphPropertyEnum.IS_HIGHEST_VERSION, true);
367 propertiesNotToMatch.put(GraphPropertyEnum.IS_DELETED, true);
368 final Either<List<GraphVertex>, JanusGraphOperationStatus> highestResources = janusGraphDao
369 .getByCriteria(null, propertiesToMatch, propertiesNotToMatch, parseFlag, model);
370 if (highestResources.isRight()) {
371 final JanusGraphOperationStatus status = highestResources.right().value();
372 log.debug("failed to find resource with name {}. status={} ", nodeName, status);
373 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status));
376 final List<GraphVertex> resources = highestResources.left().value();
377 double version = 0.0;
378 GraphVertex highestResource = null;
379 for (final GraphVertex vertex : resources) {
380 final Object versionObj = vertex.getMetadataProperty(GraphPropertyEnum.VERSION);
381 double resourceVersion = Double.parseDouble((String) versionObj);
382 if (resourceVersion > version) {
383 version = resourceVersion;
384 highestResource = vertex;
387 return getToscaElementByOperation(highestResource, filter);
390 public <T extends Component> Either<T, StorageOperationStatus> getLatestByToscaResourceName(String toscaResourceName, String modelName) {
391 return getLatestByName(GraphPropertyEnum.TOSCA_RESOURCE_NAME, toscaResourceName, modelName);
394 public <T extends Component> Either<T, StorageOperationStatus> getFullLatestComponentByToscaResourceName(String toscaResourceName) {
395 ComponentParametersView fetchAllFilter = new ComponentParametersView();
396 fetchAllFilter.setIgnoreServicePath(true);
397 fetchAllFilter.setIgnoreCapabiltyProperties(false);
398 return getLatestByName(GraphPropertyEnum.TOSCA_RESOURCE_NAME, toscaResourceName, JsonParseFlagEnum.ParseAll, fetchAllFilter, null);
401 public <T extends Component> Either<T, StorageOperationStatus> getLatestByName(String resourceName, String modelName) {
402 return getLatestByName(GraphPropertyEnum.NAME, resourceName, modelName);
405 public StorageOperationStatus validateCsarUuidUniqueness(String csarUUID) {
406 Map<GraphPropertyEnum, Object> properties = new EnumMap<>(GraphPropertyEnum.class);
407 properties.put(GraphPropertyEnum.CSAR_UUID, csarUUID);
408 Either<List<GraphVertex>, JanusGraphOperationStatus> resources = janusGraphDao
409 .getByCriteria(null, properties, JsonParseFlagEnum.ParseMetadata);
410 if (resources.isRight()) {
411 if (resources.right().value() == JanusGraphOperationStatus.NOT_FOUND) {
412 return StorageOperationStatus.OK;
414 log.debug("failed to get resources from graph with property name: {}", csarUUID);
415 return DaoStatusConverter.convertJanusGraphStatusToStorageStatus(resources.right().value());
418 return StorageOperationStatus.ENTITY_ALREADY_EXISTS;
421 public <T extends Component> Either<Set<T>, StorageOperationStatus> getFollowed(String userId, Set<LifecycleStateEnum> lifecycleStates,
422 Set<LifecycleStateEnum> lastStateStates,
423 ComponentTypeEnum componentType) {
424 Either<List<ToscaElement>, StorageOperationStatus> followedResources;
425 if (componentType == ComponentTypeEnum.RESOURCE) {
426 followedResources = nodeTypeOperation.getFollowedComponent(userId, lifecycleStates, lastStateStates, componentType);
428 followedResources = topologyTemplateOperation.getFollowedComponent(userId, lifecycleStates, lastStateStates, componentType);
430 Set<T> components = new HashSet<>();
431 if (followedResources.isRight() && followedResources.right().value() != StorageOperationStatus.NOT_FOUND) {
432 return Either.right(followedResources.right().value());
434 if (followedResources.isLeft()) {
435 List<ToscaElement> toscaElements = followedResources.left().value();
436 toscaElements.forEach(te -> {
437 T component = ModelConverter.convertFromToscaElement(te);
438 components.add(component);
441 return Either.left(components);
444 public Either<Resource, StorageOperationStatus> getLatestCertifiedNodeTypeByToscaResourceName(String toscaResourceName) {
445 return getLatestCertifiedByToscaResourceName(toscaResourceName, VertexTypeEnum.NODE_TYPE, JsonParseFlagEnum.ParseMetadata);
448 public Either<Resource, StorageOperationStatus> getByToscaResourceNameMatchingVendorRelease(final String toscaResourceName,
449 final String vendorVersion) {
450 return getByToscaResourceNameMatchingVendorRelease(toscaResourceName, VertexTypeEnum.NODE_TYPE, JsonParseFlagEnum.ParseMetadata,
454 public Either<Resource, StorageOperationStatus> getByToscaResourceNameMatchingVendorRelease(String toscaResourceName, VertexTypeEnum vertexType,
455 JsonParseFlagEnum parseFlag, String vendorRelease) {
456 Map<GraphPropertyEnum, Object> props = new EnumMap<>(GraphPropertyEnum.class);
457 props.put(GraphPropertyEnum.TOSCA_RESOURCE_NAME, toscaResourceName);
458 props.put(GraphPropertyEnum.STATE, LifecycleStateEnum.CERTIFIED.name());
459 Map<String, Entry<JanusGraphPredicate, Object>> predicateCriteria = getVendorVersionPredicate(vendorRelease);
460 Either<List<GraphVertex>, JanusGraphOperationStatus> getLatestRes = janusGraphDao
461 .getByCriteria(vertexType, props, null, predicateCriteria, parseFlag, null);
462 if (getLatestRes.isRight() || CollectionUtils.isEmpty(getLatestRes.left().value())) {
463 getLatestRes = janusGraphDao.getByCriteria(vertexType, props, parseFlag);
465 return getLatestRes.right().map(status -> {
467 .addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to fetch {} with name {}. status={} ", vertexType, toscaResourceName, status);
468 return DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status);
469 }).left().bind(resources -> {
470 double version = 0.0;
471 GraphVertex highestResource = null;
472 for (GraphVertex resource : resources) {
473 double resourceVersion = Double.parseDouble((String) resource.getJsonMetadataField(JsonPresentationFields.VERSION));
474 if (resourceVersion > version && isValidForVendorRelease(resource, vendorRelease)) {
475 version = resourceVersion;
476 highestResource = resource;
479 if (highestResource != null) {
480 return getToscaFullElement(highestResource.getUniqueId());
482 log.debug("The vertex with the highest version could not be found for {}", toscaResourceName);
483 return Either.right(StorageOperationStatus.GENERAL_ERROR);
488 public <T extends Component> Either<T, StorageOperationStatus> getByToscaResourceNameAndVersion(final String toscaResourceName, final String version, final String model) {
489 Either<T, StorageOperationStatus> result;
491 Map<GraphPropertyEnum, Object> hasProperties = new EnumMap<>(GraphPropertyEnum.class);
492 Map<GraphPropertyEnum, Object> hasNotProperties = new EnumMap<>(GraphPropertyEnum.class);
494 hasProperties.put(GraphPropertyEnum.TOSCA_RESOURCE_NAME, toscaResourceName);
495 hasProperties.put(GraphPropertyEnum.VERSION, version);
496 hasNotProperties.put(GraphPropertyEnum.IS_DELETED, true);
498 Either<List<GraphVertex>, JanusGraphOperationStatus> getResourceRes = janusGraphDao
499 .getByCriteria(VertexTypeEnum.NODE_TYPE, hasProperties, hasNotProperties, JsonParseFlagEnum.ParseAll, model);
500 if (getResourceRes.isRight()) {
501 JanusGraphOperationStatus status = getResourceRes.right().value();
502 log.debug("failed to find resource with toscaResourceName {}, version {}. Status is {} ", toscaResourceName, version, status);
503 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status));
506 return getToscaElementByOperation(getResourceRes.left().value().get(0));
509 private Map<String, Entry<JanusGraphPredicate, Object>> getVendorVersionPredicate(final String vendorRelease) {
510 Map<String, Entry<JanusGraphPredicate, Object>> predicateCriteria = new HashMap<>();
511 if (!"1.0".equals(vendorRelease)) {
512 String[] vendorReleaseElements = vendorRelease.split("\\.");
513 if (vendorReleaseElements.length > 0) {
514 String regex = ".*\"vendorRelease\":\"";
515 for (int i = 0; i < vendorReleaseElements.length; i++) {
516 regex += vendorReleaseElements[i];
517 regex += i < vendorReleaseElements.length - 1 ? "\\." : "\".*";
519 predicateCriteria.put("metadata", new HashMap.SimpleEntry<>(REGEX, regex));
522 return predicateCriteria;
525 public boolean isNodeAssociatedToModel(final String model, final Resource resource) {
526 final List<GraphVertex> modelElementVertices = getResourceModelElementVertices(resource);
528 return modelElementVertices.isEmpty();
530 return modelElementVertices.stream().anyMatch(graphVertex -> graphVertex.getMetadataProperty(GraphPropertyEnum.NAME).equals(model));
533 public List<GraphVertex> getResourceModelElementVertices(final Resource resource) {
534 final Either<GraphVertex, JanusGraphOperationStatus> vertex =
535 janusGraphDao.getVertexById(resource.getUniqueId(), JsonParseFlagEnum.NoParse);
536 if (vertex.isRight() || Objects.isNull(vertex.left().value())) {
537 return Collections.emptyList();
539 final Either<List<GraphVertex>, JanusGraphOperationStatus> nodeModelVertices =
540 janusGraphDao.getParentVertices(vertex.left().value(), EdgeLabelEnum.MODEL_ELEMENT, JsonParseFlagEnum.NoParse);
541 if (nodeModelVertices.isRight() || nodeModelVertices.left().value() == null) {
542 return Collections.emptyList();
544 return nodeModelVertices.left().value();
547 private boolean isValidForVendorRelease(final GraphVertex resource, final String vendorRelease) {
548 if (!vendorRelease.equals("1.0")) {
550 Semver resourceSemVer = new Semver((String) resource.getJsonMetadataField(JsonPresentationFields.VENDOR_RELEASE), SemverType.NPM);
551 Semver packageSemVer = new Semver(vendorRelease, SemverType.NPM);
552 return !resourceSemVer.isGreaterThan(packageSemVer);
553 } catch (Exception exception) {
554 log.debug("Error in comparing vendor release", exception);
561 public Either<Resource, StorageOperationStatus> getLatestCertifiedByToscaResourceName(String toscaResourceName, VertexTypeEnum vertexType,
562 JsonParseFlagEnum parseFlag) {
563 Map<GraphPropertyEnum, Object> props = new EnumMap<>(GraphPropertyEnum.class);
564 props.put(GraphPropertyEnum.TOSCA_RESOURCE_NAME, toscaResourceName);
565 props.put(GraphPropertyEnum.IS_HIGHEST_VERSION, true);
566 props.put(GraphPropertyEnum.STATE, LifecycleStateEnum.CERTIFIED.name());
567 Either<List<GraphVertex>, JanusGraphOperationStatus> getLatestRes = janusGraphDao.getByCriteria(vertexType, props, parseFlag);
568 return getLatestRes.right().map(status -> {
570 .addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to fetch {} with name {}. status={} ", vertexType, toscaResourceName, status);
571 return DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status);
572 }).left().bind(resources -> {
573 double version = 0.0;
574 GraphVertex highestResource = null;
575 for (GraphVertex resource : resources) {
576 double resourceVersion = Double.parseDouble((String) resource.getJsonMetadataField(JsonPresentationFields.VERSION));
577 if (resourceVersion > version) {
578 version = resourceVersion;
579 highestResource = resource;
582 if (highestResource != null) {
583 return getToscaFullElement(highestResource.getUniqueId());
585 log.debug("The vertex with the highest version could not be found for {}", toscaResourceName);
586 return Either.right(StorageOperationStatus.GENERAL_ERROR);
591 public Either<Resource, StorageOperationStatus> getLatestResourceByToscaResourceName(String toscaResourceName) {
592 if (toscaResourceName != null && toscaResourceName.contains("org.openecomp.resource.vf")) {
593 return getLatestResourceByToscaResourceName(toscaResourceName, VertexTypeEnum.TOPOLOGY_TEMPLATE, JsonParseFlagEnum.ParseMetadata);
595 return getLatestResourceByToscaResourceName(toscaResourceName, VertexTypeEnum.NODE_TYPE, JsonParseFlagEnum.ParseMetadata);
599 public Either<Resource, StorageOperationStatus> getLatestResourceByToscaResourceName(String toscaResourceName, VertexTypeEnum vertexType,
600 JsonParseFlagEnum parseFlag) {
601 Either<Resource, StorageOperationStatus> result = null;
602 Map<GraphPropertyEnum, Object> props = new EnumMap<>(GraphPropertyEnum.class);
603 props.put(GraphPropertyEnum.TOSCA_RESOURCE_NAME, toscaResourceName);
604 props.put(GraphPropertyEnum.IS_HIGHEST_VERSION, true);
605 if (!toscaResourceName.contains("org.openecomp.resource.vf")) {
606 props.put(GraphPropertyEnum.STATE, LifecycleStateEnum.CERTIFIED.name());
608 Either<List<GraphVertex>, JanusGraphOperationStatus> getLatestRes = janusGraphDao.getByCriteria(vertexType, props, parseFlag);
609 if (getLatestRes.isRight()) {
610 JanusGraphOperationStatus status = getLatestRes.right().value();
612 .addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to fetch {} with name {}. status={} ", vertexType, toscaResourceName, status);
613 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status));
615 if (result == null) {
616 List<GraphVertex> resources = getLatestRes.left().value();
617 double version = 0.0;
618 GraphVertex highestResource = null;
619 for (GraphVertex resource : resources) {
620 double resourceVersion = Double.parseDouble((String) resource.getJsonMetadataField(JsonPresentationFields.VERSION));
621 if (resourceVersion > version) {
622 version = resourceVersion;
623 highestResource = resource;
626 if (highestResource != null) {
627 result = getToscaFullElement(highestResource.getUniqueId());
629 log.debug("The vertex with the highest version could not be found for {}", toscaResourceName);
630 result = Either.right(StorageOperationStatus.GENERAL_ERROR);
636 public Either<Boolean, StorageOperationStatus> validateToscaResourceNameExists(String templateName) {
637 Either<Boolean, StorageOperationStatus> validateUniquenessRes = validateToscaResourceNameUniqueness(templateName);
638 if (validateUniquenessRes.isLeft()) {
639 return Either.left(!validateUniquenessRes.left().value());
641 return validateUniquenessRes;
644 public Either<RequirementCapabilityRelDef, StorageOperationStatus> dissociateResourceInstances(String componentId,
645 RequirementCapabilityRelDef requirementDef) {
646 return nodeTemplateOperation.dissociateResourceInstances(componentId, requirementDef);
650 * Allows to get fulfilled requirement by relation and received predicate
652 public Either<RequirementDataDefinition, StorageOperationStatus> getFulfilledRequirementByRelation(String componentId, String instanceId,
653 RequirementCapabilityRelDef relation,
654 BiPredicate<RelationshipInfo, RequirementDataDefinition> predicate) {
655 return nodeTemplateOperation.getFulfilledRequirementByRelation(componentId, instanceId, relation, predicate);
659 * Allows to get fulfilled capability by relation and received predicate
661 public Either<CapabilityDataDefinition, StorageOperationStatus> getFulfilledCapabilityByRelation(String componentId, String instanceId,
662 RequirementCapabilityRelDef relation,
663 BiPredicate<RelationshipInfo, CapabilityDataDefinition> predicate) {
664 return nodeTemplateOperation.getFulfilledCapabilityByRelation(componentId, instanceId, relation, predicate);
667 public Either<List<RequirementCapabilityRelDef>, StorageOperationStatus> associateResourceInstances(Component component, String componentId,
668 List<RequirementCapabilityRelDef> relations) {
669 Either<List<RequirementCapabilityRelDef>, StorageOperationStatus> reqAndCapListEither = nodeTemplateOperation
670 .associateResourceInstances(component, componentId, relations);
671 if (component != null) {
672 updateInstancesCapAndReqOnComponentFromDB(component);
674 return reqAndCapListEither;
677 protected Either<Boolean, StorageOperationStatus> validateToscaResourceNameUniqueness(String name) {
678 Map<GraphPropertyEnum, Object> properties = new EnumMap<>(GraphPropertyEnum.class);
679 properties.put(GraphPropertyEnum.TOSCA_RESOURCE_NAME, name);
680 Either<List<GraphVertex>, JanusGraphOperationStatus> resources = janusGraphDao
681 .getByCriteria(null, properties, JsonParseFlagEnum.ParseMetadata);
682 if (resources.isRight() && resources.right().value() != JanusGraphOperationStatus.NOT_FOUND) {
683 log.debug("failed to get resources from graph with property name: {}", name);
684 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(resources.right().value()));
686 List<GraphVertex> resourceList = (resources.isLeft() ? resources.left().value() : null);
687 if (isNotEmpty(resourceList)) {
688 if (log.isDebugEnabled()) {
689 StringBuilder builder = new StringBuilder();
690 for (GraphVertex resourceData : resourceList) {
691 builder.append(resourceData.getUniqueId() + "|");
693 log.debug("resources with property name:{} exists in graph. found {}", name, builder);
695 return Either.left(false);
697 log.debug("resources with property name:{} does not exists in graph", name);
698 return Either.left(true);
702 // region - Component Update
703 public Either<Resource, StorageOperationStatus> overrideComponent(Resource newComponent, Resource oldComponent) {
704 copyArtifactsToNewComponent(newComponent, oldComponent);
705 Either<GraphVertex, JanusGraphOperationStatus> componentVEither = janusGraphDao
706 .getVertexById(oldComponent.getUniqueId(), JsonParseFlagEnum.NoParse);
707 if (componentVEither.isRight()) {
708 log.debug("Failed to fetch component {} error {}", oldComponent.getUniqueId(), componentVEither.right().value());
709 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(componentVEither.right().value()));
711 GraphVertex componentv = componentVEither.left().value();
712 Either<GraphVertex, JanusGraphOperationStatus> parentVertexEither = janusGraphDao
713 .getParentVertex(componentv, EdgeLabelEnum.VERSION, JsonParseFlagEnum.NoParse);
714 if (parentVertexEither.isRight() && parentVertexEither.right().value() != JanusGraphOperationStatus.NOT_FOUND) {
715 log.debug("Failed to fetch parent version for component {} error {}", oldComponent.getUniqueId(), parentVertexEither.right().value());
716 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(parentVertexEither.right().value()));
718 Either<ToscaElement, StorageOperationStatus> deleteToscaComponent = deleteToscaElement(componentv);
719 if (deleteToscaComponent.isRight()) {
720 log.debug("Failed to remove old component {} error {}", oldComponent.getUniqueId(), deleteToscaComponent.right().value());
721 return Either.right(deleteToscaComponent.right().value());
723 Either<Resource, StorageOperationStatus> createToscaComponent = createToscaComponent(newComponent);
724 if (createToscaComponent.isRight()) {
725 log.debug("Failed to create tosca element component {} error {}", newComponent.getUniqueId(), createToscaComponent.right().value());
726 return Either.right(createToscaComponent.right().value());
728 Resource newElement = createToscaComponent.left().value();
729 Either<GraphVertex, JanusGraphOperationStatus> newVersionEither = janusGraphDao
730 .getVertexById(newElement.getUniqueId(), JsonParseFlagEnum.NoParse);
731 if (newVersionEither.isRight()) {
732 log.debug("Failed to fetch new tosca element component {} error {}", newComponent.getUniqueId(), newVersionEither.right().value());
733 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(newVersionEither.right().value()));
735 if (parentVertexEither.isLeft()) {
736 GraphVertex previousVersionV = parentVertexEither.left().value();
737 JanusGraphOperationStatus createEdge = janusGraphDao
738 .createEdge(previousVersionV, newVersionEither.left().value(), EdgeLabelEnum.VERSION, null);
739 if (createEdge != JanusGraphOperationStatus.OK) {
740 log.debug("Failed to associate to previous version {} new version {} error {}", previousVersionV.getUniqueId(),
741 newVersionEither.right().value(), createEdge);
742 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(createEdge));
745 return Either.left(newElement);
748 void copyArtifactsToNewComponent(Resource newComponent, Resource oldComponent) {
749 // TODO - check if required
750 Map<String, ArtifactDefinition> toscaArtifacts = oldComponent.getToscaArtifacts();
751 if (toscaArtifacts != null && !toscaArtifacts.isEmpty()) {
752 toscaArtifacts.values().stream().forEach(a -> a.setDuplicated(Boolean.TRUE));
754 newComponent.setToscaArtifacts(toscaArtifacts);
755 Map<String, ArtifactDefinition> artifacts = oldComponent.getArtifacts();
756 if (artifacts != null && !artifacts.isEmpty()) {
757 artifacts.values().stream().forEach(a -> a.setDuplicated(Boolean.TRUE));
759 newComponent.setArtifacts(artifacts);
760 Map<String, ArtifactDefinition> depArtifacts = oldComponent.getDeploymentArtifacts();
761 if (depArtifacts != null && !depArtifacts.isEmpty()) {
762 depArtifacts.values().stream().forEach(a -> a.setDuplicated(Boolean.TRUE));
764 newComponent.setDeploymentArtifacts(depArtifacts);
765 newComponent.setLastUpdateDate(null);
766 newComponent.setHighestVersion(true);
769 public <T extends Component> Either<T, StorageOperationStatus> updateToscaElement(T componentToUpdate) {
770 return updateToscaElement(componentToUpdate, new ComponentParametersView());
773 public <T extends Component> Either<T, StorageOperationStatus> updateToscaElement(T componentToUpdate, ComponentParametersView filterResult) {
774 String componentId = componentToUpdate.getUniqueId();
775 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.ParseAll);
776 if (getVertexEither.isRight()) {
777 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
778 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
780 GraphVertex elementV = getVertexEither.left().value();
781 ToscaElementOperation toscaElementOperation = getToscaElementOperation(elementV);
782 ToscaElement toscaElementToUpdate = ModelConverter.convertToToscaElement(componentToUpdate);
783 Either<ToscaElement, StorageOperationStatus> updateToscaElement = null;
784 if (toscaElementOperation != null) {
785 updateToscaElement = toscaElementOperation.updateToscaElement(toscaElementToUpdate, elementV, filterResult);
787 log.debug("Null value returned by `getToscaElementOperation` with value {}", elementV);
788 updateToscaElement = Either.right(StorageOperationStatus.GENERAL_ERROR);
790 return updateToscaElement.bimap(ModelConverter::convertFromToscaElement, status -> {
791 log.debug("Failed to update tosca element {} error {}", componentId, status);
796 private <T extends Component> Either<T, StorageOperationStatus> getLatestByName(GraphPropertyEnum property, String nodeName,
797 JsonParseFlagEnum parseFlag, String modelName) {
798 return getLatestByName(property, nodeName, parseFlag, new ComponentParametersView(), modelName);
801 private <T extends Component> Either<T, StorageOperationStatus> getLatestByName(GraphPropertyEnum property, String nodeName,
802 JsonParseFlagEnum parseFlag, ComponentParametersView filter,
804 Either<T, StorageOperationStatus> result;
805 Map<GraphPropertyEnum, Object> propertiesToMatch = new EnumMap<>(GraphPropertyEnum.class);
806 Map<GraphPropertyEnum, Object> propertiesNotToMatch = new EnumMap<>(GraphPropertyEnum.class);
807 propertiesToMatch.put(property, nodeName);
808 propertiesToMatch.put(GraphPropertyEnum.IS_HIGHEST_VERSION, true);
809 propertiesNotToMatch.put(GraphPropertyEnum.IS_DELETED, true);
810 Either<List<GraphVertex>, JanusGraphOperationStatus> highestResources = janusGraphDao
811 .getByCriteria(null, propertiesToMatch, propertiesNotToMatch, parseFlag, model);
812 if (highestResources.isRight()) {
813 JanusGraphOperationStatus status = highestResources.right().value();
814 log.debug("failed to find resource with name {}. status={} ", nodeName, status);
815 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status));
818 List<GraphVertex> resources = highestResources.left().value();
819 double version = 0.0;
820 GraphVertex highestResource = null;
821 for (GraphVertex vertex : resources) {
822 Object versionObj = vertex.getMetadataProperty(GraphPropertyEnum.VERSION);
823 double resourceVersion = Double.parseDouble((String) versionObj);
824 if (resourceVersion > version) {
825 version = resourceVersion;
826 highestResource = vertex;
829 return getToscaElementByOperation(highestResource, filter);
832 // region - Component Get By ..
833 private <T extends Component> Either<T, StorageOperationStatus> getLatestByName(GraphPropertyEnum property, String nodeName, String modelName) {
834 return getLatestByName(property, nodeName, JsonParseFlagEnum.ParseMetadata, modelName);
837 public <T extends Component> Either<List<T>, StorageOperationStatus> getBySystemName(ComponentTypeEnum componentType, String systemName) {
838 Either<List<T>, StorageOperationStatus> result = null;
839 Either<T, StorageOperationStatus> getComponentRes;
840 List<T> components = new ArrayList<>();
841 List<GraphVertex> componentVertices;
842 Map<GraphPropertyEnum, Object> propertiesToMatch = new EnumMap<>(GraphPropertyEnum.class);
843 Map<GraphPropertyEnum, Object> propertiesNotToMatch = new EnumMap<>(GraphPropertyEnum.class);
844 propertiesToMatch.put(GraphPropertyEnum.SYSTEM_NAME, systemName);
845 if (componentType != null) {
846 propertiesToMatch.put(GraphPropertyEnum.COMPONENT_TYPE, componentType.name());
848 propertiesNotToMatch.put(GraphPropertyEnum.IS_DELETED, true);
849 Either<List<GraphVertex>, JanusGraphOperationStatus> getComponentsRes = janusGraphDao
850 .getByCriteria(null, propertiesToMatch, propertiesNotToMatch, JsonParseFlagEnum.ParseAll);
851 if (getComponentsRes.isRight()) {
852 JanusGraphOperationStatus status = getComponentsRes.right().value();
853 log.debug("Failed to fetch the component with system name {}. Status is {} ", systemName, status);
854 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status));
856 if (result == null) {
857 componentVertices = getComponentsRes.left().value();
858 for (GraphVertex componentVertex : componentVertices) {
859 getComponentRes = getToscaElementByOperation(componentVertex);
860 if (getComponentRes.isRight()) {
861 log.debug("Failed to get the component {}. Status is {} ", componentVertex.getJsonMetadataField(JsonPresentationFields.NAME),
862 getComponentRes.right().value());
863 result = Either.right(getComponentRes.right().value());
866 T componentBySystemName = getComponentRes.left().value();
867 log.debug("Found component, id: {}", componentBySystemName.getUniqueId());
868 components.add(componentBySystemName);
871 if (result == null) {
872 result = Either.left(components);
877 public <T extends Component> Either<T, StorageOperationStatus> getComponentByNameAndVersion(ComponentTypeEnum componentType, String name,
879 return getComponentByNameAndVersion(componentType, name, version, JsonParseFlagEnum.ParseAll);
882 public <T extends Component> Either<T, StorageOperationStatus> getComponentByNameAndVersion(ComponentTypeEnum componentType, String name,
883 String version, JsonParseFlagEnum parseFlag) {
884 Either<T, StorageOperationStatus> result;
885 Map<GraphPropertyEnum, Object> hasProperties = new EnumMap<>(GraphPropertyEnum.class);
886 Map<GraphPropertyEnum, Object> hasNotProperties = new EnumMap<>(GraphPropertyEnum.class);
887 hasProperties.put(GraphPropertyEnum.NAME, name);
888 hasProperties.put(GraphPropertyEnum.VERSION, version);
889 hasNotProperties.put(GraphPropertyEnum.IS_DELETED, true);
890 if (componentType != null) {
891 hasProperties.put(GraphPropertyEnum.COMPONENT_TYPE, componentType.name());
893 Either<List<GraphVertex>, JanusGraphOperationStatus> getResourceRes = janusGraphDao
894 .getByCriteria(null, hasProperties, hasNotProperties, parseFlag);
895 if (getResourceRes.isRight()) {
896 JanusGraphOperationStatus status = getResourceRes.right().value();
897 log.debug("failed to find resource with name {}, version {}. Status is {} ", name, version, status);
898 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status));
901 return getToscaElementByOperation(getResourceRes.left().value().get(0));
904 public <T extends Component> Either<T, StorageOperationStatus> getComponentByNameAndVendorRelease(final ComponentTypeEnum componentType,
905 final String name, final String vendorRelease,
906 final JsonParseFlagEnum parseFlag, final String modelName) {
907 Map<GraphPropertyEnum, Object> hasProperties = new EnumMap<>(GraphPropertyEnum.class);
908 Map<GraphPropertyEnum, Object> hasNotProperties = new EnumMap<>(GraphPropertyEnum.class);
909 hasProperties.put(GraphPropertyEnum.NAME, name);
910 hasNotProperties.put(GraphPropertyEnum.IS_DELETED, true);
911 if (componentType != null) {
912 hasProperties.put(GraphPropertyEnum.COMPONENT_TYPE, componentType.name());
914 Map<String, Entry<JanusGraphPredicate, Object>> predicateCriteria = getVendorVersionPredicate(vendorRelease);
915 Either<List<GraphVertex>, JanusGraphOperationStatus> getResourceRes = janusGraphDao.getByCriteria(null, hasProperties, hasNotProperties,
916 predicateCriteria, parseFlag, modelName);
917 if (getResourceRes.isRight()) {
918 JanusGraphOperationStatus status = getResourceRes.right().value();
919 log.debug("failed to find resource with name {}, version {}. Status is {} ", name, predicateCriteria, status);
920 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status));
922 return getToscaElementByOperation(getResourceRes.left().value().get(0));
925 public Either<List<CatalogComponent>, StorageOperationStatus> getCatalogOrArchiveComponents(boolean isCatalog,
926 List<OriginTypeEnum> excludeTypes) {
927 List<ResourceTypeEnum> excludedResourceTypes = Optional.ofNullable(excludeTypes).orElse(Collections.emptyList()).stream()
928 .filter(type -> !type.equals(OriginTypeEnum.SERVICE)).map(type -> ResourceTypeEnum.getTypeByName(type.name()))
929 .collect(Collectors.toList());
930 return topologyTemplateOperation.getElementCatalogData(isCatalog, excludedResourceTypes);
934 public <T extends Component> Either<List<T>, StorageOperationStatus> getCatalogComponents(ComponentTypeEnum componentType,
935 List<OriginTypeEnum> excludeTypes,
936 boolean isHighestVersions) {
937 List<T> components = new ArrayList<>();
938 Either<List<ToscaElement>, StorageOperationStatus> catalogDataResult;
939 List<ToscaElement> toscaElements = new ArrayList<>();
940 List<ResourceTypeEnum> excludedResourceTypes = Optional.ofNullable(excludeTypes).orElse(Collections.emptyList()).stream()
941 .filter(type -> !type.equals(OriginTypeEnum.SERVICE)).map(type -> ResourceTypeEnum.getTypeByName(type.name()))
942 .collect(Collectors.toList());
943 switch (componentType) {
945 catalogDataResult = nodeTypeOperation.getElementCatalogData(ComponentTypeEnum.RESOURCE, excludedResourceTypes, isHighestVersions);
946 if (catalogDataResult.isRight()) {
947 return Either.right(catalogDataResult.right().value());
949 toscaElements = catalogDataResult.left().value();
952 if (excludeTypes != null && excludeTypes.contains(OriginTypeEnum.SERVICE)) {
955 catalogDataResult = topologyTemplateOperation.getElementCatalogData(ComponentTypeEnum.SERVICE, null, isHighestVersions);
956 if (catalogDataResult.isRight()) {
957 return Either.right(catalogDataResult.right().value());
959 toscaElements = catalogDataResult.left().value();
962 log.debug(NOT_SUPPORTED_COMPONENT_TYPE, componentType);
963 return Either.right(StorageOperationStatus.BAD_REQUEST);
965 toscaElements.forEach(te -> {
966 T component = ModelConverter.convertFromToscaElement(te);
967 components.add(component);
969 return Either.left(components);
972 public Either<List<String>, StorageOperationStatus> deleteMarkedElements(ComponentTypeEnum componentType) {
973 Either<List<GraphVertex>, StorageOperationStatus> allComponentsMarkedForDeletion;
974 switch (componentType) {
976 allComponentsMarkedForDeletion = nodeTypeOperation.getAllComponentsMarkedForDeletion(componentType);
980 allComponentsMarkedForDeletion = topologyTemplateOperation.getAllComponentsMarkedForDeletion(componentType);
983 log.debug(NOT_SUPPORTED_COMPONENT_TYPE, componentType);
984 return Either.right(StorageOperationStatus.BAD_REQUEST);
986 if (allComponentsMarkedForDeletion.isRight()) {
987 return Either.right(allComponentsMarkedForDeletion.right().value());
989 List<GraphVertex> allMarked = allComponentsMarkedForDeletion.left().value();
990 return Either.left(checkIfInUseAndDelete(allMarked));
993 private List<String> checkIfInUseAndDelete(List<GraphVertex> allMarked) {
994 final List<EdgeLabelEnum> forbiddenEdgeLabelEnums = Arrays
995 .asList(EdgeLabelEnum.INSTANCE_OF, EdgeLabelEnum.PROXY_OF, EdgeLabelEnum.ALLOTTED_OF);
996 List<String> deleted = new ArrayList<>();
997 for (GraphVertex elementV : allMarked) {
998 boolean isAllowedToDelete = true;
999 for (EdgeLabelEnum edgeLabelEnum : forbiddenEdgeLabelEnums) {
1000 Either<Edge, JanusGraphOperationStatus> belongingEdgeByCriteria = janusGraphDao
1001 .getBelongingEdgeByCriteria(elementV, edgeLabelEnum, null);
1002 if (belongingEdgeByCriteria.isLeft()) {
1003 log.debug("Marked element {} in use. don't delete it", elementV.getUniqueId());
1004 isAllowedToDelete = false;
1008 if (isAllowedToDelete) {
1009 Either<ToscaElement, StorageOperationStatus> deleteToscaElement = deleteToscaElement(elementV);
1010 if (deleteToscaElement.isRight()) {
1011 log.debug("Failed to delete marked element UniqueID {}, Name {}, error {}", elementV.getUniqueId(),
1012 elementV.getMetadataProperties().get(GraphPropertyEnum.NAME), deleteToscaElement.right().value());
1015 deleted.add(elementV.getUniqueId());
1021 public Either<List<String>, StorageOperationStatus> getAllComponentsMarkedForDeletion(ComponentTypeEnum componentType) {
1022 Either<List<GraphVertex>, StorageOperationStatus> allComponentsMarkedForDeletion;
1023 switch (componentType) {
1025 allComponentsMarkedForDeletion = nodeTypeOperation.getAllComponentsMarkedForDeletion(componentType);
1029 allComponentsMarkedForDeletion = topologyTemplateOperation.getAllComponentsMarkedForDeletion(componentType);
1032 log.debug(NOT_SUPPORTED_COMPONENT_TYPE, componentType);
1033 return Either.right(StorageOperationStatus.BAD_REQUEST);
1035 if (allComponentsMarkedForDeletion.isRight()) {
1036 return Either.right(allComponentsMarkedForDeletion.right().value());
1038 return Either.left(allComponentsMarkedForDeletion.left().value().stream().map(GraphVertex::getUniqueId).collect(Collectors.toList()));
1041 // region - Component Update
1042 public Either<ImmutablePair<Component, String>, StorageOperationStatus> addComponentInstanceToTopologyTemplate(Component containerComponent,
1043 Component origComponent,
1044 ComponentInstance componentInstance,
1045 boolean allowDeleted, User user) {
1046 Either<ImmutablePair<Component, String>, StorageOperationStatus> result = null;
1047 Either<ToscaElement, StorageOperationStatus> updateContainerComponentRes = null;
1048 if (StringUtils.isEmpty(componentInstance.getIcon())) {
1049 componentInstance.setIcon(origComponent.getIcon());
1051 String nameToFindForCounter;
1052 switch (componentInstance.getOriginType()) {
1054 nameToFindForCounter = ValidationUtils.normaliseComponentName(componentInstance.getSourceModelName()) + PROXY_SUFFIX;
1056 case ServiceSubstitution:
1057 nameToFindForCounter = ValidationUtils.normaliseComponentName(componentInstance.getSourceModelName());
1060 nameToFindForCounter = origComponent.getName();
1062 String nextComponentInstanceCounter = getNextComponentInstanceCounter(containerComponent, nameToFindForCounter);
1063 Either<ImmutablePair<TopologyTemplate, String>, StorageOperationStatus> addResult = nodeTemplateOperation
1064 .addComponentInstanceToTopologyTemplate(ModelConverter.convertToToscaElement(containerComponent),
1065 ModelConverter.convertToToscaElement(origComponent), nextComponentInstanceCounter, componentInstance, allowDeleted, user);
1066 if (addResult.isRight()) {
1067 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to add the component instance {} to container component {}. ",
1068 componentInstance.getName(), containerComponent.getName());
1069 result = Either.right(addResult.right().value());
1071 if (result == null) {
1072 updateContainerComponentRes = topologyTemplateOperation.getToscaElement(containerComponent.getUniqueId());
1073 if (updateContainerComponentRes.isRight()) {
1075 .addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to fetch updated topology template {} with updated component instance {}. ",
1076 containerComponent.getName(), componentInstance.getName());
1077 result = Either.right(updateContainerComponentRes.right().value());
1080 if (result == null) {
1081 Component updatedComponent = ModelConverter.convertFromToscaElement(updateContainerComponentRes.left().value());
1082 String createdInstanceId = addResult.left().value().getRight();
1084 .addRecordToLog(log, LogLevelEnum.TRACE, "The component instance {} has been added to container component {}. ", createdInstanceId,
1085 updatedComponent.getName());
1086 result = Either.left(new ImmutablePair<>(updatedComponent, createdInstanceId));
1091 public void associateComponentInstancesToComponent(Component containerComponent, Map<ComponentInstance, Resource> resourcesInstancesMap,
1092 boolean allowDeleted, boolean isUpdateCsar) {
1093 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, "Going to add component instances to component {}", containerComponent.getUniqueId());
1094 Either<GraphVertex, JanusGraphOperationStatus> metadataVertex = janusGraphDao
1095 .getVertexById(containerComponent.getUniqueId(), JsonParseFlagEnum.ParseAll);
1096 if (metadataVertex.isRight()) {
1097 JanusGraphOperationStatus status = metadataVertex.right().value();
1098 if (status == JanusGraphOperationStatus.NOT_FOUND) {
1099 status = JanusGraphOperationStatus.INVALID_ID;
1101 throw new StorageException(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status));
1103 Map<String, ComponentInstanceDataDefinition> compnentInstancesMap = nodeTemplateOperation
1104 .associateComponentInstancesToComponent(containerComponent, resourcesInstancesMap, metadataVertex.left().value(), allowDeleted,
1106 containerComponent.setComponentInstances(ModelConverter.getComponentInstancesFromMapObject(compnentInstancesMap, containerComponent));
1109 public Either<ImmutablePair<Component, String>, StorageOperationStatus> updateComponentInstanceMetadataOfTopologyTemplate(
1110 Component containerComponent, Component origComponent, ComponentInstance componentInstance) {
1111 Either<ImmutablePair<Component, String>, StorageOperationStatus> result = null;
1112 CommonUtility.addRecordToLog(log, LogLevelEnum.TRACE,
1113 "Going to update the metadata of the component instance {} belonging to container component {}. ", componentInstance.getName(),
1114 containerComponent.getName());
1115 componentInstance.setIcon(origComponent.getIcon());
1116 Either<ImmutablePair<TopologyTemplate, String>, StorageOperationStatus> updateResult = nodeTemplateOperation
1117 .updateComponentInstanceMetadataOfTopologyTemplate(ModelConverter.convertToToscaElement(containerComponent),
1118 ModelConverter.convertToToscaElement(origComponent), componentInstance);
1119 if (updateResult.isRight()) {
1120 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG,
1121 "Failed to update the metadata of the component instance {} belonging to container component {}. ", componentInstance.getName(),
1122 containerComponent.getName());
1123 result = Either.right(updateResult.right().value());
1125 if (result == null) {
1126 Component updatedComponent = ModelConverter.convertFromToscaElement(updateResult.left().value().getLeft());
1127 String createdInstanceId = updateResult.left().value().getRight();
1129 .addRecordToLog(log, LogLevelEnum.TRACE, "The metadata of the component instance {} has been updated to container component {}. ",
1130 createdInstanceId, updatedComponent.getName());
1131 result = Either.left(new ImmutablePair<>(updatedComponent, createdInstanceId));
1136 public Either<Component, StorageOperationStatus> updateComponentInstanceMetadataOfTopologyTemplate(Component containerComponent) {
1137 return updateComponentInstanceMetadataOfTopologyTemplate(containerComponent, new ComponentParametersView());
1140 public Either<Component, StorageOperationStatus> updateComponentInstanceMetadataOfTopologyTemplate(Component containerComponent,
1141 ComponentParametersView filter) {
1142 Either<Component, StorageOperationStatus> result = null;
1143 CommonUtility.addRecordToLog(log, LogLevelEnum.TRACE, "Going to update the metadata belonging to container component {}. ",
1144 containerComponent.getName());
1145 Either<TopologyTemplate, StorageOperationStatus> updateResult = nodeTemplateOperation
1146 .updateComponentInstanceMetadataOfTopologyTemplate(ModelConverter.convertToToscaElement(containerComponent), filter);
1147 if (updateResult.isRight()) {
1148 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to update the metadata belonging to container component {}. ",
1149 containerComponent.getName());
1150 result = Either.right(updateResult.right().value());
1152 if (result == null) {
1153 Component updatedComponent = ModelConverter.convertFromToscaElement(updateResult.left().value());
1155 .addRecordToLog(log, LogLevelEnum.TRACE, "The metadata has been updated to container component {}. ", updatedComponent.getName());
1156 result = Either.left(updatedComponent);
1162 public Either<ImmutablePair<Component, String>, StorageOperationStatus> deleteComponentInstanceFromTopologyTemplate(Component containerComponent,
1163 String resourceInstanceId) {
1164 Either<ImmutablePair<Component, String>, StorageOperationStatus> result = null;
1165 CommonUtility.addRecordToLog(log, LogLevelEnum.TRACE, "Going to delete the component instance {} belonging to container component {}. ",
1166 resourceInstanceId, containerComponent.getName());
1167 Either<ImmutablePair<TopologyTemplate, String>, StorageOperationStatus> updateResult = nodeTemplateOperation
1168 .deleteComponentInstanceFromTopologyTemplate(ModelConverter.convertToToscaElement(containerComponent), resourceInstanceId);
1169 if (updateResult.isRight()) {
1170 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to delete the component instance {} belonging to container component {}. ",
1171 resourceInstanceId, containerComponent.getName());
1172 result = Either.right(updateResult.right().value());
1174 if (result == null) {
1175 Component updatedComponent = ModelConverter.convertFromToscaElement(updateResult.left().value().getLeft());
1176 String deletedInstanceId = updateResult.left().value().getRight();
1177 CommonUtility.addRecordToLog(log, LogLevelEnum.TRACE, "The component instance {} has been deleted from container component {}. ",
1178 deletedInstanceId, updatedComponent.getName());
1179 result = Either.left(new ImmutablePair<>(updatedComponent, deletedInstanceId));
1184 private String getNextComponentInstanceCounter(Component containerComponent, String originResourceName) {
1185 Integer nextCounter = 0;
1186 if (CollectionUtils.isNotEmpty(containerComponent.getComponentInstances())) {
1187 String normalizedName = ValidationUtils.normalizeComponentInstanceName(originResourceName);
1188 Integer maxCounter = getMaxCounterFromNamesAndIds(containerComponent, normalizedName);
1189 if (maxCounter != null) {
1190 nextCounter = maxCounter + 1;
1193 return nextCounter.toString();
1197 * @return max counter of component instance Id's, null if not found
1199 private Integer getMaxCounterFromNamesAndIds(Component containerComponent, String normalizedName) {
1200 List<String> countersInNames = containerComponent.getComponentInstances().stream()
1201 .filter(ci -> ci.getNormalizedName() != null && ci.getNormalizedName().startsWith(normalizedName))
1202 .map(ci -> ci.getNormalizedName().split(normalizedName)[1]).collect(Collectors.toList());
1203 List<String> countersInIds = containerComponent.getComponentInstances().stream()
1204 .filter(ci -> ci.getUniqueId() != null && ci.getUniqueId().contains(normalizedName)).map(ci -> ci.getUniqueId().split(normalizedName)[1])
1205 .collect(Collectors.toList());
1206 List<String> namesAndIdsList = new ArrayList<>(countersInNames);
1207 namesAndIdsList.addAll(countersInIds);
1208 return getMaxInteger(namesAndIdsList);
1211 private Integer getMaxInteger(List<String> counters) {
1212 Integer maxCounter = 0;
1213 Integer currCounter = null;
1214 for (String counter : counters) {
1216 currCounter = Integer.parseInt(counter);
1217 if (maxCounter < currCounter) {
1218 maxCounter = currCounter;
1220 } catch (NumberFormatException e) {
1224 return currCounter == null ? null : maxCounter;
1227 public Either<RequirementCapabilityRelDef, StorageOperationStatus> associateResourceInstances(Component component, String componentId,
1228 RequirementCapabilityRelDef requirementDef) {
1229 return nodeTemplateOperation.associateResourceInstances(component, componentId, requirementDef);
1232 public Either<List<InputDefinition>, StorageOperationStatus> createAndAssociateInputs(Map<String, InputDefinition> inputs, String componentId) {
1233 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
1234 if (getVertexEither.isRight()) {
1235 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
1236 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
1238 GraphVertex vertex = getVertexEither.left().value();
1239 Map<String, PropertyDataDefinition> inputsMap = inputs.entrySet().stream()
1240 .collect(Collectors.toMap(Map.Entry::getKey, e -> new PropertyDataDefinition(e.getValue())));
1241 StorageOperationStatus status = topologyTemplateOperation.associateInputsToComponent(vertex, inputsMap, componentId);
1242 if (StorageOperationStatus.OK == status) {
1243 log.debug(COMPONENT_CREATED_SUCCESSFULLY);
1244 List<InputDefinition> inputsResList = null;
1245 if (inputsMap != null && !inputsMap.isEmpty()) {
1246 inputsResList = inputsMap.values().stream().map(InputDefinition::new).collect(Collectors.toList());
1248 return Either.left(inputsResList);
1250 return Either.right(status);
1253 public Either<List<InputDefinition>, StorageOperationStatus> addInputsToComponent(Map<String, InputDefinition> inputs, String componentId) {
1254 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
1255 if (getVertexEither.isRight()) {
1256 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
1257 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
1259 GraphVertex vertex = getVertexEither.left().value();
1260 Map<String, PropertyDefinition> inputsMap = inputs.entrySet().stream()
1261 .collect(Collectors.toMap(Map.Entry::getKey, e -> new PropertyDefinition(e.getValue())));
1262 StorageOperationStatus status = topologyTemplateOperation
1263 .addToscaDataToToscaElement(vertex, EdgeLabelEnum.INPUTS, VertexTypeEnum.INPUTS, inputsMap, JsonPresentationFields.NAME);
1264 if (StorageOperationStatus.OK == status) {
1265 log.debug(COMPONENT_CREATED_SUCCESSFULLY);
1266 List<InputDefinition> inputsResList = null;
1267 if (inputsMap != null && !inputsMap.isEmpty()) {
1268 inputsResList = inputsMap.values().stream().map(InputDefinition::new).collect(Collectors.toList());
1270 return Either.left(inputsResList);
1272 return Either.right(status);
1275 public Either<List<OutputDefinition>, StorageOperationStatus> addOutputsToComponent(Map<String, OutputDefinition> outputs, String componentId) {
1276 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
1277 if (getVertexEither.isRight()) {
1278 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
1279 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
1281 GraphVertex vertex = getVertexEither.left().value();
1282 Map<String, AttributeDefinition> outputsMap = outputs.entrySet().stream()
1283 .collect(Collectors.toMap(Map.Entry::getKey, e -> new AttributeDefinition(e.getValue())));
1284 StorageOperationStatus status = topologyTemplateOperation
1285 .addToscaDataToToscaElement(vertex, EdgeLabelEnum.OUTPUTS, VertexTypeEnum.OUTPUTS, outputsMap, JsonPresentationFields.NAME);
1286 if (StorageOperationStatus.OK == status) {
1287 log.debug(COMPONENT_CREATED_SUCCESSFULLY);
1288 List<OutputDefinition> outputsResList = null;
1289 if (outputsMap != null && !outputsMap.isEmpty()) {
1290 outputsResList = outputsMap.values().stream().map(OutputDefinition::new).collect(Collectors.toList());
1292 return Either.left(outputsResList);
1294 return Either.right(status);
1298 * Add data types into a Component.
1300 * @param dataTypes datatypes to be added. the key should be each name of data type.
1301 * @param componentId unique ID of Component.
1302 * @return list of data types.
1304 public Either<List<DataTypeDefinition>, StorageOperationStatus> addDataTypesToComponent(Map<String, DataTypeDefinition> dataTypes,
1305 String componentId) {
1306 log.trace("#addDataTypesToComponent - enter, componentId={}", componentId);
1307 /* get component vertex */
1308 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao
1309 .getVertexById(componentId, JsonParseFlagEnum.NoParse);
1310 if (getVertexEither.isRight()) {
1311 /* not found / error */
1312 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
1313 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
1315 GraphVertex vertex = getVertexEither.left().value();
1316 log.trace("#addDataTypesToComponent - get vertex ok");
1317 // convert DataTypeDefinition to DataTypeDataDefinition
1318 Map<String, DataTypeDataDefinition> dataTypeDataMap = dataTypes.entrySet().stream()
1319 .collect(Collectors.toMap(Map.Entry::getKey, e -> convertDataTypeToDataTypeData(e.getValue())));
1320 // add datatype(s) to the Component.
1322 // if child vertex does not exist, it will be created.
1323 StorageOperationStatus status = topologyTemplateOperation
1324 .addToscaDataToToscaElement(vertex, EdgeLabelEnum.DATA_TYPES, VertexTypeEnum.DATA_TYPES, dataTypeDataMap, JsonPresentationFields.NAME);
1325 if (StorageOperationStatus.OK == status) {
1326 log.debug(COMPONENT_CREATED_SUCCESSFULLY);
1327 List<DataTypeDefinition> inputsResList = null;
1328 if (!dataTypes.isEmpty()) {
1329 inputsResList = new ArrayList<>(dataTypes.values());
1331 return Either.left(inputsResList);
1333 log.trace("#addDataTypesToComponent - leave");
1334 return Either.right(status);
1337 private DataTypeDataDefinition convertDataTypeToDataTypeData(DataTypeDefinition dataType) {
1338 DataTypeDataDefinition dataTypeData = new DataTypeDataDefinition(dataType);
1339 if (CollectionUtils.isNotEmpty(dataType.getProperties())) {
1340 List<PropertyDataDefinition> propertyDataList = dataType.getProperties().stream().map(PropertyDataDefinition::new)
1341 .collect(Collectors.toList());
1342 dataTypeData.setPropertiesData(propertyDataList);
1344 // if "derivedFrom" data_type exists, copy the name to "derivedFromName"
1345 if (dataType.getDerivedFrom() != null && StringUtils.isNotEmpty(dataType.getDerivedFrom().getName())) {
1346 // if names are different, log it
1347 if (!StringUtils.equals(dataTypeData.getDerivedFromName(), dataType.getDerivedFrom().getName())) {
1348 log.debug("#convertDataTypeToDataTypeData - derivedFromName(={}) overwritten by derivedFrom.name(={})", dataType.getDerivedFromName(),
1349 dataType.getDerivedFrom().getName());
1351 dataTypeData.setDerivedFromName(dataType.getDerivedFrom().getName());
1353 // supply "name" field to toscaPresentationValue in each datatype object for DAO operations
1354 dataTypeData.setToscaPresentationValue(JsonPresentationFields.NAME, dataType.getName());
1355 return dataTypeData;
1358 public Either<List<InputDefinition>, StorageOperationStatus> getComponentInputs(String componentId) {
1359 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
1360 if (getVertexEither.isRight()) {
1361 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
1362 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
1364 Either<ToscaElement, StorageOperationStatus> toscaElement = topologyTemplateOperation.getToscaElement(componentId);
1365 if (toscaElement.isRight()) {
1366 return Either.right(toscaElement.right().value());
1368 TopologyTemplate topologyTemplate = (TopologyTemplate) toscaElement.left().value();
1369 Map<String, PropertyDataDefinition> inputsMap = topologyTemplate.getInputs();
1370 List<InputDefinition> inputs = new ArrayList<>();
1371 if (MapUtils.isNotEmpty(inputsMap)) {
1372 inputs = inputsMap.values().stream().map(p -> new InputDefinition(p)).collect(Collectors.toList());
1374 return Either.left(inputs);
1377 public Either<List<InputDefinition>, StorageOperationStatus> updateInputsToComponent(List<InputDefinition> inputs, String componentId) {
1378 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
1379 if (getVertexEither.isRight()) {
1380 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
1381 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
1383 GraphVertex vertex = getVertexEither.left().value();
1384 List<PropertyDataDefinition> inputsAsDataDef = inputs.stream().map(PropertyDataDefinition::new).collect(Collectors.toList());
1385 StorageOperationStatus status = topologyTemplateOperation
1386 .updateToscaDataOfToscaElement(vertex, EdgeLabelEnum.INPUTS, VertexTypeEnum.INPUTS, inputsAsDataDef, JsonPresentationFields.NAME);
1387 if (StorageOperationStatus.OK == status) {
1388 log.debug(COMPONENT_CREATED_SUCCESSFULLY);
1389 List<InputDefinition> inputsResList = null;
1390 if (inputsAsDataDef != null && !inputsAsDataDef.isEmpty()) {
1391 inputsResList = inputsAsDataDef.stream().map(InputDefinition::new).collect(Collectors.toList());
1393 return Either.left(inputsResList);
1395 return Either.right(status);
1398 // region - ComponentInstance
1399 public Either<Map<String, List<ComponentInstanceProperty>>, StorageOperationStatus> associateComponentInstancePropertiesToComponent(
1400 Map<String, List<ComponentInstanceProperty>> instProperties, String componentId) {
1401 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
1402 if (getVertexEither.isRight()) {
1403 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
1404 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
1406 GraphVertex vertex = getVertexEither.left().value();
1407 Map<String, MapPropertiesDataDefinition> instPropsMap = new HashMap<>();
1408 if (instProperties != null) {
1409 MapPropertiesDataDefinition propertiesMap;
1410 for (Entry<String, List<ComponentInstanceProperty>> entry : instProperties.entrySet()) {
1411 propertiesMap = new MapPropertiesDataDefinition();
1412 propertiesMap.setMapToscaDataDefinition(
1413 entry.getValue().stream().map(PropertyDataDefinition::new).collect(Collectors.toMap(PropertyDataDefinition::getName, e -> e)));
1414 instPropsMap.put(entry.getKey(), propertiesMap);
1417 StorageOperationStatus status = topologyTemplateOperation.associateInstPropertiesToComponent(vertex, instPropsMap);
1418 if (StorageOperationStatus.OK == status) {
1419 log.debug(COMPONENT_CREATED_SUCCESSFULLY);
1420 return Either.left(instProperties);
1422 return Either.right(status);
1426 * saves the instInputs as the updated instance inputs of the component container in DB
1428 public Either<Map<String, List<ComponentInstanceInput>>, StorageOperationStatus> updateComponentInstanceInputsToComponent(
1429 Map<String, List<ComponentInstanceInput>> instInputs, String componentId) {
1430 if (instInputs == null || instInputs.isEmpty()) {
1431 return Either.left(instInputs);
1433 StorageOperationStatus status;
1434 for (Entry<String, List<ComponentInstanceInput>> inputsPerIntance : instInputs.entrySet()) {
1435 List<ComponentInstanceInput> toscaDataListPerInst = inputsPerIntance.getValue();
1436 List<String> pathKeysPerInst = new ArrayList<>();
1437 pathKeysPerInst.add(inputsPerIntance.getKey());
1438 status = topologyTemplateOperation
1439 .updateToscaDataDeepElementsOfToscaElement(componentId, EdgeLabelEnum.INST_INPUTS, VertexTypeEnum.INST_INPUTS, toscaDataListPerInst,
1440 pathKeysPerInst, JsonPresentationFields.NAME);
1441 if (status != StorageOperationStatus.OK) {
1442 log.debug("Failed to update component instance inputs for instance {} in component {} edge type {} error {}",
1443 inputsPerIntance.getKey(), componentId, EdgeLabelEnum.INST_INPUTS, status);
1444 return Either.right(status);
1447 return Either.left(instInputs);
1451 * saves the instProps as the updated instance properties of the component container in DB
1453 public Either<Map<String, List<ComponentInstanceProperty>>, StorageOperationStatus> updateComponentInstancePropsToComponent(
1454 Map<String, List<ComponentInstanceProperty>> instProps, String componentId) {
1455 if (instProps == null || instProps.isEmpty()) {
1456 return Either.left(instProps);
1458 StorageOperationStatus status;
1459 for (Entry<String, List<ComponentInstanceProperty>> propsPerIntance : instProps.entrySet()) {
1460 List<ComponentInstanceProperty> toscaDataListPerInst = propsPerIntance.getValue();
1461 List<String> pathKeysPerInst = new ArrayList<>();
1462 pathKeysPerInst.add(propsPerIntance.getKey());
1463 status = topologyTemplateOperation
1464 .updateToscaDataDeepElementsOfToscaElement(componentId, EdgeLabelEnum.INST_PROPERTIES, VertexTypeEnum.INST_PROPERTIES,
1465 toscaDataListPerInst, pathKeysPerInst, JsonPresentationFields.NAME);
1466 if (status != StorageOperationStatus.OK) {
1467 log.debug("Failed to update component instance inputs for instance {} in component {} edge type {} error {}",
1468 propsPerIntance.getKey(), componentId, EdgeLabelEnum.INST_PROPERTIES, status);
1469 return Either.right(status);
1472 return Either.left(instProps);
1475 public Either<Map<String, List<ComponentInstanceInput>>, StorageOperationStatus> associateComponentInstanceInputsToComponent(
1476 Map<String, List<ComponentInstanceInput>> instInputs, String componentId) {
1477 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
1478 if (getVertexEither.isRight()) {
1479 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
1480 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
1482 GraphVertex vertex = getVertexEither.left().value();
1483 Map<String, MapPropertiesDataDefinition> instPropsMap = new HashMap<>();
1484 if (instInputs != null) {
1485 MapPropertiesDataDefinition propertiesMap;
1486 for (Entry<String, List<ComponentInstanceInput>> entry : instInputs.entrySet()) {
1487 propertiesMap = new MapPropertiesDataDefinition();
1488 propertiesMap.setMapToscaDataDefinition(
1489 entry.getValue().stream().map(PropertyDataDefinition::new).collect(Collectors.toMap(PropertyDataDefinition::getName, e -> e)));
1490 instPropsMap.put(entry.getKey(), propertiesMap);
1493 StorageOperationStatus status = topologyTemplateOperation.associateInstInputsToComponent(vertex, instPropsMap);
1494 if (StorageOperationStatus.OK == status) {
1495 log.debug(COMPONENT_CREATED_SUCCESSFULLY);
1496 return Either.left(instInputs);
1498 return Either.right(status);
1501 public Either<Map<String, List<ComponentInstanceInput>>, StorageOperationStatus> addComponentInstanceInputsToComponent(
1502 Component containerComponent, Map<String, List<ComponentInstanceInput>> instProperties) {
1503 requireNonNull(instProperties);
1504 StorageOperationStatus status;
1505 for (Entry<String, List<ComponentInstanceInput>> entry : instProperties.entrySet()) {
1506 List<ComponentInstanceInput> props = entry.getValue();
1507 String componentInstanceId = entry.getKey();
1508 if (!isEmpty(props)) {
1509 for (ComponentInstanceInput property : props) {
1510 List<ComponentInstanceInput> componentInstancesInputs = containerComponent.getComponentInstancesInputs().get(componentInstanceId);
1511 Optional<ComponentInstanceInput> instanceProperty = componentInstancesInputs.stream()
1512 .filter(p -> p.getName().equals(property.getName())).findAny();
1513 if (instanceProperty.isPresent()) {
1514 status = updateComponentInstanceInput(containerComponent, componentInstanceId, property);
1516 status = addComponentInstanceInput(containerComponent, componentInstanceId, property);
1518 if (status != StorageOperationStatus.OK) {
1519 log.debug("Failed to update instance input {} for instance {} error {} ", property, componentInstanceId, status);
1520 return Either.right(status);
1522 log.trace("instance input {} for instance {} updated", property, componentInstanceId);
1527 return Either.left(instProperties);
1530 public Either<Map<String, List<ComponentInstanceOutput>>, StorageOperationStatus> addComponentInstanceOutputsToComponent(
1531 Component containerComponent, Map<String, List<ComponentInstanceOutput>> instProperties) {
1532 requireNonNull(instProperties);
1533 StorageOperationStatus status;
1534 for (final Entry<String, List<ComponentInstanceOutput>> entry : instProperties.entrySet()) {
1535 final List<ComponentInstanceOutput> props = entry.getValue();
1536 final String componentInstanceId = entry.getKey();
1537 if (!isEmpty(props)) {
1538 for (final ComponentInstanceOutput property : props) {
1539 final List<ComponentInstanceOutput> componentInstancesInputs = containerComponent.getComponentInstancesOutputs()
1540 .get(componentInstanceId);
1541 final Optional<ComponentInstanceOutput> instanceProperty = componentInstancesInputs.stream()
1542 .filter(p -> p.getName().equals(property.getName())).findAny();
1543 if (instanceProperty.isPresent()) {
1544 status = updateComponentInstanceOutput(containerComponent, componentInstanceId, property);
1546 status = addComponentInstanceOutput(containerComponent, componentInstanceId, property);
1548 if (status != StorageOperationStatus.OK) {
1549 log.debug("Failed to update instance input {} for instance {} error {} ", property, componentInstanceId, status);
1550 return Either.right(status);
1552 log.trace("instance input {} for instance {} updated", property, componentInstanceId);
1557 return Either.left(instProperties);
1560 public Either<Map<String, List<ComponentInstanceProperty>>, StorageOperationStatus> addComponentInstancePropertiesToComponent(
1561 Component containerComponent, Map<String, List<ComponentInstanceProperty>> instProperties) {
1562 requireNonNull(instProperties);
1563 for (Entry<String, List<ComponentInstanceProperty>> entry : instProperties.entrySet()) {
1564 List<ComponentInstanceProperty> props = entry.getValue();
1565 String componentInstanceId = entry.getKey();
1566 List<ComponentInstanceProperty> originalComponentInstProps = containerComponent.getComponentInstancesProperties()
1567 .get(componentInstanceId);
1568 Map<String, List<CapabilityDefinition>> containerComponentCapabilities = containerComponent.getCapabilities();
1569 if (isEmpty(props)) {
1572 for (ComponentInstanceProperty property : props) {
1573 StorageOperationStatus status = null;
1574 String propertyParentUniqueId = property.getParentUniqueId();
1575 Optional<CapabilityDefinition> capPropDefinition = getPropertyCapability(propertyParentUniqueId, containerComponent);
1576 if (capPropDefinition.isPresent() && MapUtils.isNotEmpty(containerComponentCapabilities)) {
1577 status = populateAndUpdateInstanceCapProperty(containerComponent, componentInstanceId, containerComponentCapabilities, property,
1578 capPropDefinition.get());
1580 if (status == null) {
1581 status = updateOrAddComponentInstanceProperty(containerComponent, componentInstanceId, originalComponentInstProps, property);
1583 if (status != StorageOperationStatus.OK) {
1584 return Either.right(status);
1588 return Either.left(instProperties);
1591 public Either<Map<String, List<ComponentInstanceAttribute>>, StorageOperationStatus> addComponentInstanceAttributesToComponent(
1592 final Component containerComponent, final Map<String, List<ComponentInstanceAttribute>> instProperties) {
1593 requireNonNull(instProperties);
1594 for (final Entry<String, List<ComponentInstanceAttribute>> entry : instProperties.entrySet()) {
1595 final List<ComponentInstanceAttribute> props = entry.getValue();
1596 if (isEmpty(props)) {
1599 final String componentInstanceId = entry.getKey();
1600 final List<ComponentInstanceAttribute> originalComponentInstProps = containerComponent.getComponentInstancesAttributes()
1601 .get(componentInstanceId);
1602 for (final ComponentInstanceAttribute property : props) {
1603 final StorageOperationStatus status = updateOrAddComponentInstanceAttribute(containerComponent, componentInstanceId,
1604 originalComponentInstProps, property);
1605 if (status != StorageOperationStatus.OK) {
1606 return Either.right(status);
1610 return Either.left(instProperties);
1613 private StorageOperationStatus populateAndUpdateInstanceCapProperty(Component containerComponent, String componentInstanceId,
1614 Map<String, List<CapabilityDefinition>> containerComponentCapabilities,
1615 ComponentInstanceProperty property,
1616 CapabilityDefinition capabilityDefinition) {
1617 List<CapabilityDefinition> capabilityDefinitions = containerComponentCapabilities.get(capabilityDefinition.getType());
1618 if (CollectionUtils.isEmpty(capabilityDefinitions)) {
1621 Optional<CapabilityDefinition> capDefToGetProp = capabilityDefinitions.stream()
1622 .filter(cap -> cap.getUniqueId().equals(capabilityDefinition.getUniqueId()) && cap.getPath().size() == 1).findAny();
1623 if (capDefToGetProp.isPresent()) {
1624 return updateInstanceCapabilityProperty(containerComponent, componentInstanceId, property, capDefToGetProp.get());
1629 private StorageOperationStatus updateOrAddComponentInstanceProperty(Component containerComponent, String componentInstanceId,
1630 List<ComponentInstanceProperty> originalComponentInstProps,
1631 ComponentInstanceProperty property) {
1632 StorageOperationStatus status;
1633 // check if the property already exists or not
1634 Optional<ComponentInstanceProperty> instanceProperty = originalComponentInstProps.stream()
1635 .filter(p -> p.getUniqueId().equals(property.getUniqueId())).findAny();
1636 if (instanceProperty.isPresent()) {
1637 status = updateComponentInstanceProperty(containerComponent, componentInstanceId, property);
1639 status = addComponentInstanceProperty(containerComponent, componentInstanceId, property);
1641 if (status != StorageOperationStatus.OK) {
1642 log.debug("Failed to update instance property {} for instance {} error {} ", property, componentInstanceId, status);
1647 private StorageOperationStatus updateOrAddComponentInstanceAttribute(Component containerComponent, String componentInstanceId,
1648 List<ComponentInstanceAttribute> originalComponentInstProps,
1649 ComponentInstanceAttribute property) {
1650 StorageOperationStatus status;
1651 // check if the property already exists or not
1652 Optional<ComponentInstanceAttribute> instanceProperty = originalComponentInstProps.stream()
1653 .filter(p -> p.getUniqueId().equals(property.getUniqueId())).findAny();
1654 if (instanceProperty.isPresent()) {
1655 status = updateComponentInstanceAttribute(containerComponent, componentInstanceId, property);
1657 status = addComponentInstanceAttribute(containerComponent, componentInstanceId, property);
1659 if (status != StorageOperationStatus.OK) {
1660 log.debug("Failed to update instance property {} for instance {} error {} ", property, componentInstanceId, status);
1665 public StorageOperationStatus updateInstanceCapabilityProperty(Component containerComponent, String componentInstanceId,
1666 ComponentInstanceProperty property, CapabilityDefinition capabilityDefinition) {
1667 Optional<ComponentInstance> fetchedCIOptional = containerComponent.getComponentInstanceById(componentInstanceId);
1668 if (!fetchedCIOptional.isPresent()) {
1669 return StorageOperationStatus.GENERAL_ERROR;
1671 Either<Component, StorageOperationStatus> getComponentRes = getToscaFullElement(fetchedCIOptional.get().getComponentUid());
1672 if (getComponentRes.isRight()) {
1673 return StorageOperationStatus.GENERAL_ERROR;
1675 Optional<Component> componentOptional = isNodeServiceProxy(getComponentRes.left().value());
1677 if (!componentOptional.isPresent()) {
1678 propOwner = componentInstanceId;
1680 propOwner = fetchedCIOptional.get().getSourceModelUid();
1682 StorageOperationStatus status;
1683 StringBuilder sb = new StringBuilder(componentInstanceId);
1684 sb.append(ModelConverter.CAP_PROP_DELIM).append(propOwner).append(ModelConverter.CAP_PROP_DELIM).append(capabilityDefinition.getType())
1685 .append(ModelConverter.CAP_PROP_DELIM).append(capabilityDefinition.getName());
1686 String capKey = sb.toString();
1687 status = updateComponentInstanceCapabiltyProperty(containerComponent, componentInstanceId, capKey, property);
1688 if (status != StorageOperationStatus.OK) {
1689 log.debug("Failed to update instance capability property {} for instance {} error {} ", property, componentInstanceId, status);
1692 return StorageOperationStatus.OK;
1695 private Optional<Component> isNodeServiceProxy(Component component) {
1696 if (component.getComponentType().equals(ComponentTypeEnum.SERVICE)) {
1697 return Optional.empty();
1699 Resource resource = (Resource) component;
1700 ResourceTypeEnum resType = resource.getResourceType();
1701 if (resType.equals(ResourceTypeEnum.ServiceProxy)) {
1702 return Optional.of(component);
1704 return Optional.empty();
1707 public StorageOperationStatus associateCapabilitiesToService(Map<String, ListCapabilityDataDefinition> capabilities, String componentId) {
1708 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
1709 if (getVertexEither.isRight()) {
1710 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
1711 return DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value());
1713 GraphVertex vertex = getVertexEither.left().value();
1714 if (MapUtils.isNotEmpty(capabilities)) {
1715 Either<GraphVertex, StorageOperationStatus> associateElementToData = topologyTemplateOperation
1716 .associateElementToData(vertex, VertexTypeEnum.CAPABILITIES, EdgeLabelEnum.CAPABILITIES, capabilities);
1717 if (associateElementToData.isRight()) {
1718 return associateElementToData.right().value();
1721 return StorageOperationStatus.OK;
1724 public StorageOperationStatus associateRequirementsToService(Map<String, ListRequirementDataDefinition> requirements, String componentId) {
1725 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
1726 if (getVertexEither.isRight()) {
1727 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
1728 return DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value());
1730 GraphVertex vertex = getVertexEither.left().value();
1731 if (MapUtils.isNotEmpty(requirements)) {
1732 Either<GraphVertex, StorageOperationStatus> associateElementToData = topologyTemplateOperation
1733 .associateElementToData(vertex, VertexTypeEnum.REQUIREMENTS, EdgeLabelEnum.REQUIREMENTS, requirements);
1734 if (associateElementToData.isRight()) {
1735 return associateElementToData.right().value();
1738 return StorageOperationStatus.OK;
1741 public StorageOperationStatus associateDeploymentArtifactsToInstances(Map<String, Map<String, ArtifactDefinition>> instDeploymentArtifacts,
1742 Component component, User user) {
1743 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao
1744 .getVertexById(component.getUniqueId(), JsonParseFlagEnum.NoParse);
1745 if (getVertexEither.isRight()) {
1746 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, component.getUniqueId(), getVertexEither.right().value());
1747 return DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value());
1749 GraphVertex vertex = getVertexEither.left().value();
1750 Map<String, MapArtifactDataDefinition> instArtMap = new HashMap<>();
1751 if (instDeploymentArtifacts != null) {
1752 MapArtifactDataDefinition artifactsMap;
1753 for (Entry<String, Map<String, ArtifactDefinition>> entry : instDeploymentArtifacts.entrySet()) {
1754 Map<String, ArtifactDefinition> artList = entry.getValue();
1755 Map<String, ArtifactDataDefinition> artifacts = artList.entrySet().stream()
1756 .collect(Collectors.toMap(Map.Entry::getKey, e -> new ArtifactDataDefinition(e.getValue())));
1757 artifactsMap = nodeTemplateOperation
1758 .prepareInstDeploymentArtifactPerInstance(artifacts, entry.getKey(), user, NodeTemplateOperation.HEAT_VF_ENV_NAME);
1759 instArtMap.put(entry.getKey(), artifactsMap);
1762 ModelConverter.setComponentInstancesDeploymentArtifactsToComponent(instArtMap, component);
1763 return topologyTemplateOperation.associateInstDeploymentArtifactsToComponent(vertex, instArtMap);
1766 public StorageOperationStatus associateArtifactsToInstances(Map<String, Map<String, ArtifactDefinition>> instArtifacts, Component component) {
1767 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao
1768 .getVertexById(component.getUniqueId(), JsonParseFlagEnum.NoParse);
1769 if (getVertexEither.isRight()) {
1770 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, component.getUniqueId(), getVertexEither.right().value());
1771 return DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value());
1773 GraphVertex vertex = getVertexEither.left().value();
1774 Map<String, MapArtifactDataDefinition> instArtMap = new HashMap<>();
1775 if (instArtifacts != null) {
1776 MapArtifactDataDefinition artifactsMap;
1777 for (Entry<String, Map<String, ArtifactDefinition>> entry : instArtifacts.entrySet()) {
1778 Map<String, ArtifactDefinition> artList = entry.getValue();
1779 Map<String, ArtifactDataDefinition> artifacts = artList.entrySet().stream()
1780 .collect(Collectors.toMap(Map.Entry::getKey, e -> new ArtifactDataDefinition(e.getValue())));
1781 artifactsMap = new MapArtifactDataDefinition(artifacts);
1782 instArtMap.put(entry.getKey(), artifactsMap);
1785 ModelConverter.setComponentInstancesInformationalArtifactsToComponent(instArtMap, component);
1786 return topologyTemplateOperation.associateInstArtifactsToComponent(vertex, instArtMap);
1789 public StorageOperationStatus associateInstAttributeToComponentToInstances(Map<String, List<AttributeDefinition>> instArttributes,
1790 Component component) {
1791 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao
1792 .getVertexById(component.getUniqueId(), JsonParseFlagEnum.NoParse);
1793 if (getVertexEither.isRight()) {
1794 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, component.getUniqueId(), getVertexEither.right().value());
1795 return DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value());
1797 GraphVertex vertex = getVertexEither.left().value();
1798 Map<String, MapAttributesDataDefinition> instAttr = new HashMap<>();
1799 if (instArttributes != null) {
1800 MapAttributesDataDefinition attributesMap;
1801 for (Entry<String, List<AttributeDefinition>> entry : instArttributes.entrySet()) {
1802 final List<AttributeDefinition> value = entry.getValue();
1803 attributesMap = new MapAttributesDataDefinition();
1804 attributesMap.setMapToscaDataDefinition(
1805 value.stream().map(AttributeDefinition::new).collect(Collectors.toMap(AttributeDefinition::getName, e -> e)));
1806 instAttr.put(entry.getKey(), attributesMap);
1809 setComponentInstanceAttributesOnComponent(component, instAttr);
1810 return topologyTemplateOperation.associateInstAttributeToComponent(vertex, instAttr);
1814 private void setComponentInstanceAttributesOnComponent(Component resource, Map<String, MapAttributesDataDefinition> instAttr) {
1815 Map<String, List<ComponentInstanceAttribute>> componentInstancesAttributes = resource.getComponentInstancesAttributes();
1816 if (componentInstancesAttributes == null) {
1817 componentInstancesAttributes = new HashMap<>();
1819 componentInstancesAttributes.putAll(ModelConverter.getComponentInstancesAttributes(instAttr));
1820 resource.setComponentInstancesAttributes(componentInstancesAttributes);
1823 public StorageOperationStatus associateOrAddCalculatedCapReq(Map<ComponentInstance, Map<String, List<CapabilityDefinition>>> instCapabilties,
1824 Map<ComponentInstance, Map<String, List<RequirementDefinition>>> instReg,
1825 Component component) {
1826 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao
1827 .getVertexById(component.getUniqueId(), JsonParseFlagEnum.NoParse);
1828 if (getVertexEither.isRight()) {
1829 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, component.getUniqueId(), getVertexEither.right().value());
1830 return DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value());
1832 GraphVertex vertex = getVertexEither.left().value();
1833 Map<String, MapListRequirementDataDefinition> calcRequirements = new HashMap<>();
1834 Map<String, MapListCapabilityDataDefinition> calcCapabilty = new HashMap<>();
1835 Map<String, MapCapabilityProperty> calculatedCapabilitiesProperties = new HashMap<>();
1836 if (instCapabilties != null) {
1837 for (Entry<ComponentInstance, Map<String, List<CapabilityDefinition>>> entry : instCapabilties.entrySet()) {
1838 Map<String, List<CapabilityDefinition>> caps = entry.getValue();
1839 Map<String, ListCapabilityDataDefinition> mapToscaDataDefinition = new HashMap<>();
1840 for (Entry<String, List<CapabilityDefinition>> instCapability : caps.entrySet()) {
1841 mapToscaDataDefinition.put(instCapability.getKey(), new ListCapabilityDataDefinition(
1842 instCapability.getValue().stream().map(CapabilityDataDefinition::new).collect(Collectors.toList())));
1844 ComponentInstanceDataDefinition componentInstance = new ComponentInstanceDataDefinition(entry.getKey());
1845 MapListCapabilityDataDefinition capMap = nodeTemplateOperation
1846 .prepareCalculatedCapabiltyForNodeType(mapToscaDataDefinition, componentInstance);
1847 MapCapabilityProperty mapCapabilityProperty = ModelConverter
1848 .convertToMapOfMapCapabiltyProperties(caps, componentInstance.getUniqueId(), true);
1849 calcCapabilty.put(entry.getKey().getUniqueId(), capMap);
1850 calculatedCapabilitiesProperties.put(entry.getKey().getUniqueId(), mapCapabilityProperty);
1853 if (instReg != null) {
1854 for (Entry<ComponentInstance, Map<String, List<RequirementDefinition>>> entry : instReg.entrySet()) {
1855 Map<String, List<RequirementDefinition>> req = entry.getValue();
1856 Map<String, ListRequirementDataDefinition> mapToscaDataDefinition = new HashMap<>();
1857 for (Entry<String, List<RequirementDefinition>> instReq : req.entrySet()) {
1858 mapToscaDataDefinition.put(instReq.getKey(), new ListRequirementDataDefinition(
1859 instReq.getValue().stream().map(RequirementDataDefinition::new).collect(Collectors.toList())));
1861 MapListRequirementDataDefinition reqMap = nodeTemplateOperation
1862 .prepareCalculatedRequirementForNodeType(mapToscaDataDefinition, new ComponentInstanceDataDefinition(entry.getKey()));
1863 String componentInstanceId = entry.getKey().getUniqueId();
1864 calcRequirements.put(componentInstanceId, reqMap);
1867 StorageOperationStatus storageOperationStatus = topologyTemplateOperation
1868 .associateOrAddCalcCapReqToComponent(vertex, calcRequirements, calcCapabilty, calculatedCapabilitiesProperties);
1869 updateInstancesCapAndReqOnComponentFromDB(component);
1870 return storageOperationStatus;
1873 public StorageOperationStatus updateCalculatedCapabilitiesRequirements(final Map<ComponentInstance, Map<String, List<CapabilityDefinition>>> instCapabilties,
1874 final Map<ComponentInstance, Map<String, List<RequirementDefinition>>> instReg,
1875 final Component component) {
1876 StorageOperationStatus storageOperationStatus = StorageOperationStatus.OK;
1877 if (instCapabilties != null) {
1878 for (Entry<ComponentInstance, Map<String, List<CapabilityDefinition>>> entry : instCapabilties.entrySet()) {
1879 final Map<String, List<CapabilityDefinition>> cap = entry.getValue();
1880 for (List<CapabilityDefinition> capabilityList: cap.values()) {
1881 for (CapabilityDefinition capability: capabilityList) {
1882 nodeTemplateOperation.updateComponentInstanceCapabilities(component.getUniqueId(), entry.getKey().getUniqueId(), capability);
1887 if (instReg != null) {
1888 for (Entry<ComponentInstance, Map<String, List<RequirementDefinition>>> entry : instReg.entrySet()) {
1889 final Map<String, List<RequirementDefinition>> req = entry.getValue();
1890 for (List<RequirementDefinition> requirementList: req.values()) {
1891 for (RequirementDefinition requirement: requirementList) {
1892 storageOperationStatus = nodeTemplateOperation.updateComponentInstanceRequirement(component.getUniqueId(), entry.getKey().getUniqueId(), requirement);
1893 if (storageOperationStatus != StorageOperationStatus.OK) {
1894 return storageOperationStatus;
1900 return storageOperationStatus;
1903 private void updateInstancesCapAndReqOnComponentFromDB(Component component) {
1904 ComponentParametersView componentParametersView = new ComponentParametersView(true);
1905 componentParametersView.setIgnoreCapabilities(false);
1906 componentParametersView.setIgnoreRequirements(false);
1907 componentParametersView.setIgnoreCapabiltyProperties(false);
1908 componentParametersView.setIgnoreComponentInstances(false);
1909 Either<Component, StorageOperationStatus> componentEither = getToscaElement(component.getUniqueId(), componentParametersView);
1910 if (componentEither.isRight()) {
1911 throw new StorageException(StorageOperationStatus.NOT_FOUND);
1913 Component updatedComponent = componentEither.left().value();
1914 component.setCapabilities(updatedComponent.getCapabilities());
1915 component.setRequirements(updatedComponent.getRequirements());
1916 component.setComponentInstances(updatedComponent.getComponentInstances());
1919 private Either<List<Service>, StorageOperationStatus> getLatestVersionNonCheckoutServicesMetadataOnly(Map<GraphPropertyEnum, Object> hasProps,
1920 Map<GraphPropertyEnum, Object> hasNotProps,
1922 List<Service> services = new ArrayList<>();
1923 List<LifecycleStateEnum> states = new ArrayList<>();
1925 hasProps.put(GraphPropertyEnum.COMPONENT_TYPE, ComponentTypeEnum.SERVICE.name());
1926 hasProps.put(GraphPropertyEnum.IS_HIGHEST_VERSION, true);
1927 if (modelName != null) {
1928 hasProps.put(GraphPropertyEnum.MODEL, modelName);
1931 states.add(LifecycleStateEnum.NOT_CERTIFIED_CHECKOUT);
1932 hasNotProps.put(GraphPropertyEnum.STATE, states);
1933 hasNotProps.put(GraphPropertyEnum.IS_DELETED, true);
1934 hasNotProps.put(GraphPropertyEnum.IS_ARCHIVED, true);
1935 return fetchServicesByCriteria(services, hasProps, hasNotProps, modelName);
1938 private Either<List<Component>, StorageOperationStatus> getLatestVersionNotAbstractToscaElementsMetadataOnly(final boolean isAbstract,
1939 final ComponentTypeEnum componentTypeEnum,
1940 final String internalComponentType,
1941 final VertexTypeEnum vertexType,
1942 final String modelName,
1943 final boolean includeNormativeExtensionModels) {
1944 List<Service> services = null;
1945 Map<GraphPropertyEnum, Object> hasProps = new EnumMap<>(GraphPropertyEnum.class);
1946 Map<GraphPropertyEnum, Object> hasNotProps = new EnumMap<>(GraphPropertyEnum.class);
1947 fillPropsMap(hasProps, hasNotProps, internalComponentType, componentTypeEnum, isAbstract, vertexType, modelName);
1948 Either<List<GraphVertex>, JanusGraphOperationStatus> getRes = janusGraphDao
1949 .getByCriteria(vertexType, hasProps, hasNotProps, JsonParseFlagEnum.ParseMetadata, modelName, includeNormativeExtensionModels);
1950 if (getRes.isRight() && !JanusGraphOperationStatus.NOT_FOUND.equals(getRes.right().value())) {
1951 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getRes.right().value()));
1953 // region -> Fetch non checked-out services
1954 if (internalComponentType != null && internalComponentType.toLowerCase().trim().equals(SERVICE) && VertexTypeEnum.NODE_TYPE == vertexType) {
1955 Either<List<Service>, StorageOperationStatus> result = getLatestVersionNonCheckoutServicesMetadataOnly(
1956 new EnumMap<>(GraphPropertyEnum.class), new EnumMap<>(GraphPropertyEnum.class), modelName);
1957 if (result.isRight()) {
1958 log.debug("Failed to fetch services for");
1959 return Either.right(result.right().value());
1961 services = result.left().value();
1962 if (log.isTraceEnabled() && isEmpty(services)) {
1963 log.trace("No relevant services available");
1967 List<Component> nonAbstractLatestComponents = new ArrayList<>();
1968 ComponentParametersView params = new ComponentParametersView(true);
1969 params.setIgnoreAllVersions(false);
1970 if (getRes.isLeft()) {
1971 for (GraphVertex vertexComponent : getRes.left().value()) {
1972 Either<ToscaElement, StorageOperationStatus> componentRes = topologyTemplateOperation
1973 .getLightComponent(vertexComponent, componentTypeEnum, params);
1974 if (componentRes.isRight()) {
1975 log.debug("Failed to fetch light element for {} error {}", vertexComponent.getUniqueId(), componentRes.right().value());
1976 return Either.right(componentRes.right().value());
1978 Component component = ModelConverter.convertFromToscaElement(componentRes.left().value());
1979 nonAbstractLatestComponents.add(component);
1983 if (CollectionUtils.isNotEmpty(services)) {
1984 nonAbstractLatestComponents.addAll(services);
1986 return Either.left(nonAbstractLatestComponents);
1989 public Either<ComponentMetadataData, StorageOperationStatus> getLatestComponentMetadataByUuid(String componentUuid, JsonParseFlagEnum parseFlag,
1990 Boolean isHighest) {
1991 Either<ComponentMetadataData, StorageOperationStatus> result;
1992 Map<GraphPropertyEnum, Object> hasProperties = new EnumMap<>(GraphPropertyEnum.class);
1993 hasProperties.put(GraphPropertyEnum.UUID, componentUuid);
1994 if (isHighest != null) {
1995 hasProperties.put(GraphPropertyEnum.IS_HIGHEST_VERSION, isHighest);
1997 Map<GraphPropertyEnum, Object> propertiesNotToMatch = new EnumMap<>(GraphPropertyEnum.class);
1998 propertiesNotToMatch.put(GraphPropertyEnum.IS_DELETED, true);
1999 propertiesNotToMatch.put(GraphPropertyEnum.IS_ARCHIVED, true); //US382674, US382683
2000 Either<List<GraphVertex>, JanusGraphOperationStatus> getRes = janusGraphDao
2001 .getByCriteria(null, hasProperties, propertiesNotToMatch, parseFlag);
2002 if (getRes.isRight()) {
2003 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getRes.right().value()));
2005 List<ComponentMetadataData> latestVersionList = getRes.left().value().stream().map(ModelConverter::convertToComponentMetadata)
2006 .collect(Collectors.toList());
2007 ComponentMetadataData latestVersion = latestVersionList.size() == 1 ? latestVersionList.get(0) : latestVersionList.stream().max(
2008 (c1, c2) -> Double.compare(Double.parseDouble(c1.getMetadataDataDefinition().getVersion()),
2009 Double.parseDouble(c2.getMetadataDataDefinition().getVersion()))).get();
2010 result = Either.left(latestVersion);
2015 public Either<ComponentMetadataData, StorageOperationStatus> getComponentMetadata(String componentId) {
2016 Either<ComponentMetadataData, StorageOperationStatus> result;
2017 Either<GraphVertex, JanusGraphOperationStatus> getRes = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.ParseMetadata);
2018 if (getRes.isRight()) {
2019 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getRes.right().value()));
2021 ComponentMetadataData componentMetadata = ModelConverter.convertToComponentMetadata(getRes.left().value());
2022 result = Either.left(componentMetadata);
2027 public Either<List<Component>, StorageOperationStatus> getLatestVersionNotAbstractComponents(boolean isAbstract,
2028 ComponentTypeEnum componentTypeEnum,
2029 String internalComponentType,
2030 List<String> componentUids) {
2031 List<Component> components = new ArrayList<>();
2032 if (componentUids == null) {
2033 Either<List<String>, StorageOperationStatus> componentUidsRes = getComponentUids(isAbstract, componentTypeEnum, internalComponentType);
2034 if (componentUidsRes.isRight()) {
2035 return Either.right(componentUidsRes.right().value());
2037 componentUids = componentUidsRes.left().value();
2039 if (!isEmpty(componentUids)) {
2040 for (String componentUid : componentUids) {
2041 ComponentParametersView componentParametersView = buildComponentViewForNotAbstract();
2042 if ("vl".equalsIgnoreCase(internalComponentType)) {
2043 componentParametersView.setIgnoreCapabilities(false);
2044 componentParametersView.setIgnoreRequirements(false);
2046 Either<ToscaElement, StorageOperationStatus> getToscaElementRes = nodeTemplateOperation.getToscaElementOperation(componentTypeEnum)
2047 .getLightComponent(componentUid, componentTypeEnum, componentParametersView);
2048 if (getToscaElementRes.isRight()) {
2049 log.debug("Failed to fetch resource for error is {}", getToscaElementRes.right().value());
2050 return Either.right(getToscaElementRes.right().value());
2052 Component component = ModelConverter.convertFromToscaElement(getToscaElementRes.left().value());
2053 nullifySomeComponentProperties(component);
2054 components.add(component);
2057 return Either.left(components);
2060 public void nullifySomeComponentProperties(Component component) {
2061 component.setContactId(null);
2062 component.setCreationDate(null);
2063 component.setCreatorUserId(null);
2064 component.setCreatorFullName(null);
2065 component.setLastUpdateDate(null);
2066 component.setLastUpdaterUserId(null);
2067 component.setLastUpdaterFullName(null);
2068 component.setNormalizedName(null);
2071 private Either<List<String>, StorageOperationStatus> getComponentUids(boolean isAbstract, ComponentTypeEnum componentTypeEnum,
2072 String internalComponentType) {
2073 Either<List<Component>, StorageOperationStatus> getToscaElementsRes = getLatestVersionNotAbstractMetadataOnly(isAbstract, componentTypeEnum,
2074 internalComponentType, null, false);
2075 if (getToscaElementsRes.isRight()) {
2076 return Either.right(getToscaElementsRes.right().value());
2078 List<Component> collection = getToscaElementsRes.left().value();
2079 List<String> componentUids;
2080 if (collection == null) {
2081 componentUids = new ArrayList<>();
2083 componentUids = collection.stream().map(Component::getUniqueId).collect(Collectors.toList());
2085 return Either.left(componentUids);
2088 private ComponentParametersView buildComponentViewForNotAbstract() {
2089 ComponentParametersView componentParametersView = new ComponentParametersView();
2090 componentParametersView.disableAll();
2091 componentParametersView.setIgnoreCategories(false);
2092 componentParametersView.setIgnoreAllVersions(false);
2093 return componentParametersView;
2096 public Either<Boolean, StorageOperationStatus> validateComponentNameExists(String name, ResourceTypeEnum resourceType,
2097 ComponentTypeEnum componentType) {
2098 Either<Boolean, StorageOperationStatus> result = validateComponentNameUniqueness(name, resourceType, componentType);
2099 if (result.isLeft()) {
2100 result = Either.left(!result.left().value());
2104 public Either<Boolean, StorageOperationStatus> validateComponentNameUniqueness(String name, ResourceTypeEnum resourceType,
2105 ComponentTypeEnum componentType) {
2106 String normalizedName = ValidationUtils.normaliseComponentName(name);
2107 Either<List<GraphVertex>, JanusGraphOperationStatus> vertexEither = janusGraphDao
2108 .getByCriteria(getVertexTypeEnum(resourceType), propertiesToMatch(normalizedName, componentType), JsonParseFlagEnum.NoParse);
2109 if (vertexEither.isRight() && vertexEither.right().value() != JanusGraphOperationStatus.NOT_FOUND) {
2110 log.debug("failed to get vertex from graph with property normalizedName: {}", normalizedName);
2111 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(vertexEither.right().value()));
2113 return Either.left(CollectionUtils.isEmpty(vertexEither.isLeft() ? vertexEither.left().value() : null));
2116 public Either<Boolean, StorageOperationStatus> validateComponentNameAndModelExists(final String resourceName, final String model,
2117 final ResourceTypeEnum resourceType,
2118 final ComponentTypeEnum componentType) {
2119 Either<Boolean, StorageOperationStatus> result = validateComponentNameAndModelUniqueness(resourceName, model, resourceType, componentType);
2120 if (result.isLeft()) {
2121 result = Either.left(!result.left().value());
2126 private Either<Boolean, StorageOperationStatus> validateComponentNameAndModelUniqueness(final String resourceName, final String modelName,
2127 final ResourceTypeEnum resourceType,
2128 final ComponentTypeEnum componentType) {
2129 final String normalizedName = ValidationUtils.normaliseComponentName(resourceName);
2130 final Either<List<GraphVertex>, JanusGraphOperationStatus> vertexEither = janusGraphDao
2131 .getByCriteria(getVertexTypeEnum(resourceType), propertiesToMatch(normalizedName, componentType), null, null, JsonParseFlagEnum.NoParse, modelName);
2132 if (vertexEither.isRight() && vertexEither.right().value() != JanusGraphOperationStatus.NOT_FOUND) {
2133 log.debug("failed to get vertex from graph with property normalizedName: {} and model: {}", normalizedName, modelName);
2134 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(vertexEither.right().value()));
2136 return Either.left(CollectionUtils.isEmpty(vertexEither.isLeft() ? vertexEither.left().value().stream()
2137 .collect(Collectors.toList()) : null));
2140 private VertexTypeEnum getVertexTypeEnum(final ResourceTypeEnum resourceType) {
2141 return ModelConverter.isAtomicComponent(resourceType) ? VertexTypeEnum.NODE_TYPE : VertexTypeEnum.TOPOLOGY_TEMPLATE;
2144 private Map<GraphPropertyEnum, Object> propertiesToMatch(final String normalizedName, final ComponentTypeEnum componentType) {
2145 final Map<GraphPropertyEnum, Object> properties = new EnumMap<>(GraphPropertyEnum.class);
2146 properties.put(GraphPropertyEnum.NORMALIZED_NAME, normalizedName);
2147 properties.put(GraphPropertyEnum.COMPONENT_TYPE, componentType.name());
2151 private void fillNodeTypePropsMap(final Map<GraphPropertyEnum, Object> hasProps, final Map<GraphPropertyEnum, Object> hasNotProps,
2152 final String internalComponentType) {
2153 final Configuration configuration = ConfigurationManager.getConfigurationManager().getConfiguration();
2154 final List<String> allowedTypes;
2155 if (ComponentTypeEnum.SERVICE.getValue().equalsIgnoreCase(internalComponentType)) {
2156 allowedTypes = containerInstanceTypesData.getComponentAllowedList(ComponentTypeEnum.SERVICE, null);
2158 final ResourceTypeEnum resourceType = ResourceTypeEnum.getTypeIgnoreCase(internalComponentType);
2159 allowedTypes = containerInstanceTypesData.getComponentAllowedList(ComponentTypeEnum.RESOURCE, resourceType);
2161 final List<String> allResourceTypes = configuration.getResourceTypes();
2162 if (allowedTypes == null) {
2163 hasNotProps.put(GraphPropertyEnum.RESOURCE_TYPE, allResourceTypes);
2166 if (ResourceTypeEnum.VL.getValue().equalsIgnoreCase(internalComponentType)) {
2167 hasProps.put(GraphPropertyEnum.RESOURCE_TYPE, allowedTypes);
2169 final List<String> notAllowedTypes = allResourceTypes.stream().filter(s -> !allowedTypes.contains(s)).collect(Collectors.toList());
2170 hasNotProps.put(GraphPropertyEnum.RESOURCE_TYPE, notAllowedTypes);
2174 private void fillTopologyTemplatePropsMap(Map<GraphPropertyEnum, Object> hasProps, Map<GraphPropertyEnum, Object> hasNotProps,
2175 ComponentTypeEnum componentTypeEnum) {
2176 switch (componentTypeEnum) {
2178 hasProps.put(GraphPropertyEnum.COMPONENT_TYPE, ComponentTypeEnum.RESOURCE.name());
2181 hasProps.put(GraphPropertyEnum.COMPONENT_TYPE, ComponentTypeEnum.SERVICE.name());
2186 hasNotProps.put(GraphPropertyEnum.RESOURCE_TYPE, ResourceTypeEnum.CVFC.name());
2189 private void fillPropsMap(Map<GraphPropertyEnum, Object> hasProps, Map<GraphPropertyEnum, Object> hasNotProps, String internalComponentType,
2190 ComponentTypeEnum componentTypeEnum, boolean isAbstract, VertexTypeEnum internalVertexType, String modelName) {
2191 hasNotProps.put(GraphPropertyEnum.STATE, LifecycleStateEnum.NOT_CERTIFIED_CHECKOUT.name());
2192 hasNotProps.put(GraphPropertyEnum.IS_DELETED, true);
2193 hasNotProps.put(GraphPropertyEnum.IS_ARCHIVED, true);
2194 hasProps.put(GraphPropertyEnum.IS_HIGHEST_VERSION, true);
2196 if (VertexTypeEnum.NODE_TYPE == internalVertexType) {
2197 hasProps.put(GraphPropertyEnum.IS_ABSTRACT, isAbstract);
2198 if (internalComponentType != null) {
2199 fillNodeTypePropsMap(hasProps, hasNotProps, internalComponentType);
2202 fillTopologyTemplatePropsMap(hasProps, hasNotProps, componentTypeEnum);
2206 private List<VertexTypeEnum> getInternalVertexTypes(ComponentTypeEnum componentTypeEnum, String internalComponentType) {
2207 List<VertexTypeEnum> internalVertexTypes = new ArrayList<>();
2208 if (ComponentTypeEnum.RESOURCE == componentTypeEnum) {
2209 internalVertexTypes.add(VertexTypeEnum.NODE_TYPE);
2211 if (ComponentTypeEnum.SERVICE == componentTypeEnum || SERVICE.equalsIgnoreCase(internalComponentType)) {
2212 internalVertexTypes.add(VertexTypeEnum.TOPOLOGY_TEMPLATE);
2214 return internalVertexTypes;
2217 public Either<List<Component>, StorageOperationStatus> getLatestVersionNotAbstractMetadataOnly(boolean isAbstract,
2218 final ComponentTypeEnum componentTypeEnum,
2219 final String internalComponentType,
2220 final String modelName,
2221 final boolean includeNormativeExtensionModels) {
2222 List<VertexTypeEnum> internalVertexTypes = getInternalVertexTypes(componentTypeEnum, internalComponentType);
2223 List<Component> result = new ArrayList<>();
2224 for (VertexTypeEnum vertexType : internalVertexTypes) {
2225 Either<List<Component>, StorageOperationStatus> listByVertexType = getLatestVersionNotAbstractToscaElementsMetadataOnly(isAbstract,
2226 componentTypeEnum, internalComponentType, vertexType, modelName, includeNormativeExtensionModels);
2227 if (listByVertexType.isRight()) {
2228 return listByVertexType;
2230 result.addAll(listByVertexType.left().value());
2232 return Either.left(result);
2235 private Either<List<Component>, StorageOperationStatus> getLatestComponentListByUuid(String componentUuid,
2236 Map<GraphPropertyEnum, Object> additionalPropertiesToMatch) {
2237 Map<GraphPropertyEnum, Object> propertiesToMatch = new EnumMap<>(GraphPropertyEnum.class);
2238 if (additionalPropertiesToMatch != null) {
2239 propertiesToMatch.putAll(additionalPropertiesToMatch);
2241 propertiesToMatch.put(GraphPropertyEnum.IS_HIGHEST_VERSION, true);
2242 return getComponentListByUuid(componentUuid, propertiesToMatch);
2245 public Either<Component, StorageOperationStatus> getComponentByUuidAndVersion(String componentUuid, String version) {
2246 Map<GraphPropertyEnum, Object> propertiesToMatch = new EnumMap<>(GraphPropertyEnum.class);
2247 propertiesToMatch.put(GraphPropertyEnum.UUID, componentUuid);
2248 propertiesToMatch.put(GraphPropertyEnum.VERSION, version);
2249 Map<GraphPropertyEnum, Object> propertiesNotToMatch = new EnumMap<>(GraphPropertyEnum.class);
2250 propertiesNotToMatch.put(GraphPropertyEnum.IS_DELETED, true);
2251 Either<List<GraphVertex>, JanusGraphOperationStatus> vertexEither = janusGraphDao
2252 .getByCriteria(null, propertiesToMatch, propertiesNotToMatch, JsonParseFlagEnum.ParseAll);
2253 if (vertexEither.isRight()) {
2254 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(vertexEither.right().value()));
2256 List<GraphVertex> vertexList = vertexEither.isLeft() ? vertexEither.left().value() : null;
2257 if (vertexList == null || vertexList.isEmpty() || vertexList.size() > 1) {
2258 return Either.right(StorageOperationStatus.NOT_FOUND);
2260 return getToscaElementByOperation(vertexList.get(0));
2263 public Either<List<Component>, StorageOperationStatus> getComponentListByUuid(String componentUuid,
2264 Map<GraphPropertyEnum, Object> additionalPropertiesToMatch) {
2265 Map<GraphPropertyEnum, Object> propertiesToMatch = new EnumMap<>(GraphPropertyEnum.class);
2266 if (additionalPropertiesToMatch != null) {
2267 propertiesToMatch.putAll(additionalPropertiesToMatch);
2269 propertiesToMatch.put(GraphPropertyEnum.UUID, componentUuid);
2270 Map<GraphPropertyEnum, Object> propertiesNotToMatch = new EnumMap<>(GraphPropertyEnum.class);
2271 propertiesNotToMatch.put(GraphPropertyEnum.IS_DELETED, true);
2272 propertiesNotToMatch.put(GraphPropertyEnum.IS_ARCHIVED, true); //US382674, US382683
2273 Either<List<GraphVertex>, JanusGraphOperationStatus> vertexEither = janusGraphDao
2274 .getByCriteria(null, propertiesToMatch, propertiesNotToMatch, JsonParseFlagEnum.ParseAll);
2275 if (vertexEither.isRight()) {
2276 log.debug("Couldn't fetch metadata for component with uuid {}, error: {}", componentUuid, vertexEither.right().value());
2277 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(vertexEither.right().value()));
2279 List<GraphVertex> vertexList = vertexEither.isLeft() ? vertexEither.left().value() : null;
2280 if (vertexList == null || vertexList.isEmpty()) {
2281 log.debug("Component with uuid {} was not found", componentUuid);
2282 return Either.right(StorageOperationStatus.NOT_FOUND);
2284 ArrayList<Component> latestComponents = new ArrayList<>();
2285 for (GraphVertex vertex : vertexList) {
2286 Either<Component, StorageOperationStatus> toscaElementByOperation = getToscaElementByOperation(vertex);
2287 if (toscaElementByOperation.isRight()) {
2288 log.debug("Could not fetch the following Component by UUID {}", vertex.getUniqueId());
2289 return Either.right(toscaElementByOperation.right().value());
2291 latestComponents.add(toscaElementByOperation.left().value());
2293 if (latestComponents.size() > 1) {
2294 for (Component component : latestComponents) {
2295 if (Boolean.TRUE.equals(component.isHighestVersion())) {
2296 LinkedList<Component> highestComponent = new LinkedList<>();
2297 highestComponent.add(component);
2298 return Either.left(highestComponent);
2302 return Either.left(latestComponents);
2305 public Either<Component, StorageOperationStatus> getLatestServiceByUuid(String serviceUuid) {
2306 Map<GraphPropertyEnum, Object> propertiesToMatch = new EnumMap<>(GraphPropertyEnum.class);
2307 propertiesToMatch.put(GraphPropertyEnum.COMPONENT_TYPE, ComponentTypeEnum.SERVICE.name());
2308 return getLatestComponentByUuid(serviceUuid, propertiesToMatch);
2311 public Either<Component, StorageOperationStatus> getLatestComponentByUuid(String componentUuid) {
2312 return getLatestComponentByUuid(componentUuid, null);
2315 public Either<Component, StorageOperationStatus> getLatestComponentByUuid(String componentUuid,
2316 Map<GraphPropertyEnum, Object> propertiesToMatch) {
2317 Either<List<Component>, StorageOperationStatus> latestVersionListEither = getLatestComponentListByUuid(componentUuid, propertiesToMatch);
2318 if (latestVersionListEither.isRight()) {
2319 return Either.right(latestVersionListEither.right().value());
2321 List<Component> latestVersionList = latestVersionListEither.left().value();
2322 if (latestVersionList.isEmpty()) {
2323 return Either.right(StorageOperationStatus.NOT_FOUND);
2325 Component component = latestVersionList.size() == 1 ? latestVersionList.get(0)
2326 : latestVersionList.stream().max((c1, c2) -> Double.compare(Double.parseDouble(c1.getVersion()), Double.parseDouble(c2.getVersion())))
2328 return Either.left(component);
2331 public Either<List<Resource>, StorageOperationStatus> getAllCertifiedResources(boolean isAbstract, Boolean isHighest) {
2332 List<Resource> resources = new ArrayList<>();
2333 Map<GraphPropertyEnum, Object> propertiesToMatch = new EnumMap<>(GraphPropertyEnum.class);
2334 Map<GraphPropertyEnum, Object> propertiesNotToMatch = new EnumMap<>(GraphPropertyEnum.class);
2335 propertiesToMatch.put(GraphPropertyEnum.IS_ABSTRACT, isAbstract);
2336 if (isHighest != null) {
2337 propertiesToMatch.put(GraphPropertyEnum.IS_HIGHEST_VERSION, isHighest);
2339 propertiesToMatch.put(GraphPropertyEnum.STATE, LifecycleStateEnum.CERTIFIED.name());
2340 propertiesToMatch.put(GraphPropertyEnum.COMPONENT_TYPE, ComponentTypeEnum.RESOURCE.name());
2341 propertiesNotToMatch.put(GraphPropertyEnum.IS_DELETED, true);
2342 Either<List<GraphVertex>, JanusGraphOperationStatus> getResourcesRes = janusGraphDao
2343 .getByCriteria(null, propertiesToMatch, propertiesNotToMatch, JsonParseFlagEnum.ParseAll);
2344 if (getResourcesRes.isRight()) {
2345 log.debug("Failed to fetch all certified resources. Status is {}", getResourcesRes.right().value());
2346 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getResourcesRes.right().value()));
2348 List<GraphVertex> resourceVerticies = getResourcesRes.left().value();
2349 for (GraphVertex resourceV : resourceVerticies) {
2350 Either<Resource, StorageOperationStatus> getResourceRes = getToscaElement(resourceV);
2351 if (getResourceRes.isRight()) {
2352 return Either.right(getResourceRes.right().value());
2354 resources.add(getResourceRes.left().value());
2356 return Either.left(resources);
2359 public <T extends Component> Either<T, StorageOperationStatus> getLatestByNameAndVersion(String name, String version,
2360 JsonParseFlagEnum parseFlag, String model) {
2361 Either<T, StorageOperationStatus> result;
2362 Map<GraphPropertyEnum, Object> hasProperties = new EnumMap<>(GraphPropertyEnum.class);
2363 Map<GraphPropertyEnum, Object> hasNotProperties = new EnumMap<>(GraphPropertyEnum.class);
2364 hasProperties.put(GraphPropertyEnum.NAME, name);
2365 hasProperties.put(GraphPropertyEnum.VERSION, version);
2366 hasProperties.put(GraphPropertyEnum.IS_HIGHEST_VERSION, true);
2367 hasNotProperties.put(GraphPropertyEnum.IS_DELETED, true);
2368 Either<List<GraphVertex>, JanusGraphOperationStatus> getResourceRes = janusGraphDao
2369 .getByCriteria(null, hasProperties, hasNotProperties, parseFlag, model);
2370 if (getResourceRes.isRight()) {
2371 JanusGraphOperationStatus status = getResourceRes.right().value();
2372 log.debug("failed to find resource with name {}, version {}. Status is {} ", name, version, status);
2373 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status));
2376 return getToscaElementByOperation(getResourceRes.left().value().get(0));
2379 public Either<Resource, StorageOperationStatus> getLatestComponentByCsarOrName(ComponentTypeEnum componentType, String csarUUID,
2380 String systemName) {
2381 return getLatestComponentByCsarOrName(componentType, csarUUID, systemName, JsonParseFlagEnum.ParseAll);
2384 public Either<Resource, StorageOperationStatus> getLatestComponentByCsarOrName(ComponentTypeEnum componentType, String csarUUID,
2385 String systemName, JsonParseFlagEnum parseFlag) {
2386 Map<GraphPropertyEnum, Object> props = new EnumMap<>(GraphPropertyEnum.class);
2387 Map<GraphPropertyEnum, Object> propsHasNot = new EnumMap<>(GraphPropertyEnum.class);
2388 props.put(GraphPropertyEnum.CSAR_UUID, csarUUID);
2389 props.put(GraphPropertyEnum.IS_HIGHEST_VERSION, true);
2390 if (componentType != null) {
2391 props.put(GraphPropertyEnum.COMPONENT_TYPE, componentType.name());
2393 propsHasNot.put(GraphPropertyEnum.IS_DELETED, true);
2394 GraphVertex resourceMetadataData = null;
2395 List<GraphVertex> resourceMetadataDataList = null;
2396 Either<List<GraphVertex>, JanusGraphOperationStatus> byCsar = janusGraphDao
2397 .getByCriteria(null, props, propsHasNot, JsonParseFlagEnum.ParseMetadata);
2398 if (byCsar.isRight()) {
2399 if (JanusGraphOperationStatus.NOT_FOUND == byCsar.right().value()) {
2400 // Fix Defect DE256036
2401 if (StringUtils.isEmpty(systemName)) {
2402 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(JanusGraphOperationStatus.NOT_FOUND));
2405 props.put(GraphPropertyEnum.IS_HIGHEST_VERSION, true);
2406 props.put(GraphPropertyEnum.SYSTEM_NAME, systemName);
2407 Either<List<GraphVertex>, JanusGraphOperationStatus> bySystemname = janusGraphDao
2408 .getByCriteria(null, props, JsonParseFlagEnum.ParseMetadata);
2409 if (bySystemname.isRight()) {
2410 log.debug("getLatestResourceByCsarOrName - Failed to find by system name {} error {} ", systemName,
2411 bySystemname.right().value());
2412 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(bySystemname.right().value()));
2414 if (bySystemname.left().value().size() > 2) {
2416 "getLatestResourceByCsarOrName - getByCriteria(by system name) must return only 2 latest version, but was returned - {}",
2417 bySystemname.left().value().size());
2418 return Either.right(StorageOperationStatus.GENERAL_ERROR);
2420 resourceMetadataDataList = bySystemname.left().value();
2421 if (resourceMetadataDataList.size() == 1) {
2422 resourceMetadataData = resourceMetadataDataList.get(0);
2424 for (GraphVertex curResource : resourceMetadataDataList) {
2425 if (!((String) curResource.getJsonMetadataField(JsonPresentationFields.LIFECYCLE_STATE)).equals("CERTIFIED")) {
2426 resourceMetadataData = curResource;
2431 if (resourceMetadataData == null) {
2432 log.debug("getLatestResourceByCsarOrName - getByCriteria(by system name) returned 2 latest CERTIFIED versions");
2433 return Either.right(StorageOperationStatus.GENERAL_ERROR);
2435 final Object csarUuid = resourceMetadataData.getJsonMetadataField(JsonPresentationFields.CSAR_UUID);
2436 if (csarUuid != null && !csarUuid.equals(csarUUID)) {
2437 log.debug("getLatestResourceByCsarOrName - same system name {} but different csarUUID. exist {} and new {} ", systemName,
2438 csarUuid, csarUUID);
2439 // correct error will be returned from create flow. with all
2441 // correct audit records!!!!!
2442 return Either.right(StorageOperationStatus.NOT_FOUND);
2444 return getToscaElement(resourceMetadataData.getUniqueId());
2447 resourceMetadataDataList = byCsar.left().value();
2448 if (resourceMetadataDataList.size() > 2) {
2449 log.debug("getLatestResourceByCsarOrName - getByCriteria(by csar) must return only 2 latest version, but was returned - {}",
2450 byCsar.left().value().size());
2451 return Either.right(StorageOperationStatus.GENERAL_ERROR);
2453 if (resourceMetadataDataList.size() == 1) {
2454 resourceMetadataData = resourceMetadataDataList.get(0);
2456 for (GraphVertex curResource : resourceMetadataDataList) {
2457 if (!((String) curResource.getJsonMetadataField(JsonPresentationFields.LIFECYCLE_STATE)).equals("CERTIFIED")) {
2458 resourceMetadataData = curResource;
2463 if (resourceMetadataData == null) {
2464 log.debug("getLatestResourceByCsarOrName - getByCriteria(by csar) returned 2 latest CERTIFIED versions");
2465 return Either.right(StorageOperationStatus.GENERAL_ERROR);
2467 return getToscaElement((String) resourceMetadataData.getJsonMetadataField(JsonPresentationFields.UNIQUE_ID), parseFlag);
2472 public Either<Boolean, StorageOperationStatus> validateToscaResourceNameExtends(String templateNameCurrent, String templateNameExtends, String model) {
2473 String currentTemplateNameChecked = templateNameExtends;
2474 while (currentTemplateNameChecked != null && !currentTemplateNameChecked.equalsIgnoreCase(templateNameCurrent)) {
2475 Either<Resource, StorageOperationStatus> latestByToscaResourceName = getLatestByToscaResourceName(currentTemplateNameChecked, model);
2476 if (latestByToscaResourceName.isRight()) {
2477 return latestByToscaResourceName.right().value() == StorageOperationStatus.NOT_FOUND ? Either.left(false)
2478 : Either.right(latestByToscaResourceName.right().value());
2480 Resource value = latestByToscaResourceName.left().value();
2481 if (value.getDerivedFrom() != null) {
2482 currentTemplateNameChecked = value.getDerivedFrom().get(0);
2484 currentTemplateNameChecked = null;
2487 return (currentTemplateNameChecked != null && currentTemplateNameChecked.equalsIgnoreCase(templateNameCurrent)) ? Either.left(true)
2488 : Either.left(false);
2491 public Either<List<Component>, StorageOperationStatus> fetchMetaDataByResourceType(String resourceType, ComponentParametersView filterBy) {
2492 Map<GraphPropertyEnum, Object> props = new EnumMap<>(GraphPropertyEnum.class);
2493 props.put(GraphPropertyEnum.RESOURCE_TYPE, resourceType);
2494 props.put(GraphPropertyEnum.IS_HIGHEST_VERSION, true);
2495 Map<GraphPropertyEnum, Object> propsHasNotToMatch = new EnumMap<>(GraphPropertyEnum.class);
2496 propsHasNotToMatch.put(GraphPropertyEnum.IS_DELETED, true);
2497 Either<List<GraphVertex>, JanusGraphOperationStatus> resourcesByTypeEither = janusGraphDao
2498 .getByCriteria(null, props, propsHasNotToMatch, JsonParseFlagEnum.ParseMetadata);
2499 if (resourcesByTypeEither.isRight()) {
2500 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(resourcesByTypeEither.right().value()));
2502 List<GraphVertex> vertexList = resourcesByTypeEither.left().value();
2503 List<Component> components = new ArrayList<>();
2504 for (GraphVertex vertex : vertexList) {
2505 components.add(getToscaElementByOperation(vertex, filterBy).left().value());
2507 return Either.left(components);
2510 public void commit() {
2511 janusGraphDao.commit();
2514 public Either<Service, StorageOperationStatus> updateDistributionStatus(Service service, User user, DistributionStatusEnum distributionStatus) {
2515 Either<GraphVertex, StorageOperationStatus> updateDistributionStatus = topologyTemplateOperation
2516 .updateDistributionStatus(service.getUniqueId(), user, distributionStatus);
2517 if (updateDistributionStatus.isRight()) {
2518 return Either.right(updateDistributionStatus.right().value());
2520 GraphVertex serviceV = updateDistributionStatus.left().value();
2521 service.setDistributionStatus(distributionStatus);
2522 service.setLastUpdateDate((Long) serviceV.getJsonMetadataField(JsonPresentationFields.LAST_UPDATE_DATE));
2523 return Either.left(service);
2526 public Either<ComponentMetadataData, StorageOperationStatus> updateComponentLastUpdateDateOnGraph(Component component) {
2527 Either<ComponentMetadataData, StorageOperationStatus> result = null;
2528 GraphVertex serviceVertex;
2529 Either<GraphVertex, JanusGraphOperationStatus> updateRes = null;
2530 Either<GraphVertex, JanusGraphOperationStatus> getRes = janusGraphDao.getVertexById(component.getUniqueId(), JsonParseFlagEnum.ParseMetadata);
2531 if (getRes.isRight()) {
2532 JanusGraphOperationStatus status = getRes.right().value();
2533 log.error("Failed to fetch component {}. status is {}", component.getUniqueId(), status);
2534 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(status));
2536 if (result == null) {
2537 serviceVertex = getRes.left().value();
2538 long lastUpdateDate = System.currentTimeMillis();
2539 serviceVertex.setJsonMetadataField(JsonPresentationFields.LAST_UPDATE_DATE, lastUpdateDate);
2540 component.setLastUpdateDate(lastUpdateDate);
2541 updateRes = janusGraphDao.updateVertex(serviceVertex);
2542 if (updateRes.isRight()) {
2543 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(updateRes.right().value()));
2546 if (result == null) {
2547 result = Either.left(ModelConverter.convertToComponentMetadata(updateRes.left().value()));
2552 public HealingJanusGraphDao getJanusGraphDao() {
2553 return janusGraphDao;
2556 public Either<List<Service>, StorageOperationStatus> getCertifiedServicesWithDistStatus(Set<DistributionStatusEnum> distStatus) {
2557 Map<GraphPropertyEnum, Object> propertiesToMatch = new EnumMap<>(GraphPropertyEnum.class);
2558 propertiesToMatch.put(GraphPropertyEnum.STATE, LifecycleStateEnum.CERTIFIED.name());
2559 return getServicesWithDistStatus(distStatus, propertiesToMatch);
2562 public Either<List<Service>, StorageOperationStatus> getServicesWithDistStatus(Set<DistributionStatusEnum> distStatus,
2563 Map<GraphPropertyEnum, Object> additionalPropertiesToMatch) {
2564 List<Service> servicesAll = new ArrayList<>();
2565 Map<GraphPropertyEnum, Object> propertiesToMatch = new EnumMap<>(GraphPropertyEnum.class);
2566 Map<GraphPropertyEnum, Object> propertiesNotToMatch = new EnumMap<>(GraphPropertyEnum.class);
2567 if (additionalPropertiesToMatch != null && !additionalPropertiesToMatch.isEmpty()) {
2568 propertiesToMatch.putAll(additionalPropertiesToMatch);
2570 propertiesToMatch.put(GraphPropertyEnum.COMPONENT_TYPE, ComponentTypeEnum.SERVICE.name());
2571 propertiesNotToMatch.put(GraphPropertyEnum.IS_DELETED, true);
2572 if (distStatus != null && !distStatus.isEmpty()) {
2573 for (DistributionStatusEnum state : distStatus) {
2574 propertiesToMatch.put(GraphPropertyEnum.DISTRIBUTION_STATUS, state.name());
2575 Either<List<Service>, StorageOperationStatus> fetchServicesByCriteria = fetchServicesByCriteria(servicesAll, propertiesToMatch,
2576 propertiesNotToMatch, null);
2577 if (fetchServicesByCriteria.isRight()) {
2578 return fetchServicesByCriteria;
2580 servicesAll = fetchServicesByCriteria.left().value();
2583 return Either.left(servicesAll);
2585 return fetchServicesByCriteria(servicesAll, propertiesToMatch, propertiesNotToMatch, null);
2589 private Either<List<Service>, StorageOperationStatus> fetchServicesByCriteria(List<Service> servicesAll,
2590 Map<GraphPropertyEnum, Object> propertiesToMatch,
2591 Map<GraphPropertyEnum, Object> propertiesNotToMatch,
2593 Either<List<GraphVertex>, JanusGraphOperationStatus> getRes = janusGraphDao
2594 .getByCriteria(VertexTypeEnum.TOPOLOGY_TEMPLATE, propertiesToMatch, propertiesNotToMatch, JsonParseFlagEnum.ParseAll, modelName);
2595 if (getRes.isRight()) {
2596 if (getRes.right().value() != JanusGraphOperationStatus.NOT_FOUND) {
2597 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG,
2598 "Failed to fetch certified services by match properties {} not match properties {} . Status is {}. ", propertiesToMatch,
2599 propertiesNotToMatch, getRes.right().value());
2600 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getRes.right().value()));
2603 for (final GraphVertex vertex : getRes.left().value()) {
2604 Either<ToscaElement, StorageOperationStatus> getServiceRes = topologyTemplateOperation
2605 .getLightComponent(vertex, ComponentTypeEnum.SERVICE, new ComponentParametersView(true));
2606 if (getServiceRes.isRight()) {
2607 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to fetch certified service {}. Status is {}. ",
2608 vertex.getJsonMetadataField(JsonPresentationFields.NAME), getServiceRes.right().value());
2609 return Either.right(getServiceRes.right().value());
2611 servicesAll.add(ModelConverter.convertFromToscaElement(getServiceRes.left().value()));
2615 return Either.left(servicesAll);
2618 private List<GraphVertex> getVerticesForModel(final String modelName, final List<GraphVertex> graphVertexList) {
2619 final Predicate<? super GraphVertex> filterPredicate =
2620 StringUtils.isEmpty(modelName) ? this::vertexNotConnectedToAnyModel
2621 : graphVertex -> vertexValidForModel(graphVertex, modelName).isPresent();
2622 return StreamSupport.stream(graphVertexList.spliterator(), false).filter(filterPredicate).collect(Collectors.toList());
2625 private boolean vertexNotConnectedToAnyModel(final GraphVertex vertex) {
2626 return !vertex.getVertex().edges(Direction.OUT, EdgeLabelEnum.MODEL.name()).hasNext();
2629 private Optional<GraphVertex> vertexValidForModel(final GraphVertex vertex, final String model) {
2630 final Either<List<GraphVertex>, JanusGraphOperationStatus> nodeModelVertices = janusGraphDao
2631 .getParentVertices(vertex, EdgeLabelEnum.MODEL, JsonParseFlagEnum.NoParse);
2632 if (nodeModelVertices.isRight() || Objects.isNull(nodeModelVertices.left().value())) {
2633 return Optional.empty();
2635 return nodeModelVertices.left().value().stream().filter(graphVertex -> graphVertex.getMetadataProperty(GraphPropertyEnum.MODEL).equals(model))
2639 public void rollback() {
2640 janusGraphDao.rollback();
2643 public StorageOperationStatus addDeploymentArtifactsToInstance(String componentId, ComponentInstance componentInstance,
2644 Map<String, ArtifactDefinition> finalDeploymentArtifacts) {
2645 Map<String, ArtifactDataDefinition> instDeplArtifacts = finalDeploymentArtifacts.entrySet().stream()
2646 .collect(Collectors.toMap(Map.Entry::getKey, e -> new ArtifactDataDefinition(e.getValue())));
2647 return nodeTemplateOperation.addDeploymentArtifactsToInstance(componentId, componentInstance.getUniqueId(), instDeplArtifacts);
2650 public StorageOperationStatus addInformationalArtifactsToInstance(String componentId, ComponentInstance componentInstance,
2651 Map<String, ArtifactDefinition> artifacts) {
2652 StorageOperationStatus status = StorageOperationStatus.OK;
2653 if (MapUtils.isNotEmpty(artifacts)) {
2654 Map<String, ArtifactDataDefinition> instDeplArtifacts = artifacts.entrySet().stream()
2655 .collect(Collectors.toMap(Map.Entry::getKey, e -> new ArtifactDataDefinition(e.getValue())));
2656 status = nodeTemplateOperation.addInformationalArtifactsToInstance(componentId, componentInstance.getUniqueId(), instDeplArtifacts);
2661 public StorageOperationStatus generateCustomizationUUIDOnInstance(String componentId, String instanceId) {
2662 return nodeTemplateOperation.generateCustomizationUUIDOnInstance(componentId, instanceId);
2665 public StorageOperationStatus generateCustomizationUUIDOnInstanceGroup(String componentId, String instanceId, List<String> groupInstances) {
2666 return nodeTemplateOperation.generateCustomizationUUIDOnInstanceGroup(componentId, instanceId, groupInstances);
2669 public Either<PropertyDefinition, StorageOperationStatus> addPropertyToComponent(String propertyName, PropertyDefinition newPropertyDefinition,
2670 Component component) {
2671 newPropertyDefinition.setName(propertyName);
2672 StorageOperationStatus status = getToscaElementOperation(component)
2673 .addToscaDataToToscaElement(component.getUniqueId(), EdgeLabelEnum.PROPERTIES, VertexTypeEnum.PROPERTIES, newPropertyDefinition,
2674 JsonPresentationFields.NAME);
2675 if (status != StorageOperationStatus.OK) {
2676 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to add the property {} to the component {}. Status is {}. ", propertyName,
2677 component.getName(), status);
2678 return Either.right(status);
2680 ComponentParametersView filter = new ComponentParametersView(true);
2681 filter.setIgnoreProperties(false);
2682 filter.setIgnoreInputs(false);
2683 Either<Component, StorageOperationStatus> getUpdatedComponentRes = getToscaElement(component.getUniqueId(), filter);
2684 if (getUpdatedComponentRes.isRight()) {
2685 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to get updated component {}. Status is {}. ", component.getUniqueId(),
2686 getUpdatedComponentRes.right().value());
2687 return Either.right(status);
2689 PropertyDefinition newProperty = null;
2690 List<PropertyDefinition> properties = (getUpdatedComponentRes.left().value()).getProperties();
2691 if (CollectionUtils.isNotEmpty(properties)) {
2692 Optional<PropertyDefinition> propertyOptional = properties.stream().filter(propertyEntry -> propertyEntry.getName().equals(propertyName))
2694 if (propertyOptional.isPresent()) {
2695 newProperty = propertyOptional.get();
2698 if (newProperty == null) {
2699 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to find recently added property {} on the component {}. Status is {}. ",
2700 propertyName, component.getUniqueId(), StorageOperationStatus.NOT_FOUND);
2701 return Either.right(StorageOperationStatus.NOT_FOUND);
2703 return Either.left(newProperty);
2706 public Either<InputDefinition, StorageOperationStatus> addInputToComponent(String inputName, InputDefinition newInputDefinition,
2707 Component component) {
2708 newInputDefinition.setName(inputName);
2709 StorageOperationStatus status = getToscaElementOperation(component)
2710 .addToscaDataToToscaElement(component.getUniqueId(), EdgeLabelEnum.INPUTS, VertexTypeEnum.INPUTS, newInputDefinition,
2711 JsonPresentationFields.NAME);
2712 if (status != StorageOperationStatus.OK) {
2713 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to add the input {} to the component {}. Status is {}. ", inputName,
2714 component.getName(), status);
2715 return Either.right(status);
2717 ComponentParametersView filter = new ComponentParametersView(true);
2718 filter.setIgnoreProperties(false);
2719 filter.setIgnoreInputs(false);
2720 Either<Component, StorageOperationStatus> getUpdatedComponentRes = getToscaElement(component.getUniqueId(), filter);
2721 if (getUpdatedComponentRes.isRight()) {
2722 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to get updated component {}. Status is {}. ", component.getUniqueId(),
2723 getUpdatedComponentRes.right().value());
2724 return Either.right(status);
2726 InputDefinition newInput = null;
2727 List<InputDefinition> inputs = (getUpdatedComponentRes.left().value()).getInputs();
2728 if (CollectionUtils.isNotEmpty(inputs)) {
2729 Optional<InputDefinition> inputOptional = inputs.stream().filter(inputEntry -> inputEntry.getName().equals(inputName)).findAny();
2730 if (inputOptional.isPresent()) {
2731 newInput = inputOptional.get();
2734 if (newInput == null) {
2736 .addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to find recently added input {} " + "on the component {}. Status is {}. ", inputs,
2737 component.getUniqueId(), StorageOperationStatus.NOT_FOUND);
2738 return Either.right(StorageOperationStatus.NOT_FOUND);
2740 return Either.left(newInput);
2743 public StorageOperationStatus deletePropertyOfComponent(Component component, String propertyName) {
2744 return getToscaElementOperation(component)
2745 .deleteToscaDataElement(component.getUniqueId(), EdgeLabelEnum.PROPERTIES, VertexTypeEnum.PROPERTIES, propertyName,
2746 JsonPresentationFields.NAME);
2749 public StorageOperationStatus deleteAttributeOfResource(Component component, String attributeName) {
2750 return getToscaElementOperation(component)
2751 .deleteToscaDataElement(component.getUniqueId(), EdgeLabelEnum.ATTRIBUTES, VertexTypeEnum.ATTRIBUTES, attributeName,
2752 JsonPresentationFields.NAME);
2755 public StorageOperationStatus deleteInputOfResource(Component resource, String inputName) {
2756 return getToscaElementOperation(resource)
2757 .deleteToscaDataElement(resource.getUniqueId(), EdgeLabelEnum.INPUTS, VertexTypeEnum.INPUTS, inputName, JsonPresentationFields.NAME);
2760 public StorageOperationStatus deleteOutputOfResource(final Component resource, final String outputName) {
2761 return getToscaElementOperation(resource)
2762 .deleteToscaDataElement(resource.getUniqueId(), EdgeLabelEnum.OUTPUTS, VertexTypeEnum.OUTPUTS, outputName, JsonPresentationFields.NAME);
2766 * Deletes a data type from a component.
2768 * @param component the container which has the data type
2769 * @param dataTypeName the data type name to be deleted
2770 * @return Operation result.
2772 public StorageOperationStatus deleteDataTypeOfComponent(Component component, String dataTypeName) {
2773 return getToscaElementOperation(component)
2774 .deleteToscaDataElement(component.getUniqueId(), EdgeLabelEnum.DATA_TYPES, VertexTypeEnum.DATA_TYPES, dataTypeName,
2775 JsonPresentationFields.NAME);
2778 public Either<PropertyDefinition, StorageOperationStatus> updatePropertyOfComponent(Component component,
2779 PropertyDefinition newPropertyDefinition) {
2780 Either<Component, StorageOperationStatus> getUpdatedComponentRes = null;
2781 Either<PropertyDefinition, StorageOperationStatus> result = null;
2782 StorageOperationStatus status = getToscaElementOperation(component)
2783 .updateToscaDataOfToscaElement(component.getUniqueId(), EdgeLabelEnum.PROPERTIES, VertexTypeEnum.PROPERTIES, newPropertyDefinition,
2784 JsonPresentationFields.NAME);
2785 if (status != StorageOperationStatus.OK) {
2787 .addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_ADD_THE_PROPERTY_TO_THE_RESOURCE_STATUS_IS, newPropertyDefinition.getName(),
2788 component.getName(), status);
2789 result = Either.right(status);
2791 if (result == null) {
2792 ComponentParametersView filter = new ComponentParametersView(true);
2793 filter.setIgnoreProperties(false);
2794 getUpdatedComponentRes = getToscaElement(component.getUniqueId(), filter);
2795 if (getUpdatedComponentRes.isRight()) {
2796 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_GET_UPDATED_RESOURCE_STATUS_IS, component.getUniqueId(),
2797 getUpdatedComponentRes.right().value());
2798 result = Either.right(status);
2801 if (result == null) {
2802 Optional<PropertyDefinition> newProperty = (getUpdatedComponentRes.left().value()).getProperties().stream()
2803 .filter(p -> p.getName().equals(newPropertyDefinition.getName())).findAny();
2804 if (newProperty.isPresent()) {
2805 result = Either.left(newProperty.get());
2807 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_FIND_RECENTLY_ADDED_PROPERTY_ON_THE_RESOURCE_STATUS_IS,
2808 newPropertyDefinition.getName(), component.getUniqueId(), StorageOperationStatus.NOT_FOUND);
2809 result = Either.right(StorageOperationStatus.NOT_FOUND);
2815 public Either<AttributeDefinition, StorageOperationStatus> updateAttributeOfComponent(Component component,
2816 AttributeDefinition newPropertyDefinition) {
2817 Either<Component, StorageOperationStatus> getUpdatedComponentRes = null;
2818 Either<AttributeDefinition, StorageOperationStatus> result = null;
2819 StorageOperationStatus status = getToscaElementOperation(component)
2820 .updateToscaDataOfToscaElement(component.getUniqueId(), EdgeLabelEnum.ATTRIBUTES, VertexTypeEnum.ATTRIBUTES, newPropertyDefinition,
2821 JsonPresentationFields.NAME);
2822 if (status != StorageOperationStatus.OK) {
2824 .addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_ADD_THE_PROPERTY_TO_THE_RESOURCE_STATUS_IS, newPropertyDefinition.getName(),
2825 component.getName(), status);
2826 result = Either.right(status);
2828 if (result == null) {
2829 ComponentParametersView filter = new ComponentParametersView(true);
2830 filter.setIgnoreProperties(false);
2831 getUpdatedComponentRes = getToscaElement(component.getUniqueId(), filter);
2832 if (getUpdatedComponentRes.isRight()) {
2833 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_GET_UPDATED_RESOURCE_STATUS_IS, component.getUniqueId(),
2834 getUpdatedComponentRes.right().value());
2835 result = Either.right(status);
2838 if (result == null) {
2839 Optional<AttributeDefinition> newProperty = (getUpdatedComponentRes.left().value()).getAttributes().stream()
2840 .filter(p -> p.getName().equals(newPropertyDefinition.getName())).findAny();
2841 if (newProperty.isPresent()) {
2842 result = Either.left(newProperty.get());
2844 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_FIND_RECENTLY_ADDED_PROPERTY_ON_THE_RESOURCE_STATUS_IS,
2845 newPropertyDefinition.getName(), component.getUniqueId(), StorageOperationStatus.NOT_FOUND);
2846 result = Either.right(StorageOperationStatus.NOT_FOUND);
2852 public Either<AttributeDefinition, StorageOperationStatus> addAttributeOfResource(Component component, AttributeDefinition newAttributeDef) {
2853 Either<Component, StorageOperationStatus> getUpdatedComponentRes = null;
2854 Either<AttributeDefinition, StorageOperationStatus> result = null;
2855 if (newAttributeDef.getUniqueId() == null || newAttributeDef.getUniqueId().isEmpty()) {
2856 String attUniqueId = UniqueIdBuilder.buildAttributeUid(component.getUniqueId(), newAttributeDef.getName());
2857 newAttributeDef.setUniqueId(attUniqueId);
2858 newAttributeDef.setOwnerId(component.getUniqueId());
2860 StorageOperationStatus status = getToscaElementOperation(component)
2861 .addToscaDataToToscaElement(component.getUniqueId(), EdgeLabelEnum.ATTRIBUTES, VertexTypeEnum.ATTRIBUTES, newAttributeDef,
2862 JsonPresentationFields.NAME);
2863 if (status != StorageOperationStatus.OK) {
2864 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_ADD_THE_PROPERTY_TO_THE_RESOURCE_STATUS_IS, newAttributeDef.getName(),
2865 component.getName(), status);
2866 result = Either.right(status);
2868 if (result == null) {
2869 ComponentParametersView filter = new ComponentParametersView(true);
2870 filter.setIgnoreAttributes(false);
2871 getUpdatedComponentRes = getToscaElement(component.getUniqueId(), filter);
2872 if (getUpdatedComponentRes.isRight()) {
2873 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_GET_UPDATED_RESOURCE_STATUS_IS, component.getUniqueId(),
2874 getUpdatedComponentRes.right().value());
2875 result = Either.right(status);
2878 if (result == null) {
2879 Optional<AttributeDefinition> newAttribute = ((Resource) getUpdatedComponentRes.left().value()).getAttributes().stream()
2880 .filter(p -> p.getName().equals(newAttributeDef.getName())).findAny();
2881 if (newAttribute.isPresent()) {
2882 result = Either.left(newAttribute.get());
2884 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_FIND_RECENTLY_ADDED_PROPERTY_ON_THE_RESOURCE_STATUS_IS,
2885 newAttributeDef.getName(), component.getUniqueId(), StorageOperationStatus.NOT_FOUND);
2886 result = Either.right(StorageOperationStatus.NOT_FOUND);
2892 public Either<AttributeDefinition, StorageOperationStatus> updateAttributeOfResource(Component component, AttributeDefinition newAttributeDef) {
2893 Either<Component, StorageOperationStatus> getUpdatedComponentRes = null;
2894 Either<AttributeDefinition, StorageOperationStatus> result = null;
2895 StorageOperationStatus status = getToscaElementOperation(component)
2896 .updateToscaDataOfToscaElement(component.getUniqueId(), EdgeLabelEnum.ATTRIBUTES, VertexTypeEnum.ATTRIBUTES, newAttributeDef,
2897 JsonPresentationFields.NAME);
2898 if (status != StorageOperationStatus.OK) {
2899 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_ADD_THE_PROPERTY_TO_THE_RESOURCE_STATUS_IS, newAttributeDef.getName(),
2900 component.getName(), status);
2901 result = Either.right(status);
2903 if (result == null) {
2904 ComponentParametersView filter = new ComponentParametersView(true);
2905 filter.setIgnoreAttributes(false);
2906 getUpdatedComponentRes = getToscaElement(component.getUniqueId(), filter);
2907 if (getUpdatedComponentRes.isRight()) {
2908 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_GET_UPDATED_RESOURCE_STATUS_IS, component.getUniqueId(),
2909 getUpdatedComponentRes.right().value());
2910 result = Either.right(status);
2913 if (result == null) {
2914 Optional<AttributeDefinition> newProperty = ((Resource) getUpdatedComponentRes.left().value()).getAttributes().stream()
2915 .filter(p -> p.getName().equals(newAttributeDef.getName())).findAny();
2916 if (newProperty.isPresent()) {
2917 result = Either.left(newProperty.get());
2919 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_FIND_RECENTLY_ADDED_PROPERTY_ON_THE_RESOURCE_STATUS_IS,
2920 newAttributeDef.getName(), component.getUniqueId(), StorageOperationStatus.NOT_FOUND);
2921 result = Either.right(StorageOperationStatus.NOT_FOUND);
2927 public Either<InputDefinition, StorageOperationStatus> updateInputOfComponent(Component component, InputDefinition newInputDefinition) {
2928 Either<Component, StorageOperationStatus> getUpdatedComponentRes = null;
2929 Either<InputDefinition, StorageOperationStatus> result = null;
2930 StorageOperationStatus status = getToscaElementOperation(component)
2931 .updateToscaDataOfToscaElement(component.getUniqueId(), EdgeLabelEnum.INPUTS, VertexTypeEnum.INPUTS, newInputDefinition,
2932 JsonPresentationFields.NAME);
2933 if (status != StorageOperationStatus.OK) {
2934 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to update the input {} to the component {}. Status is {}. ",
2935 newInputDefinition.getName(), component.getName(), status);
2936 result = Either.right(status);
2938 if (result == null) {
2939 ComponentParametersView filter = new ComponentParametersView(true);
2940 filter.setIgnoreInputs(false);
2941 getUpdatedComponentRes = getToscaElement(component.getUniqueId(), filter);
2942 if (getUpdatedComponentRes.isRight()) {
2943 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, FAILED_TO_GET_UPDATED_RESOURCE_STATUS_IS, component.getUniqueId(),
2944 getUpdatedComponentRes.right().value());
2945 result = Either.right(status);
2948 if (result == null) {
2949 Optional<InputDefinition> updatedInput = getUpdatedComponentRes.left().value().getInputs().stream()
2950 .filter(p -> p.getName().equals(newInputDefinition.getName())).findAny();
2951 if (updatedInput.isPresent()) {
2952 result = Either.left(updatedInput.get());
2954 CommonUtility.addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to find recently updated inputs {} on the resource {}. Status is {}. ",
2955 newInputDefinition.getName(), component.getUniqueId(), StorageOperationStatus.NOT_FOUND);
2956 result = Either.right(StorageOperationStatus.NOT_FOUND);
2963 * method - ename the group instances after referenced container name renamed flow - VF rename -(triggers)-> Group rename
2965 * @param containerComponent - container such as service
2966 * @param componentInstance - context component
2967 * @param componentInstanceId - id
2968 * @return - successfull/failed status
2970 public Either<StorageOperationStatus, StorageOperationStatus> cleanAndAddGroupInstancesToComponentInstance(Component containerComponent,
2971 ComponentInstance componentInstance,
2972 String componentInstanceId) {
2973 String uniqueId = componentInstance.getUniqueId();
2974 StorageOperationStatus status = nodeTemplateOperation
2975 .deleteToscaDataDeepElementsBlockOfToscaElement(containerComponent.getUniqueId(), EdgeLabelEnum.INST_GROUPS, VertexTypeEnum.INST_GROUPS,
2977 if (status != StorageOperationStatus.OK && status != StorageOperationStatus.NOT_FOUND) {
2979 .addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to delete group instances for container {}. error {] ", componentInstanceId, status);
2980 return Either.right(status);
2982 if (componentInstance.getGroupInstances() != null) {
2983 status = addGroupInstancesToComponentInstance(containerComponent, componentInstance, componentInstance.getGroupInstances());
2984 if (status != StorageOperationStatus.OK && status != StorageOperationStatus.NOT_FOUND) {
2986 .addRecordToLog(log, LogLevelEnum.DEBUG, "Failed to add group instances for container {}. error {] ", componentInstanceId,
2988 return Either.right(status);
2991 return Either.left(status);
2994 public StorageOperationStatus addGroupInstancesToComponentInstance(Component containerComponent, ComponentInstance componentInstance,
2995 List<GroupDefinition> groups,
2996 Map<String, List<ArtifactDefinition>> groupInstancesArtifacts) {
2997 return nodeTemplateOperation.addGroupInstancesToComponentInstance(containerComponent, componentInstance, groups, groupInstancesArtifacts);
3000 public Either<List<GroupDefinition>, StorageOperationStatus> updateGroupsOnComponent(Component component,
3001 List<GroupDataDefinition> updatedGroups) {
3002 return groupsOperation.updateGroups(component, updatedGroups, PromoteVersionEnum.MINOR);
3005 public Either<List<GroupInstance>, StorageOperationStatus> updateGroupInstancesOnComponent(Component component, String instanceId,
3006 List<GroupInstance> updatedGroupInstances) {
3007 return groupsOperation.updateGroupInstances(component, instanceId, updatedGroupInstances);
3010 public StorageOperationStatus addGroupInstancesToComponentInstance(Component containerComponent, ComponentInstance componentInstance,
3011 List<GroupInstance> groupInstances) {
3012 return nodeTemplateOperation.addGroupInstancesToComponentInstance(containerComponent, componentInstance, groupInstances);
3015 public StorageOperationStatus addDeploymentArtifactsToComponentInstance(Component containerComponent, ComponentInstance componentInstance,
3016 Map<String, ArtifactDefinition> deploymentArtifacts) {
3017 return nodeTemplateOperation.addDeploymentArtifactsToComponentInstance(containerComponent, componentInstance, deploymentArtifacts);
3020 public StorageOperationStatus updateComponentInstanceProperty(Component containerComponent, String componentInstanceId,
3021 ComponentInstanceProperty property) {
3022 return nodeTemplateOperation.updateComponentInstanceProperty(containerComponent, componentInstanceId, property);
3025 public StorageOperationStatus updateComponentInstanceProperties(Component containerComponent, String componentInstanceId,
3026 List<ComponentInstanceProperty> properties) {
3027 return nodeTemplateOperation.updateComponentInstanceProperties(containerComponent, componentInstanceId, properties);
3030 public StorageOperationStatus updateComponentInstanceAttributes(final Component containerComponent, final String componentInstanceId,
3031 final List<ComponentInstanceAttribute> attributes) {
3032 return nodeTemplateOperation.updateComponentInstanceAttributes(containerComponent, componentInstanceId, attributes);
3035 public StorageOperationStatus addComponentInstanceProperty(Component containerComponent, String componentInstanceId,
3036 ComponentInstanceProperty property) {
3037 return nodeTemplateOperation.addComponentInstanceProperty(containerComponent, componentInstanceId, property);
3040 public StorageOperationStatus updateComponentInstanceAttribute(final Component containerComponent, final String componentInstanceId,
3041 final ComponentInstanceAttribute attribute) {
3042 return nodeTemplateOperation.updateComponentInstanceAttribute(containerComponent, componentInstanceId, attribute);
3045 public StorageOperationStatus addComponentInstanceAttribute(Component containerComponent, String componentInstanceId,
3046 ComponentInstanceAttribute attribute) {
3047 return nodeTemplateOperation.addComponentInstanceAttribute(containerComponent, componentInstanceId, attribute);
3050 public StorageOperationStatus updateComponentInstanceInput(Component containerComponent, String componentInstanceId,
3051 ComponentInstanceInput property) {
3052 return nodeTemplateOperation.updateComponentInstanceInput(containerComponent, componentInstanceId, property);
3055 public StorageOperationStatus updateComponentInstanceOutput(Component containerComponent, String componentInstanceId,
3056 ComponentInstanceOutput property) {
3057 return nodeTemplateOperation.updateComponentInstanceOutput(containerComponent, componentInstanceId, property);
3060 public StorageOperationStatus updateComponentInstanceInputs(Component containerComponent, String componentInstanceId,
3061 List<ComponentInstanceInput> instanceInputs) {
3062 return nodeTemplateOperation.updateComponentInstanceInputs(containerComponent, componentInstanceId, instanceInputs);
3065 public StorageOperationStatus updateComponentInstanceOutputs(Component containerComponent, String componentInstanceId,
3066 List<ComponentInstanceOutput> instanceInputs) {
3067 return nodeTemplateOperation.updateComponentInstanceOutputs(containerComponent, componentInstanceId, instanceInputs);
3070 public StorageOperationStatus addComponentInstanceInput(Component containerComponent, String componentInstanceId,
3071 ComponentInstanceInput property) {
3072 return nodeTemplateOperation.addComponentInstanceInput(containerComponent, componentInstanceId, property);
3075 public StorageOperationStatus addComponentInstanceOutput(Component containerComponent, String componentInstanceId,
3076 ComponentInstanceOutput property) {
3077 return nodeTemplateOperation.addComponentInstanceOutput(containerComponent, componentInstanceId, property);
3080 public void setNodeTypeOperation(NodeTypeOperation nodeTypeOperation) {
3081 this.nodeTypeOperation = nodeTypeOperation;
3084 public void setTopologyTemplateOperation(TopologyTemplateOperation topologyTemplateOperation) {
3085 this.topologyTemplateOperation = topologyTemplateOperation;
3088 public StorageOperationStatus deleteComponentInstanceInputsFromTopologyTemplate(Component containerComponent,
3089 List<InputDefinition> inputsToDelete) {
3090 return topologyTemplateOperation.deleteToscaDataElements(containerComponent.getUniqueId(), EdgeLabelEnum.INPUTS,
3091 inputsToDelete.stream().map(PropertyDataDefinition::getName).collect(Collectors.toList()));
3094 public StorageOperationStatus deleteComponentInstanceOutputsFromTopologyTemplate(final Component containerComponent,
3095 final List<OutputDefinition> outputsToDelete) {
3096 return topologyTemplateOperation.deleteToscaDataElements(containerComponent.getUniqueId(), EdgeLabelEnum.OUTPUTS,
3097 outputsToDelete.stream().map(AttributeDataDefinition::getName).collect(Collectors.toList()));
3100 public StorageOperationStatus updateComponentInstanceCapabiltyProperty(Component containerComponent, String componentInstanceUniqueId,
3101 String capabilityPropertyKey, ComponentInstanceProperty property) {
3102 return nodeTemplateOperation
3103 .updateComponentInstanceCapabilityProperty(containerComponent, componentInstanceUniqueId, capabilityPropertyKey, property);
3106 public StorageOperationStatus updateComponentInstanceCapabilityProperties(Component containerComponent, String componentInstanceUniqueId) {
3107 return convertComponentInstanceProperties(containerComponent, componentInstanceUniqueId).map(instanceCapProps -> topologyTemplateOperation
3108 .updateComponentInstanceCapabilityProperties(containerComponent, componentInstanceUniqueId, instanceCapProps))
3109 .orElse(StorageOperationStatus.NOT_FOUND);
3112 public StorageOperationStatus updateComponentInstanceRequirement(String containerComponentId, String componentInstanceUniqueId,
3113 RequirementDataDefinition requirementDataDefinition) {
3114 return nodeTemplateOperation.updateComponentInstanceRequirement(containerComponentId, componentInstanceUniqueId, requirementDataDefinition);
3117 public CapabilityDataDefinition updateComponentInstanceCapability(final String containerComponentId, final String componentInstanceUniqueId,
3118 final CapabilityDataDefinition capabilityDataDefinition) {
3120 return nodeTemplateOperation.updateComponentInstanceCapabilities(containerComponentId, componentInstanceUniqueId, capabilityDataDefinition);
3123 public StorageOperationStatus updateComponentInstanceInterfaces(Component containerComponent, String componentInstanceUniqueId) {
3124 MapInterfaceDataDefinition mapInterfaceDataDefinition = convertComponentInstanceInterfaces(containerComponent, componentInstanceUniqueId);
3125 return topologyTemplateOperation.updateComponentInstanceInterfaces(containerComponent, componentInstanceUniqueId, mapInterfaceDataDefinition);
3128 public StorageOperationStatus updateComponentCalculatedCapabilitiesProperties(Component containerComponent) {
3129 Map<String, MapCapabilityProperty> mapCapabiltyPropertyMap = convertComponentCapabilitiesProperties(containerComponent);
3130 return nodeTemplateOperation.overrideComponentCapabilitiesProperties(containerComponent, mapCapabiltyPropertyMap);
3133 public StorageOperationStatus deleteAllCalculatedCapabilitiesRequirements(String topologyTemplateId) {
3134 StorageOperationStatus status = topologyTemplateOperation
3135 .removeToscaData(topologyTemplateId, EdgeLabelEnum.CALCULATED_CAPABILITIES, VertexTypeEnum.CALCULATED_CAPABILITIES);
3136 if (status == StorageOperationStatus.OK) {
3137 status = topologyTemplateOperation
3138 .removeToscaData(topologyTemplateId, EdgeLabelEnum.CALCULATED_REQUIREMENTS, VertexTypeEnum.CALCULATED_REQUIREMENTS);
3140 if (status == StorageOperationStatus.OK) {
3141 status = topologyTemplateOperation
3142 .removeToscaData(topologyTemplateId, EdgeLabelEnum.CALCULATED_CAP_PROPERTIES, VertexTypeEnum.CALCULATED_CAP_PROPERTIES);
3147 public Either<Component, StorageOperationStatus> shouldUpgradeToLatestDerived(Resource clonedResource) {
3148 String componentId = clonedResource.getUniqueId();
3149 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
3150 if (getVertexEither.isRight()) {
3151 log.debug(COULDNT_FETCH_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
3152 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
3154 GraphVertex nodeTypeV = getVertexEither.left().value();
3155 ToscaElement toscaElementToUpdate = ModelConverter.convertToToscaElement(clonedResource);
3156 Either<ToscaElement, StorageOperationStatus> shouldUpdateDerivedVersion = nodeTypeOperation
3157 .shouldUpdateDerivedVersion(toscaElementToUpdate, nodeTypeV);
3158 if (shouldUpdateDerivedVersion.isRight() && StorageOperationStatus.OK != shouldUpdateDerivedVersion.right().value()) {
3159 log.debug("Failed to update derived version for node type {} derived {}, error: {}", componentId, clonedResource.getDerivedFrom().get(0),
3160 shouldUpdateDerivedVersion.right().value());
3161 return Either.right(shouldUpdateDerivedVersion.right().value());
3163 if (shouldUpdateDerivedVersion.isLeft()) {
3164 return Either.left(ModelConverter.convertFromToscaElement(shouldUpdateDerivedVersion.left().value()));
3166 return Either.left(clonedResource);
3170 * Returns list of ComponentInstanceProperty belonging to component instance capability specified by name, type and ownerId
3172 public Either<List<ComponentInstanceProperty>, StorageOperationStatus> getComponentInstanceCapabilityProperties(String componentId,
3174 String capabilityName,
3175 String capabilityType,
3177 return topologyTemplateOperation.getComponentInstanceCapabilityProperties(componentId, instanceId, capabilityName, capabilityType, ownerId);
3180 private MapInterfaceDataDefinition convertComponentInstanceInterfaces(Component currComponent, String componentInstanceId) {
3181 MapInterfaceDataDefinition mapInterfaceDataDefinition = new MapInterfaceDataDefinition();
3182 List<ComponentInstanceInterface> componentInterface = currComponent.getComponentInstancesInterfaces().get(componentInstanceId);
3183 if (CollectionUtils.isNotEmpty(componentInterface)) {
3184 componentInterface.stream().forEach(interfaceDef -> mapInterfaceDataDefinition.put(interfaceDef.getUniqueId(), interfaceDef));
3186 return mapInterfaceDataDefinition;
3189 private Map<String, MapCapabilityProperty> convertComponentCapabilitiesProperties(Component currComponent) {
3190 Map<String, MapCapabilityProperty> map = ModelConverter.extractCapabilityPropertiesFromGroups(currComponent.getGroups(), true);
3191 map.putAll(ModelConverter.extractCapabilityProperteisFromInstances(currComponent.getComponentInstances(), true));
3195 private Optional<MapCapabilityProperty> convertComponentInstanceProperties(Component component, String instanceId) {
3196 return component.fetchInstanceById(instanceId)
3197 .map(ci -> ModelConverter.convertToMapOfMapCapabilityProperties(ci.getCapabilities(), instanceId, ci.getOriginType().isAtomicType()));
3200 public Either<PolicyDefinition, StorageOperationStatus> associatePolicyToComponent(String componentId, PolicyDefinition policyDefinition,
3202 Either<PolicyDefinition, StorageOperationStatus> result = null;
3203 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither;
3204 getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.ParseMetadata);
3205 if (getVertexEither.isRight()) {
3206 log.error(COULDNT_FETCH_A_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
3207 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
3209 if (getVertexEither.left().value().getLabel() != VertexTypeEnum.TOPOLOGY_TEMPLATE) {
3210 log.error("Policy association to component of Tosca type {} is not allowed. ", getVertexEither.left().value().getLabel());
3211 result = Either.right(StorageOperationStatus.BAD_REQUEST);
3214 if (result == null) {
3215 StorageOperationStatus status = topologyTemplateOperation
3216 .addPolicyToToscaElement(getVertexEither.left().value(), policyDefinition, counter);
3217 if (status != StorageOperationStatus.OK) {
3218 return Either.right(status);
3221 if (result == null) {
3222 result = Either.left(policyDefinition);
3227 public StorageOperationStatus associatePoliciesToComponent(String componentId, List<PolicyDefinition> policies) {
3228 log.debug("#associatePoliciesToComponent - associating policies for component {}.", componentId);
3229 return janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.ParseMetadata)
3230 .either(containerVertex -> topologyTemplateOperation.addPoliciesToToscaElement(containerVertex, policies),
3231 DaoStatusConverter::convertJanusGraphStatusToStorageStatus);
3234 public Either<PolicyDefinition, StorageOperationStatus> updatePolicyOfComponent(String componentId, PolicyDefinition policyDefinition,
3235 PromoteVersionEnum promoteVersionEnum) {
3236 Either<PolicyDefinition, StorageOperationStatus> result = null;
3237 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither;
3238 getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
3239 if (getVertexEither.isRight()) {
3240 log.error(COULDNT_FETCH_A_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
3241 result = Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value()));
3243 if (result == null) {
3244 policyDefinition.setVersion(GroupUtils.updateVersion(promoteVersionEnum, policyDefinition.getVersion()));
3245 StorageOperationStatus status = topologyTemplateOperation.updatePolicyOfToscaElement(getVertexEither.left().value(), policyDefinition);
3246 if (status != StorageOperationStatus.OK) {
3247 return Either.right(status);
3250 if (result == null) {
3251 result = Either.left(policyDefinition);
3256 public StorageOperationStatus updatePoliciesOfComponent(String componentId, List<PolicyDefinition> policyDefinition) {
3257 log.debug("#updatePoliciesOfComponent - updating policies for component {}", componentId);
3258 return janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse).right()
3259 .map(DaoStatusConverter::convertJanusGraphStatusToStorageStatus)
3260 .either(containerVertex -> topologyTemplateOperation.updatePoliciesOfToscaElement(containerVertex, policyDefinition), err -> err);
3263 public StorageOperationStatus removePolicyFromComponent(String componentId, String policyId) {
3264 StorageOperationStatus status = null;
3265 Either<GraphVertex, JanusGraphOperationStatus> getVertexEither = janusGraphDao.getVertexById(componentId, JsonParseFlagEnum.NoParse);
3266 if (getVertexEither.isRight()) {
3267 log.error(COULDNT_FETCH_A_COMPONENT_WITH_AND_UNIQUE_ID_ERROR, componentId, getVertexEither.right().value());
3268 status = DaoStatusConverter.convertJanusGraphStatusToStorageStatus(getVertexEither.right().value());
3270 if (status == null) {
3271 status = topologyTemplateOperation.removePolicyFromToscaElement(getVertexEither.left().value(), policyId);
3276 public boolean canAddGroups(String componentId) {
3277 GraphVertex vertex = janusGraphDao.getVertexById(componentId).left().on(this::onJanusGraphError);
3278 return topologyTemplateOperation.hasEdgeOfType(vertex, EdgeLabelEnum.GROUPS);
3281 GraphVertex onJanusGraphError(JanusGraphOperationStatus toe) {
3282 throw new StorageException(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(toe));
3285 public CatalogUpdateTimestamp updateCatalogTimes() {
3286 long now = System.currentTimeMillis();
3287 GraphVertex catalogRoot = janusGraphDao.getVertexByLabel(VertexTypeEnum.CATALOG_ROOT).left().on(this::onJanusGraphError);
3288 Long currentTime = (Long) catalogRoot.getMetadataProperty(GraphPropertyEnum.CURRENT_CATALOG_UPDATE_TIME);
3289 catalogRoot.addMetadataProperty(GraphPropertyEnum.PREV_CATALOG_UPDATE_TIME, currentTime);
3290 catalogRoot.addMetadataProperty(GraphPropertyEnum.CURRENT_CATALOG_UPDATE_TIME, now);
3291 janusGraphDao.updateVertex(catalogRoot).left().on(this::onJanusGraphError);
3292 return new CatalogUpdateTimestamp(currentTime, now);
3295 public CatalogUpdateTimestamp getCatalogTimes() {
3296 GraphVertex catalogRoot = janusGraphDao.getVertexByLabel(VertexTypeEnum.CATALOG_ROOT).left().on(this::onJanusGraphError);
3297 Long currentTime = (Long) catalogRoot.getMetadataProperty(GraphPropertyEnum.CURRENT_CATALOG_UPDATE_TIME);
3298 Long prevTime = (Long) catalogRoot.getMetadataProperty(GraphPropertyEnum.PREV_CATALOG_UPDATE_TIME);
3299 return new CatalogUpdateTimestamp(prevTime == null ? 0 : prevTime.longValue(), currentTime == null ? 0 : currentTime.longValue());
3302 public void updateNamesOfCalculatedCapabilitiesRequirements(String componentId) {
3303 topologyTemplateOperation.updateNamesOfCalculatedCapabilitiesRequirements(componentId, getTopologyTemplate(componentId));
3306 public void revertNamesOfCalculatedCapabilitiesRequirements(String componentId) {
3307 topologyTemplateOperation.revertNamesOfCalculatedCapabilitiesRequirements(componentId, getTopologyTemplate(componentId));
3310 private TopologyTemplate getTopologyTemplate(String componentId) {
3311 return (TopologyTemplate) topologyTemplateOperation.getToscaElement(componentId, getFilterComponentWithCapProperties()).left()
3312 .on(this::throwStorageException);
3315 private ComponentParametersView getFilterComponentWithCapProperties() {
3316 ComponentParametersView filter = new ComponentParametersView();
3317 filter.setIgnoreCapabiltyProperties(false);
3321 private ToscaElement throwStorageException(StorageOperationStatus status) {
3322 throw new StorageException(status);
3325 public Either<Boolean, StorageOperationStatus> isComponentInUse(String componentId) {
3326 final List<EdgeLabelEnum> forbiddenEdgeLabelEnums = Arrays
3327 .asList(EdgeLabelEnum.INSTANCE_OF, EdgeLabelEnum.PROXY_OF, EdgeLabelEnum.ALLOTTED_OF);
3328 Either<GraphVertex, JanusGraphOperationStatus> vertexById = janusGraphDao.getVertexById(componentId);
3329 if (vertexById.isLeft()) {
3330 for (EdgeLabelEnum edgeLabelEnum : forbiddenEdgeLabelEnums) {
3331 Iterator<Edge> edgeItr = vertexById.left().value().getVertex().edges(Direction.IN, edgeLabelEnum.name());
3332 if (edgeItr != null && edgeItr.hasNext()) {
3333 return Either.left(true);
3337 return Either.left(false);
3340 public Either<List<Component>, StorageOperationStatus> getComponentListByInvariantUuid(String componentInvariantUuid,
3341 Map<GraphPropertyEnum, Object> additionalPropertiesToMatch) {
3342 Map<GraphPropertyEnum, Object> propertiesToMatch = new EnumMap<>(GraphPropertyEnum.class);
3343 if (MapUtils.isNotEmpty(additionalPropertiesToMatch)) {
3344 propertiesToMatch.putAll(additionalPropertiesToMatch);
3346 propertiesToMatch.put(GraphPropertyEnum.INVARIANT_UUID, componentInvariantUuid);
3347 Either<List<GraphVertex>, JanusGraphOperationStatus> vertexEither = janusGraphDao
3348 .getByCriteria(null, propertiesToMatch, JsonParseFlagEnum.ParseMetadata);
3349 if (vertexEither.isRight()) {
3350 log.debug("Couldn't fetch metadata for component with type {} and invariantUUId {}, error: {}", componentInvariantUuid,
3351 vertexEither.right().value());
3352 return Either.right(DaoStatusConverter.convertJanusGraphStatusToStorageStatus(vertexEither.right().value()));
3354 List<GraphVertex> vertexList = vertexEither.isLeft() ? vertexEither.left().value() : null;
3355 if (vertexList == null || vertexList.isEmpty()) {
3356 log.debug("Component with invariantUUId {} was not found", componentInvariantUuid);
3357 return Either.right(StorageOperationStatus.NOT_FOUND);
3359 ArrayList<Component> components = new ArrayList<>();
3360 for (GraphVertex vertex : vertexList) {
3361 Either<Component, StorageOperationStatus> toscaElementByOperation = getToscaElementByOperation(vertex);
3362 if (toscaElementByOperation.isRight()) {
3363 log.debug("Could not fetch the following Component by Invariant UUID {}", vertex.getUniqueId());
3364 return Either.right(toscaElementByOperation.right().value());
3366 components.add(toscaElementByOperation.left().value());
3368 return Either.left(components);
3371 public Either<List<Component>, StorageOperationStatus> getParentComponents(String componentId) {
3372 List<Component> parentComponents = new ArrayList<>();
3373 final List<EdgeLabelEnum> relationEdgeLabelEnums = Arrays.asList(EdgeLabelEnum.INSTANCE_OF, EdgeLabelEnum.PROXY_OF);
3374 Either<GraphVertex, JanusGraphOperationStatus> vertexById = janusGraphDao.getVertexById(componentId);
3375 if (vertexById.isLeft()) {
3376 for (EdgeLabelEnum edgeLabelEnum : relationEdgeLabelEnums) {
3377 Either<GraphVertex, JanusGraphOperationStatus> parentVertexEither = janusGraphDao
3378 .getParentVertex(vertexById.left().value(), edgeLabelEnum, JsonParseFlagEnum.ParseJson);
3379 if (parentVertexEither.isLeft()) {
3380 Either<Component, StorageOperationStatus> componentEither = getToscaElement(parentVertexEither.left().value().getUniqueId());
3381 if (componentEither.isLeft()) {
3382 parentComponents.add(componentEither.left().value());
3387 return Either.left(parentComponents);
3390 public void updateCapReqPropertiesOwnerId(String componentId) {
3391 topologyTemplateOperation.updateCapReqPropertiesOwnerId(componentId, getTopologyTemplate(componentId));
3394 public <T extends Component> Either<T, StorageOperationStatus> getLatestByServiceName(String serviceName) {
3395 return getLatestByName(GraphPropertyEnum.NAME, serviceName, null);