2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
21 package org.openecomp.sdc.be.model.operations.api;
23 import java.util.List;
25 import org.apache.commons.lang3.tuple.ImmutablePair;
26 import org.openecomp.sdc.be.dao.graph.datatype.GraphEdge;
27 import org.openecomp.sdc.be.dao.titan.TitanOperationStatus;
28 import org.openecomp.sdc.be.model.CapabilityDefinition;
29 import org.openecomp.sdc.be.model.ComponentInstanceProperty;
30 import org.openecomp.sdc.be.model.PropertyDefinition;
31 import org.openecomp.sdc.be.resources.data.CapabilityInstData;
32 import org.openecomp.sdc.be.resources.data.ComponentInstanceData;
33 import org.openecomp.sdc.be.resources.data.PropertyValueData;
35 import com.thinkaurelius.titan.core.TitanVertex;
37 import fj.data.Either;
40 * public interface ICapabilityInstanceOperation provides methods for CRUD operations for CapabilityInstance on component instance level
45 public interface ICapabilityInstanceOperation {
47 * create capability instance of capability with property values for resource instance
49 * @param resourceInstanceId
51 * @param propertyValues
52 * @param validateCapabilityInstExistance
53 * @param capabilityName
56 public Either<Map<CapabilityInstData, List<PropertyValueData>>, TitanOperationStatus> createCapabilityInstanceOfCapabilityWithPropertyValuesForResourceInstance(String resourceInstanceId, String capabilityId, String capabilityName,
57 List<ComponentInstanceProperty> propertyValues, boolean validateCapabilityInstExistance);
61 * @param resourceInstanceVertex
63 * @param capabilityName
64 * @param propertyValues
65 * @param validateCapabilityInstExistence
68 public TitanOperationStatus createCapabilityInstanceOfCapabilityWithPropertyValuesForResourceInstance(TitanVertex resourceInstanceVertex, String resourceInstanceId, String capabilityId, String capabilityName,
69 List<ComponentInstanceProperty> propertyValues, boolean validateCapabilityInstExistence);
72 * validate capability instance uniqueness
74 * @param resourceInstanceId
78 public Either<Boolean, TitanOperationStatus> validateCapabilityInstExistence(String resourceInstanceId, String capabilityId);
81 * delete capability instance from resource instance
83 * @param resourceInstanceId
84 * @param capabilityInstanceId
87 public Either<CapabilityInstData, TitanOperationStatus> deleteCapabilityInstanceFromResourceInstance(String resourceInstanceId, String capabilityInstanceId);
90 * get all capability instances for resource instance returns all Capability Instances related to Resource Instance as List<CapabilityInstData> or TitanOperationStatus if error occurs or if Resource Instance have no any related Capability
93 * @param resourceInstanceId
94 * @return Either<List<CapabilityInstData>, TitanOperationStatus>
96 public Either<List<ImmutablePair<CapabilityInstData, GraphEdge>>, TitanOperationStatus> getAllCapabilityInstancesOfResourceInstance(String resourceInstanceId);
99 * get capability instance of capability for resource instance
101 * @param resourceInstanceId
102 * @param capabilityId
105 public Either<CapabilityInstData, TitanOperationStatus> getCapabilityInstanceOfCapabilityOfResourceInstance(String resourceInstanceId, String capabilityId);
108 * update capability property values
110 * @param resourceInstanceId
111 * @param capabilityInstanceId
112 * @param propertyValues
113 * @param capabilityId
116 public Either<List<PropertyValueData>, TitanOperationStatus> updateCapabilityPropertyValues(String resourceInstanceId, String capabilityId, List<ComponentInstanceProperty> propertyValues);
119 * clone and associate capability instance with property values
121 * @param createdComponentInstance
123 * @param capabilityInstPair
126 public Either<ImmutablePair<CapabilityInstData, List<PropertyValueData>>, TitanOperationStatus> cloneAssociateCapabilityInstanceWithPropertyValues(ComponentInstanceData createdComponentInstance, CapabilityDefinition capability,
127 ImmutablePair<CapabilityInstData, GraphEdge> capabilityInstPair);
129 Either<Boolean, TitanOperationStatus> validateCapabilityInstExistence(TitanVertex instanceVertex, String resourceInstanceId, String capabilityId);