1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
package org.openecomp.sdc.be.components.merge.instance;
import fj.data.Either;
import org.apache.commons.collections.CollectionUtils;
import org.openecomp.sdc.be.components.merge.VspComponentsMergeCommand;
import org.openecomp.sdc.be.components.merge.capability.CapabilityResolver;
import org.openecomp.sdc.be.components.merge.property.DataDefinitionsValuesMergingBusinessLogic;
import org.openecomp.sdc.be.dao.api.ActionStatus;
import org.openecomp.sdc.be.dao.utils.MapUtil;
import org.openecomp.sdc.be.impl.ComponentsUtils;
import org.openecomp.sdc.be.model.CapabilityDefinition;
import org.openecomp.sdc.be.model.Component;
import org.openecomp.sdc.be.model.ComponentInstance;
import org.openecomp.sdc.be.model.ComponentParametersView;
import org.openecomp.sdc.be.model.jsonjanusgraph.operations.ToscaOperationFacade;
import org.openecomp.sdc.be.model.operations.api.StorageOperationStatus;
import org.openecomp.sdc.common.log.wrappers.Logger;
import org.springframework.core.annotation.Order;
import java.util.List;
import java.util.Map;
import static org.openecomp.sdc.be.components.merge.resource.ResourceDataMergeBusinessLogic.ANY_ORDER_COMMAND;
@org.springframework.stereotype.Component
@Order(ANY_ORDER_COMMAND)
public class ComponentCapabilitiesPropertiesMergeBL implements VspComponentsMergeCommand {
private static final Logger log = Logger.getLogger(ComponentCapabilitiesPropertiesMergeBL.class);
private final DataDefinitionsValuesMergingBusinessLogic dataDefinitionsValuesMergingBusinessLogic;
private final ToscaOperationFacade toscaOperationFacade;
private final ComponentsUtils componentsUtils;
private final CapabilityResolver capabilityResolver;
public ComponentCapabilitiesPropertiesMergeBL(DataDefinitionsValuesMergingBusinessLogic dataDefinitionsValuesMergingBusinessLogic, ToscaOperationFacade toscaOperationFacade, ComponentsUtils componentsUtils, CapabilityResolver capabilityResolver) {
this.dataDefinitionsValuesMergingBusinessLogic = dataDefinitionsValuesMergingBusinessLogic;
this.toscaOperationFacade = toscaOperationFacade;
this.componentsUtils = componentsUtils;
this.capabilityResolver = capabilityResolver;
}
@Override
public String description() {
return "merge component instances capabilities properties";
}
@Override
public ActionStatus mergeComponents(Component prevComponent, Component currentComponent) {
StorageOperationStatus mergeStatus = getCmptWithCapabilitiesProps(currentComponent.getUniqueId())
.either(currCmptWithCap -> mergeCmptCalculatedCapabilitiesProperties(prevComponent, currCmptWithCap),
err -> err);
return componentsUtils.convertFromStorageResponse(mergeStatus);
}
public ActionStatus mergeComponentInstanceCapabilities(Component currentComponent, Component origInstanceCmpt, String instanceId, List<CapabilityDefinition> prevInstanceCapabilities) {
if (CollectionUtils.isEmpty(prevInstanceCapabilities)) {
return ActionStatus.OK;
}
Map<CapabilityDefinition, CapabilityDefinition> oldToNewCap = capabilityResolver.resolvePrevCapToNewCapability(currentComponent, origInstanceCmpt, instanceId, prevInstanceCapabilities);
oldToNewCap.forEach(this::mergeCapabilityProperties);
StorageOperationStatus updateStatus = updateInstanceCapabilitiesProperties(currentComponent, instanceId);
return componentsUtils.convertFromStorageResponse(updateStatus);
}
private StorageOperationStatus mergeCmptCalculatedCapabilitiesProperties(Component prevComponent, Component currentComponent) {
List<ComponentInstance> prevInstances = prevComponent.getComponentInstances();
if (prevInstances == null) {
return StorageOperationStatus.OK;
}
prevInstances.forEach(prevInstance -> mergeInstanceCapabilities(prevInstance, currentComponent));
return updateComponentCapabilitiesProperties(currentComponent);
}
private void mergeInstanceCapabilities(ComponentInstance prevInstance, Component currComponent) {
ComponentInstance currInstance = MapUtil.toMap(currComponent.getComponentInstances(), ComponentInstance::getName).get(prevInstance.getName());
Map<CapabilityDefinition, CapabilityDefinition> oldToNewCapabilities = capabilityResolver.resolvePrevCapIdToNewCapability(prevInstance, currInstance);
oldToNewCapabilities.forEach(this::mergeCapabilityProperties);
}
private void mergeCapabilityProperties(CapabilityDefinition prevCapability, CapabilityDefinition currCapability) {
dataDefinitionsValuesMergingBusinessLogic.mergeInstanceDataDefinitions(prevCapability.getProperties(), currCapability.getProperties());
}
private StorageOperationStatus updateComponentCapabilitiesProperties(Component currComponent) {
return toscaOperationFacade.updateComponentCalculatedCapabilitiesProperties(currComponent);
}
private StorageOperationStatus updateInstanceCapabilitiesProperties(Component currComponent, String instanceId) {
return toscaOperationFacade.updateComponentInstanceCapabilityProperties(currComponent, instanceId);
}
private Either<Component, StorageOperationStatus> getCmptWithCapabilitiesProps(String cmptId) {
ComponentParametersView propertiesCapabilitiesFilter = new ComponentParametersView(true);
propertiesCapabilitiesFilter.setIgnoreCapabiltyProperties(false);
propertiesCapabilitiesFilter.setIgnoreComponentInstances(false);
propertiesCapabilitiesFilter.setIgnoreCapabilities(false);
return toscaOperationFacade.getToscaElement(cmptId, propertiesCapabilitiesFilter)
.right()
.map(err -> {
log.debug("failed to fetch cmpt {} with properties capabilities. status: {}", cmptId, err);
return err;
});
}
}
|