Final commit to master merge from
[sdc.git] / catalog-be / src / main / java / org / openecomp / sdc / be / components / impl / ResourceBusinessLogic.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * SDC
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
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
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=========================================================
19  */
20
21 package org.openecomp.sdc.be.components.impl;
22
23 import static org.openecomp.sdc.be.tosca.CsarUtils.ARTIFACTS_PATH;
24 import static org.openecomp.sdc.be.tosca.CsarUtils.VF_NODE_TYPE_ARTIFACTS_PATH_PATTERN;
25
26 import java.util.ArrayList;
27 import java.util.Collection;
28 import java.util.Collections;
29 import java.util.EnumMap;
30 import java.util.HashMap;
31 import java.util.HashSet;
32 import java.util.Iterator;
33 import java.util.List;
34 import java.util.Map;
35 import java.util.Map.Entry;
36 import java.util.Optional;
37 import java.util.Set;
38 import java.util.function.Function;
39 import java.util.regex.Matcher;
40 import java.util.regex.Pattern;
41 import java.util.stream.Collectors;
42
43 import javax.servlet.ServletContext;
44
45 import org.apache.commons.codec.binary.Base64;
46 import org.apache.commons.collections.CollectionUtils;
47 import org.apache.commons.collections.MapUtils;
48 import org.apache.commons.lang.StringUtils;
49 import org.apache.commons.lang3.tuple.ImmutablePair;
50 import org.openecomp.sdc.be.components.impl.ArtifactsBusinessLogic.ArtifactOperationEnum;
51 import org.openecomp.sdc.be.components.impl.ArtifactsBusinessLogic.ArtifactOperationInfo;
52 import org.openecomp.sdc.be.components.impl.ImportUtils.ResultStatusEnum;
53 import org.openecomp.sdc.be.components.impl.ImportUtils.ToscaElementTypeEnum;
54 import org.openecomp.sdc.be.components.impl.ImportUtils.ToscaTagNamesEnum;
55 import org.openecomp.sdc.be.components.lifecycle.LifecycleBusinessLogic;
56 import org.openecomp.sdc.be.components.lifecycle.LifecycleChangeInfoWithAction;
57 import org.openecomp.sdc.be.components.lifecycle.LifecycleChangeInfoWithAction.LifecycleChanceActionEnum;
58 import org.openecomp.sdc.be.components.merge.resource.MergeResourceBLFactory;
59 import org.openecomp.sdc.be.components.merge.resource.MergeResourceBusinessLogic;
60 import org.openecomp.sdc.be.config.BeEcompErrorManager;
61 import org.openecomp.sdc.be.config.BeEcompErrorManager.ErrorSeverity;
62 import org.openecomp.sdc.be.config.Configuration.VfModuleProperty;
63 import org.openecomp.sdc.be.config.ConfigurationManager;
64 import org.openecomp.sdc.be.dao.api.ActionStatus;
65 import org.openecomp.sdc.be.dao.titan.TitanOperationStatus;
66 import org.openecomp.sdc.be.datamodel.api.HighestFilterEnum;
67 import org.openecomp.sdc.be.datamodel.utils.ArtifactUtils;
68 import org.openecomp.sdc.be.datamodel.utils.UiComponentDataConverter;
69 import org.openecomp.sdc.be.datatypes.elements.CapabilityDataDefinition;
70 import org.openecomp.sdc.be.datatypes.elements.GetInputValueDataDefinition;
71 import org.openecomp.sdc.be.datatypes.elements.RequirementDataDefinition;
72 import org.openecomp.sdc.be.datatypes.enums.ComponentTypeEnum;
73 import org.openecomp.sdc.be.datatypes.enums.NodeTypeEnum;
74 import org.openecomp.sdc.be.datatypes.enums.ResourceTypeEnum;
75 import org.openecomp.sdc.be.impl.ComponentsUtils;
76 import org.openecomp.sdc.be.impl.WebAppContextWrapper;
77 import org.openecomp.sdc.be.info.ArtifactTemplateInfo;
78 import org.openecomp.sdc.be.info.MergedArtifactInfo;
79 import org.openecomp.sdc.be.model.ArtifactDefinition;
80 import org.openecomp.sdc.be.model.CapabilityDefinition;
81 import org.openecomp.sdc.be.model.CapabilityRequirementRelationship;
82 import org.openecomp.sdc.be.model.CapabilityTypeDefinition;
83 import org.openecomp.sdc.be.model.Component;
84 import org.openecomp.sdc.be.model.ComponentInstance;
85 import org.openecomp.sdc.be.model.ComponentInstanceInput;
86 import org.openecomp.sdc.be.model.ComponentInstanceProperty;
87 import org.openecomp.sdc.be.model.ComponentParametersView;
88 import org.openecomp.sdc.be.model.CsarInfo;
89 import org.openecomp.sdc.be.model.DataTypeDefinition;
90 import org.openecomp.sdc.be.model.GroupDefinition;
91 import org.openecomp.sdc.be.model.GroupProperty;
92 import org.openecomp.sdc.be.model.GroupTypeDefinition;
93 import org.openecomp.sdc.be.model.HeatParameterDefinition;
94 import org.openecomp.sdc.be.model.InputDefinition;
95 import org.openecomp.sdc.be.model.InterfaceDefinition;
96 import org.openecomp.sdc.be.model.LifeCycleTransitionEnum;
97 import org.openecomp.sdc.be.model.LifecycleStateEnum;
98 import org.openecomp.sdc.be.model.NodeTypeInfo;
99 import org.openecomp.sdc.be.model.Operation;
100 import org.openecomp.sdc.be.model.ParsedToscaYamlInfo;
101 import org.openecomp.sdc.be.model.PropertyDefinition;
102 import org.openecomp.sdc.be.model.RelationshipImpl;
103 import org.openecomp.sdc.be.model.RelationshipInfo;
104 import org.openecomp.sdc.be.model.RequirementCapabilityRelDef;
105 import org.openecomp.sdc.be.model.RequirementDefinition;
106 import org.openecomp.sdc.be.model.Resource;
107 import org.openecomp.sdc.be.model.UploadCapInfo;
108 import org.openecomp.sdc.be.model.UploadComponentInstanceInfo;
109 import org.openecomp.sdc.be.model.UploadPropInfo;
110 import org.openecomp.sdc.be.model.UploadReqInfo;
111 import org.openecomp.sdc.be.model.UploadResourceInfo;
112 import org.openecomp.sdc.be.model.User;
113 import org.openecomp.sdc.be.model.cache.ApplicationDataTypeCache;
114 import org.openecomp.sdc.be.model.category.CategoryDefinition;
115 import org.openecomp.sdc.be.model.category.SubCategoryDefinition;
116 import org.openecomp.sdc.be.model.heat.HeatParameterType;
117 import org.openecomp.sdc.be.model.jsontitan.utils.ModelConverter;
118 import org.openecomp.sdc.be.model.operations.api.ICacheMangerOperation;
119 import org.openecomp.sdc.be.model.operations.api.ICapabilityTypeOperation;
120 import org.openecomp.sdc.be.model.operations.api.IElementOperation;
121 import org.openecomp.sdc.be.model.operations.api.IInterfaceLifecycleOperation;
122 import org.openecomp.sdc.be.model.operations.api.IPropertyOperation;
123 import org.openecomp.sdc.be.model.operations.api.StorageOperationStatus;
124 import org.openecomp.sdc.be.model.operations.impl.CsarOperation;
125 import org.openecomp.sdc.be.model.operations.impl.DaoStatusConverter;
126 import org.openecomp.sdc.be.model.operations.impl.UniqueIdBuilder;
127 import org.openecomp.sdc.be.model.operations.utils.ComponentValidationUtils;
128 import org.openecomp.sdc.be.model.tosca.ToscaPropertyType;
129 import org.openecomp.sdc.be.resources.data.auditing.AuditingActionEnum;
130 import org.openecomp.sdc.be.servlets.RepresentationUtils;
131 import org.openecomp.sdc.be.tosca.CsarUtils;
132 import org.openecomp.sdc.be.tosca.CsarUtils.NonMetaArtifactInfo;
133 import org.openecomp.sdc.be.ui.model.UiComponentDataTransfer;
134 import org.openecomp.sdc.be.user.IUserBusinessLogic;
135 import org.openecomp.sdc.be.user.Role;
136 import org.openecomp.sdc.be.user.UserBusinessLogic;
137 import org.openecomp.sdc.be.utils.CommonBeUtils;
138 import org.openecomp.sdc.common.api.ArtifactGroupTypeEnum;
139 import org.openecomp.sdc.common.api.ArtifactTypeEnum;
140 import org.openecomp.sdc.common.api.Constants;
141 import org.openecomp.sdc.common.datastructure.AuditingFieldsKeysEnum;
142 import org.openecomp.sdc.common.datastructure.FunctionalInterfaces;
143 import org.openecomp.sdc.common.datastructure.Wrapper;
144 import org.openecomp.sdc.common.kpi.api.ASDCKpiApi;
145 import org.openecomp.sdc.common.util.GeneralUtility;
146 import org.openecomp.sdc.common.util.ValidationUtils;
147 import org.openecomp.sdc.exception.ResponseFormat;
148 import org.slf4j.Logger;
149 import org.slf4j.LoggerFactory;
150 import org.springframework.beans.factory.annotation.Autowired;
151 import org.springframework.web.context.WebApplicationContext;
152 import org.yaml.snakeyaml.DumperOptions;
153 import org.yaml.snakeyaml.Yaml;
154 import org.yaml.snakeyaml.parser.ParserException;
155
156 import com.google.gson.Gson;
157 import com.google.gson.JsonElement;
158 import com.google.gson.JsonObject;
159
160 import fj.data.Either;
161
162 @org.springframework.stereotype.Component("resourceBusinessLogic")
163 public class ResourceBusinessLogic extends ComponentBusinessLogic {
164
165         private static final String PLACE_HOLDER_RESOURCE_TYPES = "validForResourceTypes";
166         public static final String INITIAL_VERSION = "0.1";
167
168         private Pattern STR_REPLACE_PATTERN = Pattern.compile("^[ ]*\\{[ ]*" + "str_replace" + "=");
169         private Pattern TOKEN_PATTERN = Pattern.compile("[ ]*\\{[ ]*" + "token" + "=");
170         private Pattern GET_PROPERTY_PATTERN = Pattern.compile("[ ]*\\{[ ]*" + "get_property" + "=");
171         private Pattern CONCAT_PATTERN = Pattern.compile("[ ]*\\{[ ]*" + "concat" + "=");
172
173         private static Logger log = LoggerFactory.getLogger(ResourceBusinessLogic.class.getName());
174
175         private static Pattern pattern = Pattern.compile("\\..(.*?)\\..");
176
177         /**
178          * Default constructor
179          */
180         public ResourceBusinessLogic() {
181                 log.debug("ResourceBusinessLogic started");
182         }
183
184         @Autowired
185         private ICapabilityTypeOperation capabilityTypeOperation = null;
186
187         @Autowired
188         private IInterfaceLifecycleOperation interfaceTypeOperation = null;
189
190         @Autowired
191         private LifecycleBusinessLogic lifecycleBusinessLogic;
192
193         @Autowired
194         private IPropertyOperation propertyOperation;
195
196         @Autowired
197         private CsarOperation csarOperation;
198
199         @Autowired
200         private VFComponentInstanceBusinessLogic vfComponentInstanceBusinessLogic;
201
202         @Autowired
203         private ResourceImportManager resourceImportManager;
204
205         @Autowired
206         private GroupBusinessLogic groupBusinessLogic;
207
208         @Autowired
209         private InputsBusinessLogic inputsBusinessLogic;
210
211         @Autowired
212         private CompositionBusinessLogic compositionBusinessLogic;
213
214         @Autowired
215         private ICacheMangerOperation cacheManagerOperation;
216
217         @Autowired
218         private ApplicationDataTypeCache dataTypeCache;
219
220         @Autowired
221         private MergeResourceBLFactory mergeResourceBLFactory;
222
223         private Gson gson = new Gson();
224
225         public CsarOperation getCsarOperation() {
226                 return csarOperation;
227         }
228
229         public void setCsarOperation(CsarOperation csarOperation) {
230                 this.csarOperation = csarOperation;
231         }
232
233         public LifecycleBusinessLogic getLifecycleBusinessLogic() {
234                 return lifecycleBusinessLogic;
235         }
236
237         public void setLifecycleManager(LifecycleBusinessLogic lifecycleBusinessLogic) {
238                 this.lifecycleBusinessLogic = lifecycleBusinessLogic;
239         }
240
241         public IElementOperation getElementDao() {
242                 return elementDao;
243         }
244
245         public void setElementDao(IElementOperation elementDao) {
246                 this.elementDao = elementDao;
247         }
248
249         public IUserBusinessLogic getUserAdmin() {
250                 return this.userAdmin;
251         }
252
253         public void setUserAdmin(UserBusinessLogic userAdmin) {
254                 this.userAdmin = userAdmin;
255         }
256
257         public ComponentsUtils getComponentsUtils() {
258                 return this.componentsUtils;
259         }
260
261         public void setComponentsUtils(ComponentsUtils componentsUtils) {
262                 this.componentsUtils = componentsUtils;
263         }
264
265         public ArtifactsBusinessLogic getArtifactsManager() {
266                 return artifactsBusinessLogic;
267         }
268
269         public void setArtifactsManager(ArtifactsBusinessLogic artifactsManager) {
270                 this.artifactsBusinessLogic = artifactsManager;
271         }
272
273         public void setPropertyOperation(IPropertyOperation propertyOperation) {
274                 this.propertyOperation = propertyOperation;
275         }
276
277         public ApplicationDataTypeCache getApplicationDataTypeCache() {
278                 return applicationDataTypeCache;
279         }
280
281         public void setApplicationDataTypeCache(ApplicationDataTypeCache applicationDataTypeCache) {
282                 this.applicationDataTypeCache = applicationDataTypeCache;
283         }
284
285         /**
286          * the method returns a list of all the resources that are certified, the returned resources are only abstract or only none abstract according to the given param
287          *
288          * @param getAbstract
289          * @param userId      TODO
290          * @return
291          */
292         public Either<List<Resource>, ResponseFormat> getAllCertifiedResources(boolean getAbstract, HighestFilterEnum highestFilter, String userId) {
293                 Either<User, ResponseFormat> resp = validateUserExists(userId, "get All Certified Resources", false);
294                 if (resp.isRight()) {
295                         return Either.right(resp.right().value());
296                 }
297                 Boolean isHighest = null;
298                 switch (highestFilter) {
299                 case ALL:
300                         break;
301                 case HIGHEST_ONLY:
302                         isHighest = true;
303                         break;
304                 case NON_HIGHEST_ONLY:
305                         isHighest = false;
306                         break;
307                 default:
308                         break;
309                 }
310                 Either<List<Resource>, StorageOperationStatus> getResponse = toscaOperationFacade.getAllCertifiedResources(getAbstract, isHighest);
311
312                 if (getResponse.isRight()) {
313                         return Either.right(componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(getResponse.right().value())));
314                 }
315
316                 return Either.left(getResponse.left().value());
317         }
318
319         public Either<Map<String, Boolean>, ResponseFormat> validateResourceNameExists(String resourceName, ResourceTypeEnum resourceTypeEnum, String userId) {
320
321                 Either<User, ResponseFormat> resp = validateUserExists(userId, "validate Resource Name Exists", false);
322                 if (resp.isRight()) {
323                         return Either.right(resp.right().value());
324                 }
325
326                 Either<Boolean, StorageOperationStatus> dataModelResponse = toscaOperationFacade.validateComponentNameUniqueness(resourceName, resourceTypeEnum, ComponentTypeEnum.RESOURCE);
327                 // DE242223
328                 titanDao.commit();
329
330                 if (dataModelResponse.isLeft()) {
331                         Map<String, Boolean> result = new HashMap<>();
332                         result.put("isValid", dataModelResponse.left().value());
333                         log.debug("validation was successfully performed.");
334                         return Either.left(result);
335                 }
336
337                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(dataModelResponse.right().value()));
338
339                 return Either.right(responseFormat);
340         }
341
342         public Either<Resource, ResponseFormat> createResource(Resource resource, AuditingActionEnum auditingAction, User user, Map<String, byte[]> csarUIPayload, String payloadName) {
343                 Either<Resource, ResponseFormat> createResourceResponse = validateResourceBeforeCreate(resource, user, false);
344                 if (createResourceResponse.isRight()) {
345                         return createResourceResponse;
346                 }
347
348                 // Creating resource either by DAO or from CSAR
349                 String csarUUID = null;
350                 if (payloadName == null) {
351                         csarUUID = resource.getCsarUUID();
352                 } else {
353                         csarUUID = payloadName;
354                 }
355                 if (csarUUID != null && !csarUUID.isEmpty()) {
356                         // check if VF with the same Csar UUID or with he same name already
357                         // exists
358                         Either<Integer, StorageOperationStatus> validateCsarUuidUniquenessRes = toscaOperationFacade.validateCsarUuidUniqueness(csarUUID);
359                         if (validateCsarUuidUniquenessRes.isRight()) {
360                                 log.debug("Failed to validate uniqueness of CsarUUID {} for resource", csarUUID, resource.getSystemName());
361                                 return Either.right(componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(validateCsarUuidUniquenessRes.right().value())));
362                         }
363
364                         Integer existingResourceRes = validateCsarUuidUniquenessRes.left().value();
365                         if (existingResourceRes.intValue() > 0) {
366                                 log.debug("Failed to create resource {}, csarUUID {} already exist for a different VF ", resource.getSystemName(), csarUUID);
367                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.VSP_ALREADY_EXISTS, csarUUID);
368                                 componentsUtils.auditResource(errorResponse, user, resource, "", "", auditingAction, null);
369                                 return Either.right(errorResponse);
370                         }
371
372                         log.debug("CsarUUID is {} - going to create resource from CSAR", csarUUID);
373                         createResourceResponse = createResourceFromCsar(resource, user, Either.left(csarUIPayload), csarUUID);
374                         return createResourceResponse;
375                 }
376
377                 return createResourceByDao(resource, user, auditingAction, false, false, null);
378         }
379
380         public Either<Resource, ResponseFormat> validateAndUpdateResourceFromCsar(Resource resource, User user, Map<String, byte[]> csarUIPayload, String payloadName, String resourceUniqueId) {
381                 Either<Resource, ResponseFormat> updateResourceResponse = null;
382                 Either<Resource, ResponseFormat> validateResourceResponse = null;
383                 Wrapper<ResponseFormat> responseWrapper = new Wrapper<ResponseFormat>();
384                 String csarUUID = null;
385                 String csarVersion = null;
386                 if (payloadName == null) {
387                         csarUUID = resource.getCsarUUID();
388                         csarVersion = resource.getCsarVersion();
389                 } else {
390                         csarUUID = payloadName;
391                 }
392                 if (csarUUID != null && !csarUUID.isEmpty()) {
393                         Resource oldResource = getResourceByUniqueId(responseWrapper, resourceUniqueId);
394                         if (responseWrapper.isEmpty()) {
395                                 validateCsarUuidMatching(responseWrapper, oldResource, resource, csarUUID, resourceUniqueId, user);
396                         }
397                         if (responseWrapper.isEmpty()) {
398                                 validateCsarIsNotAlreadyUsed(responseWrapper, oldResource, resource, csarUUID, user);
399                         }
400                         if (responseWrapper.isEmpty()) {
401                                 if (oldResource != null && ValidationUtils.hasBeenCertified(oldResource.getVersion())) {
402                                         overrideImmutableMetadata(oldResource, resource);
403                                 }
404                                 validateResourceResponse = validateResourceBeforeCreate(resource, user, false);
405                                 if (validateResourceResponse.isRight()) {
406                                         responseWrapper.setInnerElement(validateResourceResponse.right().value());
407                                 }
408                         }
409                         if (responseWrapper.isEmpty()) {
410                                 String oldCsarVersion = oldResource.getCsarVersion();
411                                 log.debug("CsarUUID is {} - going to update resource with UniqueId {} from CSAR", csarUUID, resourceUniqueId);
412                                 // (on boarding flow): If the update includes same csarUUID and
413                                 // same csarVersion as already in the VF - no need to import the
414                                 // csar (do only metadata changes if there are).
415                                 if (csarVersion != null && oldCsarVersion != null && oldCsarVersion.equals(csarVersion)) {
416                                         updateResourceResponse = updateResourceMetadata(resourceUniqueId, resource, oldResource, user, false);
417                                 } else {
418                                         updateResourceResponse = updateResourceFromCsar(oldResource, resource, user, AuditingActionEnum.UPDATE_RESOURCE_METADATA, false, Either.left(csarUIPayload), csarUUID);
419                                 }
420                         }
421                 } else {
422                         log.debug("Failed to update resource {}, csarUUID or payload name is missing", resource.getSystemName());
423                         ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.MISSING_CSAR_UUID, resource.getName());
424                         componentsUtils.auditResource(errorResponse, user, resource, "", "", AuditingActionEnum.CREATE_RESOURCE, null);
425                         responseWrapper.setInnerElement(errorResponse);
426                 }
427                 if (responseWrapper.isEmpty()) {
428                         return updateResourceResponse;
429                 }
430                 return Either.right(responseWrapper.getInnerElement());
431         }
432
433         private void validateCsarIsNotAlreadyUsed(Wrapper<ResponseFormat> responseWrapper, Resource oldResource, Resource resource, String csarUUID, User user) {
434                 // (on boarding flow): If the update includes a csarUUID: verify this
435                 // csarUUID is not in use by another VF, If it is - use same error as
436                 // above:
437                 // "Error: The VSP with UUID %1 was already imported for VF %2. Please
438                 // select another or update the existing VF." %1 - csarUUID, %2 - VF
439                 // name
440                 Either<Resource, StorageOperationStatus> resourceLinkedToCsarRes = toscaOperationFacade.getLatestComponentByCsarOrName(ComponentTypeEnum.RESOURCE, csarUUID, resource.getSystemName());
441                 if (resourceLinkedToCsarRes.isRight()) {
442                         if (!StorageOperationStatus.NOT_FOUND.equals(resourceLinkedToCsarRes.right().value())) {
443                                 log.debug("Failed to find previous resource by CSAR {} and system name {}", csarUUID, resource.getSystemName());
444                                 responseWrapper.setInnerElement(componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(resourceLinkedToCsarRes.right().value())));
445                         }
446                 } else if (!resourceLinkedToCsarRes.left().value().getUniqueId().equals(oldResource.getUniqueId()) && !resourceLinkedToCsarRes.left().value().getName().equals(oldResource.getName())) {
447                         ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.VSP_ALREADY_EXISTS, csarUUID, resourceLinkedToCsarRes.left().value().getName());
448                         componentsUtils.auditResource(errorResponse, user, resource, "", "", AuditingActionEnum.UPDATE_RESOURCE_METADATA, null);
449                         responseWrapper.setInnerElement(errorResponse);
450                 }
451         }
452
453         private void validateCsarUuidMatching(Wrapper<ResponseFormat> responseWrapper, Resource resource, Resource oldResource, String csarUUID, String resourceUniqueId, User user) {
454                 // (on boarding flow): If the update includes csarUUID which is
455                 // different from the csarUUID of the VF - fail with
456                 // error: "Error: Resource %1 cannot be updated using since it is linked
457                 // to a different VSP" %1 - VF name
458                 String oldCsarUUID = oldResource.getCsarUUID();
459                 if (oldCsarUUID != null && !oldCsarUUID.isEmpty() && !csarUUID.equals(oldCsarUUID)) {
460                         log.debug("Failed to update resource with UniqueId {} using Csar {}, since the resource is linked to a different VSP {}", resourceUniqueId, csarUUID, oldCsarUUID);
461                         ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.RESOURCE_LINKED_TO_DIFFERENT_VSP, resource.getName(), csarUUID, oldCsarUUID);
462                         componentsUtils.auditResource(errorResponse, user, resource, "", "", AuditingActionEnum.UPDATE_RESOURCE_METADATA, null);
463                         responseWrapper.setInnerElement(errorResponse);
464                 }
465         }
466
467         private Resource getResourceByUniqueId(Wrapper<ResponseFormat> responseWrapper, String resourceUniqueId) {
468                 Either<Resource, StorageOperationStatus> oldResourceRes = toscaOperationFacade.getToscaElement(resourceUniqueId);
469                 if (oldResourceRes.isRight()) {
470                         log.debug("Failed to find previous resource by UniqueId {}, status: {}", resourceUniqueId, oldResourceRes.right().value());
471                         responseWrapper.setInnerElement(componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(oldResourceRes.right().value())));
472                         return null;
473                 }
474                 return oldResourceRes.left().value();
475         }
476
477         private void overrideImmutableMetadata(Resource oldRresource, Resource resource) {
478                 resource.setName(oldRresource.getName());
479                 resource.setIcon(oldRresource.getIcon());
480                 resource.setTags(oldRresource.getTags());
481                 resource.setVendorName(oldRresource.getVendorName());
482                 resource.setCategories(oldRresource.getCategories());
483                 resource.setDerivedFrom(oldRresource.getDerivedFrom());
484         }
485
486         private Either<Resource, ResponseFormat> updateResourceFromCsar(Resource oldRresource, Resource newRresource, User user, AuditingActionEnum updateResource, boolean inTransaction, Either<Map<String, byte[]>, StorageOperationStatus> csarUIPayload,
487                         String csarUUID) {
488
489                 // check state
490                 if (LifecycleStateEnum.NOT_CERTIFIED_CHECKOUT.equals(oldRresource.getLifecycleState())) {
491                         if (!oldRresource.getLastUpdaterUserId().equals(user.getUserId())) {
492                                 log.debug("Current user is not last updater, last updater userId: {}, current user userId: {}", oldRresource.getLastUpdaterUserId(), user.getUserId());
493                                 return Either.right(componentsUtils.getResponseFormat(ActionStatus.RESTRICTED_OPERATION));
494                         }
495                 }
496                 String lockedResourceId = oldRresource.getUniqueId();
497                 List<ArtifactDefinition> createdArtifacts = new ArrayList<>();
498
499                 Either<Map<String, byte[]>, StorageOperationStatus> csar = null;
500                 if (csarUIPayload != null && csarUIPayload.left() != null && csarUIPayload.left().value() != null) {
501                         csar = csarUIPayload;
502                 } else {
503                         csar = csarOperation.getCsar(csarUUID, user);
504                 }
505                 if (csar.isRight()) {
506                         log.debug("Failed to get csar for casrUUID{} ", csarUUID);
507                         return Either.right(componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(csar.right().value())));
508                 }
509
510                 Either<ImmutablePair<String, String>, ResponseFormat> toscaYamlCsarStatus = validateAndParseCsar(newRresource, user, csarUUID, csar);
511                 if (toscaYamlCsarStatus.isRight()) {
512                         return Either.right(toscaYamlCsarStatus.right().value());
513                 }
514                 Either<String, ResponseFormat> checksum = CsarValidationUtils.getToscaYamlChecksum(csar.left().value(), csarUUID, componentsUtils);
515                 if (checksum.isRight()) {
516                         log.debug("Failed to calculate checksum for casrUUID{} error {} ", csarUUID, checksum.right().value());
517                         return Either.right(checksum.right().value());
518                 }
519                 boolean isUpdateYaml = true;
520                 if (checksum.left().value().equals(oldRresource.getComponentMetadataDefinition().getMetadataDataDefinition().getImportedToscaChecksum())) {
521                         log.debug("The checksums are equals for csarUUID {}, existing checsum is {}, new one is {} ", csarUUID, oldRresource.getComponentMetadataDefinition().getMetadataDataDefinition().getImportedToscaChecksum(), checksum.left().value());
522                         if (oldRresource.getLifecycleState().equals(LifecycleStateEnum.NOT_CERTIFIED_CHECKOUT))
523                                 isUpdateYaml = false;
524                 } else {
525                         oldRresource.getComponentMetadataDefinition().getMetadataDataDefinition().setImportedToscaChecksum(checksum.left().value());
526                 }
527
528                 Either<Boolean, ResponseFormat> lockResult = lockComponent(lockedResourceId, oldRresource, "update Resource From Csar");
529                 if (lockResult.isRight()) {
530                         return Either.right(lockResult.right().value());
531                 }
532
533                 String yamlFileName = toscaYamlCsarStatus.left().value().getKey();
534                 String yamlFileContents = toscaYamlCsarStatus.left().value().getValue();
535                 CsarInfo csarInfo = new CsarInfo(newRresource.getName(), user, csarUUID, csar.left().value(), yamlFileContents, true);
536                 Map<String, NodeTypeInfo> nodeTypesInfo = extractNodeTypesInfo(csarInfo);
537                 Either<Resource, ResponseFormat>  result = null;
538                 
539                 Either<Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>>, ResponseFormat> findNodeTypesArtifactsToHandleRes = findNodeTypesArtifactsToHandle(nodeTypesInfo, csarInfo, oldRresource);
540                 if (findNodeTypesArtifactsToHandleRes.isRight()) {
541                         log.debug("failed to find node types for update with artifacts during import csar {}. ", csarInfo.getCsarUUID());
542                         result = Either.right(findNodeTypesArtifactsToHandleRes.right().value());
543                         return result;
544                 }
545                 Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>> nodeTypesArtifactsToHandle = findNodeTypesArtifactsToHandleRes.left().value();
546                 try{
547                         result =  updateResourceFromYaml(oldRresource, newRresource, updateResource, createdArtifacts, isUpdateYaml, yamlFileName, yamlFileContents, csarInfo, nodeTypesInfo, nodeTypesArtifactsToHandle, null, false);
548                 
549                 } finally {
550                         if (result == null || result.isRight()) {
551                                 log.warn("operation failed. do rollback");
552                                 titanDao.rollback();
553                         } else {
554                                 log.debug("operation success. do commit");
555                                 titanDao.commit();
556                         }
557                         log.debug("unlock resource {}", lockedResourceId);
558                         graphLockOperation.unlockComponent(lockedResourceId, NodeTypeEnum.Resource);
559                 }
560                 return result;
561
562         }
563
564         private Either<Resource, ResponseFormat> updateResourceFromYaml(Resource oldRresource, Resource newRresource, AuditingActionEnum updateResource, List<ArtifactDefinition> createdArtifacts,
565                         boolean isUpdateYaml, String yamlFileName,      String yamlFileContent, CsarInfo csarInfo, Map<String, NodeTypeInfo> nodeTypesInfo,
566                         Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>> nodeTypesArtifactsToHandle, String nodeName, boolean isNested) {
567                 Either<Resource, ResponseFormat> result;
568                 Either<Map<String, Resource>, ResponseFormat> parseNodeTypeInfoYamlEither;
569                 boolean inTransaction = true;
570                 boolean shouldLock = false;
571                 
572                         Either<ImmutablePair<Resource, ActionStatus>, ResponseFormat> prepareForUpdate;
573                         Resource preparedResource;
574                         Either<ParsedToscaYamlInfo, ResponseFormat> uploadComponentInstanceInfoMap = parseResourceInfoFromYaml(yamlFileName, newRresource, yamlFileContent, csarInfo.getCreatedNodesToscaResourceNames(), nodeTypesInfo, nodeName);
575                         if (uploadComponentInstanceInfoMap.isRight()) {
576                                 ResponseFormat responseFormat = uploadComponentInstanceInfoMap.right().value();
577                                 componentsUtils.auditResource(responseFormat, csarInfo.getModifier(), newRresource, "", "", updateResource, null);
578                                 result = Either.right(responseFormat);
579                                 return result;
580                         }
581                         
582                         Map<String, UploadComponentInstanceInfo> instances = uploadComponentInstanceInfoMap.left().value().getInstances();
583
584                         if (isUpdateYaml || !nodeTypesArtifactsToHandle.isEmpty()) {
585
586                                 prepareForUpdate = updateExistingResourceByImport(newRresource, oldRresource, csarInfo.getModifier(), inTransaction, shouldLock, isNested);
587                                 if (prepareForUpdate.isRight()) {
588                                         log.debug("Failed to prepare resource for update : {}", prepareForUpdate.right().value());
589                                         result = Either.right(prepareForUpdate.right().value());
590                                         return result;
591                                 }
592                                 preparedResource = prepareForUpdate.left().value().left;
593
594                                 log.trace("YAML topology file found in CSAR, file name: {}, contents: {}", yamlFileName, yamlFileContent);
595
596                                 Either<Resource, ResponseFormat> genericResourceEither = handleResourceGenericType(preparedResource);
597                                 if (genericResourceEither.isRight()) {
598                                         log.debug("failed to get resource generic type. status is {}", genericResourceEither.right().value());
599                                         ResponseFormat responseFormat = genericResourceEither.right().value();
600                                         componentsUtils.auditResource(genericResourceEither.right().value(), csarInfo.getModifier(), preparedResource, "", "", updateResource, null);
601                                         return Either.right(responseFormat);
602                                 }
603
604                                 parseNodeTypeInfoYamlEither = this.handleNodeTypes(yamlFileName, preparedResource, yamlFileContent, shouldLock, nodeTypesArtifactsToHandle, createdArtifacts, nodeTypesInfo, csarInfo, nodeName);
605                                 if (parseNodeTypeInfoYamlEither.isRight()) {
606                                         ResponseFormat responseFormat = parseNodeTypeInfoYamlEither.right().value();
607                                         componentsUtils.auditResource(responseFormat, csarInfo.getModifier(), preparedResource, "", "", updateResource, null);
608                                         result = Either.right(responseFormat);
609                                         return result;
610                                 }
611
612                                 Map<String, InputDefinition> inputs = uploadComponentInstanceInfoMap.left().value().getInputs();
613                                 Either<Resource, ResponseFormat> createInputsOnResource = createInputsOnResource(preparedResource, csarInfo.getModifier(), inputs, inTransaction);
614                                 if (createInputsOnResource.isRight()) {
615                                         log.debug("failed to create resource inputs status is {}", createInputsOnResource.right().value());
616                                         ResponseFormat responseFormat = createInputsOnResource.right().value();
617                                         componentsUtils.auditResource(createInputsOnResource.right().value(), csarInfo.getModifier(), preparedResource, "", "", updateResource, null);
618                                         result = Either.right(responseFormat);
619                                         return result;
620                                 }
621                                 preparedResource = createInputsOnResource.left().value();
622
623                                 Either<Resource, ResponseFormat> createResourcesInstancesEither = createResourceInstances(csarInfo.getModifier(), yamlFileName, preparedResource, instances, inTransaction, shouldLock, csarInfo.getCreatedNodes());
624                                 if (createResourcesInstancesEither.isRight()) {
625                                         log.debug("failed to create resource instances status is {}", createResourcesInstancesEither.right().value());
626                                         ResponseFormat responseFormat = createResourcesInstancesEither.right().value();
627                                         componentsUtils.auditResource(createResourcesInstancesEither.right().value(), csarInfo.getModifier(), preparedResource, "", "", updateResource, null);
628                                         result = Either.right(responseFormat);
629                                         return result;
630                                 }
631                                 preparedResource = createResourcesInstancesEither.left().value();
632                                 
633                                 createResourcesInstancesEither = createResourceInstancesRelations(csarInfo.getModifier(), yamlFileName, preparedResource, instances);
634                                 if (createResourcesInstancesEither.isRight()) {
635                                         log.debug("failed to create relation between resource instances status is {}", createResourcesInstancesEither.right().value());
636                                         result = Either.right(createResourcesInstancesEither.right().value());
637                                         return result;
638                                 }
639
640                                 preparedResource = createResourcesInstancesEither.left().value();
641
642                                 Either<Map<String, GroupDefinition>, ResponseFormat> validateUpdateVfGroupNamesRes = groupBusinessLogic.validateUpdateVfGroupNames(uploadComponentInstanceInfoMap.left().value().getGroups(), preparedResource.getSystemName());
643                                 if (validateUpdateVfGroupNamesRes.isRight()) {
644
645                                         return Either.right(validateUpdateVfGroupNamesRes.right().value());
646                                 }
647                                 // add groups to resource
648                                 Map<String, GroupDefinition> groups;
649
650                                 if (!validateUpdateVfGroupNamesRes.left().value().isEmpty()) {
651                                         groups = validateUpdateVfGroupNamesRes.left().value();
652                                 } else {
653                                         groups = uploadComponentInstanceInfoMap.left().value().getGroups();
654                                 }
655                                 Either<Resource, ResponseFormat> updatedGroupsOnResource = updateGroupsOnResource(preparedResource, csarInfo.getModifier(), groups);
656                                 if (updatedGroupsOnResource.isRight()) {
657
658                                         return updatedGroupsOnResource;
659                                 }
660                                 preparedResource = updatedGroupsOnResource.left().value();
661
662                         } else {
663                                 Either<Resource, ResponseFormat> dataModelResponse = updateResourceMetadata(oldRresource.getUniqueId(), newRresource, csarInfo.getModifier(), oldRresource, shouldLock, inTransaction);
664                                 if (dataModelResponse.isRight()) {
665                                         log.debug("failed to update resource metadata {}", dataModelResponse.right().value());
666                                         result = Either.right(dataModelResponse.right().value());
667                                         return result;
668                                 }
669                                 preparedResource = dataModelResponse.left().value();
670                         }
671
672                         if(preparedResource.getResourceType() == ResourceTypeEnum.CVFC){
673                                 if(nodeName != null && nodeTypesArtifactsToHandle.get(nodeName) != null && !nodeTypesArtifactsToHandle.get(nodeName).isEmpty()){
674                                         Either<List<ArtifactDefinition>, ResponseFormat> handleNodeTypeArtifactsRes = 
675                                                         handleNodeTypeArtifacts(preparedResource, nodeTypesArtifactsToHandle.get(nodeName), createdArtifacts, csarInfo.getModifier(), inTransaction, true);
676                                         if(handleNodeTypeArtifactsRes.isRight()){
677                                                 return Either.right(handleNodeTypeArtifactsRes.right().value());
678                                         }
679                                 }
680                         } else {
681                                 Either<Resource, ResponseFormat> createdCsarArtifactsEither = handleVfCsarArtifacts(preparedResource, csarInfo, createdArtifacts,
682                                                 artifactsBusinessLogic.new ArtifactOperationInfo(false, false, ArtifactOperationEnum.Update), shouldLock, inTransaction);
683                                 log.trace("************* Finished to add artifacts from yaml {}", yamlFileName);
684                                 if (createdCsarArtifactsEither.isRight()) {
685                                         return createdCsarArtifactsEither;
686                                 }
687                                 preparedResource = createdCsarArtifactsEither.left().value();
688                         }
689
690                         ActionStatus mergingPropsAndInputsStatus = mergeResourceEntities(oldRresource, preparedResource);
691                         if (mergingPropsAndInputsStatus != ActionStatus.OK) {
692                                 ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(mergingPropsAndInputsStatus, preparedResource);
693                                 return Either.right(responseFormat);
694                         }
695
696                         Either<List<ComponentInstance>, ResponseFormat> eitherSetPosition = compositionBusinessLogic.setPositionsForComponentInstances(preparedResource, csarInfo.getModifier().getUserId());
697                         result = eitherSetPosition.isRight() ? Either.right(eitherSetPosition.right().value()) : Either.left(preparedResource);
698
699                         return result;
700
701         }
702
703         private ActionStatus mergeResourceEntities(Resource oldResource, Resource newResource) {
704                 Either<MergeResourceBusinessLogic, ActionStatus> mergeResourceBLEither = mergeResourceBLFactory.getInstance(oldResource, newResource);
705                 if (mergeResourceBLEither.isRight()) {
706                         return mergeResourceBLEither.right().value();
707                 }
708                 MergeResourceBusinessLogic mergeResourceBusinessLogic = mergeResourceBLEither.left().value();
709                 return mergeResourceBusinessLogic.mergeResourceEntities(oldResource, newResource);
710         }
711
712         private Either<Resource, ResponseFormat> handleResourceGenericType(Resource resource) {
713                 Either<Resource, ResponseFormat> genericResourceEither = fetchAndSetDerivedFromGenericType(resource);
714                 if (genericResourceEither.isRight()) {
715                         return genericResourceEither;
716                 }
717                 if (resource.shouldGenerateInputs()) {
718                         generateAndAddInputsFromGenericTypeProperties(resource, genericResourceEither.left().value());
719                 }
720                 return genericResourceEither;
721         }
722
723         private Either<Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>>, ResponseFormat> findNodeTypesArtifactsToHandle(Map<String, NodeTypeInfo> nodeTypesInfo, CsarInfo csarInfo, Resource oldResource) {
724
725                 Map<String, List<ArtifactDefinition>> extractedVfcsArtifacts = CsarUtils.extractVfcsArtifactsFromCsar(csarInfo.getCsar());
726                 Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>> nodeTypesArtifactsToHandle = new HashMap<>();
727                 Either<Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>>, ResponseFormat> nodeTypesArtifactsToHandleRes;
728
729                 try {
730                         nodeTypesArtifactsToHandleRes = Either.left(nodeTypesArtifactsToHandle);
731                         Map<String, ImmutablePair<String,String>> extractedVfcToscaNames = extractVfcToscaNames(nodeTypesInfo, oldResource.getName(), csarInfo);
732                         Either<EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>, ResponseFormat> curNodeTypeArtifactsToHandleRes;
733                         EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>> curNodeTypeArtifactsToHandle = null;
734                         log.debug("Going to fetch node types for resource with name {} during import csar with UUID {}. ", oldResource.getName(), csarInfo.getCsarUUID());
735
736                         for (Entry<String, ImmutablePair<String,String>> currVfcToscaNameEntry : extractedVfcToscaNames.entrySet()) {
737                                 String currVfcToscaName = currVfcToscaNameEntry.getValue().getLeft();
738                                 String previousVfcToscaName = currVfcToscaNameEntry.getValue().getRight();
739                                 String currNamespace = currVfcToscaNameEntry.getKey();
740                                 log.debug("Going to fetch node type with tosca name {}. ", currVfcToscaName);
741
742                                 Either<Resource, StorageOperationStatus> curVfcRes = toscaOperationFacade.getLatestByToscaResourceName(currVfcToscaName);
743                                 Resource curNodeType = null;
744                                 if (curVfcRes.isRight() && curVfcRes.right().value() == StorageOperationStatus.NOT_FOUND) {
745                                         curVfcRes = toscaOperationFacade.getLatestByToscaResourceName(previousVfcToscaName);
746                                 }
747                                 if (curVfcRes.isRight() && curVfcRes.right().value() != StorageOperationStatus.NOT_FOUND) {
748                                         log.debug("Error occured during fetching node type with tosca name {}, error: {}", currVfcToscaName, curVfcRes.right().value());
749                                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(curVfcRes.right().value()), csarInfo.getCsarUUID());
750                                         componentsUtils.auditResource(responseFormat, csarInfo.getModifier(), oldResource, "", "", AuditingActionEnum.CREATE_RESOURCE, null);
751                                         nodeTypesArtifactsToHandleRes = Either.right(responseFormat);
752                                         break;
753                                 } else if (curVfcRes.isLeft()) {
754                                         curNodeType = curVfcRes.left().value();
755                                 }
756                                 if (!MapUtils.isEmpty(extractedVfcsArtifacts)) {
757                                         List<ArtifactDefinition> currArtifacts = new ArrayList<>();
758                                         if (extractedVfcsArtifacts.containsKey(currNamespace)) {
759                                                 handleAndAddExtractedVfcsArtifacts(currArtifacts, extractedVfcsArtifacts.get(currNamespace));
760                                         }
761                                         curNodeTypeArtifactsToHandleRes = findNodeTypeArtifactsToHandle(curNodeType, currArtifacts);
762                                         if (curNodeTypeArtifactsToHandleRes.isRight()) {
763                                                 nodeTypesArtifactsToHandleRes = Either.right(curNodeTypeArtifactsToHandleRes.right().value());
764                                                 break;
765                                         }
766                                         curNodeTypeArtifactsToHandle = curNodeTypeArtifactsToHandleRes.left().value();
767
768                                 } else if (curNodeType != null) {
769                                         // delete all artifacts if have not received artifacts from csar
770                                         curNodeTypeArtifactsToHandle = new EnumMap<>(ArtifactOperationEnum.class);
771                                         List<ArtifactDefinition> artifactsToDelete = new ArrayList<>();
772                                         // delete all informational artifacts
773                                         artifactsToDelete.addAll(curNodeType.getArtifacts().values().stream().filter(a -> a.getArtifactGroupType() == ArtifactGroupTypeEnum.INFORMATIONAL).collect(Collectors.toList()));
774                                         // delete all deployment artifacts
775                                         artifactsToDelete.addAll(curNodeType.getDeploymentArtifacts().values());
776                                         if (!artifactsToDelete.isEmpty()) {
777                                                 curNodeTypeArtifactsToHandle.put(ArtifactOperationEnum.Delete, artifactsToDelete);
778                                         }
779                                 }
780                                 if (MapUtils.isNotEmpty(curNodeTypeArtifactsToHandle)) {
781                                         nodeTypesArtifactsToHandle.put(currVfcToscaNameEntry.getKey(), curNodeTypeArtifactsToHandle);
782                                 }
783                         }
784                 } catch (Exception e) {
785                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR);
786                         nodeTypesArtifactsToHandleRes = Either.right(responseFormat);
787                         log.debug("Exception occured when findNodeTypesUpdatedArtifacts, error is:{}", e.getMessage(), e);
788                 }
789                 return nodeTypesArtifactsToHandleRes;
790         }
791
792         private Either<EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>, ResponseFormat> findNodeTypeArtifactsToHandle(Resource curNodeType, List<ArtifactDefinition> extractedArtifacts) {
793
794                 Either<EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>, ResponseFormat> nodeTypeArtifactsToHandleRes = null;
795                 EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>> nodeTypeArtifactsToHandle = null;
796                 Wrapper<ResponseFormat> responseWrapper = new Wrapper<>();
797                 try {
798                         List<ArtifactDefinition> artifactsToUpload = new ArrayList<>(extractedArtifacts);
799                         List<ArtifactDefinition> artifactsToUpdate = new ArrayList<>();
800                         List<ArtifactDefinition> artifactsToDelete = new ArrayList<>();
801                         if (curNodeType != null) {
802                                 Map<String, ArtifactDefinition> existingArtifacts = new HashMap<>();
803                                 if (curNodeType.getDeploymentArtifacts() != null) {
804                                         existingArtifacts.putAll(curNodeType.getDeploymentArtifacts());
805                                 }
806                                 if (curNodeType.getArtifacts() != null) {
807                                         existingArtifacts.putAll(curNodeType.getArtifacts().entrySet().stream().filter(e -> e.getValue().getArtifactGroupType() == ArtifactGroupTypeEnum.INFORMATIONAL).collect(Collectors.toMap(e -> e.getKey(), e -> e.getValue())));
808                                 }
809                                 for (ArtifactDefinition currNewArtifact : extractedArtifacts) {
810                                         ArtifactDefinition foundArtifact;
811
812                                         if (!existingArtifacts.isEmpty()) {
813                                                 foundArtifact = existingArtifacts.values().stream().filter(a -> a.getArtifactName().equals(currNewArtifact.getArtifactName())).findFirst().orElse(null);
814                                                 if (foundArtifact != null) {
815                                                         if (foundArtifact.getArtifactType().equals(currNewArtifact.getArtifactType())) {
816                                                                 if (!foundArtifact.getArtifactChecksum().equals(currNewArtifact.getArtifactChecksum())) {
817                                                                         foundArtifact.setPayload(currNewArtifact.getPayloadData());
818                                                                         foundArtifact.setPayloadData(Base64.encodeBase64String(currNewArtifact.getPayloadData()));
819                                                                         foundArtifact.setArtifactChecksum(GeneralUtility.calculateMD5Base64EncodedByByteArray(currNewArtifact.getPayloadData()));
820                                                                         artifactsToUpdate.add(foundArtifact);
821                                                                 }
822                                                                 existingArtifacts.remove(foundArtifact.getArtifactLabel());
823                                                                 artifactsToUpload.remove(currNewArtifact);
824                                                         } else {
825                                                                 log.debug("Can't upload two artifact with the same name {}.", currNewArtifact.getArtifactName());
826                                                                 ResponseFormat responseFormat = ResponseFormatManager.getInstance().getResponseFormat(ActionStatus.ARTIFACT_ALRADY_EXIST_IN_DIFFERENT_TYPE_IN_CSAR, currNewArtifact.getArtifactName(), currNewArtifact.getArtifactType(),
827                                                                                 foundArtifact.getArtifactType());
828                                                                 responseWrapper.setInnerElement(responseFormat);
829                                                                 break;
830                                                         }
831                                                 }
832                                         }
833                                 }
834                                 if (responseWrapper.isEmpty()) {
835                                         artifactsToDelete.addAll(existingArtifacts.values());
836                                 }
837                         }
838                         if (responseWrapper.isEmpty()) {
839                                 if (!artifactsToUpload.isEmpty() || !artifactsToUpdate.isEmpty() || !artifactsToDelete.isEmpty()) {
840                                         nodeTypeArtifactsToHandle = new EnumMap<>(ArtifactOperationEnum.class);
841                                         if (!artifactsToUpload.isEmpty())
842                                                 nodeTypeArtifactsToHandle.put(ArtifactOperationEnum.Create, artifactsToUpload);
843                                         if (!artifactsToUpdate.isEmpty())
844                                                 nodeTypeArtifactsToHandle.put(ArtifactOperationEnum.Update, artifactsToUpdate);
845                                         if (!artifactsToDelete.isEmpty())
846                                                 nodeTypeArtifactsToHandle.put(ArtifactOperationEnum.Delete, artifactsToDelete);
847                                 }
848                                 nodeTypeArtifactsToHandleRes = Either.left(nodeTypeArtifactsToHandle);
849                         }
850                         if (!responseWrapper.isEmpty()) {
851                                 nodeTypeArtifactsToHandleRes = Either.right(responseWrapper.getInnerElement());
852                         }
853                 } catch (Exception e) {
854                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR);
855                         responseWrapper.setInnerElement(responseFormat);
856                         log.debug("Exception occured when findNodeTypeArtifactsToHandle, error is:{}", e.getMessage(), e);
857                 }
858                 return nodeTypeArtifactsToHandleRes;
859         }
860
861         /**
862          * Changes resource life cycle state to checked out
863          *
864          * @param resource
865          * @param user
866          * @param inTransaction
867          * @return
868          */
869         private Either<Resource, ResponseFormat> checkoutResource(Resource resource, User user, boolean inTransaction) {
870                 Either<Resource, ResponseFormat> checkoutResourceRes;
871                 try {
872                         if (!resource.getComponentMetadataDefinition().getMetadataDataDefinition().getState().equals(LifecycleStateEnum.NOT_CERTIFIED_CHECKOUT.name())) {
873                                 log.debug("************* Going to change life cycle state of resource {} to not certified checked out. ", resource.getName());
874                                 Either<? extends Component, ResponseFormat> checkoutRes = lifecycleBusinessLogic.changeComponentState(resource.getComponentType(), resource.getUniqueId(), user, LifeCycleTransitionEnum.CHECKOUT,
875                                                 new LifecycleChangeInfoWithAction("certification on import", LifecycleChanceActionEnum.CREATE_FROM_CSAR), inTransaction, true);
876                                 if (checkoutRes.isRight()) {
877                                         log.debug("Could not change state of component {} with uid {} to checked out. Status is {}. ", resource.getComponentType().getNodeType(), resource.getUniqueId(), checkoutRes.right().value().getStatus());
878                                         checkoutResourceRes = Either.right(checkoutRes.right().value());
879                                 } else {
880                                         checkoutResourceRes = Either.left((Resource) checkoutRes.left().value());
881                                 }
882                         } else {
883                                 checkoutResourceRes = Either.left(resource);
884                         }
885                 } catch (Exception e) {
886                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR);
887                         checkoutResourceRes = Either.right(responseFormat);
888                         log.debug("Exception occured when checkoutResource {} , error is:{}", resource.getName(), e.getMessage(), e);
889                 }
890                 return checkoutResourceRes;
891         }
892
893         /**
894          * Handles Artifacts of NodeType
895          *
896          * @param nodeTypeResource
897          * @param nodeTypeArtifactsToHandle
898          * @param vfcsNewCreatedArtifacts
899          * @param user
900          * @param inTransaction
901          * @return
902          */
903         public Either<List<ArtifactDefinition>, ResponseFormat> handleNodeTypeArtifacts(Resource nodeTypeResource, Map<ArtifactOperationEnum, List<ArtifactDefinition>> nodeTypeArtifactsToHandle, List<ArtifactDefinition> createdArtifacts,
904                         User user, boolean inTransaction, boolean ignoreLifecycleState) {
905                 Either<List<ArtifactDefinition>, ResponseFormat> handleNodeTypeArtifactsRequestRes;
906                 Either<List<ArtifactDefinition>, ResponseFormat> handleNodeTypeArtifactsRes = null;
907                 Either<Resource, ResponseFormat> changeStateResponse;
908                 try {
909                         changeStateResponse = checkoutResource(nodeTypeResource, user, inTransaction);
910                         if (changeStateResponse.isRight()) {
911                                 return Either.right(changeStateResponse.right().value());
912                         }
913                         nodeTypeResource = changeStateResponse.left().value();
914
915                         List<ArtifactDefinition> handledNodeTypeArtifacts = new ArrayList<>();
916                         log.debug("************* Going to handle artifacts of node type resource {}. ", nodeTypeResource.getName());
917                         for (Entry<ArtifactOperationEnum, List<ArtifactDefinition>> curOperationEntry : nodeTypeArtifactsToHandle.entrySet()) {
918                                 ArtifactOperationEnum curOperation = curOperationEntry.getKey();
919                                 List<ArtifactDefinition> curArtifactsToHandle = curOperationEntry.getValue();
920                                 if (curArtifactsToHandle != null && !curArtifactsToHandle.isEmpty()) {
921                                         log.debug("************* Going to {} artifact to vfc {}", curOperation.name(), nodeTypeResource.getName());
922                                         handleNodeTypeArtifactsRequestRes = artifactsBusinessLogic.handleArtifactsRequestForInnerVfcComponent(curArtifactsToHandle, nodeTypeResource, user, createdArtifacts,
923                                                         artifactsBusinessLogic.new ArtifactOperationInfo(false, ignoreLifecycleState, curOperation), false, inTransaction);
924                                         if (handleNodeTypeArtifactsRequestRes.isRight()) {
925                                                 handleNodeTypeArtifactsRes = Either.right(handleNodeTypeArtifactsRequestRes.right().value());
926                                                 break;
927                                         }
928                                         if (ArtifactOperationEnum.isCreateOrLink(curOperation)) {
929                                                 createdArtifacts.addAll(handleNodeTypeArtifactsRequestRes.left().value());
930                                         }
931                                         handledNodeTypeArtifacts.addAll(handleNodeTypeArtifactsRequestRes.left().value());
932                                 }
933                         }
934                         if (handleNodeTypeArtifactsRes == null) {
935                                 handleNodeTypeArtifactsRes = Either.left(handledNodeTypeArtifacts);
936                         }
937                 } catch (Exception e) {
938                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR);
939                         handleNodeTypeArtifactsRes = Either.right(responseFormat);
940                         log.debug("Exception occured when handleVfcArtifacts, error is:{}", e.getMessage(), e);
941                 }
942                 return handleNodeTypeArtifactsRes;
943         }
944
945         private Map<String, ImmutablePair<String,String>> extractVfcToscaNames(Map<String, NodeTypeInfo> nodeTypesInfo, String vfResourceName, CsarInfo csarInfo) {
946                 Map<String, ImmutablePair<String,String>> vfcToscaNames = new HashMap<>();
947                         
948                 Map<String, Object> nodes = extractAllNodes(nodeTypesInfo, csarInfo);
949                 if (!nodes.isEmpty()) {
950                         Iterator<Entry<String, Object>> nodesNameEntry = nodes.entrySet().iterator();
951                         while (nodesNameEntry.hasNext()) {
952                                 Entry<String, Object> nodeType = nodesNameEntry.next();
953                                 ImmutablePair<String,String> toscaResourceName = buildNestedToscaResourceName(ResourceTypeEnum.VFC.name(), vfResourceName, nodeType.getKey());
954                                 vfcToscaNames.put(nodeType.getKey(), toscaResourceName);
955                         }
956                 }
957                 for(NodeTypeInfo cvfc : nodeTypesInfo.values()){
958                         vfcToscaNames.put(cvfc.getType(), buildNestedToscaResourceName(ResourceTypeEnum.CVFC.name(), vfResourceName, cvfc.getType()));
959                 }
960                 return vfcToscaNames;
961         }
962
963         private Map<String, Object> extractAllNodes(Map<String, NodeTypeInfo> nodeTypesInfo, CsarInfo csarInfo) {
964                 Map<String, Object> nodes = new HashMap<>();
965                 for(NodeTypeInfo nodeTypeInfo: nodeTypesInfo.values()){
966                         extractNodeTypes(nodes, nodeTypeInfo.getMappedToscaTemplate());
967                 }
968                 extractNodeTypes(nodes, csarInfo.getMappedToscaMainTemplate());
969                 return nodes;
970         }
971
972         private void extractNodeTypes(Map<String, Object> nodes, Map<String, Object> mappedToscaTemplate) {
973                 Either<Map<String, Object>, ResultStatusEnum> eitherNodeTypes = ImportUtils.findFirstToscaMapElement(mappedToscaTemplate, ToscaTagNamesEnum.NODE_TYPES);
974                 if (eitherNodeTypes.isLeft()) {
975                         nodes.putAll(eitherNodeTypes.left().value());
976                 }
977         }
978
979         public Either<Resource, ResponseFormat> createResourceFromCsar(Resource resource, User user, Either<Map<String, byte[]>, StorageOperationStatus> csarUIPayload, String csarUUID) {
980                 log.trace("************* created successfully from YAML, resource TOSCA ");
981
982                 Either<Map<String, byte[]>, StorageOperationStatus> csar = null;
983                 if (csarUIPayload != null && csarUIPayload.left() != null && csarUIPayload.left().value() != null) {
984                         csar = csarUIPayload;
985                 } else {
986                         csar = csarOperation.getCsar(csarUUID, user);
987                 }
988
989                 Either<ImmutablePair<String, String>, ResponseFormat> toscaYamlCsarStatus = validateAndParseCsar(resource, user, csarUUID, csar);
990                 if (toscaYamlCsarStatus.isRight()) {
991                         return Either.right(toscaYamlCsarStatus.right().value());
992                 }
993                 Either<String, ResponseFormat> toscaYamlChecksum = CsarValidationUtils.getToscaYamlChecksum(csar.left().value(), csarUUID, componentsUtils);
994                 if (toscaYamlChecksum.isRight()) {
995                         log.debug("Failed to calculate checksum for CSAR {}, error  {}", csarUUID, toscaYamlChecksum.right().value());
996                         return Either.right(toscaYamlChecksum.right().value());
997                 }
998                 resource.getComponentMetadataDefinition().getMetadataDataDefinition().setImportedToscaChecksum(toscaYamlChecksum.left().value());
999
1000                 String yamlFileName = toscaYamlCsarStatus.left().value().getKey();
1001                 String yamlFileContents = toscaYamlCsarStatus.left().value().getValue();
1002                 log.trace("YAML topology file found in CSAR, file name: {}, contents: {}", yamlFileName, yamlFileContents);
1003
1004                 CsarInfo csarInfo = new CsarInfo(resource.getName(), user, csarUUID, csar.left().value(), yamlFileContents, false);
1005                 Map<String, NodeTypeInfo> nodeTypesInfo = extractNodeTypesInfo(csarInfo);
1006                 Either<Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>>, ResponseFormat> findNodeTypesArtifactsToHandleRes = findNodeTypesArtifactsToHandle(nodeTypesInfo, csarInfo, resource);
1007                 if (findNodeTypesArtifactsToHandleRes.isRight()) {
1008                         log.debug("failed to find node types for update with artifacts during import csar {}. ", csarInfo.getCsarUUID());
1009                         return Either.right(findNodeTypesArtifactsToHandleRes.right().value());
1010                 }
1011                 Either<Resource, ResponseFormat> createResourceFromYaml = createResourceFromYaml(resource, yamlFileContents, yamlFileName, nodeTypesInfo, csarInfo, findNodeTypesArtifactsToHandleRes.left().value(), true, false, null);
1012                 if (createResourceFromYaml.isRight()) {
1013                         log.debug("Couldn't create resource from YAML");
1014                         return Either.right(createResourceFromYaml.right().value());
1015                 }
1016
1017                 Resource vfResource = createResourceFromYaml.left().value();
1018                 log.trace("*************VF Resource created successfully from YAML, resource TOSCA name: {}", vfResource.getToscaResourceName());
1019                 return Either.left(vfResource);
1020         }
1021
1022         private Map<String, NodeTypeInfo> extractNodeTypesInfo(CsarInfo csarInfo) {
1023                 Map<String, NodeTypeInfo> nodeTypesInfo = new HashMap<>();
1024                 List<Entry<String, byte[]>> globalSubstitutes = new ArrayList<>();
1025                 for (Map.Entry<String, byte[]> entry : csarInfo.getCsar().entrySet()) {
1026                         extractNodeTypeInfo(nodeTypesInfo, globalSubstitutes, entry);
1027                 }
1028                 if (CollectionUtils.isNotEmpty(globalSubstitutes)) {
1029                         setDerivedFrom(nodeTypesInfo, globalSubstitutes);
1030                 }
1031                 markNestedVfc(csarInfo.getMappedToscaMainTemplate(), nodeTypesInfo);
1032                 return nodeTypesInfo;
1033         }
1034
1035         @SuppressWarnings("unchecked")
1036         private void setDerivedFrom(Map<String, NodeTypeInfo> nodeTypesInfo, List<Entry<String, byte[]>> globalSubstitutes) {
1037                 for (Map.Entry<String, byte[]> entry : globalSubstitutes) {
1038                         String yamlFileContents = new String(entry.getValue());
1039                         Map<String, Object> mappedToscaTemplate = (Map<String, Object>) new Yaml().load(yamlFileContents);
1040                         Either<Object, ResultStatusEnum> nodeTypesEither = ImportUtils.findToscaElement(mappedToscaTemplate, ToscaTagNamesEnum.NODE_TYPES, ToscaElementTypeEnum.MAP);
1041                         if (nodeTypesEither.isLeft()) {
1042                                 Map<String, Object> nodeTypes = (Map<String, Object>) nodeTypesEither.left().value();
1043                                 for (Entry<String, Object> nodeType : nodeTypes.entrySet()) {
1044                                         Map<String, Object> nodeTypeMap = (Map<String, Object>) nodeType.getValue();
1045                                         if (nodeTypeMap.containsKey(ToscaTagNamesEnum.DERIVED_FROM.getElementName())) {
1046                                                 if (nodeTypesInfo.containsKey(nodeType.getKey())) {
1047                                                         NodeTypeInfo nodeTypeInfo = nodeTypesInfo.get(nodeType.getKey());
1048                                                         List<String> derivedFrom = new ArrayList<>();
1049                                                         derivedFrom.add((String) nodeTypeMap.get(ToscaTagNamesEnum.DERIVED_FROM.getElementName()));
1050                                                         nodeTypeInfo.setDerivedFrom(derivedFrom);
1051                                                 }
1052                                         }
1053                                 }
1054                         }
1055                 }
1056         }
1057
1058         @SuppressWarnings("unchecked")
1059         private void extractNodeTypeInfo(Map<String, NodeTypeInfo> nodeTypesInfo,
1060                         List<Entry<String, byte[]>> globalSubstitutes, Map.Entry<String, byte[]> entry) {
1061                 if (Pattern.compile(CsarUtils.SERVICE_TEMPLATE_PATH_PATTERN).matcher(entry.getKey()).matches()) {
1062                         if (!isGlobalSubstitute(entry.getKey())) {
1063                                 String yamlFileContents = new String(entry.getValue());
1064                                 Map<String, Object> mappedToscaTemplate = (Map<String, Object>) new Yaml().load(yamlFileContents);
1065                                 Either<Object, ResultStatusEnum> substitutionMappingsEither = ImportUtils.findToscaElement(mappedToscaTemplate, ToscaTagNamesEnum.SUBSTITUTION_MAPPINGS, ToscaElementTypeEnum.MAP);
1066                                 if (substitutionMappingsEither.isLeft()) {
1067                                         Map<String, Object> substitutionMappings = (Map<String, Object>) substitutionMappingsEither.left().value();
1068                                         if (substitutionMappings.containsKey(ToscaTagNamesEnum.NODE_TYPE.getElementName())) {
1069                                                 NodeTypeInfo nodeTypeInfo = new NodeTypeInfo();
1070                                                 nodeTypeInfo.setType((String) substitutionMappings.get(ToscaTagNamesEnum.NODE_TYPE.getElementName()));
1071                                                 nodeTypeInfo.setTemplateFileName(entry.getKey());
1072                                                 nodeTypeInfo.setMappedToscaTemplate(mappedToscaTemplate);
1073                                                 nodeTypesInfo.put(nodeTypeInfo.getType(), nodeTypeInfo);
1074                                         }
1075                                 }
1076                         } else {
1077                                 globalSubstitutes.add(entry);
1078                         }
1079                 }
1080         }
1081
1082
1083         @SuppressWarnings("unchecked")
1084         private void markNestedVfc(Map<String, Object> mappedToscaTemplate, Map<String, NodeTypeInfo> nodeTypesInfo) {
1085                 Either<Object, ResultStatusEnum> nodeTemplatesEither = ImportUtils.findToscaElement(mappedToscaTemplate, ToscaTagNamesEnum.NODE_TEMPLATES, ToscaElementTypeEnum.MAP);
1086                 if (nodeTemplatesEither.isLeft()) {
1087                         Map<String, Object> nodeTemplates = (Map<String, Object>) nodeTemplatesEither.left().value();
1088                         for (Entry<String, Object> nodeTemplateEntry : nodeTemplates.entrySet()) {
1089                                 Map<String, Object> nodeTemplate = (Map<String, Object>) nodeTemplateEntry.getValue();
1090                                 if (nodeTemplate.containsKey(ToscaTagNamesEnum.TYPE.getElementName())) {
1091                                         String type = (String) nodeTemplate.get(ToscaTagNamesEnum.TYPE.getElementName());
1092                                         if (nodeTypesInfo.containsKey(type)) {
1093                                                 NodeTypeInfo nodeTypeInfo = nodeTypesInfo.get(type);
1094                                                 nodeTypeInfo.setNested(true);
1095                                         }
1096                                 }
1097                         }
1098                 }
1099         }
1100
1101         private boolean isGlobalSubstitute(String fileName) {
1102                 return fileName.equalsIgnoreCase(Constants.GLOBAL_SUBSTITUTION_TYPES_SERVICE_TEMPLATE) || fileName.equalsIgnoreCase(Constants.ABSTRACT_SUBSTITUTE_GLOBAL_TYPES_SERVICE_TEMPLATE);
1103         }
1104
1105         private Either<ImmutablePair<String, String>, ResponseFormat> validateAndParseCsar(Resource resource, User user, String csarUUID, Either<Map<String, byte[]>, StorageOperationStatus> csar) {
1106                 if (csar.isRight()) {
1107                         StorageOperationStatus value = csar.right().value();
1108                         log.debug("Error when fetching csar with ID {}, error: {}", csarUUID, value);
1109                         BeEcompErrorManager.getInstance().logBeDaoSystemError("Creating resource from CSAR: fetching CSAR with id " + csarUUID + " failed");
1110                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(value), csarUUID);
1111                         componentsUtils.auditResource(responseFormat, user, resource, "", "", AuditingActionEnum.CREATE_RESOURCE, null);
1112                         return Either.right(responseFormat);
1113                 }
1114
1115                 Either<Boolean, ResponseFormat> validateCsarStatus = CsarValidationUtils.validateCsar(csar.left().value(), csarUUID, componentsUtils);
1116                 if (validateCsarStatus.isRight()) {
1117                         ResponseFormat responseFormat = validateCsarStatus.right().value();
1118                         log.debug("Error when validate csar with ID {}, error: {}", csarUUID, responseFormat);
1119                         BeEcompErrorManager.getInstance().logBeDaoSystemError("Creating resource from CSAR: fetching CSAR with id " + csarUUID + " failed");
1120                         componentsUtils.auditResource(responseFormat, user, resource, "", "", AuditingActionEnum.CREATE_RESOURCE, null);
1121                         return Either.right(responseFormat);
1122                 }
1123
1124                 Either<ImmutablePair<String, String>, ResponseFormat> toscaYamlCsarStatus = CsarValidationUtils.getToscaYaml(csar.left().value(), csarUUID, componentsUtils);
1125
1126                 if (toscaYamlCsarStatus.isRight()) {
1127                         ResponseFormat responseFormat = toscaYamlCsarStatus.right().value();
1128                         log.debug("Error when try to get csar toscayamlFile with csar ID {}, error: {}", csarUUID, responseFormat);
1129                         BeEcompErrorManager.getInstance().logBeDaoSystemError("Creating resource from CSAR: fetching CSAR with id " + csarUUID + " failed");
1130                         componentsUtils.auditResource(responseFormat, user, resource, "", "", AuditingActionEnum.CREATE_RESOURCE, null);
1131                         return Either.right(responseFormat);
1132                 }
1133                 return toscaYamlCsarStatus;
1134         }
1135
1136         private Either<Resource, ResponseFormat> validateResourceBeforeCreate(Resource resource, User user, boolean inTransaction) {
1137                 log.trace("validating resource before create");
1138                 Either<User, ResponseFormat> eitherCreator = validateUser(user, "Create Resource", resource, AuditingActionEnum.CREATE_RESOURCE, false);
1139                 if (eitherCreator.isRight()) {
1140                         return Either.right(eitherCreator.right().value());
1141                 }
1142                 user.copyData(eitherCreator.left().value());
1143
1144                 // validate user role
1145                 Either<Boolean, ResponseFormat> validateRes = validateUserRole(user, resource, new ArrayList<Role>(), AuditingActionEnum.CREATE_RESOURCE, null);
1146                 if (validateRes.isRight()) {
1147                         return Either.right(validateRes.right().value());
1148                 }
1149                 // VF / PNF "derivedFrom" should be null (or ignored)
1150                 if (ModelConverter.isAtomicComponent(resource)) {
1151                         Either<Boolean, ResponseFormat> validateDerivedFromNotEmpty = validateDerivedFromNotEmpty(user, resource, AuditingActionEnum.CREATE_RESOURCE);
1152                         if (validateDerivedFromNotEmpty.isRight()) {
1153                                 return Either.right(validateDerivedFromNotEmpty.right().value());
1154                         }
1155                 }
1156                 return validateResourceBeforeCreate(resource, user, AuditingActionEnum.CREATE_RESOURCE, inTransaction, null);
1157
1158         }
1159 //resource, yamlFileContents, yamlFileName, nodeTypesInfo,csarInfo, nodeTypesArtifactsToCreate, true, false, null
1160         private Either<Resource, ResponseFormat> createResourceFromYaml(Resource resource, String topologyTemplateYaml, String yamlName,
1161                         Map<String, NodeTypeInfo> nodeTypesInfo, CsarInfo csarInfo,
1162                         Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>> nodeTypesArtifactsToCreate,
1163                         boolean shouldLock, boolean inTransaction, String nodeName) {
1164
1165                 List<ArtifactDefinition> createdArtifacts = new ArrayList<ArtifactDefinition>();
1166                 log.trace("************* createResourceFromYaml before parse yaml ");
1167                 Either<ParsedToscaYamlInfo, ResponseFormat> parseResourceInfoFromYamlEither = parseResourceInfoFromYaml(yamlName, resource, topologyTemplateYaml, csarInfo.getCreatedNodesToscaResourceNames(), nodeTypesInfo, nodeName);
1168                 if (parseResourceInfoFromYamlEither.isRight()) {
1169                         ResponseFormat responseFormat = parseResourceInfoFromYamlEither.right().value();
1170                         componentsUtils.auditResource(responseFormat, csarInfo.getModifier(), resource, "", "", AuditingActionEnum.IMPORT_RESOURCE, null);
1171                         return Either.right(responseFormat);
1172                 }
1173                 log.trace("************* createResourceFromYaml after parse yaml ");
1174                 ParsedToscaYamlInfo parsedToscaYamlInfo = parseResourceInfoFromYamlEither.left().value();
1175                 log.debug("The parsed tosca yaml info is {}", parsedToscaYamlInfo);
1176                 log.trace("************* createResourceFromYaml before create ");
1177                 Either<Resource, ResponseFormat> createdResourceResponse = createResourceAndRIsFromYaml(yamlName, resource, parsedToscaYamlInfo, 
1178                                 AuditingActionEnum.IMPORT_RESOURCE, false, createdArtifacts, topologyTemplateYaml,
1179                                 nodeTypesInfo, csarInfo, nodeTypesArtifactsToCreate, shouldLock, inTransaction, nodeName);
1180                 log.trace("************* createResourceFromYaml after create ");
1181                 if (createdResourceResponse.isRight()) {
1182                         ResponseFormat responseFormat = createdResourceResponse.right().value();
1183                         componentsUtils.auditResource(responseFormat, csarInfo.getModifier(), resource, "", "", AuditingActionEnum.IMPORT_RESOURCE, null);
1184                         return Either.right(responseFormat);
1185                 }
1186
1187                 return createdResourceResponse;
1188
1189         }
1190
1191         public Either<Map<String, Resource>, ResponseFormat> createResourcesFromYamlNodeTypesList(String yamlName, Resource resource, Map<String, Object> mappedToscaTemplate, boolean needLock,
1192                                                                                                                                                                                           Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>> nodeTypesArtifactsToHandle, List<ArtifactDefinition> nodeTypesNewCreatedArtifacts,
1193                                                                                                                                                                                           Map<String, NodeTypeInfo> nodeTypesInfo, CsarInfo csarInfo) {
1194
1195                 Either<String, ResultStatusEnum> tosca_version = ImportUtils.findFirstToscaStringElement(mappedToscaTemplate, ToscaTagNamesEnum.TOSCA_VERSION);
1196                 if (tosca_version.isRight()) {
1197                         ResponseFormat responseFormat = getComponentsUtils().getResponseFormat(ActionStatus.INVALID_TOSCA_TEMPLATE);
1198                         return Either.right(responseFormat);
1199                 }
1200                 Either<Map<String, Object>, ResultStatusEnum> eitherNodeTypes = ImportUtils.findFirstToscaMapElement(mappedToscaTemplate, ToscaTagNamesEnum.NODE_TYPES);
1201                 Either<Map<String, Resource>, ResponseFormat> result = Either.left(csarInfo.getCreatedNodes());
1202                 Map<String, Object> mapToConvert = new HashMap<String, Object>();
1203                 mapToConvert.put(ToscaTagNamesEnum.TOSCA_VERSION.getElementName(), tosca_version.left().value());
1204                 Resource vfcCreated = null;
1205                 if (eitherNodeTypes.isLeft()) {
1206                         Iterator<Entry<String, Object>> nodesNameValue = eitherNodeTypes.left().value().entrySet().iterator();
1207                         while (nodesNameValue.hasNext()) {
1208                                 Entry<String, Object> nodeType = nodesNameValue.next();
1209                                 Map<ArtifactOperationEnum, List<ArtifactDefinition>> nodeTypeArtifactsToHandle = nodeTypesArtifactsToHandle == null || nodeTypesArtifactsToHandle.isEmpty() ? null : nodeTypesArtifactsToHandle.get(nodeType.getKey());
1210
1211                                 if (nodeTypesInfo.containsKey(nodeType.getKey())) {
1212                                         log.trace("************* Going to handle nested vfc {}", nodeType.getKey());
1213                                         Either<Resource, ResponseFormat> handleNeatedVfcYaml = handleNestedVfc(resource, nodeTypesArtifactsToHandle, nodeTypesNewCreatedArtifacts, nodeTypesInfo, csarInfo, nodeType.getKey());
1214                                         log.trace("************* Finished to handle nested vfc {}", nodeType.getKey());
1215                                         if (handleNeatedVfcYaml.isRight()) {
1216                                                 return Either.right(handleNeatedVfcYaml.right().value());
1217                                         }
1218                                         vfcCreated = handleNeatedVfcYaml.left().value();
1219                                 } else if(csarInfo.getCreatedNodesToscaResourceNames()!= null && !csarInfo.getCreatedNodesToscaResourceNames().containsKey(nodeType.getKey())){
1220                                         log.trace("************* Going to create node {}", nodeType.getKey());
1221                                         Either<ImmutablePair<Resource, ActionStatus>, ResponseFormat> resourceCreated = this.createNodeTypeResourceFromYaml(yamlName, nodeType, csarInfo.getModifier(), mapToConvert, resource, needLock, nodeTypeArtifactsToHandle, nodeTypesNewCreatedArtifacts, true, csarInfo, true);
1222                                         log.debug("************* Finished to create node {}", nodeType.getKey());
1223
1224                                         if (resourceCreated.isRight()) {
1225                                                 return Either.right(resourceCreated.right().value());
1226                                         }
1227                                         vfcCreated = resourceCreated.left().value().getLeft();
1228                                         csarInfo.getCreatedNodesToscaResourceNames().put(nodeType.getKey(),vfcCreated.getToscaResourceName());
1229                                 }
1230                                 if (vfcCreated != null) {
1231                                         csarInfo.getCreatedNodes().put(nodeType.getKey(), vfcCreated);
1232                                 }
1233                                 mapToConvert.remove(ToscaTagNamesEnum.NODE_TYPES.getElementName());
1234                         }
1235                 }
1236                 return result;
1237         }
1238
1239         private Either<Resource, ResponseFormat> handleNestedVfc(Resource resource, Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>> nodesArtifactsToHandle,
1240                         List<ArtifactDefinition> createdArtifacts, Map<String, NodeTypeInfo> nodesInfo, CsarInfo csarInfo, String nodeName) {
1241
1242                 Either<Resource, ResponseFormat> handleNestedVfcRes = Either.left(resource);
1243                 String yamlName = nodesInfo.get(nodeName).getTemplateFileName();
1244                 Map<String, Object> nestedVfcJsonMap = nodesInfo.get(nodeName).getMappedToscaTemplate();
1245
1246                 log.debug("************* Going to create node types from yaml {}", yamlName);
1247                 Either<Map<String, Resource>, ResponseFormat> createNodeTypesRes =      createResourcesFromYamlNodeTypesList(yamlName, resource,
1248                                                 nestedVfcJsonMap, false, nodesArtifactsToHandle, createdArtifacts, nodesInfo, csarInfo);
1249                 if (createNodeTypesRes.isRight()) {
1250                         log.debug("Failed to create node types from yaml {}. Status is {}", yamlName, createNodeTypesRes.right().value());
1251                         return Either.right(createNodeTypesRes.right().value());
1252                 }
1253                 log.debug("************* Finished to create node types from yaml {}", yamlName);
1254                 
1255                 if (nestedVfcJsonMap.containsKey(ToscaTagNamesEnum.TOPOLOGY_TEMPLATE.getElementName())) {
1256                         log.debug("************* Going to handle complex VFC from yaml {}", yamlName);
1257                         handleNestedVfcRes = handleComplexVfc(resource, nodesArtifactsToHandle, createdArtifacts, nodesInfo, csarInfo, nodeName, yamlName);
1258                 }
1259                 return handleNestedVfcRes;
1260         }
1261
1262         private Either<Resource, ResponseFormat> handleComplexVfc(Resource resource, Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>> nodesArtifactsToHandle, List<ArtifactDefinition> createdArtifacts,
1263                         Map<String, NodeTypeInfo> nodesInfo, CsarInfo csarInfo, String nodeName, String yamlName) {
1264                 
1265                 Either<Resource, ResponseFormat> result = null;
1266                 Resource  oldComplexVfc = null;
1267                 Resource  newComplexVfc = null;
1268                 
1269                 Either<Resource, ResponseFormat> buildCvfcRes = buildValidComplexVfc(resource, csarInfo, nodeName, nodesInfo);
1270                 if(buildCvfcRes.isRight()){
1271                         log.debug("Failed to validate complex VFC for node {}. ", nodeName);
1272                         result = buildCvfcRes;
1273                 }
1274                 if(result == null){
1275                         newComplexVfc = buildCvfcRes.left().value();
1276                         Either<Resource, StorageOperationStatus> oldComplexVfcRes = toscaOperationFacade.getFullLatestComponentByToscaResourceName(newComplexVfc.getToscaResourceName());
1277                         if(oldComplexVfcRes.isRight() && oldComplexVfcRes.right().value() == StorageOperationStatus.NOT_FOUND){
1278                                 oldComplexVfcRes = toscaOperationFacade.getFullLatestComponentByToscaResourceName(buildNestedToscaResourceName(ResourceTypeEnum.CVFC.name(), csarInfo.getVfResourceName(), nodeName).getRight());
1279                         }
1280                         if(oldComplexVfcRes.isRight() && oldComplexVfcRes.right().value() != StorageOperationStatus.NOT_FOUND){
1281                                 log.debug("Failed to fetch previous complex VFC by tosca resource name {}. Status is {}. ", newComplexVfc.getToscaResourceName(), oldComplexVfcRes.right().value());
1282                                 result = Either.right(componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR));
1283                         } else if(oldComplexVfcRes.isLeft()){
1284                                 log.debug("validate derived before update");
1285                                 Either<Boolean, ResponseFormat> eitherValidation = validateNestedDerivedFromDuringUpdate(oldComplexVfcRes.left().value(), newComplexVfc, ValidationUtils.hasBeenCertified(oldComplexVfcRes.left().value().getVersion()));
1286                                 if (eitherValidation.isLeft()) {
1287                                         oldComplexVfc = oldComplexVfcRes.left().value();
1288                                 }
1289                         }
1290                 }
1291                 if(result == null){
1292                         result = handleComplexVfc(nodesArtifactsToHandle, createdArtifacts, nodesInfo, csarInfo, nodeName, yamlName, oldComplexVfc, newComplexVfc);
1293                 }
1294                 if(result.isLeft()){
1295                         newComplexVfc = result.left().value();
1296                         csarInfo.getCreatedNodesToscaResourceNames().put(nodeName, newComplexVfc.getToscaResourceName());
1297                         LifecycleChangeInfoWithAction lifecycleChangeInfo = new LifecycleChangeInfoWithAction("certification on import", LifecycleChanceActionEnum.CREATE_FROM_CSAR);
1298                         log.debug("Going to certify cvfc {}. ", newComplexVfc.getName());
1299                         result = propagateStateToCertified(csarInfo.getModifier(), newComplexVfc, lifecycleChangeInfo, true, false, true);
1300                         if (result.isRight()) {
1301                                 log.debug("Failed to certify complex VFC resource {}. ", newComplexVfc.getName());
1302                         }
1303                 }
1304                 if(result.isLeft()){
1305                         csarInfo.getCreatedNodes().put(nodeName, result.left().value());
1306                         csarInfo.getCvfcToCreateQueue().remove();
1307                 }
1308                 return result;
1309         }
1310
1311         private Either<Resource, ResponseFormat> handleComplexVfc(Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>> nodesArtifactsToHandle, List<ArtifactDefinition> createdArtifacts, Map<String, NodeTypeInfo> nodesInfo,
1312                         CsarInfo csarInfo, String nodeName, String yamlName, Resource oldComplexVfc, Resource newComplexVfc) {
1313                 
1314                 Either<Resource, ResponseFormat> handleComplexVfcRes;
1315                 Map<String, Object> mappedToscaTemplate = nodesInfo.get(nodeName).getMappedToscaTemplate();
1316                 String yamlContent =  new String(csarInfo.getCsar().get(yamlName));
1317                 Map<String, NodeTypeInfo> newNodeTypesInfo = nodesInfo.entrySet().stream().collect(Collectors.toMap(e -> e.getKey(), e -> e.getValue().getUnmarkedCopy()));
1318                 markNestedVfc(mappedToscaTemplate, newNodeTypesInfo);
1319                 if(oldComplexVfc == null){
1320                         handleComplexVfcRes = createResourceFromYaml(newComplexVfc, yamlContent, yamlName, newNodeTypesInfo, csarInfo, nodesArtifactsToHandle, false, true, nodeName);
1321                         if (handleComplexVfcRes.isRight()) {
1322                                 log.debug("Failed to create resource {} from YAML {}. ", newComplexVfc.getName(), yamlName);
1323                         }
1324                 } else {
1325                         handleComplexVfcRes = updateResourceFromYaml(oldComplexVfc, newComplexVfc, AuditingActionEnum.UPDATE_RESOURCE_METADATA, createdArtifacts, true, yamlContent, yamlName, csarInfo, newNodeTypesInfo, nodesArtifactsToHandle, nodeName, true);
1326                         if (handleComplexVfcRes.isRight()) {
1327                                 log.debug("Failed to update resource {} from YAML {}. ", oldComplexVfc.getName(), yamlName);
1328                         }
1329                 }
1330                 return handleComplexVfcRes;
1331         }
1332
1333         private Either<Resource, ResponseFormat> buildValidComplexVfc(Resource resource, CsarInfo csarInfo, String nodeName, Map<String, NodeTypeInfo> nodesInfo) {
1334                 
1335                 Either<Resource, ResponseFormat> result = null;
1336                 Resource complexVfc = buildComplexVfcMetadata(resource, csarInfo, nodeName, nodesInfo);
1337                 log.debug("************* Going to validate complex VFC from yaml {}", complexVfc.getName());
1338                 
1339                 if(!csarInfo.getCvfcToCreateQueue().contains(nodeName)){
1340                         csarInfo.getCvfcToCreateQueue().add(nodeName);
1341                 } else {
1342                         log.debug("Failed to validate complex VFC {}. Loop detected, VSP {}. ",  complexVfc.getName(), csarInfo.getVfResourceName());
1343                         result = Either.right(componentsUtils.getResponseFormat(ActionStatus.CFVC_LOOP_DETECTED, csarInfo.getVfResourceName(), complexVfc.getName()));
1344                 }
1345                 if(result == null){
1346                         result = validateResourceBeforeCreate(complexVfc, csarInfo.getModifier(), AuditingActionEnum.IMPORT_RESOURCE, true, csarInfo);
1347                         if(result.isRight()){
1348                                 log.debug("Failed to validate complex VFC {}. ", complexVfc.getName());
1349                         }
1350                 }
1351                 return result;
1352         }
1353
1354         private String getNodeTypeActualName(String fullName) {
1355                 String nameWithouNamespacePrefix = fullName.substring(Constants.USER_DEFINED_RESOURCE_NAMESPACE_PREFIX.length());
1356                 String[] findTypes = nameWithouNamespacePrefix.split("\\.");
1357                 String resourceType = findTypes[0];
1358                 return nameWithouNamespacePrefix.substring(resourceType.length());
1359         }
1360
1361         private Either<ImmutablePair<Resource, ActionStatus>, ResponseFormat> createNodeTypeResourceFromYaml(String yamlName, Entry<String, Object> nodeNameValue, User user, Map<String, Object> mapToConvert, Resource resourceVf, boolean needLock,
1362                         Map<ArtifactOperationEnum, List<ArtifactDefinition>> nodeTypeArtifactsToHandle, List<ArtifactDefinition> nodeTypesNewCreatedArtifacts, boolean forceCertificationAllowed, CsarInfo csarInfo, boolean isNested) {
1363
1364                 Either<UploadResourceInfo, ResponseFormat> resourceMetaData = fillResourceMetadata(yamlName, resourceVf, nodeNameValue.getKey(), user);
1365                 if (resourceMetaData.isRight()) {
1366                         return Either.right(resourceMetaData.right().value());
1367                 }
1368                 String singleVfcYaml = buildNodeTypeYaml(nodeNameValue, mapToConvert, resourceMetaData.left().value().getResourceType(), csarInfo);
1369
1370                 Either<User, ResponseFormat> eitherCreator = validateUser(user, "CheckIn Resource", resourceVf, AuditingActionEnum.CHECKIN_RESOURCE, true);
1371                 if (eitherCreator.isRight()) {
1372                         return Either.right(eitherCreator.right().value());
1373                 }
1374                 user = eitherCreator.left().value();
1375
1376                 return this.createResourceFromNodeType(singleVfcYaml, resourceMetaData.left().value(), user, true, needLock, nodeTypeArtifactsToHandle, nodeTypesNewCreatedArtifacts, forceCertificationAllowed, csarInfo, nodeNameValue.getKey(), isNested);
1377         }
1378
1379         private String buildNodeTypeYaml(Entry<String, Object> nodeNameValue, Map<String, Object> mapToConvert, String nodeResourceType, CsarInfo csarInfo) {
1380                 // We need to create a Yaml from each node_types in order to create
1381                 // resource from each node type using import normative flow.
1382                 DumperOptions options = new DumperOptions();
1383                 options.setDefaultFlowStyle(DumperOptions.FlowStyle.BLOCK);
1384                 Yaml yaml = new Yaml(options);
1385
1386                 Map<String, Object> node = new HashMap<>();
1387                 node.put(buildNestedToscaResourceName(nodeResourceType, csarInfo.getVfResourceName(), nodeNameValue.getKey()).getLeft(), nodeNameValue.getValue());
1388                 mapToConvert.put(ToscaTagNamesEnum.NODE_TYPES.getElementName(), node);
1389
1390                 return yaml.dumpAsMap(mapToConvert);
1391         }
1392
1393         public Either<Boolean, ResponseFormat> validateResourceCreationFromNodeType(Resource resource, User creator) {
1394
1395                 Either<Boolean, ResponseFormat> validateDerivedFromNotEmpty = this.validateDerivedFromNotEmpty(creator, resource, AuditingActionEnum.CREATE_RESOURCE);
1396                 if (validateDerivedFromNotEmpty.isRight()) {
1397                         return Either.right(validateDerivedFromNotEmpty.right().value());
1398                 }
1399                 return Either.left(true);
1400         }
1401
1402         public Either<ImmutablePair<Resource, ActionStatus>, ResponseFormat> createResourceFromNodeType(String nodeTypeYaml, UploadResourceInfo resourceMetaData, User creator, boolean isInTransaction, boolean needLock,
1403                         Map<ArtifactOperationEnum, List<ArtifactDefinition>> nodeTypeArtifactsToHandle, List<ArtifactDefinition> nodeTypesNewCreatedArtifacts, boolean forceCertificationAllowed, CsarInfo csarInfo, String nodeName, boolean isNested) {
1404
1405                 LifecycleChangeInfoWithAction lifecycleChangeInfo = new LifecycleChangeInfoWithAction("certification on import", LifecycleChanceActionEnum.CREATE_FROM_CSAR);
1406                 Function<Resource, Either<Boolean, ResponseFormat>> validator = (resource) -> this.validateResourceCreationFromNodeType(resource, creator);
1407                 return this.resourceImportManager.importCertifiedResource(nodeTypeYaml, resourceMetaData, creator, validator, lifecycleChangeInfo, isInTransaction, true, needLock, nodeTypeArtifactsToHandle, nodeTypesNewCreatedArtifacts, forceCertificationAllowed, csarInfo, nodeName, isNested);
1408         }
1409
1410         private Either<UploadResourceInfo, ResponseFormat> fillResourceMetadata(String yamlName, Resource resourceVf, String nodeName, User user) {
1411                 UploadResourceInfo resourceMetaData = new UploadResourceInfo();
1412
1413                 // validate nodetype name prefix
1414                 if (!nodeName.startsWith(Constants.USER_DEFINED_RESOURCE_NAMESPACE_PREFIX)) {
1415                         log.debug("invalid nodeName:{} does not start with {}.", nodeName, Constants.USER_DEFINED_RESOURCE_NAMESPACE_PREFIX);
1416                         ResponseFormat responseFormat = getComponentsUtils().getResponseFormat(ActionStatus.INVALID_NODE_TEMPLATE, yamlName, resourceMetaData.getName(), nodeName);
1417                         return Either.right(responseFormat);
1418                 }
1419
1420                 String actualName = this.getNodeTypeActualName(nodeName);
1421                 String namePrefix = nodeName.replace(actualName, "");
1422                 String resourceType = namePrefix.substring(Constants.USER_DEFINED_RESOURCE_NAMESPACE_PREFIX.length());
1423
1424                 // if we import from csar, the node_type name can be
1425                 // org.openecomp.resource.abstract.node_name - in this case we always
1426                 // create a vfc
1427                 if (resourceType.equals(Constants.ABSTRACT)) {
1428                         resourceType = ResourceTypeEnum.VFC.name().toLowerCase();
1429                 }
1430                 // validating type
1431                 if (!ResourceTypeEnum.containsName(resourceType.toUpperCase())) {
1432                         log.debug("invalid resourceType:{} the type is not one of the valide types:{}.", resourceType.toUpperCase(), ResourceTypeEnum.values());
1433                         ResponseFormat responseFormat = getComponentsUtils().getResponseFormat(ActionStatus.INVALID_NODE_TEMPLATE, yamlName, resourceMetaData.getName(), nodeName);
1434                         return Either.right(responseFormat);
1435                 }
1436
1437                 // Setting name
1438                 resourceMetaData.setName(resourceVf.getSystemName() + actualName);
1439
1440                 // Setting type from name
1441                 String type = resourceType.toUpperCase();
1442                 resourceMetaData.setResourceType(type);
1443
1444                 resourceMetaData.setDescription(ImportUtils.Constants.INNER_VFC_DESCRIPTION);
1445                 resourceMetaData.setIcon(ImportUtils.Constants.DEFAULT_ICON);
1446                 resourceMetaData.setContactId(user.getUserId());
1447                 resourceMetaData.setVendorName(resourceVf.getVendorName());
1448                 resourceMetaData.setVendorRelease(resourceVf.getVendorRelease());
1449
1450                 // Setting tag
1451                 List<String> tags = new ArrayList<>();
1452                 tags.add(resourceMetaData.getName());
1453                 resourceMetaData.setTags(tags);
1454
1455                 // Setting category
1456                 CategoryDefinition category = new CategoryDefinition();
1457                 category.setName(ImportUtils.Constants.ABSTRACT_CATEGORY_NAME);
1458                 SubCategoryDefinition subCategory = new SubCategoryDefinition();
1459                 subCategory.setName(ImportUtils.Constants.ABSTRACT_SUBCATEGORY);
1460                 category.addSubCategory(subCategory);
1461                 List<CategoryDefinition> categories = new ArrayList<>();
1462                 categories.add(category);
1463                 resourceMetaData.setCategories(categories);
1464
1465                 return Either.left(resourceMetaData);
1466         }
1467
1468         private Resource buildComplexVfcMetadata(Resource resourceVf, CsarInfo csarInfo, String nodeName, Map<String, NodeTypeInfo> nodesInfo) {
1469                 Resource cvfc = new Resource();
1470                 NodeTypeInfo nodeTypeInfo = nodesInfo.get(nodeName);
1471                 cvfc.setName(buildCvfcName(csarInfo.getVfResourceName(), nodeName));
1472                 cvfc.setNormalizedName(ValidationUtils.normaliseComponentName(cvfc.getName()));
1473                 cvfc.setSystemName(ValidationUtils.convertToSystemName(cvfc.getName()));
1474                 cvfc.setResourceType(ResourceTypeEnum.CVFC);
1475                 cvfc.setAbstract(true);
1476                 cvfc.setDerivedFrom(nodeTypeInfo.getDerivedFrom());
1477                 cvfc.setDescription(ImportUtils.Constants.CVFC_DESCRIPTION);
1478                 cvfc.setIcon(ImportUtils.Constants.DEFAULT_ICON);
1479                 cvfc.setContactId(csarInfo.getModifier().getUserId());
1480                 cvfc.setCreatorUserId(csarInfo.getModifier().getUserId());
1481                 cvfc.setVendorName(resourceVf.getVendorName());
1482                 cvfc.setVendorRelease(resourceVf.getVendorRelease());
1483                 cvfc.setResourceVendorModelNumber(resourceVf.getResourceVendorModelNumber());
1484                 cvfc.setToscaResourceName(buildNestedToscaResourceName(ResourceTypeEnum.CVFC.name(), csarInfo.getVfResourceName(), nodeName).getLeft());
1485                 cvfc.setInvariantUUID(UniqueIdBuilder.buildInvariantUUID());
1486                 
1487                 List<String> tags = new ArrayList<>();
1488                 tags.add(cvfc.getName());
1489                 cvfc.setTags(tags);
1490
1491                 CategoryDefinition category = new CategoryDefinition();
1492                 category.setName(ImportUtils.Constants.ABSTRACT_CATEGORY_NAME);
1493                 SubCategoryDefinition subCategory = new SubCategoryDefinition();
1494                 subCategory.setName(ImportUtils.Constants.ABSTRACT_SUBCATEGORY);
1495                 category.addSubCategory(subCategory);
1496                 List<CategoryDefinition> categories = new ArrayList<>();
1497                 categories.add(category);
1498                 cvfc.setCategories(categories);
1499
1500                 cvfc.setVersion(ImportUtils.Constants.FIRST_NON_CERTIFIED_VERSION);
1501                 cvfc.setLifecycleState(ImportUtils.Constants.NORMATIVE_TYPE_LIFE_CYCLE_NOT_CERTIFIED_CHECKOUT);
1502                 cvfc.setHighestVersion(ImportUtils.Constants.NORMATIVE_TYPE_HIGHEST_VERSION);
1503                 
1504                 return cvfc;
1505         }
1506
1507         private String buildCvfcName(String resourceVfName, String nodeName) {
1508                 String nameWithouNamespacePrefix = nodeName.substring(Constants.USER_DEFINED_RESOURCE_NAMESPACE_PREFIX.length());
1509                 String[] findTypes = nameWithouNamespacePrefix.split("\\.");
1510                 String resourceType = findTypes[0];
1511                 String resourceName = resourceVfName + "-" + nameWithouNamespacePrefix.substring(resourceType.length() + 1);
1512                 return  addCvfcSuffixToResourceName(resourceName);
1513         }
1514
1515         private Either<Resource, ResponseFormat> createResourceAndRIsFromYaml(String yamlName, Resource resource, ParsedToscaYamlInfo parsedToscaYamlInfo, AuditingActionEnum actionEnum, boolean isNormative,
1516                                                                                                                                                   List<ArtifactDefinition> createdArtifacts, String topologyTemplateYaml, Map<String, NodeTypeInfo> nodeTypesInfo,
1517                                                                                                                                                   CsarInfo csarInfo, Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>> nodeTypesArtifactsToCreate,
1518                                                                                                                                                   boolean shouldLock, boolean inTransaction, String nodeName) {
1519
1520                 boolean result = true;
1521                 List<ArtifactDefinition> nodeTypesNewCreatedArtifacts = new ArrayList<>();
1522
1523                 if (shouldLock) {
1524                         Either<Boolean, ResponseFormat> lockResult = lockComponentByName(resource.getSystemName(), resource, "Create Resource");
1525                         if (lockResult.isRight()) {
1526                                 ResponseFormat responseFormat = lockResult.right().value();
1527                                 return Either.right(responseFormat);
1528                         }
1529                         log.debug("name is locked {} status = {}", resource.getSystemName(), lockResult);
1530                 }
1531                 try {
1532                         log.trace("************* createResourceFromYaml before full create resource {}", yamlName);
1533                         Either<Resource, ResponseFormat> genericResourceEither = fetchAndSetDerivedFromGenericType(resource);
1534                         if (genericResourceEither.isRight()) {
1535                                 result = false;
1536                                 return genericResourceEither;
1537                         }
1538                         Either<Resource, ResponseFormat> createResourcesEither = createResourceTransaction(resource, csarInfo.getModifier(), isNormative, inTransaction);
1539                         log.trace("************* createResourceFromYaml after full create resource {}", yamlName);
1540                         if (createResourcesEither.isRight()) {
1541                                 result = false;
1542                                 return createResourcesEither;
1543                         }
1544                         resource = createResourcesEither.left().value();
1545                         // add groups to resource
1546                         log.trace("************* Going to add inputs from yaml {}", yamlName);
1547                         if (resource.shouldGenerateInputs())
1548                                 generateAndAddInputsFromGenericTypeProperties(resource, genericResourceEither.left().value());
1549
1550                         Map<String, InputDefinition> inputs = parsedToscaYamlInfo.getInputs();
1551                         Either<Resource, ResponseFormat> createInputsOnResource = createInputsOnResource(resource, csarInfo.getModifier(), inputs, inTransaction);
1552                         if (createInputsOnResource.isRight()) {
1553                                 result = false;
1554                                 return createInputsOnResource;
1555                         }
1556                         resource = createInputsOnResource.left().value();
1557                         log.trace("************* Finish to add inputs from yaml {}", yamlName);
1558
1559                         Map<String, UploadComponentInstanceInfo> uploadComponentInstanceInfoMap = parsedToscaYamlInfo.getInstances();
1560                         log.trace("************* Going to create nodes, RI's and Relations  from yaml {}", yamlName);
1561
1562                         createResourcesEither = createRIAndRelationsFromYaml(yamlName, resource, uploadComponentInstanceInfoMap, actionEnum, topologyTemplateYaml,
1563                                         nodeTypesNewCreatedArtifacts, nodeTypesInfo, csarInfo, nodeTypesArtifactsToCreate, nodeName);
1564                         log.trace("************* Finished to create nodes, RI and Relation  from yaml {}", yamlName);
1565                         if (createResourcesEither.isRight()) {
1566                                 result = false;
1567                                 return createResourcesEither;
1568                         }
1569
1570                         resource = createResourcesEither.left().value();
1571                         // validate update vf module group names
1572                         Either<Map<String, GroupDefinition>, ResponseFormat> validateUpdateVfGroupNamesRes = groupBusinessLogic.validateUpdateVfGroupNames(parsedToscaYamlInfo.getGroups(), resource.getSystemName());
1573                         if (validateUpdateVfGroupNamesRes.isRight()) {
1574                                 result = false;
1575                                 return Either.right(validateUpdateVfGroupNamesRes.right().value());
1576                         }
1577                         // add groups to resource
1578                         Map<String, GroupDefinition> groups;
1579                         log.trace("************* Going to add groups from yaml {}", yamlName);
1580
1581                         if (!validateUpdateVfGroupNamesRes.left().value().isEmpty()) {
1582                                 groups = validateUpdateVfGroupNamesRes.left().value();
1583                         } else {
1584                                 groups = parsedToscaYamlInfo.getGroups();
1585                         }
1586                         Either<Resource, ResponseFormat> createGroupsOnResource = createGroupsOnResource(resource, csarInfo.getModifier(), groups);
1587                         if (createGroupsOnResource.isRight()) {
1588                                 result = false;
1589                                 return createGroupsOnResource;
1590                         }
1591                         resource = createGroupsOnResource.left().value();
1592                         log.trace("************* Finished to add groups from yaml {}", yamlName);
1593
1594                         log.trace("************* Going to add artifacts from yaml {}", yamlName);
1595
1596                         if(resource.getResourceType() == ResourceTypeEnum.CVFC){
1597                                 if(nodeTypesArtifactsToCreate.containsKey(nodeName) && nodeTypesArtifactsToCreate.get(nodeName) !=null && !nodeTypesArtifactsToCreate.get(nodeName).isEmpty()){
1598                                         Either<List<ArtifactDefinition>, ResponseFormat> handleNodeTypeArtifactsRes = 
1599                                                         handleNodeTypeArtifacts(resource, nodeTypesArtifactsToCreate.get(nodeName), nodeTypesNewCreatedArtifacts, csarInfo.getModifier(), true, false);
1600                                         if(handleNodeTypeArtifactsRes.isRight()){
1601                                                 return Either.right(handleNodeTypeArtifactsRes.right().value());
1602                                         }
1603                                 }
1604                         } else {
1605                                 Either<Resource, ResponseFormat> createdCsarArtifactsEither = this.handleVfCsarArtifacts(resource, csarInfo, createdArtifacts, artifactsBusinessLogic.new ArtifactOperationInfo(false, false, ArtifactOperationEnum.Create), false,
1606                                                 inTransaction);
1607                                 log.trace("************* Finished to add artifacts from yaml {}", yamlName);
1608                                 if (createdCsarArtifactsEither.isRight()) {
1609                                         result = false;
1610                                         return createdCsarArtifactsEither;
1611                                 }
1612                                 resource = createdCsarArtifactsEither.left().value();
1613                         }
1614                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.CREATED);
1615                         componentsUtils.auditResource(responseFormat, csarInfo.getModifier(), resource, "", "", actionEnum, null);
1616                         ASDCKpiApi.countCreatedResourcesKPI();
1617                         return Either.left(resource);
1618
1619                 } finally {
1620                         if (!inTransaction) {
1621                                 if (!result) {
1622                                         log.warn("operation failed. do rollback");
1623                                         titanDao.rollback();
1624                                         if (!createdArtifacts.isEmpty() || !nodeTypesNewCreatedArtifacts.isEmpty()) {
1625                                                 createdArtifacts.addAll(nodeTypesNewCreatedArtifacts);
1626                                                 log.debug("component and all its artifacts were deleted, id = {}", resource.getName());
1627                                         }
1628
1629                                 } else {
1630                                         log.debug("operation success. do commit");
1631                                         titanDao.commit();
1632                                 }
1633                         }
1634                         if (shouldLock) {
1635                                 graphLockOperation.unlockComponentByName(resource.getSystemName(), resource.getUniqueId(), NodeTypeEnum.Resource);
1636                         }
1637                 }
1638         }
1639
1640         private Either<Resource, ResponseFormat> createGroupsOnResource(Resource resource, User user, Map<String, GroupDefinition> groups) {
1641                 if (groups != null && !groups.isEmpty()) {
1642                         Either<List<GroupDefinition>, ResponseFormat> mergeGroupsUsingResource = updateGroupMembersUsingResource(groups, resource);
1643
1644                         if (mergeGroupsUsingResource.isRight()) {
1645                                 log.debug("Failed to prepare groups for creation");
1646                                 return Either.right(mergeGroupsUsingResource.right().value());
1647                         }
1648                         List<GroupDefinition> groupsAsList = mergeGroupsUsingResource.left().value();
1649                         Either<List<GroupDefinition>, ResponseFormat> createGroups = groupBusinessLogic.createGroups(resource, user, ComponentTypeEnum.RESOURCE, groupsAsList);
1650                         if (createGroups.isRight()) {
1651                                 return Either.right(createGroups.right().value());
1652                         }
1653                 } else {
1654                         return Either.left(resource);
1655                 }
1656                 Either<Resource, StorageOperationStatus> updatedResource = toscaOperationFacade.getToscaElement(resource.getUniqueId());
1657                 if (updatedResource.isRight()) {
1658                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(updatedResource.right().value()), resource);
1659                         return Either.right(responseFormat);
1660                 }
1661                 return Either.left(updatedResource.left().value());
1662         }
1663
1664         private Either<Resource, ResponseFormat> updateGroupsOnResource(Resource resource, User user, Map<String, GroupDefinition> groups) {
1665                 if (groups != null && false == groups.isEmpty()) {
1666                         List<GroupDefinition> groupsFromResource = resource.getGroups();
1667                         Either<List<GroupDefinition>, ResponseFormat> mergeGroupsUsingResource = updateGroupMembersUsingResource(groups, resource);
1668
1669                         if (mergeGroupsUsingResource.isRight()) {
1670                                 log.debug("Failed to prepare groups for creation");
1671                                 return Either.right(mergeGroupsUsingResource.right().value());
1672                         }
1673                         List<GroupDefinition> groupsAsList = mergeGroupsUsingResource.left().value();
1674                         List<GroupDefinition> groupsToUpdate = new ArrayList<GroupDefinition>();
1675                         List<GroupDefinition> groupsToDelete = new ArrayList<GroupDefinition>();
1676                         List<GroupDefinition> groupsToCreate = new ArrayList<GroupDefinition>();
1677                         if (groupsFromResource != null && !groupsFromResource.isEmpty()) {
1678                                 for (GroupDefinition group : groupsAsList) {
1679                                         Optional<GroupDefinition> op = groupsFromResource.stream().filter(p -> p.getName().equalsIgnoreCase(group.getName())).findAny();
1680                                         if (op.isPresent()) {
1681                                                 GroupDefinition groupToUpdate = op.get();
1682                                                 groupToUpdate.setMembers(group.getMembers());
1683                                                 groupsToUpdate.add(groupToUpdate);
1684                                         } else {
1685                                                 groupsToCreate.add(group);
1686                                         }
1687                                 }
1688                                 for (GroupDefinition group : groupsFromResource) {
1689                                         Optional<GroupDefinition> op = groupsAsList.stream().filter(p -> p.getName().equalsIgnoreCase(group.getName())).findAny();
1690                                         if (!op.isPresent() && (group.getArtifacts() == null || group.getArtifacts().isEmpty())) {
1691
1692                                                 groupsToDelete.add(group);
1693                                         }
1694
1695                                 }
1696                         } else
1697                         groupsToCreate.addAll(groupsAsList);
1698                         Either<List<GroupDefinition>, ResponseFormat> prepareGroups = null;
1699                         if (!groupsToCreate.isEmpty()) {
1700
1701                                 if (groupsFromResource != null && !groupsFromResource.isEmpty()) {
1702                                         prepareGroups = groupBusinessLogic.addGroups(resource, user, ComponentTypeEnum.RESOURCE, groupsToCreate);
1703                                 } else {
1704                                         prepareGroups = groupBusinessLogic.createGroups(resource, user, ComponentTypeEnum.RESOURCE, groupsToCreate);
1705                                 }
1706
1707                                 if (prepareGroups.isRight()) {
1708                                         return Either.right(prepareGroups.right().value());
1709                                 }
1710                         }
1711
1712                         if (!groupsToDelete.isEmpty()) {
1713                                 prepareGroups = groupBusinessLogic.deleteGroups(resource, user, ComponentTypeEnum.RESOURCE, groupsToDelete);
1714                                 if (prepareGroups.isRight()) {
1715                                         return Either.right(prepareGroups.right().value());
1716                                 }
1717                         }
1718
1719                         if (groupsToUpdate != null && !groupsToUpdate.isEmpty()) {
1720                                 prepareGroups = groupBusinessLogic.updateGroups(resource, ComponentTypeEnum.RESOURCE, groupsToUpdate);
1721                                 if (prepareGroups.isRight()) {
1722                                         return Either.right(prepareGroups.right().value());
1723                                 }
1724                         }
1725
1726                 } else {
1727                         return Either.left(resource);
1728                 }
1729
1730                 Either<Resource, StorageOperationStatus> updatedResource = toscaOperationFacade.getToscaElement(resource.getUniqueId());
1731                 if (updatedResource.isRight()) {
1732                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(updatedResource.right().value()), resource);
1733                         return Either.right(responseFormat);
1734                 }
1735                 return Either.left(updatedResource.left().value());
1736         }
1737
1738         private Either<Resource, ResponseFormat> createInputsOnResource(Resource resource, User user, Map<String, InputDefinition> inputs, boolean inTransaction) {
1739                 List<InputDefinition> resourceProperties = resource.getInputs();
1740                 if ( (inputs != null && false == inputs.isEmpty()) || (resourceProperties != null && false == resourceProperties.isEmpty()) ) {
1741
1742                         Either<List<InputDefinition>, ResponseFormat> createInputs = inputsBusinessLogic.createInputsInGraph(inputs, resource);
1743                         if (createInputs.isRight()) {
1744                                 return Either.right(createInputs.right().value());
1745                         }
1746                 } else {
1747                         return Either.left(resource);
1748                 }
1749
1750                 Either<Resource, StorageOperationStatus> updatedResource = toscaOperationFacade.getToscaElement(resource.getUniqueId());
1751                 if (updatedResource.isRight()) {
1752                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(updatedResource.right().value()), resource);
1753                         return Either.right(responseFormat);
1754                 }
1755                 return Either.left(updatedResource.left().value());
1756         }
1757
1758         private Either<List<GroupDefinition>, ResponseFormat> updateGroupMembersUsingResource(Map<String, GroupDefinition> groups, Resource component) {
1759
1760                 List<GroupDefinition> result = new ArrayList<>();
1761
1762                 List<ComponentInstance> componentInstances = component.getComponentInstances();
1763
1764                 if (groups != null) {
1765                         Either<Boolean, ResponseFormat> validateCyclicGroupsDependencies = validateCyclicGroupsDependencies(groups);
1766                         if (validateCyclicGroupsDependencies.isRight()) {
1767                                 return FunctionalInterfaces.convertEitherRight(validateCyclicGroupsDependencies);
1768                         }
1769                         for (Entry<String, GroupDefinition> entry : groups.entrySet()) {
1770                                 String groupName = entry.getKey();
1771
1772                                 GroupDefinition groupDefinition = entry.getValue();
1773
1774                                 GroupDefinition updatedGroupDefinition = new GroupDefinition(groupDefinition);
1775                                 updatedGroupDefinition.setMembers(null);
1776
1777                                 // get the members of the group
1778                                 Map<String, String> members = groupDefinition.getMembers();
1779                                 if (members != null) {
1780                                         Set<String> compInstancesNames = members.keySet();
1781
1782                                         if (componentInstances == null || true == componentInstances.isEmpty()) {
1783                                                 String membersAstString = compInstancesNames.stream().collect(Collectors.joining(","));
1784                                                 log.debug("The members: {}, in group: {}, cannot be found in component {}. There are no component instances.", membersAstString, groupName, component.getNormalizedName());
1785                                                 return Either.right(componentsUtils.getResponseFormat(ActionStatus.GROUP_INVALID_COMPONENT_INSTANCE, membersAstString, groupName, component.getNormalizedName(), getComponentTypeForResponse(component)));
1786                                         }
1787                                         // Find all component instances with the member names
1788                                         Map<String, String> memberNames = componentInstances.stream().collect(Collectors.toMap(ComponentInstance::getName, ComponentInstance::getUniqueId));
1789                                         memberNames.putAll(groups.keySet().stream().collect(Collectors.toMap(g -> g, g -> "")));
1790                                         Map<String, String> relevantInstances = memberNames.entrySet().stream().filter(n -> compInstancesNames.contains(n.getKey())).collect(Collectors.toMap(n -> n.getKey(), n -> n.getValue()));
1791
1792                                         if (relevantInstances == null || relevantInstances.size() != compInstancesNames.size()) {
1793
1794                                                 List<String> foundMembers = new ArrayList<>();
1795                                                 if (relevantInstances != null) {
1796                                                         foundMembers = relevantInstances.keySet().stream().collect(Collectors.toList());
1797                                                 }
1798                                                 compInstancesNames.removeAll(foundMembers);
1799                                                 String membersAstString = compInstancesNames.stream().collect(Collectors.joining(","));
1800                                                 log.debug("The members: {}, in group: {}, cannot be found in component: {}", membersAstString, groupName, component.getNormalizedName());
1801                                                 return Either.right(componentsUtils.getResponseFormat(ActionStatus.GROUP_INVALID_COMPONENT_INSTANCE, membersAstString, groupName, component.getNormalizedName(), getComponentTypeForResponse(component)));
1802                                         }
1803
1804                                         updatedGroupDefinition.setMembers(relevantInstances);
1805                                 }
1806
1807                                 result.add(updatedGroupDefinition);
1808                         }
1809                 }
1810                 return Either.left(result);
1811         }
1812
1813         /**
1814          * This Method validates that there is no cyclic group dependencies. meaning group A as member in group B which is member in group A
1815          *
1816          * @param allGroups
1817          * @return
1818          */
1819         private Either<Boolean, ResponseFormat> validateCyclicGroupsDependencies(Map<String, GroupDefinition> allGroups) {
1820
1821                 Either<Boolean, ResponseFormat> result = Either.left(true);
1822                 try {
1823                         Iterator<Entry<String, GroupDefinition>> allGroupsItr = allGroups.entrySet().iterator();
1824                         while (allGroupsItr.hasNext() && result.isLeft()) {
1825                                 Entry<String, GroupDefinition> groupAEntry = allGroupsItr.next();
1826                                 // Fetches a group member A
1827                                 String groupAName = groupAEntry.getKey();
1828                                 // Finds all group members in group A
1829                                 Set<String> allGroupAMembersNames = new HashSet<>();
1830                                 fillAllGroupMemebersRecursivly(groupAEntry.getKey(), allGroups, allGroupAMembersNames);
1831                                 // If A is a group member of itself found cyclic dependency
1832                                 if (allGroupAMembersNames.contains(groupAName)) {
1833                                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.GROUP_HAS_CYCLIC_DEPENDENCY, groupAName);
1834                                         result = Either.right(responseFormat);
1835                                 }
1836                         }
1837                 } catch (Exception e) {
1838                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR);
1839                         result = Either.right(responseFormat);
1840                         log.debug("Exception occured when validateCyclicGroupsDependencies, error is:{}", e.getMessage(), e);
1841                 }
1842                 return result;
1843         }
1844
1845         /**
1846          * This Method fills recursively the set groupMembers with all the members of the given group which are also of type group.
1847          *
1848          * @param groupName
1849          * @param allGroups
1850          * @param allGroupMembers
1851          * @return
1852          */
1853         private void fillAllGroupMemebersRecursivly(String groupName, Map<String, GroupDefinition> allGroups, Set<String> allGroupMembers) {
1854
1855                 // Found Cyclic dependency
1856                 if (isfillGroupMemebersRecursivlyStopCondition(groupName, allGroups, allGroupMembers)) {
1857                         return;
1858                 }
1859                 GroupDefinition groupDefinition = allGroups.get(groupName);
1860                 // All Members Of Current Group Resource Instances & Other Groups
1861                 Set<String> currGroupMembers = groupDefinition.getMembers().keySet();
1862                 // Filtered Members Of Current Group containing only members which
1863                 // are groups
1864                 List<String> currGroupFilteredMembers = currGroupMembers.stream().
1865                 // Keep Only Elements of type group and not Resource Instances
1866                                 filter(innerGroupName -> allGroups.containsKey(innerGroupName)).
1867                                 // Add Filtered Elements to main Set
1868                                 peek(innerGroupName -> allGroupMembers.add(innerGroupName)).
1869                                 // Collect results
1870                                 collect(Collectors.toList());
1871
1872                 // Recursively call the method for all the filtered group members
1873                 for (String innerGroupName : currGroupFilteredMembers) {
1874                         fillAllGroupMemebersRecursivly(innerGroupName, allGroups, allGroupMembers);
1875                 }
1876
1877         }
1878
1879         private boolean isfillGroupMemebersRecursivlyStopCondition(String groupName, Map<String, GroupDefinition> allGroups, Set<String> allGroupMembers) {
1880
1881                 boolean stop = false;
1882                 // In Case Not Group Stop
1883                 if (!allGroups.containsKey(groupName)) {
1884                         stop = true;
1885                 }
1886                 // In Case Group Has no members stop
1887                 if (!stop) {
1888                         GroupDefinition groupDefinition = allGroups.get(groupName);
1889                         stop = MapUtils.isEmpty(groupDefinition.getMembers());
1890
1891                 }
1892                 // In Case all group members already contained stop
1893                 if (!stop) {
1894                         final Set<String> allMembers = allGroups.get(groupName).getMembers().keySet();
1895                         Set<String> membersOfTypeGroup = allMembers.stream().
1896                         // Filter In Only Group members
1897                                         filter(innerGroupName -> allGroups.containsKey(innerGroupName)).
1898                                         // Collect
1899                                         collect(Collectors.toSet());
1900                         stop = allGroupMembers.containsAll(membersOfTypeGroup);
1901                 }
1902                 return stop;
1903         }
1904
1905         private Either<Resource, ResponseFormat> createRIAndRelationsFromYaml(String yamlName, Resource resource, Map<String, UploadComponentInstanceInfo> uploadComponentInstanceInfoMap, AuditingActionEnum actionEnum,
1906                                                                                                                                                   String topologyTemplateYaml, List<ArtifactDefinition> nodeTypesNewCreatedArtifacts,
1907                                                                                                                                                   Map<String, NodeTypeInfo> nodeTypesInfo, CsarInfo csarInfo, Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>> nodeTypesArtifactsToCreate,
1908                                                                                                                                                   String nodeName) {
1909
1910                 Either<Resource, ResponseFormat> result;
1911                 Either<Resource, ResponseFormat> createResourcesInstancesEither;
1912
1913                 log.debug("************* Going to create all nodes {}", yamlName);
1914                 Either<Map<String, Resource>, ResponseFormat> createdResourcesFromdNodeTypeMap = this.handleNodeTypes(yamlName, resource, topologyTemplateYaml, false, nodeTypesArtifactsToCreate, nodeTypesNewCreatedArtifacts, nodeTypesInfo, csarInfo, nodeName);
1915                 log.debug("************* Finished to create all nodes {}", yamlName);
1916                 if (createdResourcesFromdNodeTypeMap.isRight()) {
1917                         log.debug("failed to resources from node types status is {}", createdResourcesFromdNodeTypeMap.right().value());
1918                         return Either.right(createdResourcesFromdNodeTypeMap.right().value());
1919                 }
1920
1921                 log.debug("************* Going to create all resource instances {}", yamlName);
1922                 createResourcesInstancesEither = createResourceInstances(csarInfo.getModifier(), yamlName, resource, uploadComponentInstanceInfoMap, true, false, csarInfo.getCreatedNodes());
1923
1924                 log.debug("************* Finished to create all resource instances {}", yamlName);
1925                 if (createResourcesInstancesEither.isRight()) {
1926                         log.debug("failed to create resource instances status is {}", createResourcesInstancesEither.right().value());
1927                         result = createResourcesInstancesEither;
1928                         return createResourcesInstancesEither;
1929                 }
1930                 resource = createResourcesInstancesEither.left().value();
1931                 log.debug("************* Going to create all relations {}", yamlName);
1932                 createResourcesInstancesEither = createResourceInstancesRelations(csarInfo.getModifier(), yamlName, resource, uploadComponentInstanceInfoMap);
1933
1934                 log.debug("************* Finished to create all relations {}", yamlName);
1935
1936                 if (createResourcesInstancesEither.isRight()) {
1937                         log.debug("failed to create relation between resource instances status is {}", createResourcesInstancesEither.right().value());
1938                         result = createResourcesInstancesEither;
1939                         return result;
1940                 } else {
1941                         resource = createResourcesInstancesEither.left().value();
1942                 }
1943
1944                 log.debug("************* Going to create positions {}", yamlName);
1945                 Either<List<ComponentInstance>, ResponseFormat> eitherSetPosition = compositionBusinessLogic.setPositionsForComponentInstances(resource, csarInfo.getModifier().getUserId());
1946                 log.debug("************* Finished to set positions {}", yamlName);
1947                 result = eitherSetPosition.isRight() ? Either.right(eitherSetPosition.right().value()) : Either.left(resource);
1948
1949                 return result;
1950         }
1951
1952         private void handleAndAddExtractedVfcsArtifacts(List<ArtifactDefinition> vfcArtifacts, List<ArtifactDefinition> artifactsToAdd) {
1953                 List<String> vfcArtifactNames = vfcArtifacts.stream().map(a -> a.getArtifactName()).collect(Collectors.toList());
1954                 artifactsToAdd.stream().forEach(a -> {
1955                         if (!vfcArtifactNames.contains(a.getArtifactName())) {
1956                                 vfcArtifacts.add(a);
1957                         } else {
1958                                 log.error("Can't upload two artifact with the same name {}. ", a.getArtifactName());
1959                         }
1960                 });
1961
1962         }
1963
1964         @SuppressWarnings("unchecked")
1965         private Either<Map<String, Resource>, ResponseFormat> handleNodeTypes(String yamlName, Resource resource, String topologyTemplateYaml, boolean needLock,
1966                                                                                                                                                  Map<String, EnumMap<ArtifactOperationEnum, List<ArtifactDefinition>>> nodeTypesArtifactsToHandle, List<ArtifactDefinition> nodeTypesNewCreatedArtifacts,
1967                                                                                                                                                   Map<String, NodeTypeInfo> nodeTypesInfo, CsarInfo csarInfo, String nodeName) {
1968
1969                 Either<Map<String, Resource>, ResponseFormat> result = Either.left(csarInfo.getCreatedNodes());
1970                 for (Entry<String, NodeTypeInfo> nodeTypeEntry : nodeTypesInfo.entrySet()) {
1971                         if (nodeTypeEntry.getValue().isNested()) {
1972
1973                                 Either<Resource, ResponseFormat> createResourceFromYaml = handleNestedVfc(resource, nodeTypesArtifactsToHandle, 
1974                                                 nodeTypesNewCreatedArtifacts, nodeTypesInfo, csarInfo, nodeTypeEntry.getKey());
1975                                 log.trace("************* finished to create node {}", nodeTypeEntry.getKey());
1976                                 if (createResourceFromYaml.isRight()) {
1977                                         return Either.right(createResourceFromYaml.right().value());
1978                                 }
1979                         }
1980                 }
1981         
1982                 Map<String, Object> mappedToscaTemplate = null;
1983                 if(StringUtils.isNotEmpty(nodeName) && MapUtils.isNotEmpty(nodeTypesInfo) && nodeTypesInfo.containsKey(nodeName)){
1984                         mappedToscaTemplate = nodeTypesInfo.get(nodeName).getMappedToscaTemplate();
1985                 }
1986                 if(MapUtils.isEmpty(mappedToscaTemplate)){
1987                         mappedToscaTemplate = (Map<String, Object>) new Yaml().load(topologyTemplateYaml);
1988                 }
1989                 
1990                 Either<Map<String, Resource>, ResponseFormat> createdNodeTypeFromMainTemplateEither = createResourcesFromYamlNodeTypesList(yamlName, resource, mappedToscaTemplate, needLock, nodeTypesArtifactsToHandle, 
1991                                 nodeTypesNewCreatedArtifacts, nodeTypesInfo, csarInfo);
1992                 if (createdNodeTypeFromMainTemplateEither.isRight()) {
1993                         ResponseFormat responseFormat = createdNodeTypeFromMainTemplateEither.right().value();
1994                         componentsUtils.auditResource(responseFormat, csarInfo.getModifier(), resource, "", "", AuditingActionEnum.IMPORT_RESOURCE, null);
1995                         return Either.right(responseFormat);
1996                 }
1997
1998                 // add the created node types to the cache although they are not in the
1999                 // graph.
2000                 csarInfo.getCreatedNodes().values().stream().forEach(p -> cacheManagerOperation.storeComponentInCache(p, NodeTypeEnum.Resource));
2001
2002                 return result;
2003         }
2004
2005         private Either<Resource, ResponseFormat> handleVfCsarArtifacts(Resource resource, CsarInfo csarInfo, List<ArtifactDefinition> createdArtifacts, ArtifactOperationInfo artifactOperation, boolean shouldLock,
2006                         boolean inTransaction) {
2007
2008                 if (csarInfo.getCsar() != null) {
2009                         String vendorLicenseModelId = null;
2010                         String vfLicenseModelId = null;
2011
2012                         if (artifactOperation.getArtifactOperationEnum() == ArtifactOperationEnum.Update) {
2013                                 Map<String, ArtifactDefinition> deploymentArtifactsMap = resource.getDeploymentArtifacts();
2014                                 if (deploymentArtifactsMap != null && !deploymentArtifactsMap.isEmpty()) {
2015                                         for (Entry<String, ArtifactDefinition> artifactEntry : deploymentArtifactsMap.entrySet()) {
2016                                                 if (artifactEntry.getValue().getArtifactName().equalsIgnoreCase(Constants.VENDOR_LICENSE_MODEL))
2017                                                         vendorLicenseModelId = artifactEntry.getValue().getUniqueId();
2018                                                 if (artifactEntry.getValue().getArtifactName().equalsIgnoreCase(Constants.VF_LICENSE_MODEL))
2019                                                         vfLicenseModelId = artifactEntry.getValue().getUniqueId();
2020                                         }
2021                                 }
2022
2023                         }
2024                         // Specific Behavior for license artifacts
2025                         createOrUpdateSingleNonMetaArtifact(resource, csarInfo, CsarUtils.ARTIFACTS_PATH + Constants.VENDOR_LICENSE_MODEL, Constants.VENDOR_LICENSE_MODEL, ArtifactTypeEnum.VENDOR_LICENSE.getType(), ArtifactGroupTypeEnum.DEPLOYMENT,
2026                                         Constants.VENDOR_LICENSE_LABEL, Constants.VENDOR_LICENSE_DISPLAY_NAME, Constants.VENDOR_LICENSE_DESCRIPTION, vendorLicenseModelId, artifactOperation, null, shouldLock, inTransaction);
2027                         createOrUpdateSingleNonMetaArtifact(resource, csarInfo, CsarUtils.ARTIFACTS_PATH + Constants.VF_LICENSE_MODEL, Constants.VF_LICENSE_MODEL, ArtifactTypeEnum.VF_LICENSE.getType(), ArtifactGroupTypeEnum.DEPLOYMENT,
2028                                         Constants.VF_LICENSE_LABEL, Constants.VF_LICENSE_DISPLAY_NAME, Constants.VF_LICENSE_DESCRIPTION, vfLicenseModelId, artifactOperation, null, shouldLock, inTransaction);
2029
2030                         Either<Resource, ResponseFormat> eitherCreateResult = createOrUpdateNonMetaArtifacts(csarInfo, resource, createdArtifacts, shouldLock, inTransaction, artifactOperation);
2031                         if (eitherCreateResult.isRight()) {
2032                                 return Either.right(eitherCreateResult.right().value());
2033                         }
2034                         Either<Resource, StorageOperationStatus> eitherGerResource = toscaOperationFacade.getToscaElement(resource.getUniqueId());
2035                         if (eitherGerResource.isRight()) {
2036                                 ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(eitherGerResource.right().value()), resource);
2037
2038                                 return Either.right(responseFormat);
2039
2040                         }
2041                         resource = eitherGerResource.left().value();
2042
2043                         Either<ImmutablePair<String, String>, ResponseFormat> artifacsMetaCsarStatus = CsarValidationUtils.getArtifactsMeta(csarInfo.getCsar(), csarInfo.getCsarUUID(), componentsUtils);
2044                         if (artifacsMetaCsarStatus.isLeft()) {
2045
2046                                 String artifactsFileName = artifacsMetaCsarStatus.left().value().getKey();
2047                                 String artifactsContents = artifacsMetaCsarStatus.left().value().getValue();
2048                                 Either<Resource, ResponseFormat> createArtifactsFromCsar = Either.left(resource);
2049                                 if (ArtifactOperationEnum.isCreateOrLink(artifactOperation.getArtifactOperationEnum()))
2050                                         createArtifactsFromCsar = createResourceArtifactsFromCsar(csarInfo, resource, artifactsContents, artifactsFileName, createdArtifacts, shouldLock, inTransaction);
2051                                 else
2052                                         createArtifactsFromCsar = updateResourceArtifactsFromCsar(csarInfo, resource, artifactsContents, artifactsFileName, createdArtifacts, shouldLock, inTransaction);
2053                                 if (createArtifactsFromCsar.isRight()) {
2054                                         log.debug("Couldn't create artifacts from artifacts.meta");
2055                                         return Either.right(createArtifactsFromCsar.right().value());
2056                                 }
2057
2058                                 resource = createArtifactsFromCsar.left().value();
2059                         } else {
2060                                 List<GroupDefinition> groupsToDelete = resource.getGroups();
2061
2062                                 if (groupsToDelete != null && !groupsToDelete.isEmpty()) {
2063                                         Set<String> artifactsToDelete = new HashSet<String>();
2064                         
2065                                         for (String artifactId : artifactsToDelete) {
2066                                                 Either<Either<ArtifactDefinition, Operation>, ResponseFormat> handleDelete = artifactsBusinessLogic.handleDelete(resource.getUniqueId(), artifactId, csarInfo.getModifier(), AuditingActionEnum.ARTIFACT_DELETE, ComponentTypeEnum.RESOURCE,
2067                                                                 resource, null, null, shouldLock, inTransaction);
2068                                                 if (handleDelete.isRight()) {
2069                                                         log.debug("Couldn't delete  artifact {}", artifactId);
2070                                                         return Either.right(handleDelete.right().value());
2071                                                 }
2072                                         }
2073                                         Either<Resource, StorageOperationStatus> eitherGetResource = toscaOperationFacade.getToscaElement(resource.getUniqueId());
2074                                         if (eitherGetResource.isRight()) {
2075                                                 ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(eitherGetResource.right().value()), resource);
2076
2077                                                 return Either.right(responseFormat);
2078
2079                                         }
2080                                         resource = eitherGetResource.left().value();
2081                                 }
2082                         }
2083                 }
2084                 return Either.left(resource);
2085         }
2086
2087         private Either<Boolean, ResponseFormat> createOrUpdateSingleNonMetaArtifact(Resource resource, CsarInfo csarInfo, String artifactPath, String artifactFileName, String artifactType,
2088                         ArtifactGroupTypeEnum artifactGroupType, String artifactLabel, String artifactDisplayName, String artifactDescription, String artifactId, ArtifactOperationInfo operation, List<ArtifactDefinition> createdArtifacts, boolean shouldLock,
2089                         boolean inTransaction) {
2090                 byte[] artifactFileBytes = null;
2091
2092                 if (csarInfo.getCsar().containsKey(artifactPath)) {
2093                         artifactFileBytes = csarInfo.getCsar().get(artifactPath);
2094                 }
2095                 Either<Boolean, ResponseFormat> result = Either.left(true);
2096                 if (operation.getArtifactOperationEnum() == ArtifactOperationEnum.Update || operation.getArtifactOperationEnum() == ArtifactOperationEnum.Delete) {
2097                         if (artifactId != null && !artifactId.isEmpty() && artifactFileBytes == null) {
2098                                 Either<Either<ArtifactDefinition, Operation>, ResponseFormat> handleDelete = artifactsBusinessLogic.handleDelete(resource.getUniqueId(), artifactId, csarInfo.getModifier(), AuditingActionEnum.ARTIFACT_DELETE, ComponentTypeEnum.RESOURCE, resource, null,
2099                                                 null, shouldLock, inTransaction);
2100                                 if (handleDelete.isRight()) {
2101                                         result = Either.right(handleDelete.right().value());
2102                                 }
2103                                 return result;
2104                         }
2105
2106                         if ((artifactId == null || artifactId.isEmpty()) && artifactFileBytes != null) {
2107                                 operation = artifactsBusinessLogic.new ArtifactOperationInfo(false, false, ArtifactOperationEnum.Create);
2108                         }
2109
2110                 }
2111                 if (artifactFileBytes != null) {
2112                         Map<String, Object> vendorLicenseModelJson = buildJsonForUpdateArtifact(artifactId, artifactFileName, artifactType, artifactGroupType, artifactLabel, artifactDisplayName, artifactDescription, artifactFileBytes, null);
2113                         Either<Either<ArtifactDefinition, Operation>, ResponseFormat> eitherNonMetaArtifacts = createOrUpdateCsarArtifactFromJson(resource, csarInfo.getModifier(), vendorLicenseModelJson, operation, shouldLock, inTransaction);
2114                         addNonMetaCreatedArtifactsToSupportRollback(operation, createdArtifacts, eitherNonMetaArtifacts);
2115                         if (eitherNonMetaArtifacts.isRight()) {
2116                                 BeEcompErrorManager.getInstance().logInternalFlowError("UploadLicenseArtifact", "Failed to upload license artifact: " + artifactFileName + "With csar uuid: " + csarInfo.getCsarUUID(), ErrorSeverity.WARNING);
2117                                 return Either.right(eitherNonMetaArtifacts.right().value());
2118                         }
2119                 }
2120                 return result;
2121         }
2122
2123         private void addNonMetaCreatedArtifactsToSupportRollback(ArtifactOperationInfo operation, List<ArtifactDefinition> createdArtifacts, Either<Either<ArtifactDefinition, Operation>, ResponseFormat> eitherNonMetaArtifacts) {
2124                 if (ArtifactOperationEnum.isCreateOrLink(operation.getArtifactOperationEnum()) && createdArtifacts != null && eitherNonMetaArtifacts.isLeft()) {
2125                         Either<ArtifactDefinition, Operation> eitherResult = eitherNonMetaArtifacts.left().value();
2126                         if (eitherResult.isLeft()) {
2127                                 createdArtifacts.add(eitherResult.left().value());
2128                         }
2129                 }
2130         }
2131
2132         private Either<Either<ArtifactDefinition, Operation>, ResponseFormat> createOrUpdateCsarArtifactFromJson(Resource resource, User user, Map<String, Object> json, ArtifactOperationInfo operation, boolean shoudLock, boolean inTransaction) {
2133
2134                 String jsonStr = gson.toJson(json);
2135
2136                 String origMd5 = GeneralUtility.calculateMD5Base64EncodedByString(jsonStr);
2137                 ArtifactDefinition artifactDefinitionFromJson = RepresentationUtils.convertJsonToArtifactDefinition(jsonStr, ArtifactDefinition.class);
2138                 String artifactUniqueId = artifactDefinitionFromJson == null ? null : artifactDefinitionFromJson.getUniqueId();
2139                 Either<Either<ArtifactDefinition, Operation>, ResponseFormat> uploadArtifactToService = artifactsBusinessLogic.validateAndHandleArtifact(resource.getUniqueId(), ComponentTypeEnum.RESOURCE, operation, artifactUniqueId,
2140                                 artifactDefinitionFromJson, origMd5, jsonStr, null, null, null, user, resource, false, true, false);
2141                 if (uploadArtifactToService.isRight())
2142                         return Either.right(uploadArtifactToService.right().value());
2143
2144                 return Either.left(uploadArtifactToService.left().value());
2145         }
2146
2147         public Either<Resource, ResponseFormat> updateResourceArtifactsFromCsar(CsarInfo csarInfo, Resource resource, String artifactsMetaFile, String artifactsMetaFileName, List<ArtifactDefinition> createdNewArtifacts,
2148                         boolean shouldLock, boolean inTransaction) {
2149
2150                 Either<Map<String, List<ArtifactTemplateInfo>>, ResponseFormat> parseResourceInfoFromYamlEither = parseResourceArtifactsInfoFromFile(resource, artifactsMetaFile, artifactsMetaFileName, csarInfo.getModifier());
2151                 if (parseResourceInfoFromYamlEither.isRight()) {
2152                         ResponseFormat responseFormat = parseResourceInfoFromYamlEither.right().value();
2153                         componentsUtils.auditResource(responseFormat, csarInfo.getModifier(), resource, "", "", AuditingActionEnum.IMPORT_RESOURCE, null);
2154                         return Either.right(responseFormat);
2155                 }
2156
2157                 List<GroupDefinition> groups = resource.getGroups();
2158                 Map<String, ArtifactDefinition> deplymentArtifact = resource.getDeploymentArtifacts();
2159                 List<ArtifactDefinition> createdDeplymentArtifactsAfterDelete = new ArrayList<ArtifactDefinition>();
2160                 if (deplymentArtifact != null && !deplymentArtifact.isEmpty()) {
2161                         for (Entry<String, ArtifactDefinition> entry : deplymentArtifact.entrySet()) {
2162                                 createdDeplymentArtifactsAfterDelete.add(entry.getValue());
2163                         }
2164                 }
2165                 int labelCounter = createdDeplymentArtifactsAfterDelete.size();
2166
2167                 if (deplymentArtifact == null || deplymentArtifact.isEmpty()) {
2168                         if (groups != null && !groups.isEmpty()) {
2169                                 for (GroupDefinition group : groups) {
2170                                         if (group.getArtifacts() != null && !group.getArtifacts().isEmpty()) {
2171                                                 log.debug("failed to update artifacts from csar. List of emty but group not empty");
2172                                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.INVALID_CONTENT);
2173                                                 return Either.right(responseFormat);
2174                                         }
2175                                 }
2176                         }
2177                         return createResourceArtifacts(csarInfo, resource, parseResourceInfoFromYamlEither.left().value(), AuditingActionEnum.CREATE_RESOURCE, createdNewArtifacts, shouldLock, inTransaction);
2178                 }
2179
2180                 // find master in group
2181                 Map<GroupDefinition, Map<ArtifactDefinition, List<ArtifactDefinition>>> groupArtifact = findMasterArtifactInGroup(groups, deplymentArtifact);
2182
2183                 ////////////////////////////////////// create set parsed
2184                 ////////////////////////////////////// artifacts///////////////////////////////////////////
2185                 Map<String, List<ArtifactTemplateInfo>> parsedArtifactsMap = parseResourceInfoFromYamlEither.left().value();
2186                 
2187                 Map<ArtifactTemplateInfo, Set<ArtifactTemplateInfo>> parsedGroup = new HashMap<ArtifactTemplateInfo, Set<ArtifactTemplateInfo>>();
2188                 List<ArtifactTemplateInfo> artifactsWithoutGroups = null;
2189                 if(parsedArtifactsMap.containsKey(ArtifactTemplateInfo.CSAR_ARTIFACT)){
2190                         artifactsWithoutGroups = parsedArtifactsMap.get(ArtifactTemplateInfo.CSAR_ARTIFACT);
2191                         parsedArtifactsMap.remove(ArtifactTemplateInfo.CSAR_ARTIFACT);
2192                 }
2193                 Collection<List<ArtifactTemplateInfo>> parsedArifactsCollection = parsedArtifactsMap.values();
2194                 for (List<ArtifactTemplateInfo> parsedGroupTemplateList : parsedArifactsCollection) {
2195                         
2196                         for (ArtifactTemplateInfo parsedGroupTemplate : parsedGroupTemplateList) {
2197                                 if(parsedGroupTemplate.getGroupName() != null){
2198                                         parsedGroupTemplate.setGroupName("");
2199                                         Set<ArtifactTemplateInfo> parsedArtifactsNames = new HashSet<ArtifactTemplateInfo>();
2200                                         parsedArtifactsNames.add(parsedGroupTemplate);
2201                                         List<ArtifactTemplateInfo> relatedGroupTemplateList = parsedGroupTemplate.getRelatedArtifactsInfo();
2202                                         if (relatedGroupTemplateList != null && !relatedGroupTemplateList.isEmpty()) {
2203                                                 createArtifactsGroupSet(parsedGroupTemplateList, parsedArtifactsNames);
2204                                         }
2205                                         parsedGroup.put(parsedGroupTemplate, parsedArtifactsNames);
2206                                 }else{
2207                                         List<ArtifactTemplateInfo> arrtifacts = new ArrayList<ArtifactTemplateInfo>();
2208                                         arrtifacts.add(parsedGroupTemplate);
2209                                         Either<Resource, ResponseFormat> resStatus = createGroupDeploymentArtifactsFromCsar(csarInfo, resource, arrtifacts, createdNewArtifacts, createdDeplymentArtifactsAfterDelete, labelCounter, shouldLock, inTransaction);
2210                                         if (resStatus.isRight())
2211                                                 return resStatus;
2212                                 
2213                                 }
2214                         }
2215                         
2216                 }
2217
2218                 ///////////////////////////////// find artifacts to
2219                 ///////////////////////////////// delete////////////////////////////////////////////////////
2220
2221                 Set<ArtifactDefinition> artifactsToDelete = new HashSet<ArtifactDefinition>();
2222                 Map<String, List<ArtifactDefinition>> groupToDelete = new HashMap<String, List<ArtifactDefinition>>();
2223
2224                 Set<ArtifactTemplateInfo> jsonMasterArtifacts = parsedGroup.keySet();
2225                 Map<GroupDefinition, MergedArtifactInfo> mergedgroup = mergeGroupInUpdateFlow(groupArtifact, parsedGroup, artifactsToDelete, groupToDelete, jsonMasterArtifacts, createdDeplymentArtifactsAfterDelete);
2226
2227                 // Set<String> deletedArtifactsName = new HashSet<String>();
2228                 Either<List<ArtifactDefinition>, ResponseFormat> deletedArtifactsEither = deleteArtifactsInUpdateCsarFlow(resource, csarInfo.getModifier(), shouldLock, inTransaction, artifactsToDelete, groupToDelete);
2229                 if (deletedArtifactsEither.isRight()) {
2230                         log.debug("Failed to delete artifacts. Status is {} ", deletedArtifactsEither.right().value());
2231
2232                         return Either.right(deletedArtifactsEither.right().value());
2233
2234                 }
2235                 List<ArtifactDefinition> deletedArtifacts = deletedArtifactsEither.left().value();
2236
2237                 // need to update resource if we updated artifacts
2238                 if (deletedArtifacts != null && !deletedArtifacts.isEmpty()) {
2239                         for (ArtifactDefinition deletedArtifact : deletedArtifacts) {
2240                                 ArtifactDefinition artToRemove = null;
2241                                 for (ArtifactDefinition artFromResource : createdDeplymentArtifactsAfterDelete) {
2242                                         if (deletedArtifact.getUniqueId().equalsIgnoreCase(artFromResource.getUniqueId())) {
2243                                                 artToRemove = artFromResource;
2244                                                 break;
2245                                         }
2246                                 }
2247                                 if (artToRemove != null)
2248                                         createdDeplymentArtifactsAfterDelete.remove(artToRemove);
2249
2250                         }
2251                 }
2252
2253                 ////////////// dissociate, associate or create
2254                 ////////////// artifacts////////////////////////////
2255                 Either<Resource, ResponseFormat> assDissotiateEither = associateAndDissociateArtifactsToGroup(csarInfo, resource, createdNewArtifacts, labelCounter, shouldLock, inTransaction, createdDeplymentArtifactsAfterDelete,
2256                                 mergedgroup, deletedArtifacts);
2257                 groups = resource.getGroups();
2258                 if (assDissotiateEither.isRight()) {
2259                         log.debug("Failed to delete artifacts. Status is {} ", assDissotiateEither.right().value());
2260
2261                         return Either.right(assDissotiateEither.right().value());
2262
2263                 }
2264                 resource = assDissotiateEither.left().value();
2265                 deplymentArtifact = resource.getDeploymentArtifacts();
2266                 createdDeplymentArtifactsAfterDelete.clear();
2267                 if (deplymentArtifact != null && !deplymentArtifact.isEmpty()) {
2268                         for (Entry<String, ArtifactDefinition> entry : deplymentArtifact.entrySet()) {
2269                                 createdDeplymentArtifactsAfterDelete.add(entry.getValue());
2270                         }
2271                 }
2272
2273                 
2274
2275                 // update vfModule names
2276                 Set<GroupDefinition> groupForAssociateWithMembers = mergedgroup.keySet();
2277                 if (groups != null && !groups.isEmpty()) {
2278                         Either<List<GroupDefinition>, ResponseFormat> validateUpdateVfGroupNamesRes = groupBusinessLogic.validateUpdateVfGroupNamesOnGraph(groups, resource, inTransaction);
2279                         if (validateUpdateVfGroupNamesRes.isRight()) {
2280                                 return Either.right(validateUpdateVfGroupNamesRes.right().value());
2281                         }
2282                         List<GroupDefinition> heatGroups = null;
2283
2284                         heatGroups = groups.stream().filter(e -> e.getMembers() != null).collect(Collectors.toList());
2285                         ;
2286
2287                         for (GroupDefinition updatedGroupDef : groupForAssociateWithMembers) {
2288
2289                                 if (updatedGroupDef.getMembers() != null && !updatedGroupDef.getMembers().isEmpty()) {
2290                                         updatedGroupDef.getMembers().clear();
2291                                 }
2292                                 Map<String, String> members = new HashMap<String, String>();
2293                                 Set<String> artifactsGroup = new HashSet<String>();
2294                                 artifactsGroup.addAll(updatedGroupDef.getArtifacts());
2295                                 associateMembersToArtifacts(createdNewArtifacts, createdDeplymentArtifactsAfterDelete, heatGroups, artifactsGroup, members);
2296                                 if (!members.isEmpty()) {
2297                                         updatedGroupDef.setMembers(members);
2298
2299                                 }
2300
2301
2302                         }
2303
2304
2305                 }
2306
2307                 //////////////// create new artifacts in update
2308                 //////////////// flow////////////////////////////
2309                 List<ArtifactTemplateInfo> newArtifactsGroup = new ArrayList<ArtifactTemplateInfo>();
2310
2311                 for (Entry<ArtifactTemplateInfo, Set<ArtifactTemplateInfo>> parsedGroupSetEntry : parsedGroup.entrySet()) {
2312                         ArtifactTemplateInfo parsedArtifactMaster = parsedGroupSetEntry.getKey();
2313                         boolean isNewGroup = true;
2314                         for (Entry<GroupDefinition, Map<ArtifactDefinition, List<ArtifactDefinition>>> groupListEntry : groupArtifact.entrySet()) {
2315                                 Map<ArtifactDefinition, List<ArtifactDefinition>> groupArtifacts = groupListEntry.getValue();
2316                                 Set<ArtifactDefinition> group = groupArtifacts.keySet();
2317                                 for (ArtifactDefinition artifactInfo : group) {
2318                                         if (parsedArtifactMaster.getFileName().equalsIgnoreCase(artifactInfo.getArtifactName())) {
2319                                                 parsedArtifactMaster.setGroupName(groupListEntry.getKey().getName());
2320                                                 isNewGroup = false;
2321                                         }
2322                                 }
2323                         }
2324                         if (isNewGroup)
2325                                 newArtifactsGroup.add(parsedArtifactMaster);
2326
2327                 }
2328                 if (!newArtifactsGroup.isEmpty()) {
2329                         Collections.sort(newArtifactsGroup, (art1, art2) -> ArtifactTemplateInfo.compareByGroupName(art1, art2));
2330                         int startGroupCounter = groupBusinessLogic.getNextVfModuleNameCounter(groups);
2331                         Either<Boolean, ResponseFormat> validateGroupNamesRes = groupBusinessLogic.validateGenerateVfModuleGroupNames(newArtifactsGroup, resource.getSystemName(), startGroupCounter);
2332                         if (validateGroupNamesRes.isRight()) {
2333                                 return Either.right(validateGroupNamesRes.right().value());
2334                         }
2335                         Either<Resource, ResponseFormat> resStatus = createGroupDeploymentArtifactsFromCsar(csarInfo, resource, newArtifactsGroup, createdNewArtifacts, createdDeplymentArtifactsAfterDelete, labelCounter, shouldLock, inTransaction);
2336                         if (resStatus.isRight())
2337                                 return resStatus;
2338                 }
2339
2340                 // updatedGroup
2341                 if (!groupForAssociateWithMembers.isEmpty()) {
2342
2343                         List<GroupDefinition> groupsId = groupForAssociateWithMembers.stream().map(e -> e).collect(Collectors.toList());
2344
2345                         Either<List<GroupDefinition>, ResponseFormat> updateVersionEither = groupBusinessLogic.updateGroups(resource, ComponentTypeEnum.RESOURCE, groupsId);
2346                         if (updateVersionEither.isRight()) {
2347                                 log.debug("Failed to update groups version. Status is {} ", updateVersionEither.right().value());
2348
2349                                 return Either.right(updateVersionEither.right().value());
2350
2351                         }
2352                 }
2353                 if(artifactsWithoutGroups != null && !artifactsWithoutGroups.isEmpty()){
2354                         for(ArtifactTemplateInfo t: artifactsWithoutGroups){
2355                                 List<ArtifactTemplateInfo> arrtifacts = new ArrayList<ArtifactTemplateInfo>();
2356                                 arrtifacts.add(t);
2357                                 Either<Resource, ResponseFormat> resStatus = createGroupDeploymentArtifactsFromCsar(csarInfo, resource, arrtifacts, createdNewArtifacts, createdDeplymentArtifactsAfterDelete, labelCounter, shouldLock, inTransaction);
2358                                 if (resStatus.isRight())
2359                                         return resStatus;
2360                         };
2361                 }
2362                 
2363                 Either<Resource, StorageOperationStatus> eitherGerResource = toscaOperationFacade.getToscaElement(resource.getUniqueId());
2364                 if (eitherGerResource.isRight()) {
2365                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(eitherGerResource.right().value()), resource);
2366
2367                         return Either.right(responseFormat);
2368
2369                 }
2370                 return Either.left(eitherGerResource.left().value());
2371
2372         }
2373
2374         private Either<List<ArtifactDefinition>, ResponseFormat> deleteArtifactsInUpdateCsarFlow(Resource resource, User user, boolean shouldLock, boolean inTransaction, Set<ArtifactDefinition> artifactsToDelete,
2375                         Map<String, List<ArtifactDefinition>> groupToDelete) {
2376                 List<ArtifactDefinition> deletedArtifacts = new ArrayList<ArtifactDefinition>();
2377                 String resourceId = resource.getUniqueId();
2378                 if (!artifactsToDelete.isEmpty()) {
2379                         for (ArtifactDefinition artifact : artifactsToDelete) {
2380                                 String artifactType = artifact.getArtifactType();
2381                                 ArtifactTypeEnum artifactTypeEnum = ArtifactTypeEnum.findType(artifactType);
2382                                 if (artifactTypeEnum != ArtifactTypeEnum.HEAT_ENV) {
2383                                         Either<Either<ArtifactDefinition, Operation>, ResponseFormat> handleDelete = artifactsBusinessLogic.handleDelete(resourceId, artifact.getUniqueId(), user, AuditingActionEnum.ARTIFACT_DELETE, ComponentTypeEnum.RESOURCE, resource,
2384                                                         null, null, shouldLock, inTransaction);
2385                                         if (handleDelete.isRight()) {
2386                                                 return Either.right(handleDelete.right().value());
2387                                         }
2388
2389                                         deletedArtifacts.add(handleDelete.left().value().left().value());
2390                                 }
2391
2392                         }
2393                 }
2394                 if (!groupToDelete.isEmpty()) {
2395                         log.debug("try to delete group");
2396                         List<GroupDefinition> groupDefinitionstoDelete = new ArrayList<>();
2397                         List<GroupDefinition> groups = resource.getGroups();
2398                         for (Entry<String, List<ArtifactDefinition>> deleteGroup : groupToDelete.entrySet()) {
2399                                 Optional<GroupDefinition> op = groups.stream().filter(gr -> gr.getUniqueId().equals(deleteGroup.getKey())).findAny();
2400                                 if (op.isPresent()) {
2401                                         groupDefinitionstoDelete.add(op.get());
2402                                 }
2403
2404                         }
2405                         if (!groupDefinitionstoDelete.isEmpty()) {
2406                                 Either<List<GroupDefinition>, ResponseFormat> prepareGroups = groupBusinessLogic.deleteGroups(resource, user, ComponentTypeEnum.RESOURCE, groupDefinitionstoDelete);
2407                                 if (prepareGroups.isRight()) {
2408                                         return Either.right(prepareGroups.right().value());
2409                                 }
2410                         }
2411                 }
2412                 return Either.left(deletedArtifacts);
2413         }
2414
2415         private Either<Resource, ResponseFormat> associateAndDissociateArtifactsToGroup(CsarInfo csarInfo, Resource resource, List<ArtifactDefinition> createdNewArtifacts, int labelCounter, boolean shouldLock,
2416                         boolean inTransaction, List<ArtifactDefinition> createdDeplymentArtifactsAfterDelete, Map<GroupDefinition, MergedArtifactInfo> mergedgroup, List<ArtifactDefinition> deletedArtifacts) {
2417                 Map<GroupDefinition, List<ArtifactTemplateInfo>> artifactsToAssotiate = new HashMap<GroupDefinition, List<ArtifactTemplateInfo>>();
2418                 Map<GroupDefinition, List<ImmutablePair<ArtifactDefinition, ArtifactTemplateInfo>>> artifactsToUpdateMap = new HashMap<GroupDefinition, List<ImmutablePair<ArtifactDefinition, ArtifactTemplateInfo>>>();
2419                 Either<Resource, ResponseFormat> resEither = Either.left(resource);
2420                 for (Entry<GroupDefinition, MergedArtifactInfo> entry : mergedgroup.entrySet()) {
2421                         List<ArtifactDefinition> dissArtifactsInGroup = entry.getValue().getListToDissotiateArtifactFromGroup(deletedArtifacts);
2422                         GroupDefinition grDef = entry.getKey();
2423                         if (dissArtifactsInGroup != null && !dissArtifactsInGroup.isEmpty()) {
2424                                 for (ArtifactDefinition art : dissArtifactsInGroup) {
2425                                         grDef.getArtifacts().remove(art.getUniqueId());
2426                                         grDef.getArtifactsUuid().remove(art.getArtifactUUID());
2427                                 }
2428                         }
2429
2430                         List<ArtifactTemplateInfo> newArtifactsInGroup = entry.getValue().getListToAssociateArtifactToGroup();
2431                         if (newArtifactsInGroup != null && !newArtifactsInGroup.isEmpty())
2432                                 artifactsToAssotiate.put(entry.getKey(), newArtifactsInGroup);
2433
2434                         List<ImmutablePair<ArtifactDefinition, ArtifactTemplateInfo>> artifactsToUpdate = entry.getValue().getListToUpdateArtifactInGroup();
2435                         if (artifactsToUpdate != null && !artifactsToUpdate.isEmpty())
2436                                 artifactsToUpdateMap.put(entry.getKey(), artifactsToUpdate);
2437                 }
2438
2439                 if (!artifactsToUpdateMap.isEmpty()) {
2440                         List<ArtifactDefinition> updatedArtifacts = new ArrayList<ArtifactDefinition>();
2441                         for (Entry<GroupDefinition, List<ImmutablePair<ArtifactDefinition, ArtifactTemplateInfo>>> artifactsToUpdateEntry : artifactsToUpdateMap.entrySet()) {
2442                                 List<ImmutablePair<ArtifactDefinition, ArtifactTemplateInfo>> artifactsToUpdateList = artifactsToUpdateEntry.getValue();
2443                                 GroupDefinition groupToUpdate = artifactsToUpdateEntry.getKey();
2444
2445                                 for (ImmutablePair<ArtifactDefinition, ArtifactTemplateInfo> artifact : artifactsToUpdateList) {
2446                                         String prevUUID = artifact.getKey().getArtifactUUID();                                  
2447                                         String prevId = artifact.getKey().getUniqueId();
2448                                         String prevHeatEnvId = checkAndGetHeatEnvId(artifact.getKey());
2449                                         Either<ArtifactDefinition, ResponseFormat> updateArtifactEither = updateDeploymentArtifactsFromCsar(csarInfo, resource, artifact.getKey(), artifact.getValue(), updatedArtifacts,
2450                                                         artifact.getRight().getRelatedArtifactsInfo(), shouldLock, inTransaction);
2451                                         if (updateArtifactEither.isRight()) {
2452                                                 log.debug("failed to update artifacts. status is {}", updateArtifactEither.right().value());
2453                                                 resEither = Either.right(updateArtifactEither.right().value());
2454                                                 return resEither;
2455                                         }
2456                                         ArtifactDefinition artAfterUpdate = updateArtifactEither.left().value();
2457                                         if (!prevUUID.equals(artAfterUpdate.getArtifactUUID()) || !prevId.equals(artAfterUpdate.getUniqueId())) {
2458                                                 groupToUpdate.getArtifacts().remove(prevId);
2459                                                 groupToUpdate.getArtifactsUuid().remove(prevUUID);
2460                                                 groupToUpdate.getArtifacts().add(artAfterUpdate.getUniqueId());
2461                                                 groupToUpdate.getArtifactsUuid().add(artAfterUpdate.getArtifactUUID());
2462                                         }
2463                                         Optional<ArtifactDefinition> op = updatedArtifacts.stream().filter(p -> p.getGeneratedFromId() != null && p.getGeneratedFromId().equals(artAfterUpdate.getUniqueId())).findAny();
2464                                         if (op.isPresent()) {
2465                                                 ArtifactDefinition artifactInfoHeatEnv = op.get();
2466                                                 groupToUpdate.getArtifacts().remove(prevHeatEnvId);                                             
2467                                                 groupToUpdate.getArtifacts().add(artifactInfoHeatEnv.getUniqueId());                                            
2468                                         }
2469                                         
2470                                 }
2471                         }
2472                 }
2473
2474                 for (Entry<GroupDefinition, List<ArtifactTemplateInfo>> associateEntry : artifactsToAssotiate.entrySet()) {
2475                         List<ArtifactTemplateInfo> associatedArtifact = associateEntry.getValue();
2476                         Set<String> arifactsUids = new HashSet<String>();
2477                         Set<String> arifactsUuids = new HashSet<String>();
2478                         for (ArtifactTemplateInfo artifactTemplate : associatedArtifact) { // try
2479                                 // to
2480                                 // find
2481                                 // artifact
2482                                 // in
2483                                 // resource
2484                                 boolean isCreate = true;
2485                                 for (ArtifactDefinition createdArtifact : createdDeplymentArtifactsAfterDelete) {
2486                                         if (artifactTemplate.getFileName().equalsIgnoreCase(createdArtifact.getArtifactName())) {
2487                                                 arifactsUids.add(createdArtifact.getUniqueId());
2488                                                 arifactsUuids.add(createdArtifact.getArtifactUUID());
2489                                                 isCreate = false;
2490                                                 String heatEnvId = checkAndGetHeatEnvId(createdArtifact);
2491                                                 if (!heatEnvId.isEmpty()) {
2492                                                         arifactsUids.add(heatEnvId);
2493                                                         Optional<ArtifactDefinition> op = createdDeplymentArtifactsAfterDelete.stream().filter(p -> p.getUniqueId().equals(heatEnvId)).findAny();
2494                                                         if (op.isPresent()) {
2495                                                                 this.artifactToscaOperation.updateHeatEnvPlaceholder(op.get(), resource.getUniqueId(), resource.getComponentType().getNodeType());
2496
2497                                                         }
2498                                                 }
2499
2500                                                 break;
2501                                         }
2502
2503                                 }
2504                                 if (isCreate) { // check if already created
2505                                         for (ArtifactDefinition createdNewArtifact : createdNewArtifacts) {
2506                                                 if (artifactTemplate.getFileName().equalsIgnoreCase(createdNewArtifact.getArtifactName())) {
2507                                                         arifactsUids.add(createdNewArtifact.getUniqueId());
2508                                                         arifactsUuids.add(createdNewArtifact.getArtifactUUID());
2509                                                         isCreate = false;
2510                                                         String heatEnvId = checkAndGetHeatEnvId(createdNewArtifact);
2511                                                         if (!heatEnvId.isEmpty()) {
2512                                                                 arifactsUids.add(heatEnvId);
2513                                                         }
2514                                                         break;
2515                                                 }
2516                                         }
2517                                 }
2518
2519                                 if (isCreate) {
2520                                         Either<ArtifactDefinition, ResponseFormat> createArtifactEither = createDeploymentArtifact(csarInfo, resource, ARTIFACTS_PATH, artifactTemplate, createdNewArtifacts, labelCounter, shouldLock, inTransaction);
2521                                         if (createArtifactEither.isRight()) {
2522                                                 resEither = Either.right(createArtifactEither.right().value());
2523                                                 return resEither;
2524                                         }
2525                                         ArtifactDefinition createdArtifact = createArtifactEither.left().value();
2526                                         arifactsUids.add(createdArtifact.getUniqueId());
2527                                         arifactsUuids.add(createdArtifact.getArtifactUUID());
2528                                         ArtifactTypeEnum artifactType = ArtifactTypeEnum.findType(createdArtifact.getArtifactType());
2529                                         if (artifactType == ArtifactTypeEnum.HEAT || artifactType == ArtifactTypeEnum.HEAT_NET || artifactType == ArtifactTypeEnum.HEAT_VOL) {
2530                                                 Either<ArtifactDefinition, ResponseFormat> createHeatEnvPlaceHolder = artifactsBusinessLogic.createHeatEnvPlaceHolder(createdArtifact, ArtifactsBusinessLogic.HEAT_VF_ENV_NAME, resource.getUniqueId(), NodeTypeEnum.Resource,
2531                                                                 resource.getName(), csarInfo.getModifier(), resource, null);
2532                                                 if (createHeatEnvPlaceHolder.isRight()) {
2533                                                         return Either.right(createHeatEnvPlaceHolder.right().value());
2534                                                 }
2535                                                 String heatEnvId = createHeatEnvPlaceHolder.left().value().getUniqueId();
2536                                                 arifactsUids.add(heatEnvId);
2537                                         }
2538                                 }
2539
2540                         }
2541                         if (arifactsUids.size() > 0) {
2542                                 List<String> artifactsToAssociate = new ArrayList<String>();
2543                                 artifactsToAssociate.addAll(arifactsUids);
2544                                 GroupDefinition assotiateGroup = associateEntry.getKey();
2545                                 assotiateGroup.getArtifacts().addAll(arifactsUids);
2546                                 assotiateGroup.getArtifactsUuid().addAll(arifactsUuids);
2547                         }
2548                 }
2549
2550         
2551
2552                 ComponentParametersView parametersView = new ComponentParametersView();
2553                 parametersView.disableAll();
2554                 parametersView.setIgnoreComponentInstances(false);
2555                 parametersView.setIgnoreUsers(false);
2556                 parametersView.setIgnoreArtifacts(false);
2557                 parametersView.setIgnoreGroups(false);
2558
2559                 Either<Resource, StorageOperationStatus> eitherGerResource = toscaOperationFacade.getToscaElement(resource.getUniqueId(), parametersView);
2560
2561                 if (eitherGerResource.isRight()) {
2562                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(eitherGerResource.right().value()), resource);
2563
2564                         resEither = Either.right(responseFormat);
2565                         return resEither;
2566
2567                 }
2568                 resEither = Either.left(eitherGerResource.left().value());
2569                 return resEither;
2570         }
2571
2572         private Map<GroupDefinition, MergedArtifactInfo> mergeGroupInUpdateFlow(Map<GroupDefinition, Map<ArtifactDefinition, List<ArtifactDefinition>>> groupArtifact, Map<ArtifactTemplateInfo, Set<ArtifactTemplateInfo>> parsedGroup,
2573                         Set<ArtifactDefinition> artifactsToDelete, Map<String, List<ArtifactDefinition>> groupToDelete, Set<ArtifactTemplateInfo> jsonMasterArtifacts, List<ArtifactDefinition> createdDeplymentArtifacts) {
2574                 Map<GroupDefinition, MergedArtifactInfo> mergedgroup = new HashMap<GroupDefinition, MergedArtifactInfo>();
2575                 for (Entry<GroupDefinition, Map<ArtifactDefinition, List<ArtifactDefinition>>> groupListEntry : groupArtifact.entrySet()) {
2576                         Map<ArtifactDefinition, List<ArtifactDefinition>> createdArtifactMap = groupListEntry.getValue();
2577                         boolean isNeedToDeleteGroup = true;
2578                         List<ArtifactDefinition> listToDelete = null;
2579                         for (ArtifactDefinition maserArtifact : createdArtifactMap.keySet()) {
2580                                 listToDelete = createdArtifactMap.get(maserArtifact);
2581                                 for (ArtifactDefinition artToDelete : listToDelete) {
2582                                         findArtifactToDelete(parsedGroup, artifactsToDelete, groupListEntry.getKey().getUniqueId(), artToDelete, createdDeplymentArtifacts);
2583                                 }
2584                                 if (artifactsToDelete != null && !artifactsToDelete.isEmpty()) {
2585                                         GroupDefinition group = groupListEntry.getKey();
2586                                         for (ArtifactDefinition artifactDefinition : artifactsToDelete) {
2587                                                 if (CollectionUtils.isNotEmpty(group.getArtifacts()) && group.getArtifacts().contains(artifactDefinition.getUniqueId())) {
2588                                                         group.getArtifacts().remove(artifactDefinition.getUniqueId());
2589
2590                                                 }
2591                                                 if (CollectionUtils.isNotEmpty(group.getArtifactsUuid()) && group.getArtifactsUuid().contains(artifactDefinition.getArtifactUUID())) {
2592                                                         group.getArtifactsUuid().remove(artifactDefinition.getArtifactUUID());
2593
2594                                                 }
2595                                         }
2596
2597                                 }
2598
2599                                 for (ArtifactTemplateInfo jsonMasterArtifact : jsonMasterArtifacts) {
2600                                         if (maserArtifact.getArtifactName().equalsIgnoreCase(jsonMasterArtifact.getFileName())) {
2601                                                 MergedArtifactInfo mergedGroup = new MergedArtifactInfo();
2602                                                 mergedGroup.setJsonArtifactTemplate(jsonMasterArtifact);
2603                                                 mergedGroup.setCreatedArtifact(createdArtifactMap.get(maserArtifact));
2604                                                 mergedgroup.put(groupListEntry.getKey(), mergedGroup);
2605                                                 isNeedToDeleteGroup = false;
2606
2607                                         }
2608                                 }
2609
2610                         }
2611                         if (isNeedToDeleteGroup) {
2612                                 groupToDelete.put(groupListEntry.getKey().getUniqueId(), listToDelete);
2613                         }
2614
2615                 }
2616                 return mergedgroup;
2617         }
2618
2619         private void findArtifactToDelete(Map<ArtifactTemplateInfo, Set<ArtifactTemplateInfo>> parsedGroup, Set<ArtifactDefinition> artifactsToDelete, String deleteGroupId, ArtifactDefinition artifact,
2620                         List<ArtifactDefinition> createdDeplymentArtifacts) {
2621                 boolean isNeedToDeleteArtifact = true;
2622                 String artifactType = artifact.getArtifactType();
2623                 ArtifactDefinition generatedFromArt = null;
2624                 if (artifact.getGeneratedFromId() != null && !artifact.getGeneratedFromId().isEmpty()) {
2625                         Optional<ArtifactDefinition> op = createdDeplymentArtifacts.stream().filter(p -> p.getUniqueId().equals(artifact.getGeneratedFromId())).findAny();
2626                         if (op.isPresent())
2627                                 generatedFromArt = op.get();
2628
2629                 }
2630
2631                 for (Entry<ArtifactTemplateInfo, Set<ArtifactTemplateInfo>> parsedGroupSetEntry : parsedGroup.entrySet()) {
2632                         Set<ArtifactTemplateInfo> artifactsNames = parsedGroupSetEntry.getValue();
2633                         for (ArtifactTemplateInfo template : artifactsNames) {
2634                                 if (artifact.getArtifactName().equalsIgnoreCase(template.getFileName()) && artifactType.equalsIgnoreCase(template.getType())) {
2635                                         isNeedToDeleteArtifact = false;
2636                                         break;
2637
2638                                 } else {
2639                                         if (generatedFromArt != null) {
2640                                                 if (generatedFromArt.getArtifactName().equalsIgnoreCase(template.getFileName()) && generatedFromArt.getArtifactType().equalsIgnoreCase(template.getType())) {
2641                                                         isNeedToDeleteArtifact = false;
2642                                                         break;
2643                                                 }
2644                                         }
2645                                 }
2646                         }
2647
2648                 }
2649                 if (isNeedToDeleteArtifact) {
2650                         artifactsToDelete.add(artifact);
2651
2652                 }
2653         }
2654
2655         private Map<GroupDefinition, Map<ArtifactDefinition, List<ArtifactDefinition>>> findMasterArtifactInGroup(List<GroupDefinition> groups, Map<String, ArtifactDefinition> deplymentArtifact) {
2656                 Map<GroupDefinition, Map<ArtifactDefinition, List<ArtifactDefinition>>> groupArtifact = new HashMap<GroupDefinition, Map<ArtifactDefinition, List<ArtifactDefinition>>>();
2657
2658                 for (GroupDefinition group : groups) {
2659                         Map<ArtifactDefinition, List<ArtifactDefinition>> gupsMap = new HashMap<ArtifactDefinition, List<ArtifactDefinition>>();
2660                         List<ArtifactDefinition> artifacts = new ArrayList<ArtifactDefinition>();
2661                         List<String> artifactsList = group.getArtifacts();
2662                         if (artifactsList != null && !artifactsList.isEmpty()) {
2663
2664                                 ArtifactDefinition masterArtifact = ArtifactUtils.findMasterArtifact(deplymentArtifact, artifacts, artifactsList);
2665                                 if (masterArtifact != null)
2666                                         gupsMap.put(masterArtifact, artifacts);
2667                                 groupArtifact.put(group, gupsMap);
2668
2669                         }
2670                 }
2671                 return groupArtifact;
2672         }
2673
2674         private void createArtifactsGroupSet(List<ArtifactTemplateInfo> parsedGroupTemplateList, Set<ArtifactTemplateInfo> parsedArtifactsName) {
2675
2676                 for (ArtifactTemplateInfo parsedGroupTemplate : parsedGroupTemplateList) {
2677                         parsedArtifactsName.add(parsedGroupTemplate);
2678                         List<ArtifactTemplateInfo> relatedArtifacts = parsedGroupTemplate.getRelatedArtifactsInfo();
2679                         if (relatedArtifacts != null && !relatedArtifacts.isEmpty()) {
2680                                 createArtifactsGroupSet(relatedArtifacts, parsedArtifactsName);
2681                         }
2682                 }
2683         }
2684
2685         public Either<Resource, ResponseFormat> createResourceArtifactsFromCsar(CsarInfo csarInfo, Resource resource, String artifactsMetaFile, String artifactsMetaFileName, List<ArtifactDefinition> createdArtifacts,
2686                         boolean shouldLock, boolean inTransaction) {
2687
2688                 log.debug("parseResourceArtifactsInfoFromFile start");
2689                 Either<Map<String, List<ArtifactTemplateInfo>>, ResponseFormat> parseResourceInfoFromYamlEither = parseResourceArtifactsInfoFromFile(resource, artifactsMetaFile, artifactsMetaFileName, csarInfo.getModifier());
2690                 if (parseResourceInfoFromYamlEither.isRight()) {
2691                         ResponseFormat responseFormat = parseResourceInfoFromYamlEither.right().value();
2692                         componentsUtils.auditResource(responseFormat, csarInfo.getModifier(), resource, "", "", AuditingActionEnum.IMPORT_RESOURCE, null);
2693                         return Either.right(responseFormat);
2694                 }
2695                 log.debug("parseResourceArtifactsInfoFromFile end");
2696
2697                 log.debug("createResourceArtifacts start");
2698                 Either<Resource, ResponseFormat> respStatus = createResourceArtifacts(csarInfo, resource, parseResourceInfoFromYamlEither.left().value(), AuditingActionEnum.CREATE_RESOURCE, createdArtifacts, shouldLock, inTransaction);
2699                 if (respStatus.isRight()) {
2700                         return respStatus;
2701                 }
2702                 log.debug("createResourceArtifacts end");
2703                 log.debug("getResource start");
2704                 Either<Resource, StorageOperationStatus> eitherGerResource = toscaOperationFacade.getToscaElement(resource.getUniqueId());
2705                 log.debug("getResource end");
2706                 if (eitherGerResource.isRight()) {
2707                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(eitherGerResource.right().value()), resource);
2708
2709                         return Either.right(responseFormat);
2710
2711                 }
2712                 return Either.left(eitherGerResource.left().value());
2713
2714         }
2715
2716         private Either<Resource, ResponseFormat> createGroupDeploymentArtifactsFromCsar(CsarInfo csarInfo, Resource resource, List<ArtifactTemplateInfo> artifactsTemplateList,
2717                         List<ArtifactDefinition> createdNewArtifacts, List<ArtifactDefinition> artifactsFromResource, int labelCounter, boolean shouldLock, boolean inTransaction) {
2718                 Either<Resource, ResponseFormat> resStatus = Either.left(resource);
2719                 List<GroupDefinition> createdGroups = resource.getGroups();
2720                 List<GroupDefinition> heatGroups = null;
2721                 if (createdGroups != null && !createdGroups.isEmpty()) {
2722                         heatGroups = createdGroups.stream().filter(e -> e.getMembers() != null).collect(Collectors.toList());
2723                 }
2724
2725                 List<GroupDefinition> needToAdd = new ArrayList<>();
2726                 for (ArtifactTemplateInfo groupTemplateInfo : artifactsTemplateList) {
2727                         String groupName = groupTemplateInfo.getGroupName();
2728                         Set<String> artifactsGroup = new HashSet<String>();
2729                         Set<String> artifactsUUIDGroup = new HashSet<String>();
2730
2731                         resStatus = createDeploymentArtifactsFromCsar(csarInfo, resource, artifactsGroup, artifactsUUIDGroup, groupTemplateInfo, createdNewArtifacts, artifactsFromResource, labelCounter, shouldLock, inTransaction);
2732                         if (resStatus.isRight())
2733                                 return resStatus;
2734                         if(groupName != null && !groupName.isEmpty()){
2735                                 Map<String, String> members = new HashMap<String, String>();
2736                                 associateMembersToArtifacts(createdNewArtifacts, artifactsFromResource, heatGroups, artifactsGroup, members);
2737         
2738                                 List<String> artifactsList = new ArrayList<String>(artifactsGroup);
2739                                 List<String> artifactsUUIDList = new ArrayList<String>(artifactsUUIDGroup);
2740         
2741                                 GroupDefinition groupDefinition = new GroupDefinition();
2742                                 groupDefinition.setName(groupName);
2743                                 groupDefinition.setType(Constants.DEFAULT_GROUP_VF_MODULE);
2744                                 groupDefinition.setArtifacts(artifactsList);
2745                                 groupDefinition.setArtifactsUuid(artifactsUUIDList);
2746         
2747                                 if (!members.isEmpty())
2748                                         groupDefinition.setMembers(members);
2749         
2750                                 List<GroupProperty> properties = new ArrayList<GroupProperty>();
2751                                 GroupProperty prop = new GroupProperty();
2752                                 prop.setName(Constants.IS_BASE);
2753                                 prop.setValue(Boolean.toString(groupTemplateInfo.isBase()));
2754                                 properties.add(prop);
2755         
2756                                 List<ArtifactDefinition> createdArtifacts = new ArrayList<>();
2757                                 createdArtifacts.addAll(createdNewArtifacts);
2758                                 createdArtifacts.addAll(artifactsFromResource);
2759                                 Either<GroupTypeDefinition, StorageOperationStatus> getLatestGroupTypeRes = groupTypeOperation.getLatestGroupTypeByType(Constants.DEFAULT_GROUP_VF_MODULE, true);
2760                                 if (getLatestGroupTypeRes.isRight()) {
2761                                         return Either.right(componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(getLatestGroupTypeRes.right().value())));
2762                                 }
2763                                 properties = createVfModuleAdditionalProperties(groupTemplateInfo.isBase(), groupName, properties, createdArtifacts, artifactsList, getLatestGroupTypeRes.left().value());
2764                                 groupDefinition.convertFromGroupProperties(properties); 
2765                                 
2766                                 needToAdd.add(groupDefinition);
2767                         }
2768                 }
2769                 ComponentParametersView componentParametersView = new ComponentParametersView();
2770                 componentParametersView.disableAll();
2771                 componentParametersView.setIgnoreArtifacts(false);
2772                 componentParametersView.setIgnoreGroups(false);
2773                 componentParametersView.setIgnoreComponentInstances(false);
2774
2775                 Either<Resource, StorageOperationStatus> component = toscaOperationFacade.getToscaElement(resource.getUniqueId(), componentParametersView);
2776                 if (component.isRight()) {
2777                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR));
2778                 }
2779                 resource = component.left().value();
2780
2781                 Either<List<GroupDefinition>, ResponseFormat> addGroups = groupBusinessLogic.addGroups(resource, csarInfo.getModifier(), ComponentTypeEnum.RESOURCE, needToAdd);
2782                 if (addGroups.isRight())
2783                         return Either.right(addGroups.right().value());
2784
2785                 return resStatus;
2786         }
2787
2788         private Either<Resource, ResponseFormat> createDeploymentArtifactsFromCsar(CsarInfo csarInfo, Resource resource, Set<String> artifactsGroup, Set<String> artifactsUUIDGroup,
2789                         ArtifactTemplateInfo artifactTemplateInfo, List<ArtifactDefinition> createdArtifacts, List<ArtifactDefinition> artifactsFromResource, int labelCounter, boolean shoudLock, boolean inTransaction) {
2790                 Either<Resource, ResponseFormat> resStatus = Either.left(resource);
2791                 String artifactFileName = artifactTemplateInfo.getFileName();
2792                 String artifactUid = "";
2793                 String artifactUUID = "";
2794                 String artifactEnvUid = "";
2795                 boolean alreadyExist = false;
2796
2797                 // check if artifacts already exist
2798                 if (artifactsFromResource != null && !artifactsFromResource.isEmpty()) {
2799                         for (ArtifactDefinition artifactFromResource : artifactsFromResource) {
2800                                 if (artifactFromResource.getArtifactName().equals(artifactFileName)) {
2801                                         artifactUid = artifactFromResource.getUniqueId();
2802                                         artifactUUID = artifactFromResource.getArtifactUUID();
2803                                         if (!artifactFromResource.getArtifactType().equalsIgnoreCase(artifactTemplateInfo.getType())) {
2804                                                 log.debug("Artifact with name {} and type {} already exist with type  {}", artifactFileName, artifactTemplateInfo.getType(), artifactFromResource.getArtifactType());
2805                                                 BeEcompErrorManager.getInstance().logInternalDataError("Artifact  file is not in expected formatr, fileName " + artifactFileName, "Artifact internals are invalid", ErrorSeverity.ERROR);
2806                                                 return Either.right(componentsUtils.getResponseFormat(ActionStatus.ARTIFACT_ALRADY_EXIST_IN_DIFFERENT_TYPE_IN_CSAR, artifactFileName, artifactTemplateInfo.getType(), artifactFromResource.getArtifactType()));
2807                                         }
2808                                         alreadyExist = true;
2809                                         artifactEnvUid = checkAndGetHeatEnvId(artifactFromResource);
2810                                         break;
2811                                 }
2812
2813                         }
2814
2815                 }
2816                 if (!alreadyExist) {
2817                         for (ArtifactDefinition createdArtifact : createdArtifacts) {
2818                                 if (createdArtifact.getArtifactName().equals(artifactFileName)) {
2819                                         artifactUid = createdArtifact.getUniqueId();
2820                                         artifactUUID = createdArtifact.getArtifactUUID();
2821
2822                                         if (!createdArtifact.getArtifactType().equalsIgnoreCase(artifactTemplateInfo.getType())) {
2823                                                 log.debug("Artifact with name {} and type {} already exist with type  {}", artifactFileName, artifactTemplateInfo.getType(), createdArtifact.getArtifactType());
2824                                                 BeEcompErrorManager.getInstance().logInternalDataError("Artifact  file is not in expected formatr, fileName " + artifactFileName, "Artifact internals are invalid", ErrorSeverity.ERROR);
2825                                                 return Either.right(componentsUtils.getResponseFormat(ActionStatus.ARTIFACT_ALRADY_EXIST_IN_DIFFERENT_TYPE_IN_CSAR, artifactFileName, artifactTemplateInfo.getType(), createdArtifact.getArtifactType()));
2826                                         }
2827                                         alreadyExist = true;
2828                                         artifactEnvUid = checkAndGetHeatEnvId(createdArtifact);
2829                                         break;
2830                                 }
2831
2832                         }
2833                 }
2834                 // if not exist need to create
2835                 if (!alreadyExist) {
2836
2837                         Either<ArtifactDefinition, ResponseFormat> newArtifactEither = createDeploymentArtifact(csarInfo, resource, ARTIFACTS_PATH, artifactTemplateInfo, createdArtifacts, labelCounter, shoudLock, inTransaction);
2838                         if (newArtifactEither.isRight()) {
2839                                 resStatus = Either.right(newArtifactEither.right().value());
2840                                 return resStatus;
2841                         }
2842                         ArtifactDefinition newArtifact = newArtifactEither.left().value();
2843                         artifactUid = newArtifact.getUniqueId();
2844                         artifactUUID = newArtifact.getArtifactUUID();
2845                         ArtifactTypeEnum artifactType = ArtifactTypeEnum.findType(newArtifact.getArtifactType());
2846                         if (artifactType == ArtifactTypeEnum.HEAT || artifactType == ArtifactTypeEnum.HEAT_NET || artifactType == ArtifactTypeEnum.HEAT_VOL) {
2847                                 Either<ArtifactDefinition, ResponseFormat> createHeatEnvPlaceHolder = artifactsBusinessLogic.createHeatEnvPlaceHolder(newArtifact, ArtifactsBusinessLogic.HEAT_VF_ENV_NAME, resource.getUniqueId(), NodeTypeEnum.Resource,
2848                                                 resource.getName(), csarInfo.getModifier(), resource, null);
2849                                 if (createHeatEnvPlaceHolder.isRight()) {
2850                                         return Either.right(createHeatEnvPlaceHolder.right().value());
2851                                 }
2852                                 artifactEnvUid = createHeatEnvPlaceHolder.left().value().getUniqueId();
2853                         }
2854                 }
2855
2856                 artifactsGroup.add(artifactUid);
2857                 artifactsUUIDGroup.add(artifactUUID);
2858                 if (!artifactEnvUid.isEmpty()) {
2859                         artifactsGroup.add(artifactEnvUid);
2860                 }
2861
2862                 List<ArtifactTemplateInfo> relatedArtifacts = artifactTemplateInfo.getRelatedArtifactsInfo();
2863                 if (relatedArtifacts != null) {
2864                         for (ArtifactTemplateInfo relatedArtifactTemplateInfo : relatedArtifacts) {
2865                                 resStatus = createDeploymentArtifactsFromCsar(csarInfo, resource, artifactsGroup, artifactsUUIDGroup, relatedArtifactTemplateInfo, createdArtifacts, artifactsFromResource, labelCounter, shoudLock, inTransaction);
2866                                 if (resStatus.isRight())
2867                                         return resStatus;
2868                         }
2869                 }
2870                 return resStatus;
2871         }
2872
2873         private Either<Resource, ResponseFormat> createResourceArtifacts(CsarInfo csarInfo, Resource resource, Map<String, List<ArtifactTemplateInfo>> artifactsMap, AuditingActionEnum createResource,
2874                         List<ArtifactDefinition> createdArtifacts, boolean shouldLock, boolean inTransaction) {
2875
2876                 Either<Resource, ResponseFormat> resStatus = Either.left(resource);
2877
2878                 Collection<List<ArtifactTemplateInfo>> arifactsCollection = artifactsMap.values();
2879
2880                 for (List<ArtifactTemplateInfo> groupTemplateList : arifactsCollection) {
2881                         if (groupTemplateList != null) {
2882                                 resStatus = createGroupDeploymentArtifactsFromCsar(csarInfo, resource, groupTemplateList, createdArtifacts, 0, shouldLock, inTransaction);
2883                                 if (resStatus.isRight())
2884                                         return resStatus;
2885                         }
2886                 }
2887
2888                 return resStatus;
2889
2890         }
2891
2892         private Either<Resource, ResponseFormat> createOrUpdateNonMetaArtifacts(CsarInfo csarInfo, Resource resource, List<ArtifactDefinition> createdArtifacts, boolean shouldLock, boolean inTransaction, ArtifactOperationInfo artifactOperation) {
2893
2894                 Either<Resource, ResponseFormat> resStatus = null;
2895                 Map<String, Set<List<String>>> collectedWarningMessages = new HashMap<>();
2896
2897                 try {
2898                         List<NonMetaArtifactInfo> artifactPathAndNameList =
2899                                         // Stream of file paths contained in csar
2900                                         csarInfo.getCsar().entrySet().stream()
2901                                                         // Filter in only VF artifact path location
2902                                                         .filter(e -> Pattern.compile(VF_NODE_TYPE_ARTIFACTS_PATH_PATTERN).matcher(e.getKey()).matches())
2903                                                         // Validate and add warnings
2904                                                         .map(e -> CsarUtils.validateNonMetaArtifact(e.getKey(), e.getValue(), collectedWarningMessages))
2905                                                         // Filter in Non Warnings
2906                                                         .filter(e -> e.isLeft())
2907                                                         // Convert from Either to NonMetaArtifactInfo
2908                                                         .map(e -> e.left().value())
2909                                                         // collect to List
2910                                                         .collect(Collectors.toList());
2911
2912                         Either<Boolean, String> responseFormatEither = validateArtifactNames(artifactPathAndNameList);
2913                         if (responseFormatEither.isRight()) {
2914                                 return Either.right(getComponentsUtils().getResponseFormatByArtifactId(ActionStatus.ARTIFACT_NAME_INVALID, responseFormatEither.right().value()));
2915                         }
2916
2917
2918                         EnumMap<ArtifactOperationEnum, List<NonMetaArtifactInfo>> vfCsarArtifactsToHandle = null;
2919
2920                         if (ArtifactOperationEnum.isCreateOrLink(artifactOperation.getArtifactOperationEnum())) {
2921                                 vfCsarArtifactsToHandle = new EnumMap<>(ArtifactOperationEnum.class);
2922                                 vfCsarArtifactsToHandle.put(artifactOperation.getArtifactOperationEnum(), artifactPathAndNameList);
2923                         } else {
2924                                 Either<EnumMap<ArtifactOperationEnum, List<NonMetaArtifactInfo>>, ResponseFormat> findVfCsarArtifactsToHandleRes = findVfCsarArtifactsToHandle(resource, artifactPathAndNameList, csarInfo.getModifier());
2925
2926                                 if (findVfCsarArtifactsToHandleRes.isRight()) {
2927                                         resStatus = Either.right(findVfCsarArtifactsToHandleRes.right().value());
2928                                 }
2929                                 if (resStatus == null) {
2930                                         vfCsarArtifactsToHandle = findVfCsarArtifactsToHandleRes.left().value();
2931                                 }
2932                         }
2933                         if (resStatus == null && vfCsarArtifactsToHandle != null) {
2934                                 for (Entry<ArtifactOperationEnum, List<NonMetaArtifactInfo>> currArtifactOperationPair : vfCsarArtifactsToHandle.entrySet()) {
2935
2936                                         Optional<ResponseFormat> optionalCreateInDBError =
2937                                                         // Stream of artifacts to be created
2938                                                         currArtifactOperationPair.getValue().stream()
2939                                                                         // create each artifact
2940                                                                         .map(e -> createOrUpdateSingleNonMetaArtifact(resource, csarInfo, e.getPath(), e.getArtifactName(), e.getArtifactType().getType(), e.getArtifactGroupType(), e.getArtifactLabel(), e.getDisplayName(),
2941                                                                                         CsarUtils.ARTIFACT_CREATED_FROM_CSAR, e.getArtifactUniqueId(), artifactsBusinessLogic.new ArtifactOperationInfo(false, false, currArtifactOperationPair.getKey()), createdArtifacts, shouldLock,
2942                                                                                         inTransaction))
2943                                                                         // filter in only error
2944                                                                         .filter(e -> e.isRight()).
2945                                                                         // Convert the error from either to ResponseFormat
2946                                                                         map(e -> e.right().value()).
2947                                                                         // Check if an error occurred
2948                                                                         findAny();
2949                                         // Error found on artifact Creation
2950                                         if (optionalCreateInDBError.isPresent()) {
2951                                                 resStatus = Either.right(optionalCreateInDBError.get());
2952                                                 break;
2953                                         }
2954                                 }
2955                         }
2956                         if (resStatus == null) {
2957                                 resStatus = Either.left(resource);
2958                         }
2959                 } catch (Exception e) {
2960                         resStatus = Either.right(componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR));
2961                         log.debug("Exception occured in createNonMetaArtifacts, message:{}", e.getMessage(), e);
2962                 } finally {
2963                         CsarUtils.handleWarningMessages(collectedWarningMessages);
2964                 }
2965                 return resStatus;
2966         }
2967
2968         private Either<Boolean, String> validateArtifactNames(List<NonMetaArtifactInfo> artifactPathAndNameList) {
2969                 Pattern englishNumbersAndUnderScoresOnly = Pattern.compile(CsarUtils.VALID_ENGLISH_ARTIFACT_NAME);
2970                 for (NonMetaArtifactInfo nonMetaArtifactInfo : artifactPathAndNameList) {
2971                         if (!englishNumbersAndUnderScoresOnly.matcher(nonMetaArtifactInfo.getDisplayName()).matches()) {
2972                                 return Either.right(nonMetaArtifactInfo.getArtifactName());
2973                         }
2974                 }
2975                 return Either.left(true);
2976         }
2977
2978
2979         private Either<EnumMap<ArtifactOperationEnum, List<NonMetaArtifactInfo>>, ResponseFormat> findVfCsarArtifactsToHandle(Resource resource, List<NonMetaArtifactInfo> artifactPathAndNameList, User user) {
2980
2981                 List<ArtifactDefinition> existingArtifacts = new ArrayList<>();
2982                 // collect all Deployment and Informational artifacts of VF
2983                 if (resource.getDeploymentArtifacts() != null && !resource.getDeploymentArtifacts().isEmpty()) {
2984                         existingArtifacts.addAll(resource.getDeploymentArtifacts().values());
2985                 }
2986                 if (resource.getArtifacts() != null && !resource.getArtifacts().isEmpty()) {
2987                         existingArtifacts.addAll(resource.getArtifacts().values());
2988                 }
2989                 existingArtifacts = existingArtifacts.stream()
2990                                 // filter MANDATORY artifacts, LICENSE artifacts and artifacts was created from HEAT.meta
2991                                 .filter(this::isNonMetaArtifact).collect(Collectors.toList());
2992
2993                 List<String> artifactsToIgnore = new ArrayList<>();
2994                 // collect IDs of Artifacts of VF which belongs to any group
2995                 if (resource.getGroups() != null) {
2996                         resource.getGroups().stream().forEach(g -> {
2997                                 if (g.getArtifacts() != null && !g.getArtifacts().isEmpty())
2998                                         artifactsToIgnore.addAll(g.getArtifacts());
2999                         });
3000                 }
3001                 existingArtifacts = existingArtifacts.stream()
3002                                 // filter artifacts which belongs to any group
3003                                 .filter(a -> !artifactsToIgnore.contains(a.getUniqueId())).collect(Collectors.toList());
3004                 return organizeVfCsarArtifactsByArtifactOperation(artifactPathAndNameList, existingArtifacts, resource, user);
3005         }
3006
3007         private boolean isNonMetaArtifact(ArtifactDefinition artifact) {
3008                 boolean result = true;
3009                 if (artifact.getMandatory() || artifact.getArtifactName() == null || !isValidArtifactType(artifact)) {
3010                         result = false;
3011                 }
3012                 return result;
3013         }
3014
3015         private boolean isValidArtifactType(ArtifactDefinition artifact) {
3016                 boolean result = true;
3017                 if (artifact.getArtifactType() == null || ArtifactTypeEnum.findType(artifact.getArtifactType()) == ArtifactTypeEnum.VENDOR_LICENSE || ArtifactTypeEnum.findType(artifact.getArtifactType()) == ArtifactTypeEnum.VF_LICENSE) {
3018                         result = false;
3019                 }
3020                 return result;
3021         }
3022
3023         private Either<Resource, ResponseFormat> createGroupDeploymentArtifactsFromCsar(CsarInfo csarInfo, Resource resource, List<ArtifactTemplateInfo> artifactsTemplateList, List<ArtifactDefinition> createdArtifacts,
3024                         int labelCounter, boolean shouldLock, boolean inTransaction) {
3025                 Either<Resource, ResponseFormat> resStatus = Either.left(resource);
3026                 List<GroupDefinition> createdGroups = resource.getGroups();
3027                 List<GroupDefinition> heatGroups = null;
3028                 if (createdGroups != null && !createdGroups.isEmpty()) {
3029
3030                         // List<IArtifactInfo> collect = resources.stream().flatMap( e ->
3031                         // e.getArtifacts().stream()).filter(p ->
3032                         // relevantArtifactTypes.contains(p.getArtifactType()
3033                         // )).collect(Collectors.toList());
3034                         // List<GroupDefinition> heatGroups = createdGroups.stream().filter(
3035                         // e -> e.getProperties().stream().filter(p ->
3036                         // p.getName().contains(Constants.HEAT_FILE_PROPS))).collect(Collectors.toList());
3037                         heatGroups = createdGroups.stream().filter(e -> e.getMembers() != null).collect(Collectors.toList());
3038                         ;
3039                 }
3040                 List<GroupDefinition> needToCreate = new ArrayList<>();
3041                 for (ArtifactTemplateInfo groupTemplateInfo : artifactsTemplateList) {
3042                         String groupName = groupTemplateInfo.getGroupName();
3043                         Set<String> artifactsGroup = new HashSet<String>();
3044                         Set<String> artifactsUUIDGroup = new HashSet<String>();
3045
3046                         log.debug("createDeploymentArtifactsFromCsar start");
3047                         resStatus = createDeploymentArtifactFromCsar(csarInfo, ARTIFACTS_PATH, resource, artifactsGroup, artifactsUUIDGroup, groupTemplateInfo, createdArtifacts, labelCounter, shouldLock, inTransaction);
3048                         log.debug("createDeploymentArtifactsFromCsar end");
3049                         if (resStatus.isRight())
3050                                 return resStatus;
3051                         if(groupName != null && !groupName.isEmpty()){
3052                                 Map<String, String> members = new HashMap<String, String>();
3053                                 associateMembersToArtifacts(createdArtifacts, null, heatGroups, artifactsGroup, members);
3054         
3055                                 List<String> artifactsList = new ArrayList<String>(artifactsGroup);
3056                                 List<String> artifactsUUIDList = new ArrayList<String>(artifactsUUIDGroup);
3057         
3058                                 GroupDefinition groupDefinition = new GroupDefinition();
3059                                 groupDefinition.setName(groupName);
3060                                 groupDefinition.setType(Constants.DEFAULT_GROUP_VF_MODULE);
3061                                 groupDefinition.setArtifacts(artifactsList);
3062                                 groupDefinition.setArtifactsUuid(artifactsUUIDList);
3063         
3064                                 if (!members.isEmpty())
3065                                         groupDefinition.setMembers(members);
3066                                 List<GroupProperty> properties = new ArrayList<GroupProperty>();
3067                                 GroupProperty prop = new GroupProperty();
3068                                 prop.setName(Constants.IS_BASE);
3069                                 prop.setValue(Boolean.toString(groupTemplateInfo.isBase()));
3070                                 properties.add(prop);
3071                                 Either<GroupTypeDefinition, StorageOperationStatus> getLatestGroupTypeRes = groupTypeOperation.getLatestGroupTypeByType(Constants.DEFAULT_GROUP_VF_MODULE, true);
3072                                 if (getLatestGroupTypeRes.isRight()) {
3073                                         return Either.right(componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(getLatestGroupTypeRes.right().value())));
3074                                 }
3075                                 properties = createVfModuleAdditionalProperties(groupTemplateInfo.isBase(), groupName, properties, createdArtifacts, artifactsList, getLatestGroupTypeRes.left().value());
3076                                 groupDefinition.convertFromGroupProperties(properties);
3077                                 log.debug("createGroup start");
3078         
3079                                 needToCreate.add(groupDefinition);
3080                         }
3081                 }
3082
3083                 ComponentParametersView componentParametersView = new ComponentParametersView();
3084                 componentParametersView.disableAll();
3085                 componentParametersView.setIgnoreUsers(false);
3086                 componentParametersView.setIgnoreArtifacts(false);
3087                 componentParametersView.setIgnoreGroups(false);
3088
3089                 componentParametersView.setIgnoreComponentInstances(false);
3090
3091                 Either<Resource, StorageOperationStatus> component = toscaOperationFacade.getToscaElement(resource.getUniqueId(), componentParametersView);
3092                 if (component.isRight()) {
3093                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR));
3094                 }
3095
3096                 Either<List<GroupDefinition>, ResponseFormat> createGroups = groupBusinessLogic.addGroups(component.left().value(), csarInfo.getModifier(), ComponentTypeEnum.RESOURCE, needToCreate);
3097                 if (createGroups.isRight()) {
3098                         return Either.right(createGroups.right().value());
3099                 }
3100
3101                 return resStatus;
3102         }
3103
3104         public List<GroupProperty> createVfModuleAdditionalProperties(boolean isBase, String moduleName, List<GroupProperty> properties, List<ArtifactDefinition> deploymentArtifacts, List<String> artifactsInGroup, GroupTypeDefinition groupType) {
3105                 Map<String, VfModuleProperty> vfModuleProperties = ConfigurationManager.getConfigurationManager().getConfiguration().getVfModuleProperties();
3106                 vfModuleProperties.entrySet().forEach(p -> {
3107                         GroupProperty prop = new GroupProperty();
3108                         prop.setName(p.getKey());
3109                         if (isBase) {
3110                                 prop.setValue(p.getValue().getForBaseModule());
3111                                 prop.setDefaultValue(p.getValue().getForBaseModule());
3112                         } else {
3113                                 prop.setValue(p.getValue().getForNonBaseModule());
3114                                 prop.setDefaultValue(p.getValue().getForNonBaseModule());
3115                         }
3116                         properties.add(prop);
3117
3118                 });
3119                 GroupProperty proplabel = new GroupProperty();
3120                 proplabel.setName("vf_module_label");
3121
3122                 Matcher matcher = pattern.matcher(moduleName);
3123
3124                 if (matcher.find()) {
3125                         proplabel.setValue(matcher.group(1));
3126                         proplabel.setDefaultValue(matcher.group(1));
3127                 } else {
3128                         proplabel.setValue(moduleName);
3129                         proplabel.setDefaultValue(moduleName);
3130                 }
3131                 properties.add(proplabel);
3132
3133                 GroupProperty propvolume = new GroupProperty();
3134                 propvolume.setName("volume_group");
3135                 boolean isVolume = false;
3136                 for (String artifactId : artifactsInGroup) {
3137                         ArtifactDefinition artifactDef = null;
3138                         artifactDef = findArtifactInList(deploymentArtifacts, artifactId);
3139                         if (artifactDef != null && artifactDef.getArtifactType().equalsIgnoreCase(ArtifactTypeEnum.HEAT_VOL.getType())) {
3140                                 isVolume = true;
3141                                 break;
3142                         }
3143                 }
3144                 propvolume.setValue(String.valueOf(isVolume));
3145                 propvolume.setDefaultValue(String.valueOf(isVolume));
3146                 properties.add(propvolume);
3147                 mergeWithGroupTypeProperties(properties, groupType.getProperties());
3148                 return properties;
3149         }
3150
3151         private void mergeWithGroupTypeProperties(List<GroupProperty> properties, List<PropertyDefinition> groupTypeProperties) {
3152
3153                 Map<String, GroupProperty> propertiesMap = properties.stream().collect(Collectors.toMap(p -> p.getName(), p -> p));
3154                 for (PropertyDefinition groupTypeProperty : groupTypeProperties) {
3155                         if (!propertiesMap.containsKey(groupTypeProperty.getName())) {
3156                                 properties.add(new GroupProperty(groupTypeProperty));
3157                         }
3158                 }
3159         }
3160
3161         private ArtifactDefinition findArtifactInList(List<ArtifactDefinition> createdArtifacts, String artifactId) {
3162                 for (ArtifactDefinition artifact : createdArtifacts) {
3163                         if (artifact.getUniqueId().equals(artifactId)) {
3164                                 return artifact;
3165                         }
3166                 }
3167                 return null;
3168         }
3169
3170         private void associateMembersToArtifacts(List<ArtifactDefinition> createdArtifacts, List<ArtifactDefinition> artifactsFromResource, List<GroupDefinition> heatGroups, Set<String> artifactsGroup, Map<String, String> members) {
3171                 if (heatGroups != null && !heatGroups.isEmpty()) {
3172                         for (GroupDefinition heatGroup : heatGroups) {
3173                                 List<GroupProperty> grpoupProps = heatGroup.convertToGroupProperties();
3174                                 if (grpoupProps != null) {
3175                                         Optional<GroupProperty> op = grpoupProps.stream().filter(p -> p.getName().equals(Constants.HEAT_FILE_PROPS)).findAny();
3176                                         if (op.isPresent()) {
3177                                                 GroupProperty prop = op.get();
3178                                                 String heatFileNAme = prop.getValue();
3179                                                 if (null == heatFileNAme || heatFileNAme.isEmpty())
3180                                                         continue;
3181                                                 List<ArtifactDefinition> artifacts = new ArrayList<ArtifactDefinition>();
3182                                                 for (String artifactId : artifactsGroup) {
3183                                                         Optional<ArtifactDefinition> opArt = createdArtifacts.stream().filter(p -> p.getUniqueId().equals(artifactId)).findAny();
3184                                                         if (opArt.isPresent()) {
3185                                                                 artifacts.add(opArt.get());
3186                                                         }
3187                                                         if (artifactsFromResource != null) {
3188                                                                 opArt = artifactsFromResource.stream().filter(p -> p.getUniqueId().equals(artifactId)).findAny();
3189                                                                 if (opArt.isPresent()) {
3190                                                                         artifacts.add(opArt.get());
3191                                                                 }
3192                                                         }
3193                                                 }
3194                                                 Optional<ArtifactDefinition> resOp = artifacts.stream().filter(p -> heatFileNAme.contains(p.getArtifactName())).findAny();
3195                                                 if (resOp.isPresent()) {
3196                                                         members.putAll(heatGroup.getMembers());
3197                                                 }
3198                                         }
3199                                 }
3200                         }
3201
3202                 }
3203         }
3204
3205         private Either<Resource, ResponseFormat> createDeploymentArtifactFromCsar(CsarInfo csarInfo, String artifactPath, Resource resource, Set<String> artifactsGroup, Set<String> artifactsUUIDGroup,
3206                         ArtifactTemplateInfo artifactTemplateInfo, List<ArtifactDefinition> createdArtifacts, int labelCounter, boolean shoudLock, boolean inTransaction) {
3207                 Either<Resource, ResponseFormat> resStatus = Either.left(resource);
3208                 String artifactFileName = artifactTemplateInfo.getFileName();
3209                 String artifactUid = "";
3210                 String artifactEnvUid = "";
3211                 String artifactUUID = "";
3212                 boolean alreadyExist = false;
3213
3214                 // check if artifacts already exist
3215                 for (ArtifactDefinition createdArtifact : createdArtifacts) {
3216                         if (createdArtifact.getArtifactName().equals(artifactFileName)) {
3217                                 artifactUid = createdArtifact.getUniqueId();
3218                                 artifactUUID = createdArtifact.getArtifactUUID();
3219                                 if (!createdArtifact.getArtifactType().equalsIgnoreCase(artifactTemplateInfo.getType())) {
3220                                         log.debug("Artifact with name {} and type {} already exist with type  {}", artifactFileName, artifactTemplateInfo.getType(), createdArtifact.getArtifactType());
3221                                         BeEcompErrorManager.getInstance().logInternalDataError("Artifact  file is not in expected formatr, fileName " + artifactFileName, "Artifact internals are invalid", ErrorSeverity.ERROR);
3222                                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.ARTIFACT_ALRADY_EXIST_IN_DIFFERENT_TYPE_IN_CSAR, artifactFileName, artifactTemplateInfo.getType(), createdArtifact.getArtifactType()));
3223                                 }
3224                                 alreadyExist = true;
3225                                 artifactEnvUid = checkAndGetHeatEnvId(createdArtifact);
3226                                 break;
3227                         }
3228                 }
3229                 // if not exist need to create
3230                 if (!alreadyExist) {
3231
3232                         Either<ArtifactDefinition, ResponseFormat> newArtifactEither = createDeploymentArtifact(csarInfo, resource, artifactPath, artifactTemplateInfo, createdArtifacts, labelCounter, shoudLock, inTransaction);
3233                         if (newArtifactEither.isRight()) {
3234                                 resStatus = Either.right(newArtifactEither.right().value());
3235                                 return resStatus;
3236                         }
3237                         ArtifactDefinition newArtifact = newArtifactEither.left().value();
3238                         artifactUid = newArtifact.getUniqueId();
3239                         artifactUUID = newArtifact.getArtifactUUID();
3240
3241                         ArtifactTypeEnum artifactType = ArtifactTypeEnum.findType(newArtifact.getArtifactType());
3242                         if (artifactType == ArtifactTypeEnum.HEAT || artifactType == ArtifactTypeEnum.HEAT_NET || artifactType == ArtifactTypeEnum.HEAT_VOL) {
3243                                 Either<ArtifactDefinition, ResponseFormat> createHeatEnvPlaceHolder = artifactsBusinessLogic.createHeatEnvPlaceHolder(newArtifact, ArtifactsBusinessLogic.HEAT_VF_ENV_NAME, resource.getUniqueId(), NodeTypeEnum.Resource,
3244                                                 resource.getName(), csarInfo.getModifier(), resource, null);
3245                                 if (createHeatEnvPlaceHolder.isRight()) {
3246                                         return Either.right(createHeatEnvPlaceHolder.right().value());
3247                                 }
3248                                 artifactEnvUid = createHeatEnvPlaceHolder.left().value().getUniqueId();
3249                         }
3250                 }
3251
3252                 artifactsGroup.add(artifactUid);
3253                 artifactsUUIDGroup.add(artifactUUID);
3254                 if (!artifactEnvUid.isEmpty()) {
3255                         artifactsGroup.add(artifactEnvUid);
3256                 }
3257
3258                 List<ArtifactTemplateInfo> relatedArtifacts = artifactTemplateInfo.getRelatedArtifactsInfo();
3259                 if (relatedArtifacts != null) {
3260                         for (ArtifactTemplateInfo relatedArtifactTemplateInfo : relatedArtifacts) {
3261                                 resStatus = createDeploymentArtifactFromCsar(csarInfo, artifactPath, resource, artifactsGroup, artifactsUUIDGroup, relatedArtifactTemplateInfo, createdArtifacts, labelCounter, shoudLock, inTransaction);
3262                                 if (resStatus.isRight())
3263                                         return resStatus;
3264                         }
3265                 }
3266                 return resStatus;
3267         }
3268
3269         private String checkAndGetHeatEnvId(ArtifactDefinition createdArtifact) {
3270                 String artifactEnvUid = "";
3271                 ArtifactTypeEnum artifactType = ArtifactTypeEnum.findType(createdArtifact.getArtifactType());
3272                 if (artifactType == ArtifactTypeEnum.HEAT || artifactType == ArtifactTypeEnum.HEAT_NET || artifactType == ArtifactTypeEnum.HEAT_VOL) {
3273                         artifactEnvUid = createdArtifact.getUniqueId() + ArtifactsBusinessLogic.HEAT_ENV_SUFFIX;
3274                 }
3275                 return artifactEnvUid;
3276         }
3277
3278         private Either<ArtifactDefinition, ResponseFormat> createDeploymentArtifact(CsarInfo csarInfo, Resource resource, String artifactPath, ArtifactTemplateInfo artifactTemplateInfo,
3279                         List<ArtifactDefinition> createdArtifacts, int labelCounter, boolean shoudLock, boolean inTransaction) {
3280                 final String artifactFileName = artifactTemplateInfo.getFileName();
3281                 Either<ImmutablePair<String, byte[]>, ResponseFormat> artifactContententStatus = CsarValidationUtils.getArtifactsContent(csarInfo.getCsarUUID(), csarInfo.getCsar(), artifactPath + artifactFileName, artifactFileName, componentsUtils);
3282                 if (artifactContententStatus.isRight()) {
3283                         return Either.right(artifactContententStatus.right().value());
3284                 }
3285                 labelCounter += createdArtifacts.size();
3286
3287                 Map<String, Object> json = buildJsonForArtifact(artifactTemplateInfo, artifactContententStatus.left().value().getValue(), labelCounter);
3288
3289                 Either<Either<ArtifactDefinition, Operation>, ResponseFormat> uploadArtifactToService = createOrUpdateCsarArtifactFromJson(resource, csarInfo.getModifier(), json, artifactsBusinessLogic.new ArtifactOperationInfo(false, false, ArtifactOperationEnum.Create),
3290                                 shoudLock, inTransaction);
3291
3292                 if (uploadArtifactToService.isRight())
3293                         return Either.right(uploadArtifactToService.right().value());
3294
3295                 ArtifactDefinition currentInfo = uploadArtifactToService.left().value().left().value();
3296                 if (currentInfo.getHeatParameters() != null) {
3297
3298                         Either<ArtifactDefinition, ResponseFormat> updateEnvEither = updateHeatParamsFromCsar(resource, csarInfo, artifactTemplateInfo, currentInfo, false);
3299                         if (updateEnvEither.isRight()) {
3300                                 log.debug("failed to update parameters to artifact {}", artifactFileName);
3301                                 return Either.right(updateEnvEither.right().value());
3302
3303                         }
3304                         currentInfo = updateEnvEither.left().value();
3305
3306                 }
3307
3308                 createdArtifacts.add(currentInfo);
3309
3310                 return Either.left(currentInfo);
3311
3312         }
3313
3314         private Either<ArtifactDefinition, ResponseFormat> updateDeploymentArtifactsFromCsar(CsarInfo csarInfo, Resource resource, ArtifactDefinition oldArtifact, ArtifactTemplateInfo artifactTemplateInfo,
3315                         List<ArtifactDefinition> updatedArtifacts, List<ArtifactTemplateInfo> updatedRequiredArtifacts, boolean shouldLock, boolean inTransaction) {
3316
3317                 Either<ArtifactDefinition, ResponseFormat> resStatus = null;
3318                 String artifactFileName = artifactTemplateInfo.getFileName();
3319
3320                 // check if artifacts already exist
3321                 for (ArtifactDefinition updatedArtifact : updatedArtifacts) {
3322                         if (updatedArtifact.getArtifactName().equals(artifactFileName)) {
3323                                 if (!updatedArtifact.getArtifactType().equalsIgnoreCase(artifactTemplateInfo.getType())) {
3324                                         log.debug("Artifact with name {} and type {} already updated with type  {}", artifactFileName, artifactTemplateInfo.getType(), updatedArtifact.getArtifactType());
3325                                         BeEcompErrorManager.getInstance().logInternalDataError("Artifact  file is not in expected formatr, fileName " + artifactFileName, "Artifact internals are invalid", ErrorSeverity.ERROR);
3326                                         resStatus = Either.right(componentsUtils.getResponseFormat(ActionStatus.ARTIFACT_ALRADY_EXIST_IN_DIFFERENT_TYPE_IN_CSAR, artifactFileName, artifactTemplateInfo.getType(), updatedArtifact.getArtifactType()));
3327                                         return resStatus;
3328                                 }
3329                                 resStatus = Either.left(updatedArtifact);
3330                                 return resStatus;
3331                         }
3332
3333                 }
3334
3335                 Either<ImmutablePair<String, byte[]>, ResponseFormat> artifactContententStatus = CsarValidationUtils.getArtifactsContent(csarInfo.getCsarUUID(), csarInfo.getCsar(), CsarUtils.ARTIFACTS_PATH + artifactFileName, artifactFileName, componentsUtils);
3336                 if (artifactContententStatus.isRight()) {
3337                         resStatus = Either.right(artifactContententStatus.right().value());
3338                         return resStatus;
3339                 }
3340
3341                 Map<String, Object> json = buildJsonForUpdateArtifact(oldArtifact.getUniqueId(), artifactFileName, oldArtifact.getArtifactType(), ArtifactGroupTypeEnum.DEPLOYMENT, oldArtifact.getArtifactLabel(), oldArtifact.getArtifactDisplayName(),
3342                                 oldArtifact.getDescription(), artifactContententStatus.left().value().getRight(), updatedRequiredArtifacts);
3343
3344                 Either<Either<ArtifactDefinition, Operation>, ResponseFormat> uploadArtifactToService = createOrUpdateCsarArtifactFromJson(resource, csarInfo.getModifier(), json, artifactsBusinessLogic.new ArtifactOperationInfo(false, false, ArtifactOperationEnum.Update),
3345                                 shouldLock, inTransaction);
3346
3347                 if (uploadArtifactToService.isRight()) {
3348                         resStatus = Either.right(uploadArtifactToService.right().value());
3349                         return resStatus;
3350                 }
3351                 ArtifactDefinition currentInfo = uploadArtifactToService.left().value().left().value();
3352                 updatedArtifacts.add(currentInfo);
3353
3354                 Either<ArtifactDefinition, ResponseFormat> updateEnvEither = updateHeatParamsFromCsar(resource, csarInfo, artifactTemplateInfo, currentInfo, true);
3355                 if (updateEnvEither.isRight()) {
3356                         log.debug("failed to update parameters to artifact {}", artifactFileName);
3357                         resStatus = Either.right(updateEnvEither.right().value());
3358                         return resStatus;
3359                 }
3360                 // TODO evg update env time ( must be separate US for this!!!!)
3361
3362                 updatedArtifacts.add(updateEnvEither.left().value());
3363                 resStatus = Either.left(currentInfo);
3364
3365                 return resStatus;
3366
3367         }
3368
3369         private Either<ArtifactDefinition, ResponseFormat> updateHeatParamsFromCsar(Resource resource, CsarInfo csarInfo, ArtifactTemplateInfo artifactTemplateInfo, ArtifactDefinition currentInfo, boolean isUpdateEnv) {
3370                 Either<ArtifactDefinition, ResponseFormat> resStatus = Either.left(currentInfo);
3371                 if (artifactTemplateInfo.getEnv() != null && !artifactTemplateInfo.getEnv().isEmpty()) {
3372
3373                         Either<ImmutablePair<String, byte[]>, ResponseFormat> artifactparamsStatus = CsarValidationUtils.getArtifactsContent(csarInfo.getCsarUUID(), csarInfo.getCsar(), CsarUtils.ARTIFACTS_PATH + artifactTemplateInfo.getEnv(), artifactTemplateInfo.getEnv(),
3374                                         componentsUtils);
3375                         if (artifactparamsStatus.isRight()) {
3376                                 resStatus = Either.right(artifactparamsStatus.right().value());
3377                                 return resStatus;
3378                         }
3379                         Either<List<HeatParameterDefinition>, ResponseFormat> propsStatus = extractHeatParameters(ArtifactTypeEnum.HEAT_ENV.getType(), artifactTemplateInfo.getEnv(), artifactparamsStatus.left().value().getValue(), false);
3380                         
3381                         if (propsStatus.isLeft()) {
3382                                 List<HeatParameterDefinition> updatedHeatEnvParams = propsStatus.left().value();
3383                                 List<HeatParameterDefinition> currentHeatEnvParams = currentInfo.getListHeatParameters();
3384                                 // List<HeatParameterDefinition> newHeatEnvParams = new ArrayList<HeatParameterDefinition>();
3385
3386                                 if (updatedHeatEnvParams != null && !updatedHeatEnvParams.isEmpty() && currentHeatEnvParams != null && !currentHeatEnvParams.isEmpty()) {
3387
3388                                         String paramName;
3389                                         for (HeatParameterDefinition heatEnvParam : updatedHeatEnvParams) {
3390
3391                                                 paramName = heatEnvParam.getName();
3392                                                 for (HeatParameterDefinition currHeatParam : currentHeatEnvParams) {
3393                                                         if (paramName.equalsIgnoreCase(currHeatParam.getName())) {
3394
3395                                                                 String updatedParamValue = heatEnvParam.getCurrentValue();
3396                                                                 if (updatedParamValue == null)
3397                                                                         updatedParamValue = heatEnvParam.getDefaultValue();
3398                                                                 HeatParameterType paramType = HeatParameterType.isValidType(currHeatParam.getType());
3399                                                                 if (!paramType.getValidator().isValid(updatedParamValue, null)) {
3400                                                                         ActionStatus status = ActionStatus.INVALID_HEAT_PARAMETER_VALUE;
3401                                                                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(status, ArtifactTypeEnum.HEAT_ENV.getType(), paramType.getType(), paramName);
3402                                                                         resStatus = Either.right(responseFormat);
3403                                                                         return resStatus;
3404                                                                 }
3405                                                                 currHeatParam.setCurrentValue(paramType.getConverter().convert(updatedParamValue, null, null));
3406                                                                 // newHeatEnvParams.add(currHeatParam);
3407                                                                 break;
3408                                                         }
3409                                                 }
3410                                         }
3411                                         currentInfo.setListHeatParameters(currentHeatEnvParams);
3412                                         Either<ArtifactDefinition, StorageOperationStatus> updateArifactOnResource = artifactToscaOperation.updateArifactOnResource(currentInfo, resource.getUniqueId(), currentInfo.getUniqueId(), null, null);
3413                                         if (updateArifactOnResource.isRight()) {
3414                                                 log.debug("Failed to update heat paratemers of heat on CSAR flow for component {} artifact {} label {}", resource.getUniqueId(), currentInfo.getUniqueId(), currentInfo.getArtifactLabel());
3415                                                 return Either.right(componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(updateArifactOnResource.right().value())));
3416                                         }
3417                                         resStatus = Either.left(updateArifactOnResource.left().value());
3418                                 }
3419                         }
3420                 }
3421                 if (isUpdateEnv) {
3422                         ComponentParametersView parametersView = new ComponentParametersView();
3423                         parametersView.disableAll();
3424                         parametersView.setIgnoreComponentInstances(false);
3425                         parametersView.setIgnoreUsers(false);
3426                         parametersView.setIgnoreArtifacts(false);
3427                         parametersView.setIgnoreGroups(false);
3428
3429                         Either<Resource, StorageOperationStatus> eitherGerResource = toscaOperationFacade.getToscaElement(resource.getUniqueId(), parametersView);
3430
3431                         if (eitherGerResource.isRight()) {
3432                                 ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(eitherGerResource.right().value()), resource);
3433
3434                                 resStatus = Either.right(responseFormat);
3435                                 return resStatus;
3436
3437                         }
3438                         resource = eitherGerResource.left().value();
3439                         Map<String, ArtifactDefinition> artifacts = resource.getDeploymentArtifacts();
3440                         Optional<ArtifactDefinition> op = artifacts.values().stream().filter(p -> p.getGeneratedFromId() != null && p.getGeneratedFromId().equals(currentInfo.getUniqueId())).findAny();
3441                         if (op.isPresent()) {
3442                                 ArtifactDefinition artifactInfoHeatEnv = op.get();
3443                                 Either<ArtifactDefinition, StorageOperationStatus> updateArifactOnResource = artifactToscaOperation.updateArifactOnResource(artifactInfoHeatEnv, resource.getUniqueId(), artifactInfoHeatEnv.getUniqueId(), null, null);
3444                                 if (updateArifactOnResource.isRight()) {
3445                                         log.debug("Failed to update heat env on CSAR flow for component {} artifact {} label {}", resource.getUniqueId(), artifactInfoHeatEnv.getUniqueId(), artifactInfoHeatEnv.getArtifactLabel());
3446                                         return Either.right(componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(updateArifactOnResource.right().value())));
3447                                 }
3448                                 resStatus = Either.left(updateArifactOnResource.left().value());
3449                         }
3450                 }
3451                 return resStatus;
3452         }
3453
3454         private Either<List<HeatParameterDefinition>, ResponseFormat> extractHeatParameters(String artifactType, String fileName, byte[] content, boolean is64Encoded) {
3455                 // extract heat parameters
3456                 String heatDecodedPayload = is64Encoded ? new String(Base64.decodeBase64(content)) : new String(content);
3457                 Either<List<HeatParameterDefinition>, ResultStatusEnum> heatParameters = ImportUtils.getHeatParamsWithoutImplicitTypes(heatDecodedPayload, artifactType);
3458                 if (heatParameters.isRight()) {
3459                         log.debug("File {} is not in expected key-value form in csar ", fileName);
3460                         BeEcompErrorManager.getInstance().logInternalDataError("File " + fileName + " is not in expected key-value form in csar ", "CSAR internals are invalid", ErrorSeverity.ERROR);
3461                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.INVALID_DEPLOYMENT_ARTIFACT_HEAT, fileName));
3462
3463                 }
3464                 return Either.left(heatParameters.left().value());
3465
3466         }
3467
3468         private Map<String, Object> buildJsonForArtifact(ArtifactTemplateInfo artifactTemplateInfo, byte[] artifactContentent, int atrifactLabelCounter) {
3469
3470                 Map<String, Object> json = new HashMap<String, Object>();
3471                 String artifactName = artifactTemplateInfo.getFileName();
3472
3473                 json.put(Constants.ARTIFACT_NAME, artifactTemplateInfo.getFileName());
3474                 json.put(Constants.ARTIFACT_TYPE, artifactTemplateInfo.getType());
3475                 json.put(Constants.ARTIFACT_DESCRIPTION, "created from csar");
3476
3477                 // DE250204: There is no need to check if base64 encoding.
3478
3479                 // String encodedPayload = new String(artifactContentent);
3480                 // boolean isEncoded = GeneralUtility.isBase64Encoded(artifactContentent);
3481                 // if (!isEncoded) {
3482                 String encodedPayload = Base64.encodeBase64String(artifactContentent);
3483                 // }
3484                 json.put(Constants.ARTIFACT_PAYLOAD_DATA, encodedPayload);
3485                 String displayName = artifactName;
3486                 if (artifactName.lastIndexOf(".") > 0)
3487                         displayName = artifactName.substring(0, artifactName.lastIndexOf("."));
3488                 json.put(Constants.ARTIFACT_DISPLAY_NAME, displayName);
3489                 String label = ValidationUtils.normalizeArtifactLabel(artifactTemplateInfo.getType() + atrifactLabelCounter);
3490                 json.put(Constants.ARTIFACT_LABEL, label);
3491                 json.put(Constants.ARTIFACT_GROUP_TYPE, ArtifactGroupTypeEnum.DEPLOYMENT.getType());
3492                 List<ArtifactTemplateInfo> requiredArtifacts = artifactTemplateInfo.getRelatedArtifactsInfo();
3493                 json.put(Constants.REQUIRED_ARTIFACTS, (requiredArtifacts == null || requiredArtifacts.isEmpty()) ? new ArrayList<>()
3494                                 : requiredArtifacts.stream().filter(e -> e.getType().equals(ArtifactTypeEnum.HEAT_ARTIFACT.getType()) || e.getType().equals(ArtifactTypeEnum.HEAT_NESTED.getType())).map(e -> e.getFileName()).collect(Collectors.toList()));
3495                 return json;
3496         }
3497
3498         private Map<String, Object> buildJsonForUpdateArtifact(String artifactId, String artifactName, String artifactType, ArtifactGroupTypeEnum artifactGroupType, String label, String displayName, String description, byte[] artifactContentent,
3499                         List<ArtifactTemplateInfo> updatedRequiredArtifacts) {
3500
3501                 Map<String, Object> json = new HashMap<String, Object>();
3502                 if (artifactId != null && !artifactId.isEmpty())
3503                         json.put(Constants.ARTIFACT_ID, artifactId);
3504
3505                 json.put(Constants.ARTIFACT_NAME, artifactName);
3506                 json.put(Constants.ARTIFACT_TYPE, artifactType);
3507                 json.put(Constants.ARTIFACT_DESCRIPTION, description);
3508
3509                 String encodedPayload = new String(artifactContentent);
3510
3511                 // boolean isEncoded = GeneralUtility.isBase64Encoded(artifactContentent);
3512                 // if (!isEncoded) {
3513                 log.debug("payload is encoded. perform decode");
3514                 encodedPayload = Base64.encodeBase64String(artifactContentent);
3515                 // }
3516
3517                 json.put(Constants.ARTIFACT_PAYLOAD_DATA, encodedPayload);
3518                 json.put(Constants.ARTIFACT_DISPLAY_NAME, displayName);
3519                 json.put(Constants.ARTIFACT_LABEL, label);
3520                 json.put(Constants.ARTIFACT_GROUP_TYPE, artifactGroupType.getType());
3521                 json.put(Constants.REQUIRED_ARTIFACTS, (updatedRequiredArtifacts == null || updatedRequiredArtifacts.isEmpty()) ? new ArrayList<>()
3522                                 : updatedRequiredArtifacts.stream().filter(e -> e.getType().equals(ArtifactTypeEnum.HEAT_ARTIFACT.getType()) || e.getType().equals(ArtifactTypeEnum.HEAT_NESTED.getType())).map(e -> e.getFileName()).collect(Collectors.toList()));
3523                 return json;
3524         }
3525
3526         @SuppressWarnings({ "unchecked", "static-access" })
3527         private Either<Map<String, List<ArtifactTemplateInfo>>, ResponseFormat> parseResourceArtifactsInfoFromFile(Resource resource, String artifactsMetaFile, String artifactFileName, User user) {
3528
3529                 try {
3530                         JsonObject jsonElement = new JsonObject();
3531                         jsonElement = gson.fromJson(artifactsMetaFile, jsonElement.getClass());
3532
3533                         JsonElement importStructureElement = jsonElement.get(Constants.IMPORT_STRUCTURE);
3534                         if (importStructureElement == null || importStructureElement.isJsonNull()) {
3535                                 log.debug("Artifact  file is not in expected formatr, fileName  {}", artifactFileName);
3536                                 BeEcompErrorManager.getInstance().logInternalDataError("Artifact  file is not in expected formatr, fileName " + artifactFileName, "Artifact internals are invalid", ErrorSeverity.ERROR);
3537                                 return Either.right(componentsUtils.getResponseFormat(ActionStatus.CSAR_INVALID_FORMAT, artifactFileName));
3538                         }
3539
3540                         Map<String, List<Map<String, Object>>> artifactTemplateMap = new HashMap<String, List<Map<String, Object>>>();
3541                         artifactTemplateMap = componentsUtils.parseJsonToObject(importStructureElement.toString(), HashMap.class);
3542                         if (artifactTemplateMap.isEmpty()) {
3543                                 log.debug("Artifact  file is not in expected formatr, fileName  {}", artifactFileName);
3544                                 BeEcompErrorManager.getInstance().logInternalDataError("Artifact  file is not in expected formatr, fileName " + artifactFileName, "Artifact internals are invalid", ErrorSeverity.ERROR);
3545                                 return Either.right(componentsUtils.getResponseFormat(ActionStatus.CSAR_INVALID_FORMAT, artifactFileName));
3546                         }
3547
3548                         Set<String> artifactsTypeKeys = artifactTemplateMap.keySet();
3549                         Map<String, List<ArtifactTemplateInfo>> artifactsMap = new HashMap<String, List<ArtifactTemplateInfo>>();
3550                         List<ArtifactTemplateInfo> allGroups = new ArrayList<>();
3551                         for (String artifactsTypeKey : artifactsTypeKeys) {
3552
3553                                 List<Map<String, Object>> o = artifactTemplateMap.get(artifactsTypeKey);
3554                                 Either<List<ArtifactTemplateInfo>, ResponseFormat> artifactTemplateInfoListPairStatus = createArtifactTemplateInfoModule(artifactsTypeKey, o);
3555                                 if (artifactTemplateInfoListPairStatus.isRight()) {
3556                                         log.debug("Artifact  file is not in expected formatr, fileName  {}", artifactFileName);
3557                                         BeEcompErrorManager.getInstance().logInternalDataError("Artifact  file is not in expected format, fileName " + artifactFileName, "Artifact internals are invalid", ErrorSeverity.ERROR);
3558                                         return Either.right(artifactTemplateInfoListPairStatus.right().value());
3559                                 }
3560                                 List<ArtifactTemplateInfo> artifactTemplateInfoList = artifactTemplateInfoListPairStatus.left().value();
3561                                 if (artifactTemplateInfoList == null) {
3562                                         log.debug("Artifact  file is not in expected formatr, fileName  {}", artifactFileName);
3563                                         BeEcompErrorManager.getInstance().logInternalDataError("Artifact  file is not in expected format, fileName " + artifactFileName, "Artifact internals are invalid", ErrorSeverity.ERROR);
3564                                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.CSAR_INVALID_FORMAT, artifactFileName));
3565
3566                                 }
3567                                 if(!artifactsTypeKey.equalsIgnoreCase(ArtifactTemplateInfo.CSAR_ARTIFACT))
3568                                         allGroups.addAll(artifactTemplateInfoList);
3569                                 artifactsMap.put(artifactsTypeKey, artifactTemplateInfoList);
3570                         }
3571                         int counter = groupBusinessLogic.getNextVfModuleNameCounter(resource.getGroups());
3572                         Either<Boolean, ResponseFormat> validateGroupNamesRes = groupBusinessLogic.validateGenerateVfModuleGroupNames(allGroups, resource.getSystemName(), counter);
3573                         if (validateGroupNamesRes.isRight()) {
3574                                 return Either.right(validateGroupNamesRes.right().value());
3575                         }
3576                         return Either.left(artifactsMap);
3577                 } catch (Exception e) {
3578                         log.debug("Artifact  file is not in expected format, fileName  {}", artifactFileName);
3579                         log.debug("failed with exception.", e);
3580                         BeEcompErrorManager.getInstance().logInternalDataError("Artifact  file is not in expected format, fileName " + artifactFileName, "Artifact internals are invalid", ErrorSeverity.ERROR);
3581                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.CSAR_INVALID_FORMAT, artifactFileName));
3582                 }
3583
3584         }
3585
3586         private Either<List<ArtifactTemplateInfo>, ResponseFormat> createArtifactTemplateInfoModule(String artifactsTypeKey, List<Map<String, Object>> jsonObject) {
3587                 List<ArtifactTemplateInfo> artifactTemplateInfoList = new ArrayList<ArtifactTemplateInfo>();
3588                 for (Map<String, Object> o : jsonObject) {
3589                         Either<ArtifactTemplateInfo, ResponseFormat> artifacttemplateInfoStatus = ArtifactTemplateInfo.createArtifactTemplateInfoFromJson(componentsUtils, artifactsTypeKey, o, artifactTemplateInfoList, null);
3590                         if (artifacttemplateInfoStatus.isRight()) {
3591                                 return Either.right(artifacttemplateInfoStatus.right().value());
3592                         }
3593
3594                         ArtifactTemplateInfo artifacttemplateInfo = artifacttemplateInfoStatus.left().value();
3595                         if (artifacttemplateInfo != null) {
3596                                 artifactTemplateInfoList.add(artifacttemplateInfo);
3597                         }
3598
3599                 }
3600                 return Either.left(artifactTemplateInfoList);
3601         }
3602
3603         private Either<Resource, ResponseFormat> createResourceInstancesRelations(User user, String yamlName, Resource resource, Map<String, UploadComponentInstanceInfo> uploadResInstancesMap) {
3604                 log.debug("createResourceInstancesRelations try to create relations ");
3605                 List<ComponentInstance> componentInstancesList = resource.getComponentInstances();
3606                 if (uploadResInstancesMap == null) {
3607                         log.debug("UploadComponentInstanceInfo is empty, fileName  {}", yamlName);
3608                         BeEcompErrorManager.getInstance().logInternalDataError("UploadComponentInstanceInfo is emty, fileName  {}", yamlName, ErrorSeverity.ERROR);
3609
3610                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE, yamlName);
3611                         return Either.right(responseFormat);
3612                 }
3613
3614                 if (componentInstancesList == null || componentInstancesList.isEmpty()) {
3615                         log.debug("componentInstancesList is empty in resource {} ", resource.getUniqueId());
3616                         BeEcompErrorManager.getInstance().logInternalDataError("componentInstancesList is empty in resource {} ", resource.getUniqueId(), ErrorSeverity.ERROR);
3617
3618                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE, yamlName);
3619                         return Either.right(responseFormat);
3620                 }
3621
3622                 log.debug("Before validateAndUpdatePropertyValue");
3623                 Either<Map<String, DataTypeDefinition>, TitanOperationStatus> allDataTypes = dataTypeCache.getAll();
3624                 if (allDataTypes.isRight()) {
3625                         TitanOperationStatus status = allDataTypes.right().value();
3626                         BeEcompErrorManager.getInstance().logInternalFlowError("UpdatePropertyValueOnComponentInstance", "Failed to update property value on instance. Status is " + status, ErrorSeverity.ERROR);
3627                         return Either.right(componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(DaoStatusConverter.convertTitanStatusToStorageStatus(status)), yamlName));
3628
3629                 }
3630
3631                 Map<String, List<ComponentInstanceProperty>> instProperties = new HashMap<>();
3632                 Map<ComponentInstance, Map<String, List<CapabilityDefinition>>> instCapabilties = new HashMap<>();
3633                 Map<ComponentInstance, Map<String, List<RequirementDefinition>>> instRequirements = new HashMap<>();
3634                 Map<String, Map<String, ArtifactDefinition>> instDeploymentArtifacts = new HashMap<>();
3635                 Map<String, Map<String, ArtifactDefinition>> instArtifacts = new HashMap<>();
3636                 Map<String, List<PropertyDefinition>> instAttributes = new HashMap<>();
3637                 Map<String, Resource> originCompMap = new HashMap<>();
3638                 List<RequirementCapabilityRelDef> relations = new ArrayList<>();
3639
3640                 Map<String, List<ComponentInstanceInput>> instInputs = new HashMap<>();
3641
3642                 for (Entry<String, UploadComponentInstanceInfo> entry : uploadResInstancesMap.entrySet()) {
3643                         log.trace("Processing entry: {}", entry);
3644                         UploadComponentInstanceInfo uploadComponentInstanceInfo = entry.getValue();
3645                         ComponentInstance currentCompInstance = null;
3646                         for (ComponentInstance compInstance : componentInstancesList) {
3647                                 log.trace("Processing component instance: {}", compInstance);
3648                                 if (compInstance.getName().equals(uploadComponentInstanceInfo.getName())) {
3649                                         currentCompInstance = compInstance;
3650                                         break;
3651                                 }
3652
3653                         }
3654                         if (currentCompInstance == null) {
3655                                 log.debug("component instance with name {}  in resource {} ", uploadComponentInstanceInfo.getName(), resource.getUniqueId());
3656                                 BeEcompErrorManager.getInstance().logInternalDataError("component instance with name " + uploadComponentInstanceInfo.getName() + "  in resource {} ", resource.getUniqueId(), ErrorSeverity.ERROR);
3657                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE, yamlName);
3658                                 return Either.right(responseFormat);
3659                         }
3660                         String resourceInstanceId = currentCompInstance.getUniqueId();
3661                         Resource originResource;
3662                         if (!originCompMap.containsKey(currentCompInstance.getComponentUid())) {
3663                                 Either<Resource, StorageOperationStatus> getOriginResourceRes = toscaOperationFacade.getToscaFullElement(currentCompInstance.getComponentUid());
3664                                 if (getOriginResourceRes.isRight()) {
3665                                         log.debug("failed to fetch resource with uniqueId {} and tosca component name {} status is {}", currentCompInstance.getComponentUid(), currentCompInstance.getToscaComponentName(), getOriginResourceRes);
3666                                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(getOriginResourceRes.right().value()), yamlName);
3667                                         return Either.right(responseFormat);
3668                                 }
3669                                 originResource = getOriginResourceRes.left().value();
3670                                 originCompMap.put(originResource.getUniqueId(), originResource);
3671                         } else {
3672                                 originResource = originCompMap.get(currentCompInstance.getComponentUid());
3673                         }
3674                         if (originResource.getRequirements() != null && !originResource.getRequirements().isEmpty())
3675                                 instRequirements.put(currentCompInstance, originResource.getRequirements());
3676                         if (MapUtils.isNotEmpty(originResource.getCapabilities())) {
3677                                 Map<String, List<CapabilityDefinition>> originCapabilities ;
3678                                 if (MapUtils.isNotEmpty(uploadComponentInstanceInfo.getCapabilities())) {
3679                                         originCapabilities = new HashMap<>(); 
3680                                         originResource.getCapabilities().entrySet().stream().forEach(e ->{
3681                                                 List<CapabilityDefinition> list =  e.getValue().stream().map(l -> new CapabilityDefinition(l)).collect(Collectors.toList()); 
3682                                                 originCapabilities.put(e.getKey(), list);
3683                                         });
3684                                         Map<String, Map<String, UploadPropInfo>> newPropertiesMap = new HashMap<>();
3685                                         for(List<UploadCapInfo> capabilities : uploadComponentInstanceInfo.getCapabilities().values()){
3686                                                 for(UploadCapInfo capability :capabilities){
3687                                                         if(CollectionUtils.isNotEmpty(capability.getProperties())){
3688                                                                 newPropertiesMap.put(capability.getName(), capability.getProperties().stream().collect(Collectors.toMap(p->p.getName(), p->p)));
3689                                                         }
3690                                                 }
3691                                         }
3692                                         for (List<CapabilityDefinition> capabilities : originCapabilities.values()) {
3693                                                 List<CapabilityDefinition> filteredCapabilities = capabilities.stream().filter(c -> newPropertiesMap.containsKey(c.getName())).collect(Collectors.toList());
3694                                                 for(CapabilityDefinition cap : filteredCapabilities){
3695                                                         Either<Boolean, ResponseFormat> updateRes = updatePropertyValues(cap.getProperties(),newPropertiesMap.get(cap.getName()), allDataTypes.left().value());
3696                                                         if(updateRes.isRight()){
3697                                                                 log.debug("Failed to update capability properties of capability {} . Status is {}. ", cap.getName(), updateRes.right().value());
3698                                                                 return Either.right(updateRes.right().value());
3699                                                         }
3700                                                 }
3701                                         }
3702                                 }
3703                                 else{
3704                                         originCapabilities = originResource.getCapabilities();
3705                                 }
3706                                 instCapabilties.put(currentCompInstance, originCapabilities);
3707                         }
3708                         if (originResource.getDeploymentArtifacts() != null && !originResource.getDeploymentArtifacts().isEmpty())
3709                                 instDeploymentArtifacts.put(resourceInstanceId, originResource.getDeploymentArtifacts());
3710                         if (originResource.getArtifacts() != null && !originResource.getArtifacts().isEmpty())
3711                                 instArtifacts.put(resourceInstanceId, originResource.getArtifacts());
3712                         if (originResource.getAttributes() != null && !originResource.getAttributes().isEmpty())
3713                                 instAttributes.put(resourceInstanceId, originResource.getAttributes());
3714                         if (originResource.getResourceType() != ResourceTypeEnum.CVFC) {
3715                                 ResponseFormat addPropertiesValueToRiRes = addPropertyValuesToRi(uploadComponentInstanceInfo, resource, originResource, currentCompInstance, yamlName, instProperties, allDataTypes.left().value());
3716                                 if (addPropertiesValueToRiRes.getStatus() != 200) {
3717                                         return Either.right(addPropertiesValueToRiRes);
3718                                 }
3719                         } else {
3720                                 ResponseFormat addInputValueToRiRes = addInputsValuesToRi(uploadComponentInstanceInfo, resource, originResource, currentCompInstance, yamlName, instInputs, allDataTypes.left().value());
3721                                 if (addInputValueToRiRes.getStatus() != 200) {
3722                                         return Either.right(addInputValueToRiRes);
3723                                 }
3724                         }
3725                 }
3726
3727                 Either<Map<String, List<ComponentInstanceProperty>>, StorageOperationStatus> addPropToInst = toscaOperationFacade.associateComponentInstancePropertiesToComponent(instProperties, resource.getUniqueId());
3728                 if (addPropToInst.isRight()) {
3729                         log.debug("failed to associate properties of resource {} status is {}", resource.getUniqueId(), addPropToInst.right().value());
3730                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(addPropToInst.right().value()), yamlName);
3731                         return Either.right(responseFormat);
3732                 }
3733                 if (instInputs != null && !instInputs.isEmpty()) {
3734                         Either<Map<String, List<ComponentInstanceInput>>, StorageOperationStatus> addInputToInst = toscaOperationFacade.associateComponentInstanceInputsToComponent(instInputs, resource.getUniqueId());
3735                         if (addInputToInst.isRight()) {
3736                                 log.debug("failed to associate inputs value of resource {} status is {}", resource.getUniqueId(), addInputToInst.right().value());
3737                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(addInputToInst.right().value()), yamlName);
3738                                 return Either.right(responseFormat);
3739                         }
3740                 }
3741                 StorageOperationStatus addArtToInst = toscaOperationFacade.associateDeploymentArtifactsToInstances(instDeploymentArtifacts, resource.getUniqueId(), user);
3742                 if (addArtToInst != StorageOperationStatus.OK && addArtToInst != StorageOperationStatus.NOT_FOUND) {
3743                         log.debug("failed to associate artifact of resource {} status is {}", resource.getUniqueId(), addArtToInst);
3744                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(addArtToInst), yamlName);
3745                         return Either.right(responseFormat);
3746                 }
3747                 
3748                 addArtToInst = toscaOperationFacade.associateArtifactsToInstances(instArtifacts, resource.getUniqueId(), user);
3749                 if (addArtToInst != StorageOperationStatus.OK && addArtToInst != StorageOperationStatus.NOT_FOUND) {
3750                         log.debug("failed to associate artifact of resource {} status is {}", resource.getUniqueId(), addArtToInst);
3751                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(addArtToInst), yamlName);
3752                         return Either.right(responseFormat);
3753                 }
3754
3755                 addArtToInst = toscaOperationFacade.associateCalculatedCapReq(instCapabilties, instRequirements, resource.getUniqueId());
3756                 if (addArtToInst != StorageOperationStatus.OK && addArtToInst != StorageOperationStatus.NOT_FOUND) {
3757                         log.debug("failed to associate cap and req of resource {} status is {}", resource.getUniqueId(), addArtToInst);
3758                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(addArtToInst), yamlName);
3759                         return Either.right(responseFormat);
3760                 }
3761
3762                 addArtToInst = toscaOperationFacade.associateInstAttributeToComponentToInstances(instAttributes, resource.getUniqueId());
3763                 if (addArtToInst != StorageOperationStatus.OK && addArtToInst != StorageOperationStatus.NOT_FOUND) {
3764                         log.debug("failed to associate attributes of resource {} status is {}", resource.getUniqueId(), addArtToInst);
3765                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(addArtToInst), yamlName);
3766                         return Either.right(responseFormat);
3767                 }
3768
3769                 ComponentParametersView parametersView = new ComponentParametersView();
3770                 parametersView.disableAll();
3771                 parametersView.setIgnoreComponentInstances(false);
3772                 parametersView.setIgnoreComponentInstancesProperties(false);
3773                 parametersView.setIgnoreCapabilities(false);
3774                 parametersView.setIgnoreRequirements(false);
3775
3776                 Either<Resource, StorageOperationStatus> eitherGetResource = toscaOperationFacade.getToscaElement(resource.getUniqueId(), parametersView);
3777
3778                 if (eitherGetResource.isRight()) {
3779                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(eitherGetResource.right().value()), resource);
3780
3781                         return Either.right(responseFormat);
3782
3783                 }
3784
3785                 resource = eitherGetResource.left().value();
3786
3787                 for (Entry<String, UploadComponentInstanceInfo> entry : uploadResInstancesMap.entrySet()) {
3788                         UploadComponentInstanceInfo uploadComponentInstanceInfo = entry.getValue();
3789                         ComponentInstance currentCompInstance = null;
3790                         for (ComponentInstance compInstance : componentInstancesList) {
3791
3792                                 if (compInstance.getName().equals(uploadComponentInstanceInfo.getName())) {
3793                                         currentCompInstance = compInstance;
3794                                         break;
3795                                 }
3796
3797                         }
3798                         if (currentCompInstance == null) {
3799                                 log.debug("component instance with name {}  in resource {} ", uploadComponentInstanceInfo.getName(), resource.getUniqueId());
3800                                 BeEcompErrorManager.getInstance().logInternalDataError("component instance with name " + uploadComponentInstanceInfo.getName() + "  in resource {} ", resource.getUniqueId(), ErrorSeverity.ERROR);
3801                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE, yamlName);
3802                                 return Either.right(responseFormat);
3803                         }
3804
3805                         ResponseFormat addRelationToRiRes = addRelationToRI(yamlName, resource, entry.getValue(), relations);
3806                         if (addRelationToRiRes.getStatus() != 200) {
3807                                 return Either.right(addRelationToRiRes);
3808                         }
3809                 }
3810
3811                 addArtToInst = toscaOperationFacade.associateResourceInstances(resource.getUniqueId(), relations);
3812                 if (addArtToInst != StorageOperationStatus.OK && addArtToInst != StorageOperationStatus.NOT_FOUND) {
3813                         log.debug("failed to associate instances of resource {} status is {}", resource.getUniqueId(), addArtToInst);
3814                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(addArtToInst), yamlName);
3815                         return Either.right(responseFormat);
3816                 }
3817
3818                 if(resource.getResourceType() == ResourceTypeEnum.CVFC){
3819                         eitherGetResource = toscaOperationFacade.getToscaFullElement(resource.getUniqueId());
3820                         if (eitherGetResource.isRight()) {
3821                                 ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(eitherGetResource.right().value()), resource);
3822                                 return Either.right(responseFormat);
3823                         }
3824                         eitherGetResource = updateCalculatedCapReqWithSubstitutionMappings(eitherGetResource.left().value(), uploadResInstancesMap);
3825                         if (eitherGetResource.isRight()) {
3826                                 ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(eitherGetResource.right().value()), resource);
3827                                 return Either.right(responseFormat);
3828                         }
3829                 }
3830                 
3831                 log.debug("************* in create relations, getResource start");
3832                 eitherGetResource = toscaOperationFacade.getToscaElement(resource.getUniqueId());
3833                 log.debug("************* in create relations, getResource end");
3834                 if (eitherGetResource.isRight()) {
3835                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(eitherGetResource.right().value()), resource);
3836                         return Either.right(responseFormat);
3837                 }
3838                 return Either.left(eitherGetResource.left().value());
3839         }
3840
3841         private Either<Boolean, ResponseFormat> updatePropertyValues(List<ComponentInstanceProperty> properties, Map<String, UploadPropInfo> newProperties, Map<String, DataTypeDefinition> allDataTypes) {
3842                 for(ComponentInstanceProperty property : properties){
3843                         Either<String, StorageOperationStatus> updateRes = updatePropertyValue(property ,newProperties.get(property.getName()), allDataTypes);
3844                         if(updateRes.isRight()){
3845                                 log.debug("Failed to update capability property {} . Status is {}. ", property.getName(), updateRes.right().value());
3846                                 return Either.right(componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(updateRes.right().value())));
3847                         }
3848                 }
3849                 return Either.left(true);
3850         }
3851
3852         private Either<String, StorageOperationStatus> updatePropertyValue(ComponentInstanceProperty property, UploadPropInfo propertyInfo, Map<String, DataTypeDefinition> allDataTypes) {
3853                 String value = null;
3854                 List<GetInputValueDataDefinition> getInputs = null;
3855                 boolean isValidate = true;
3856                 if (propertyInfo.getValue() != null) {
3857                         getInputs = propertyInfo.getGet_input();
3858                         isValidate = getInputs == null || getInputs.isEmpty();
3859                         if (isValidate) {
3860                                 value = ImportUtils.getPropertyJsonStringValue(propertyInfo.getValue(), property.getType());
3861                         } else
3862                                 value = ImportUtils.getPropertyJsonStringValue(propertyInfo.getValue(), ToscaTagNamesEnum.GET_INPUT.getElementName());
3863                 }
3864                 property.setValue(value);
3865                 return validatePropValueBeforeCreate(property, value, isValidate, null, allDataTypes);
3866         }
3867
3868         private Either<Resource, StorageOperationStatus> updateCalculatedCapReqWithSubstitutionMappings(Resource resource, Map<String, UploadComponentInstanceInfo> uploadResInstancesMap) {
3869                 Either<Resource, StorageOperationStatus> updateRes = null;
3870                 Map<ComponentInstance, Map<String, List<CapabilityDefinition>>> updatedInstCapabilities = new HashMap<>();
3871                 Map<ComponentInstance, Map<String, List<RequirementDefinition>>> updatedInstRequirements = new HashMap<>();
3872                 StorageOperationStatus status = toscaOperationFacade.deleteAllCalculatedCapabilitiesRequirements( resource.getUniqueId());
3873                 if(status != StorageOperationStatus.OK && status != StorageOperationStatus.NOT_FOUND){
3874                         log.debug("Failed to delete all calculated capabilities and requirements of resource {} upon update. Status is {}", resource.getUniqueId(), status);
3875                         updateRes =  Either.right(status);
3876                 }
3877                 if(updateRes == null){
3878                         fillUpdatedInstCapabilitiesRequirements(resource.getComponentInstances(), uploadResInstancesMap, updatedInstCapabilities, updatedInstRequirements);
3879                         status = toscaOperationFacade.associateCalculatedCapReq(updatedInstCapabilities, updatedInstRequirements,  resource.getUniqueId());
3880                         if (status != StorageOperationStatus.OK && status != StorageOperationStatus.NOT_FOUND) {
3881                                 log.debug("Failed to associate capabilities and requirementss of resource {}, updated according to a substitution mapping. Status is {}",  resource.getUniqueId(), status);
3882                                 updateRes = Either.right(status);
3883                         }
3884                 }
3885                 if(updateRes == null){
3886                         updateRes = Either.left(resource);
3887                 }
3888                 return updateRes;
3889         }
3890
3891
3892         private void fillUpdatedInstCapabilitiesRequirements(List<ComponentInstance> componentInstances, Map<String, UploadComponentInstanceInfo> uploadResInstancesMap,
3893                         Map<ComponentInstance, Map<String, List<CapabilityDefinition>>> updatedInstCapabilities, Map<ComponentInstance, Map<String, List<RequirementDefinition>>> updatedInstRequirements) {
3894                 
3895                 componentInstances.stream().forEach( i -> {
3896                         fillUpdatedInstCapabilities(updatedInstCapabilities, i, uploadResInstancesMap.get(i.getName()).getCapabilitiesNamesToUpdate());
3897                         fillUpdatedInstRequirements(updatedInstRequirements, i, uploadResInstancesMap.get(i.getName()).getRequirementsNamesToUpdate());
3898                 });
3899         }
3900
3901         private void fillUpdatedInstRequirements(Map<ComponentInstance, Map<String, List<RequirementDefinition>>> updatedInstRequirements, ComponentInstance instance, Map<String, String> requirementsNamesToUpdate) {
3902                 Map<String, List<RequirementDefinition>> updatedRequirements = new HashMap<>();
3903                 Set<String> updatedReqNames = new HashSet<>();
3904                 if(MapUtils.isNotEmpty(requirementsNamesToUpdate)){
3905                         for (Map.Entry<String, List<RequirementDefinition>> requirements : instance.getRequirements().entrySet()) {
3906                                 updatedRequirements.put(requirements.getKey(), requirements.getValue().stream()
3907                                                 .filter(r -> requirementsNamesToUpdate.containsKey(r.getName()) && !updatedReqNames.contains(requirementsNamesToUpdate.get(r.getName())))
3908                                                 .map(r ->{r.setParentName(r.getName()); r.setName(requirementsNamesToUpdate.get(r.getName())); updatedReqNames.add(r.getName()); return r;})
3909                                                 .collect(Collectors.toList()));
3910                         }
3911                 }
3912                 if(MapUtils.isNotEmpty(updatedRequirements)){
3913                         updatedInstRequirements.put(instance, updatedRequirements);
3914                 }
3915         }
3916
3917         private void fillUpdatedInstCapabilities(Map<ComponentInstance, Map<String, List<CapabilityDefinition>>> updatedInstCapabilties, ComponentInstance instance, Map<String, String> capabilitiesNamesToUpdate) {
3918                 Map<String, List<CapabilityDefinition>> updatedCapabilities = new HashMap<>();
3919                 Set<String> updatedCapNames = new HashSet<>();
3920                 if(MapUtils.isNotEmpty(capabilitiesNamesToUpdate)){
3921                         for (Map.Entry<String, List<CapabilityDefinition>> requirements : instance.getCapabilities().entrySet()) {
3922                                 updatedCapabilities.put(requirements.getKey(), requirements.getValue().stream()
3923                                                 .filter(c -> capabilitiesNamesToUpdate.containsKey(c.getName()) && !updatedCapNames.contains(capabilitiesNamesToUpdate.get(c.getName())))
3924                                                 .map(c -> {c.setParentName(c.getName()); c.setName(capabilitiesNamesToUpdate.get(c.getName())); updatedCapNames.add(c.getName()); return c;})
3925                                                 .collect(Collectors.toList()));
3926                         }
3927                 }
3928                 if(MapUtils.isNotEmpty(updatedCapabilities)){
3929                         updatedInstCapabilties.put(instance, updatedCapabilities);
3930                 }
3931         }
3932
3933         private ResponseFormat addRelationToRI(String yamlName, Resource resource, UploadComponentInstanceInfo nodesInfoValue, List<RequirementCapabilityRelDef> relations) {
3934                 List<ComponentInstance> componentInstancesList = resource.getComponentInstances();
3935
3936                 UploadComponentInstanceInfo uploadComponentInstanceInfo = nodesInfoValue;
3937
3938                 ComponentInstance currentCompInstance = null;
3939
3940                 for (ComponentInstance compInstance : componentInstancesList) {
3941
3942                         if (compInstance.getName().equals(uploadComponentInstanceInfo.getName())) {
3943                                 currentCompInstance = compInstance;
3944                                 break;
3945                         }
3946
3947                 }
3948
3949                 if (currentCompInstance == null) {
3950                         log.debug("component instance with name {}  in resource {} ", uploadComponentInstanceInfo.getName(), resource.getUniqueId());
3951                         BeEcompErrorManager.getInstance().logInternalDataError("component instance with name " + uploadComponentInstanceInfo.getName() + "  in resource {} ", resource.getUniqueId(), ErrorSeverity.ERROR);
3952                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE, yamlName);
3953                         return responseFormat;
3954                 }
3955                 String resourceInstanceId = currentCompInstance.getUniqueId();
3956
3957                 Map<String, List<UploadReqInfo>> regMap = uploadComponentInstanceInfo.getRequirements();
3958
3959                 if (regMap != null) {
3960                         Iterator<Entry<String, List<UploadReqInfo>>> nodesRegValue = regMap.entrySet().iterator();
3961
3962                         while (nodesRegValue.hasNext()) {
3963                                 Entry<String, List<UploadReqInfo>> nodesRegInfoEntry = nodesRegValue.next();
3964
3965                                 List<UploadReqInfo> uploadRegInfoList = nodesRegInfoEntry.getValue();
3966                                 for (UploadReqInfo uploadRegInfo : uploadRegInfoList) {
3967                                         log.debug("Going to create  relation {}", uploadRegInfo.getName());
3968                                         String regName = uploadRegInfo.getName();
3969                                         RequirementCapabilityRelDef regCapRelDef = new RequirementCapabilityRelDef();
3970                                         regCapRelDef.setFromNode(resourceInstanceId);
3971                                         log.debug("try to find available requirement {} ", regName);
3972                                         Either<RequirementDefinition, ResponseFormat> eitherReqStatus = findAviableRequiremen(regName, yamlName, uploadComponentInstanceInfo, currentCompInstance, uploadRegInfo.getCapabilityName());
3973                                         if (eitherReqStatus.isRight()) {
3974                                                 log.debug("failed to find available requirement {} status is {}", regName, eitherReqStatus.right().value());
3975                                                 return eitherReqStatus.right().value();
3976                                         }
3977
3978                                         RequirementDefinition validReq = eitherReqStatus.left().value();
3979                                         List<CapabilityRequirementRelationship> reqAndRelationshipPairList = regCapRelDef.getRelationships();
3980                                         if (reqAndRelationshipPairList == null)
3981                                                 reqAndRelationshipPairList = new ArrayList<>();
3982                                         RelationshipInfo reqAndRelationshipPair = new RelationshipInfo();
3983                                         reqAndRelationshipPair.setRequirement(regName);
3984                                         reqAndRelationshipPair.setRequirementOwnerId(validReq.getOwnerId());
3985                                         reqAndRelationshipPair.setRequirementUid(validReq.getUniqueId());
3986                                         RelationshipImpl relationship = new RelationshipImpl();
3987                                         relationship.setType(validReq.getCapability());
3988                                         reqAndRelationshipPair.setRelationships(relationship);
3989
3990                                         ComponentInstance currentCapCompInstance = null;
3991                                         for (ComponentInstance compInstance : componentInstancesList) {
3992                                                 if (compInstance.getName().equals(uploadRegInfo.getNode())) {
3993                                                         currentCapCompInstance = compInstance;
3994                                                         break;
3995                                                 }
3996                                         }
3997
3998                                         if (currentCapCompInstance == null) {
3999                                                 log.debug("The component instance  with name {} not found on resource {} ", uploadRegInfo.getNode(), resource.getUniqueId());
4000                                                 BeEcompErrorManager.getInstance().logInternalDataError("component instance with name " + uploadRegInfo.getNode() + "  in resource {} ", resource.getUniqueId(), ErrorSeverity.ERROR);
4001                                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE, yamlName);
4002                                                 return responseFormat;
4003                                         }
4004                                         regCapRelDef.setToNode(currentCapCompInstance.getUniqueId());
4005                                         log.debug("try to find aviable Capability  req name is {} ", validReq.getName());
4006                                         CapabilityDefinition aviableCapForRel = findAvailableCapabilityByTypeOrName(validReq, currentCapCompInstance, uploadRegInfo);
4007                                         if (aviableCapForRel == null) {
4008                                                 log.debug("aviable capability was not found. req name is {} component instance is {}", validReq.getName(), currentCapCompInstance.getUniqueId());
4009                                                 BeEcompErrorManager.getInstance().logInternalDataError("aviable capability was not found. req name is " + validReq.getName() + " component instance is " + currentCapCompInstance.getUniqueId(), resource.getUniqueId(),
4010                                                                 ErrorSeverity.ERROR);
4011                                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE, yamlName);
4012                                                 return responseFormat;
4013                                         }
4014                                         reqAndRelationshipPair.setCapability(aviableCapForRel.getName());
4015                                         reqAndRelationshipPair.setCapabilityUid(aviableCapForRel.getUniqueId());
4016                                         reqAndRelationshipPair.setCapabilityOwnerId(aviableCapForRel.getOwnerId());
4017                                         CapabilityRequirementRelationship capReqRel = new CapabilityRequirementRelationship();
4018                                         capReqRel.setRelation(reqAndRelationshipPair);
4019                                         reqAndRelationshipPairList.add(capReqRel);
4020                                         regCapRelDef.setRelationships(reqAndRelationshipPairList);
4021                                         relations.add(regCapRelDef);
4022                                 }
4023                         }
4024                 } else if (resource.getResourceType() != ResourceTypeEnum.CVFC) {
4025                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.OK, yamlName);
4026                         return responseFormat;
4027                 }
4028                 return componentsUtils.getResponseFormat(ActionStatus.OK);
4029         }
4030
4031         private ResponseFormat addInputsValuesToRi(UploadComponentInstanceInfo uploadComponentInstanceInfo, Resource resource, Resource originResource, ComponentInstance currentCompInstance, String yamlName,
4032                         Map<String, List<ComponentInstanceInput>> instInputs, Map<String, DataTypeDefinition> allDataTypes) {
4033                 Map<String, List<UploadPropInfo>> propMap = uploadComponentInstanceInfo.getProperties();
4034                 if (propMap != null && propMap.size() > 0) {
4035                         Map<String, InputDefinition> currPropertiesMap = new HashMap<String, InputDefinition>();
4036
4037                         List<InputDefinition> listFromMap = originResource.getInputs();
4038                         if (listFromMap == null || listFromMap.isEmpty()) {
4039                                 log.debug("failed to find properties ");
4040                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.PROPERTY_NOT_FOUND);
4041                                 return responseFormat;
4042                         }
4043                         for (InputDefinition prop : listFromMap) {
4044                                 String propName = prop.getName();
4045                                 if (!currPropertiesMap.containsKey(propName)) {
4046                                         currPropertiesMap.put(propName, prop);
4047                                 }
4048                         }
4049                         List<ComponentInstanceInput> instPropList = new ArrayList<>();
4050                         for (List<UploadPropInfo> propertyList : propMap.values()) {
4051
4052                                 UploadPropInfo propertyInfo = propertyList.get(0);
4053                                 String propName = propertyInfo.getName();
4054                                 if (!currPropertiesMap.containsKey(propName)) {
4055                                         log.debug("failed to find property {} ", propName);
4056                                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.PROPERTY_NOT_FOUND, propName);
4057                                         return responseFormat;
4058                                 }
4059                                 InputDefinition curPropertyDef = currPropertiesMap.get(propName);
4060                                 ComponentInstanceInput property = null;
4061
4062                                 String value = null;
4063                                 List<GetInputValueDataDefinition> getInputs = null;
4064                                 boolean isValidate = true;
4065                                 if (propertyInfo.getValue() != null) {
4066                                         getInputs = propertyInfo.getGet_input();
4067                                         isValidate = getInputs == null || getInputs.isEmpty();
4068                                         if (isValidate) {
4069                                                 value = ImportUtils.getPropertyJsonStringValue(propertyInfo.getValue(), curPropertyDef.getType());
4070                                         } else
4071                                                 value = ImportUtils.getPropertyJsonStringValue(propertyInfo.getValue(), ToscaTagNamesEnum.GET_INPUT.getElementName());
4072                                 }
4073                                 String innerType = null;
4074                                 property = new ComponentInstanceInput(curPropertyDef, value, null);
4075
4076                                 Either<String, StorageOperationStatus> validatevalueEiter = validatePropValueBeforeCreate(property, value, isValidate, innerType, allDataTypes);
4077                                 if (validatevalueEiter.isRight()) {
4078                                         return componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(validatevalueEiter.right().value()));
4079                                 }
4080
4081                                 // String uniqueId = UniqueIdBuilder.buildResourceInstancePropertyValueUid(currentCompInstance.getComponentUid(), index++);
4082                                 // property.setUniqueId(uniqueId);
4083                                 property.setValue(validatevalueEiter.left().value());
4084
4085                                 if (getInputs != null && !getInputs.isEmpty()) {
4086                                         List<GetInputValueDataDefinition> getInputValues = new ArrayList<>();
4087                                         for (GetInputValueDataDefinition getInput : getInputs) {
4088                                                 List<InputDefinition> inputs = resource.getInputs();
4089                                                 if (inputs == null || inputs.isEmpty()) {
4090                                                         log.debug("Failed to add property {} to resource instance {}. Inputs list is empty ", property, currentCompInstance.getUniqueId());
4091                                                         return componentsUtils.getResponseFormat(ActionStatus.INVALID_CONTENT);
4092                                                 }
4093
4094                                                 Optional<InputDefinition> optional = inputs.stream().filter(p -> p.getName().equals(getInput.getInputName())).findAny();
4095                                                 if (!optional.isPresent()) {
4096                                                         log.debug("Failed to find input {} ", getInput.getInputName());
4097                                                         // @@TODO error message
4098                                                         return componentsUtils.getResponseFormat(ActionStatus.INVALID_CONTENT);
4099                                                 }
4100                                                 InputDefinition input = optional.get();
4101                                                 getInput.setInputId(input.getUniqueId());
4102                                                 getInputValues.add(getInput);
4103
4104                                                 GetInputValueDataDefinition getInputIndex = getInput.getGetInputIndex();
4105                                                 if (getInputIndex != null) {
4106                                                         optional = inputs.stream().filter(p -> p.getName().equals(getInputIndex.getInputName())).findAny();
4107                                                         if (!optional.isPresent()) {
4108                                                                 log.debug("Failed to find input {} ", getInputIndex.getInputName());
4109                                                                 // @@TODO error message
4110                                                                 return componentsUtils.getResponseFormat(ActionStatus.INVALID_CONTENT);
4111                                                         }
4112                                                         InputDefinition inputIndex = optional.get();
4113                                                         getInputIndex.setInputId(inputIndex.getUniqueId());
4114                                                         getInputValues.add(getInputIndex);
4115                                                 }
4116                                         }
4117                                         property.setGetInputValues(getInputValues);
4118                                 }
4119                                 instPropList.add(property);
4120                                 // delete overriden property
4121                                 currPropertiesMap.remove(property.getName());
4122                         }
4123                         // add rest of properties
4124                         if (!currPropertiesMap.isEmpty()) {
4125                                 for (InputDefinition value : currPropertiesMap.values()) {
4126                                         instPropList.add(new ComponentInstanceInput(value));
4127                                 }
4128                         }
4129                         instInputs.put(currentCompInstance.getUniqueId(), instPropList);
4130                 }
4131                 return componentsUtils.getResponseFormat(ActionStatus.OK);
4132         }
4133
4134         private ResponseFormat addPropertyValuesToRi(UploadComponentInstanceInfo uploadComponentInstanceInfo, Resource resource, Resource originResource, ComponentInstance currentCompInstance, String yamlName,
4135                                                                                                  Map<String, List<ComponentInstanceProperty>> instProperties, Map<String, DataTypeDefinition> allDataTypes) {
4136
4137                 Map<String, List<UploadPropInfo>> propMap = uploadComponentInstanceInfo.getProperties();
4138                 Map<String, PropertyDefinition> currPropertiesMap = new HashMap<String, PropertyDefinition>();
4139
4140                 List<PropertyDefinition> listFromMap = originResource.getProperties();
4141                 if ((propMap != null && !propMap.isEmpty()) && (listFromMap == null || listFromMap.isEmpty())) {
4142                         log.debug("failed to find properties ");
4143                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.PROPERTY_NOT_FOUND);
4144                         return responseFormat;
4145                 }
4146                 if(listFromMap == null || listFromMap.isEmpty()){
4147                         return componentsUtils.getResponseFormat(ActionStatus.OK);
4148                 }
4149                 for (PropertyDefinition prop : listFromMap) {
4150                         String propName = prop.getName();
4151                         if (!currPropertiesMap.containsKey(propName)) {
4152                                 currPropertiesMap.put(propName, prop);
4153                         }
4154                 }
4155                 List<ComponentInstanceProperty> instPropList = new ArrayList<>();
4156                 if (propMap != null && propMap.size() > 0) {
4157                         for (List<UploadPropInfo> propertyList : propMap.values()) {
4158
4159                                 UploadPropInfo propertyInfo = propertyList.get(0);
4160                                 String propName = propertyInfo.getName();
4161                                 if (!currPropertiesMap.containsKey(propName)) {
4162                                         log.debug("failed to find property {} ", propName);
4163                                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.PROPERTY_NOT_FOUND, propName);
4164                                         return responseFormat;
4165                                 }
4166                                 PropertyDefinition curPropertyDef = currPropertiesMap.get(propName);
4167                                 ComponentInstanceProperty property = null;
4168
4169                                 String value = null;
4170                                 List<GetInputValueDataDefinition> getInputs = null;
4171                                 boolean isValidate = true;
4172                                 if (propertyInfo.getValue() != null) {
4173                                         getInputs = propertyInfo.getGet_input();
4174                                         isValidate = getInputs == null || getInputs.isEmpty();
4175                                         if (isValidate) {
4176                                                 value = ImportUtils.getPropertyJsonStringValue(propertyInfo.getValue(), curPropertyDef.getType());
4177                                         } else
4178                                                 value = ImportUtils.getPropertyJsonStringValue(propertyInfo.getValue(), ToscaTagNamesEnum.GET_INPUT.getElementName());
4179                                 }
4180                                 String innerType = null;
4181                                 property = new ComponentInstanceProperty(curPropertyDef, value, null);
4182
4183                                 Either<String, StorageOperationStatus> validatevalueEiter = validatePropValueBeforeCreate(property, value, isValidate, innerType, allDataTypes);
4184                                 if (validatevalueEiter.isRight()) {
4185                                         return componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(validatevalueEiter.right().value()));
4186                                 }
4187
4188                                 property.setValue(validatevalueEiter.left().value());
4189
4190                                 if (getInputs != null && !getInputs.isEmpty()) {
4191                                         List<GetInputValueDataDefinition> getInputValues = new ArrayList<>();
4192                                         for (GetInputValueDataDefinition getInput : getInputs) {
4193                                                 List<InputDefinition> inputs = resource.getInputs();
4194                                                 if (inputs == null || inputs.isEmpty()) {
4195                                                         log.debug("Failed to add property {} to resource instance {}. Inputs list is empty ", property, currentCompInstance.getUniqueId());
4196                                                         return componentsUtils.getResponseFormat(ActionStatus.INVALID_CONTENT);
4197                                                 }
4198
4199                                                 Optional<InputDefinition> optional = inputs.stream().filter(p -> p.getName().equals(getInput.getInputName())).findAny();
4200                                                 if (!optional.isPresent()) {
4201                                                         log.debug("Failed to find input {} ", getInput.getInputName());
4202                                                         // @@TODO error message
4203                                                         return componentsUtils.getResponseFormat(ActionStatus.INVALID_CONTENT);
4204                                                 }
4205                                                 InputDefinition input = optional.get();
4206                                                 getInput.setInputId(input.getUniqueId());
4207                                                 getInputValues.add(getInput);
4208
4209                                                 GetInputValueDataDefinition getInputIndex = getInput.getGetInputIndex();
4210                                                 if (getInputIndex != null) {
4211                                                         optional = inputs.stream().filter(p -> p.getName().equals(getInputIndex.getInputName())).findAny();
4212                                                         if (!optional.isPresent()) {
4213                                                                 log.debug("Failed to find input {} ", getInputIndex.getInputName());
4214                                                                 // @@TODO error message
4215                                                                 return componentsUtils.getResponseFormat(ActionStatus.INVALID_CONTENT);
4216                                                         }
4217                                                         InputDefinition inputIndex = optional.get();
4218                                                         getInputIndex.setInputId(inputIndex.getUniqueId());
4219                                                         getInputValues.add(getInputIndex);
4220
4221                                                 }
4222
4223                                         }
4224                                         property.setGetInputValues(getInputValues);
4225                                 }
4226                                 instPropList.add(property);
4227                                 // delete overriden property
4228                                 currPropertiesMap.remove(property.getName());
4229                         }
4230                 }
4231                 // add rest of properties
4232                 if (!currPropertiesMap.isEmpty()) {
4233                         for (PropertyDefinition value : currPropertiesMap.values()) {
4234                                 instPropList.add(new ComponentInstanceProperty(value));
4235                         }
4236                 }
4237                 instProperties.put(currentCompInstance.getUniqueId(), instPropList);
4238                 return componentsUtils.getResponseFormat(ActionStatus.OK);
4239         }
4240
4241         // US740820 Relate RIs according to capability name
4242         private CapabilityDefinition findAvailableCapabilityByTypeOrName(RequirementDefinition validReq, ComponentInstance currentCapCompInstance, UploadReqInfo uploadReqInfo) {
4243                 if (null == uploadReqInfo.getCapabilityName() || validReq.getCapability().equals(uploadReqInfo.getCapabilityName())) {// get
4244                         // by
4245                         // capability
4246                         // type
4247                         return findAviableCapability(validReq, currentCapCompInstance);
4248                 }
4249                 return findAvailableCapability(validReq, currentCapCompInstance, uploadReqInfo);
4250         }
4251
4252         private CapabilityDefinition findAvailableCapability(RequirementDefinition validReq, ComponentInstance currentCapCompInstance, UploadReqInfo uploadReqInfo) {
4253                 CapabilityDefinition cap = null;
4254                 Map<String, List<CapabilityDefinition>> capMap = currentCapCompInstance.getCapabilities();
4255                 if (!capMap.containsKey(validReq.getCapability())) {
4256                         return null;
4257                 }
4258                 Optional<CapabilityDefinition> capByName = capMap.get(validReq.getCapability()).stream().filter(p -> p.getName().equals(uploadReqInfo.getCapabilityName())).findAny();
4259                 if (!capByName.isPresent()) {
4260                         return null;
4261                 }
4262                 cap = capByName.get();
4263
4264                 if (cap.getMaxOccurrences() != null && !cap.getMaxOccurrences().equals(CapabilityDataDefinition.MAX_OCCURRENCES)) {
4265                         String leftOccurrences = cap.getLeftOccurrences();
4266                         int left = Integer.parseInt(leftOccurrences);
4267                         if (left > 0) {
4268                                 --left;
4269                                 cap.setLeftOccurrences(String.valueOf(left));
4270
4271                         }
4272
4273                 }
4274                 return cap;
4275         }
4276
4277         private CapabilityDefinition findAviableCapability(RequirementDefinition validReq, ComponentInstance currentCapCompInstance) {
4278                 CapabilityDefinition aviableCapForRel = null;
4279                 Map<String, List<CapabilityDefinition>> capMap = currentCapCompInstance.getCapabilities();
4280                 if (capMap.containsKey(validReq.getCapability())) {
4281                         List<CapabilityDefinition> capList = capMap.get(validReq.getCapability());
4282
4283                         for (CapabilityDefinition cap : capList) {
4284                                 if (cap.getMaxOccurrences() != null && !cap.getMaxOccurrences().equals(CapabilityDataDefinition.MAX_OCCURRENCES)) {
4285                                         String leftOccurrences = cap.getLeftOccurrences();
4286                                         if (leftOccurrences == null) {
4287                                                 leftOccurrences = cap.getMaxOccurrences();
4288                                         }
4289                                         int left = Integer.parseInt(leftOccurrences);
4290                                         if (left > 0) {
4291                                                 --left;
4292                                                 cap.setLeftOccurrences(String.valueOf(left));
4293                                                 aviableCapForRel = cap;
4294                                                 break;
4295                                         } else {
4296                                                 continue;
4297                                         }
4298                                 } else {
4299                                         aviableCapForRel = cap;
4300                                         break;
4301                                 }
4302                         }
4303                 }
4304                 return aviableCapForRel;
4305         }
4306
4307         private Either<RequirementDefinition, ResponseFormat> findAviableRequiremen(String regName, String yamlName, UploadComponentInstanceInfo uploadComponentInstanceInfo, ComponentInstance currentCompInstance, String capName) {
4308                 Map<String, List<RequirementDefinition>> comInstRegDefMap = currentCompInstance.getRequirements();
4309                 List<RequirementDefinition> list = comInstRegDefMap.get(capName);
4310                 RequirementDefinition validRegDef = null;
4311                 if (list == null) {
4312                         for (Entry<String, List<RequirementDefinition>> entry : comInstRegDefMap.entrySet()) {
4313                                 for (RequirementDefinition reqDef : entry.getValue()) {
4314                                         if (reqDef.getName().equals(regName)) {
4315                                                 if (reqDef.getMaxOccurrences() != null && !reqDef.getMaxOccurrences().equals(RequirementDataDefinition.MAX_OCCURRENCES)) {
4316                                                         String leftOccurrences = reqDef.getLeftOccurrences();
4317                                                         if (leftOccurrences == null) {
4318                                                                 leftOccurrences = reqDef.getMaxOccurrences();
4319                                                         }
4320                                                         int left = Integer.parseInt(leftOccurrences);
4321                                                         if (left > 0) {
4322                                                                 --left;
4323                                                                 reqDef.setLeftOccurrences(String.valueOf(left));
4324                                                                 validRegDef = reqDef;
4325                                                                 break;
4326                                                         } else {
4327                                                                 continue;
4328                                                         }
4329                                                 } else {
4330                                                         validRegDef = reqDef;
4331                                                         break;
4332                                                 }
4333
4334                                         }
4335                                 }
4336                                 if (validRegDef != null) {
4337                                         break;
4338                                 }
4339                         }
4340                 } else {
4341                         for (RequirementDefinition reqDef : list) {
4342                                 if (reqDef.getName().equals(regName)) {
4343                                         if (reqDef.getMaxOccurrences() != null && !reqDef.getMaxOccurrences().equals(RequirementDataDefinition.MAX_OCCURRENCES)) {
4344                                                 String leftOccurrences = reqDef.getLeftOccurrences();
4345                                                 if (leftOccurrences == null) {
4346                                                         leftOccurrences = reqDef.getMaxOccurrences();
4347                                                 }
4348                                                 int left = Integer.parseInt(leftOccurrences);
4349                                                 if (left > 0) {
4350                                                         --left;
4351                                                         reqDef.setLeftOccurrences(String.valueOf(left));
4352                                                         validRegDef = reqDef;
4353                                                         break;
4354                                                 } else {
4355                                                         continue;
4356                                                 }
4357                                         } else {
4358                                                 validRegDef = reqDef;
4359                                                 break;
4360                                         }
4361                                 }
4362                         }
4363                 }
4364                 if (validRegDef == null) {
4365                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.INVALID_NODE_TEMPLATE, yamlName, uploadComponentInstanceInfo.getName(), uploadComponentInstanceInfo.getType());
4366                         return Either.right(responseFormat);
4367                 }
4368                 return Either.left(validRegDef);
4369         }
4370
4371         @SuppressWarnings("unchecked")
4372         public Either<ParsedToscaYamlInfo, ResponseFormat> parseResourceInfoFromYaml(String yamlFileName, Resource resource, String resourceYml, Map<String, String> createdNodesToscaResourceNames, Map<String, NodeTypeInfo> nodeTypesInfo, String nodeName) {
4373
4374                 Map<String, Object> mappedToscaTemplate;
4375                 if(nodeTypesInfo != null && nodeName != null && nodeTypesInfo.containsKey(nodeName)){
4376                         mappedToscaTemplate = nodeTypesInfo.get(nodeName).getMappedToscaTemplate();
4377                 }
4378                 else {
4379                         try {
4380                                 //DE154502 Fail if duplicate key found in file
4381                                 mappedToscaTemplate = ImportUtils.loadYamlAsStrictMap(resourceYml);
4382
4383                         } catch(ParserException e) {
4384                                 log.error("Failed to load yaml file {}", yamlFileName, e);
4385                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.TOSCA_PARSE_ERROR, yamlFileName, e.getMessage());
4386                                 return Either.right(responseFormat);
4387                         }
4388                 }
4389                 Either<Object, ResultStatusEnum> toscaElementEither = ImportUtils.findToscaElement(mappedToscaTemplate, ToscaTagNamesEnum.TOPOLOGY_TEMPLATE, ToscaElementTypeEnum.ALL);
4390                 if (toscaElementEither.isRight()) {
4391                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE);
4392                         return Either.right(responseFormat);
4393                 }
4394
4395                 Either<Map<String, InputDefinition>, ResponseFormat> createInputsEither = createInputsFromYaml(yamlFileName, mappedToscaTemplate, resource);
4396                 if (createInputsEither.isRight()) {
4397                         ResponseFormat responseFormat = createInputsEither.right().value();
4398                         return Either.right(responseFormat);
4399                 }
4400
4401                 Either<Map<String, UploadComponentInstanceInfo>, ResponseFormat> uploadResInstancesEither = createResourcesInstanceInfoFromYaml(yamlFileName, mappedToscaTemplate, resource, createdNodesToscaResourceNames);
4402                 if (uploadResInstancesEither.isRight()) {
4403                         ResponseFormat responseFormat = uploadResInstancesEither.right().value();
4404                         return Either.right(responseFormat);
4405                 }
4406
4407                 Either<Map<String, GroupDefinition>, ResponseFormat> createGroupsFromYaml = createGroupsFromYaml(yamlFileName, mappedToscaTemplate, resource);
4408                 if (createGroupsFromYaml.isRight()) {
4409                         ResponseFormat responseFormat = createGroupsFromYaml.right().value();
4410                         return Either.right(responseFormat);
4411                 }
4412
4413                 ParsedToscaYamlInfo parsedToscaYamlInfo = new ParsedToscaYamlInfo();
4414                 parsedToscaYamlInfo.setInputs(createInputsEither.left().value());
4415                 parsedToscaYamlInfo.setInstances(uploadResInstancesEither.left().value());
4416                 parsedToscaYamlInfo.setGroups(createGroupsFromYaml.left().value());
4417
4418                 return Either.left(parsedToscaYamlInfo);
4419         }
4420
4421         private Either<Resource, ResponseFormat> createResourceInstances(User user, String yamlName, Resource resource, Map<String, UploadComponentInstanceInfo> uploadResInstancesMap, boolean inTransaction, boolean needLock,
4422                         Map<String, Resource> nodeNamespaceMap) {
4423
4424                 Either<Resource, ResponseFormat> eitherResource = null;
4425                 log.debug("createResourceInstances is {} - going to create resource instanse from CSAR", yamlName);
4426                 if (uploadResInstancesMap == null || uploadResInstancesMap.isEmpty()) {
4427                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE);
4428
4429                         return Either.right(responseFormat);
4430
4431                 }
4432                 Map<String, Resource> existingnodeTypeMap = new HashMap<>();
4433                 if (nodeNamespaceMap != null && !nodeNamespaceMap.isEmpty()) {
4434                         nodeNamespaceMap.entrySet().stream().forEach(x -> existingnodeTypeMap.put(x.getValue().getToscaResourceName(), x.getValue()));
4435                 }
4436
4437                 Iterator<Entry<String, UploadComponentInstanceInfo>> nodesInfoValue = uploadResInstancesMap.entrySet().iterator();
4438                 Map<ComponentInstance, Resource> resourcesInstancesMap = new HashMap<>();
4439                 while (nodesInfoValue.hasNext()) {
4440                         log.debug("*************Going to create  resource instances {}", yamlName);
4441                         Entry<String, UploadComponentInstanceInfo> uploadComponentInstanceInfoEntry = nodesInfoValue.next();
4442                         UploadComponentInstanceInfo uploadComponentInstanceInfo = uploadComponentInstanceInfoEntry.getValue();
4443
4444                         // updating type if the type is node type name - we need to take the
4445                         // updated name
4446                         log.debug("*************Going to create  resource instances {}", uploadComponentInstanceInfo.getName());
4447                         if (nodeNamespaceMap.containsKey(uploadComponentInstanceInfo.getType())) {
4448                                 uploadComponentInstanceInfo.setType(nodeNamespaceMap.get(uploadComponentInstanceInfo.getType()).getToscaResourceName());
4449                         }
4450
4451                         eitherResource = validateResourceInstanceBeforeCreate(yamlName, uploadComponentInstanceInfo, existingnodeTypeMap);
4452                         if (eitherResource.isRight()) {
4453                                 return eitherResource;
4454                         }
4455                         Resource refResource = eitherResource.left().value();
4456
4457                         ComponentInstance componentInstance = new ComponentInstance();
4458
4459                         componentInstance.setComponentUid(refResource.getUniqueId());
4460
4461                         ComponentTypeEnum containerComponentType = resource.getComponentType();
4462                         NodeTypeEnum containerNodeType = containerComponentType.getNodeType();
4463                         
4464                         if (containerNodeType.equals(NodeTypeEnum.Resource) && MapUtils.isNotEmpty(uploadComponentInstanceInfo.getCapabilities()) && MapUtils.isNotEmpty(refResource.getCapabilities())) {
4465                                 setCapabilityNamesTypes(refResource.getCapabilities(), uploadComponentInstanceInfo.getCapabilities());
4466                                 Either<Map<String, List<CapabilityDefinition>>, ResponseFormat> getValidComponentInstanceCapabilitiesRes = getValidComponentInstanceCapabilities(refResource.getUniqueId(), refResource.getCapabilities(), uploadComponentInstanceInfo.getCapabilities());
4467                                 if (getValidComponentInstanceCapabilitiesRes.isRight()) {
4468                                         return Either.right(getValidComponentInstanceCapabilitiesRes.right().value());
4469                                 } else {
4470                                         componentInstance.setCapabilities(getValidComponentInstanceCapabilitiesRes.left().value());
4471                                 }
4472                         }
4473                         if (!existingnodeTypeMap.containsKey(uploadComponentInstanceInfo.getType())) {
4474                                 log.debug("createResourceInstances - not found lates version for resource instance with name {} and type ", uploadComponentInstanceInfo.getName(), uploadComponentInstanceInfo.getType());
4475                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.INVALID_NODE_TEMPLATE, yamlName, uploadComponentInstanceInfo.getName(), uploadComponentInstanceInfo.getType());
4476                                 return Either.right(responseFormat);
4477                         }
4478                         Resource origResource = existingnodeTypeMap.get(uploadComponentInstanceInfo.getType());
4479                         componentInstance.setName(uploadComponentInstanceInfo.getName());
4480                         componentInstance.setIcon(origResource.getIcon());
4481
4482                         resourcesInstancesMap.put(componentInstance, origResource);
4483
4484                 }
4485                 if (MapUtils.isNotEmpty(resourcesInstancesMap)) {
4486
4487                         StorageOperationStatus status = toscaOperationFacade.associateComponentInstancesToComponent(resource, resourcesInstancesMap, false);
4488                         if (status != null && status != StorageOperationStatus.OK) {
4489                                 log.debug("Failed to add component instances to container component {}", resource.getName());
4490                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(status));
4491                                 eitherResource = Either.right(responseFormat);
4492                                 return eitherResource;
4493                         }
4494
4495                 }
4496
4497                 log.debug("*************Going to get resource {}", resource.getUniqueId());
4498                 ComponentParametersView parametersView = new ComponentParametersView();
4499                 parametersView.disableAll();
4500                 parametersView.setIgnoreComponentInstances(false);
4501                 parametersView.setIgnoreUsers(false);
4502                 parametersView.setIgnoreInputs(false); // inputs are read when creating
4503                 // property values on instances
4504                 Either<Resource, StorageOperationStatus> eitherGerResource = toscaOperationFacade.getToscaElement(resource.getUniqueId(), parametersView);
4505                 log.debug("*************finished to get resource {}", resource.getUniqueId());
4506                 if (eitherGerResource.isRight()) {
4507                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(eitherGerResource.right().value()), resource);
4508
4509                         return Either.right(responseFormat);
4510
4511                 }
4512
4513                 if (eitherGerResource.left().value().getComponentInstances() == null || eitherGerResource.left().value().getComponentInstances().isEmpty()) {
4514
4515                         log.debug("Error when create resource inctanse from csar. ComponentInstances list empty");
4516                         BeEcompErrorManager.getInstance().logBeDaoSystemError("Error when create resource inctanse from csar. ComponentInstances list empty");
4517                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE);
4518                         return Either.right(responseFormat);
4519
4520                 }
4521
4522                 return Either.left(eitherGerResource.left().value());
4523         }
4524
4525         private void setCapabilityNamesTypes(Map<String, List<CapabilityDefinition>> originCapabilities, Map<String, List<UploadCapInfo>> uploadedCapabilities) {
4526                 for(Entry<String, List<UploadCapInfo>> currEntry : uploadedCapabilities.entrySet()){
4527                         if(originCapabilities.containsKey(currEntry.getKey())){
4528                                 currEntry.getValue().stream().forEach(cap -> cap.setType(currEntry.getKey()));
4529                         }
4530                 }
4531                 for(Map.Entry<String, List<CapabilityDefinition>> capabilities : originCapabilities.entrySet()){
4532                         capabilities.getValue().stream().forEach(cap -> {if(uploadedCapabilities.containsKey(cap.getName())){uploadedCapabilities.get(cap.getName()).stream().forEach(c -> {c.setName(cap.getName());c.setType(cap.getType());});};});
4533                 }
4534                 
4535         }
4536
4537         private Either<Resource, ResponseFormat> validateResourceInstanceBeforeCreate(String yamlName, UploadComponentInstanceInfo uploadComponentInstanceInfo, Map<String, Resource> nodeNamespaceMap) {
4538                 log.debug("validateResourceInstanceBeforeCreate - going to validate resource instance with name {} and type before create", uploadComponentInstanceInfo.getName(), uploadComponentInstanceInfo.getType());
4539                 Resource refResource = null;
4540                 if (nodeNamespaceMap.containsKey(uploadComponentInstanceInfo.getType())) {
4541                         refResource = nodeNamespaceMap.get(uploadComponentInstanceInfo.getType());
4542                 } else {
4543                         Either<Resource, StorageOperationStatus> findResourceEither = toscaOperationFacade.getLatestCertifiedNodeTypeByToscaResourceName(uploadComponentInstanceInfo.getType());
4544                         if (findResourceEither.isRight()) {
4545                                 log.debug("validateResourceInstanceBeforeCreate - not found lates version for resource instance with name {} and type ", uploadComponentInstanceInfo.getName(), uploadComponentInstanceInfo.getType());
4546                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(findResourceEither.right().value()));
4547                                 return Either.right(responseFormat);
4548                         }
4549                         refResource = findResourceEither.left().value();
4550                         nodeNamespaceMap.put(refResource.getToscaResourceName(), refResource);
4551                 }
4552                 String componentState = refResource.getComponentMetadataDefinition().getMetadataDataDefinition().getState();
4553                 if (componentState.equals(LifecycleStateEnum.NOT_CERTIFIED_CHECKOUT.name())) {
4554                         log.debug("validateResourceInstanceBeforeCreate - component instance of component {} can not be created because the component is in an illegal state {}.", refResource.getName(), componentState);
4555                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.ILLEGAL_COMPONENT_STATE, refResource.getComponentType().getValue(), refResource.getName(), componentState);
4556                         return Either.right(responseFormat);
4557                 }
4558
4559                 if (!ModelConverter.isAtomicComponent(refResource) && refResource.getResourceType() != ResourceTypeEnum.CVFC) {
4560                         log.debug("validateResourceInstanceBeforeCreate -  ref resource type is  ", refResource.getResourceType());
4561                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.INVALID_NODE_TEMPLATE, yamlName, uploadComponentInstanceInfo.getName(), uploadComponentInstanceInfo.getType());
4562                         return Either.right(responseFormat);
4563                 }
4564                 return Either.left(refResource);
4565         }
4566
4567         private Either<Map<String, UploadComponentInstanceInfo>, ResponseFormat> createResourcesInstanceInfoFromYaml(String yamlFileName, Map<String, Object> toscaJson, Resource resource, Map<String, String> createdNodesToscaResourceNames) {
4568                 Map<String, UploadComponentInstanceInfo> moduleComponentInstances = new HashMap<String, UploadComponentInstanceInfo>();
4569                 Map<String, Object> substitutionMappings = null;
4570                 Either<Map<String, UploadComponentInstanceInfo>, ResponseFormat> result = Either.left(moduleComponentInstances);
4571                 Either<Map<String, Object>, ResultStatusEnum> eitherNodesTemlates = ImportUtils.findFirstToscaMapElement(toscaJson, ToscaTagNamesEnum.NODE_TEMPLATES);
4572                 Either<Map<String, Object>, ResultStatusEnum> eitherSubstitutionMappings = ImportUtils.findFirstToscaMapElement(toscaJson, ToscaTagNamesEnum.SUBSTITUTION_MAPPINGS);
4573                 if (eitherSubstitutionMappings.isLeft()) {
4574                         substitutionMappings = eitherSubstitutionMappings.left().value();
4575                 }
4576                 if (eitherNodesTemlates.isLeft()) {
4577                         Map<String, Object> jsonNodeTemplates = eitherNodesTemlates.left().value();
4578
4579                         Iterator<Entry<String, Object>> nodesNameValue = jsonNodeTemplates.entrySet().iterator();
4580                         while (nodesNameValue.hasNext()) {
4581                                 Entry<String, Object> nodeNameValue = nodesNameValue.next();
4582                                 Either<UploadComponentInstanceInfo, ResponseFormat> eitherNode = createModuleComponentInstanceInfo(nodeNameValue, substitutionMappings, createdNodesToscaResourceNames);
4583                                 if (eitherNode.isRight()) {
4584                                         log.info("error when creating node template:{}, for resource:{}", nodeNameValue.getKey(), resource.getName());
4585                                         return Either.right(eitherNode.right().value());
4586                                 } else {
4587                                         UploadComponentInstanceInfo uploadComponentInstanceInfo = eitherNode.left().value();
4588                                         moduleComponentInstances.put(nodeNameValue.getKey(), uploadComponentInstanceInfo);
4589                                 }
4590
4591                         }
4592
4593                 }
4594                 if (moduleComponentInstances.isEmpty()) {
4595                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE, yamlFileName);
4596                         return Either.right(responseFormat);
4597                 }
4598
4599                 return result;
4600         }
4601
4602         @SuppressWarnings("unchecked")
4603         private Either<UploadComponentInstanceInfo, ResponseFormat> createModuleComponentInstanceInfo(Entry<String, Object> nodeTemplateJsonEntry, Map<String, Object> substitutionMappings, Map<String, String> createdNodesToscaResourceNames) {
4604
4605                 UploadComponentInstanceInfo nodeTemplateInfo = new UploadComponentInstanceInfo();
4606                 Either<UploadComponentInstanceInfo, ResponseFormat> result = Either.left(nodeTemplateInfo);
4607                 nodeTemplateInfo.setName(nodeTemplateJsonEntry.getKey());
4608                 try {
4609                         if (nodeTemplateJsonEntry.getValue() instanceof String) {
4610                                 String nodeTemplateJsonString = (String) nodeTemplateJsonEntry.getValue();
4611                                 nodeTemplateInfo.setType(nodeTemplateJsonString);
4612                         } else if (nodeTemplateJsonEntry.getValue() instanceof Map) {
4613                                 Map<String, Object> nodeTemplateJsonMap = (Map<String, Object>) nodeTemplateJsonEntry.getValue();
4614                                 // Type
4615                                 if (nodeTemplateJsonMap.containsKey(ToscaTagNamesEnum.TYPE.getElementName())) {
4616                                         String toscaResourceType = (String) nodeTemplateJsonMap.get(ToscaTagNamesEnum.TYPE.getElementName());
4617                                         if (createdNodesToscaResourceNames.containsKey(toscaResourceType)) {
4618                                                 toscaResourceType = createdNodesToscaResourceNames.get(toscaResourceType);
4619                                         }
4620                                         nodeTemplateInfo.setType(toscaResourceType);
4621                                 }
4622
4623                                 if (nodeTemplateJsonMap.containsKey(ToscaTagNamesEnum.REQUIREMENTS.getElementName())) {
4624                                         Either<Map<String, List<UploadReqInfo>>, ResponseFormat> regResponse = createReqModuleFromYaml(nodeTemplateInfo, nodeTemplateJsonMap);
4625                                         if (regResponse.isRight())
4626                                                 return Either.right(regResponse.right().value());
4627                                         if (regResponse.left().value().size() > 0) {
4628                                                 nodeTemplateInfo.setRequirements(regResponse.left().value());
4629                                         }
4630                                 }
4631
4632                                 if (nodeTemplateJsonMap.containsKey(ToscaTagNamesEnum.CAPABILITIES.getElementName())) {
4633                                         Either<Map<String, List<UploadCapInfo>>, ResponseFormat> eitherCapRes = createCapModuleFromYaml(nodeTemplateInfo, nodeTemplateJsonMap);
4634                                         if (eitherCapRes.isRight())
4635                                                 return Either.right(eitherCapRes.right().value());
4636                                         if (eitherCapRes.left().value().size() > 0) {
4637                                                 nodeTemplateInfo.setCapabilities(eitherCapRes.left().value());
4638                                         }
4639                                 }
4640                                 if (nodeTemplateJsonMap.containsKey(ToscaTagNamesEnum.PROPERTIES.getElementName())) {
4641                                         Either<Map<String, List<UploadPropInfo>>, ResponseFormat> regResponse = createPropModuleFromYaml(nodeTemplateJsonMap);
4642                                         if (regResponse.isRight())
4643                                                 return Either.right(regResponse.right().value());
4644                                         if (regResponse.left().value().size() > 0) {
4645                                                 nodeTemplateInfo.setProperties(regResponse.left().value());
4646                                         }
4647                                 }
4648                                 if (substitutionMappings != null) {
4649                                         if (substitutionMappings.containsKey(ToscaTagNamesEnum.CAPABILITIES.getElementName())) {
4650                                                 Either<Map<String, String>, ResponseFormat> getCapNamesToUpdateRes = getNamesToUpdate(nodeTemplateInfo, (Map<String, List<String>>) substitutionMappings.get(ToscaTagNamesEnum.CAPABILITIES.getElementName()));
4651                                                 if (getCapNamesToUpdateRes.isRight())
4652                                                         return Either.right(getCapNamesToUpdateRes.right().value());
4653                                                 if (getCapNamesToUpdateRes.left().value().size() > 0) {
4654                                                         nodeTemplateInfo.setCapabilitiesNamesToUpdate(getCapNamesToUpdateRes.left().value());
4655                                                 }
4656                                         }
4657                                         if (substitutionMappings.containsKey(ToscaTagNamesEnum.REQUIREMENTS.getElementName())) {
4658                                                 Either<Map<String, String>, ResponseFormat> getReqNamesToUpdateRes = getNamesToUpdate(nodeTemplateInfo, (Map<String, List<String>>) substitutionMappings.get(ToscaTagNamesEnum.REQUIREMENTS.getElementName()));
4659                                                 if (getReqNamesToUpdateRes.isRight())
4660                                                         return Either.right(getReqNamesToUpdateRes.right().value());
4661                                                 if (getReqNamesToUpdateRes.left().value().size() > 0) {
4662                                                         nodeTemplateInfo.setRequirementsNamesToUpdate(getReqNamesToUpdateRes.left().value());
4663                                                 }
4664                                         }
4665                                 }
4666                         } else {
4667
4668                                 result = Either.right(componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE));
4669
4670                         }
4671                 } catch (Exception e) {
4672                         BeEcompErrorManager.getInstance().logBeSystemError("Import Resource - create capability");
4673                         log.debug("error when creating capability, message:{}", e.getMessage(), e);
4674                         result = Either.right(componentsUtils.getResponseFormat(ActionStatus.INVALID_YAML));
4675                 }
4676
4677                 return result;
4678         }
4679
4680         private Either<Map<String, String>, ResponseFormat> getNamesToUpdate(UploadComponentInstanceInfo nodeTemplateInfo, Map<String, List<String>> elements) {
4681                 Either<Map<String, String>, ResponseFormat> response;
4682                 try {
4683                         Map<String, String> namesToUpdate = elements.entrySet().stream().filter(e -> e.getValue().get(0).equalsIgnoreCase(nodeTemplateInfo.getName())).collect(Collectors.toMap(e -> e.getValue().get(1), e -> e.getKey()));
4684                         response = Either.left(namesToUpdate);
4685                 } catch (Exception e) {
4686                         log.debug("The exception {} occured upon adding names to update for instance {} . ", e.getMessage(), nodeTemplateInfo.getName());
4687                         response = Either.right(componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR));
4688                 }
4689                 return response;
4690         }
4691
4692         @SuppressWarnings("unchecked")
4693         private Either<Map<String, List<UploadPropInfo>>, ResponseFormat> createPropModuleFromYaml(Map<String, Object> nodeTemplateJsonMap) {
4694                 Map<String, List<UploadPropInfo>> moduleProp = new HashMap<String, List<UploadPropInfo>>();
4695                 Either<Map<String, List<UploadPropInfo>>, ResponseFormat> response = Either.left(moduleProp);
4696                 Either<Map<String, Object>, ResultStatusEnum> toscaProperties = ImportUtils.findFirstToscaMapElement(nodeTemplateJsonMap, ToscaTagNamesEnum.PROPERTIES);
4697                 if (toscaProperties.isLeft()) {
4698                         Map<String, Object> jsonProperties = toscaProperties.left().value();
4699                         for (Entry<String, Object> jsonPropObj : jsonProperties.entrySet()) {
4700                                 // Property
4701                                 String propName = jsonPropObj.getKey();
4702                                 Object propValue = jsonPropObj.getValue();
4703
4704                                 if (valueContainsPattern(STR_REPLACE_PATTERN, propValue)) {
4705                                         log.trace("Ignore property value {}.", propName);
4706                                         continue;
4707                                 }
4708
4709                                 if (valueContainsPattern(TOKEN_PATTERN, propValue)) {
4710                                         log.trace("Ignore property value {}.", propName);
4711                                         continue;
4712                                 }
4713                                 if (valueContainsPattern(GET_PROPERTY_PATTERN, propValue)) {
4714                                         log.trace("Ignore property value {}.", propName);
4715                                         continue;
4716                                 }
4717
4718                                 if (valueContainsPattern(CONCAT_PATTERN, propValue)) {
4719                                         log.trace("Ignore property value {}.", propName);
4720                                         continue;
4721                                 }
4722
4723                                 UploadPropInfo propertyDef = new UploadPropInfo();
4724                                 propertyDef.setValue(propValue);
4725                                 propertyDef.setName(propName);
4726                                 if (propValue instanceof Map) {
4727                                         if (((Map<String, Object>) propValue).containsKey(ToscaTagNamesEnum.TYPE.getElementName())) {
4728                                                 propertyDef.setType(((Map<String, Object>) propValue).get(ToscaTagNamesEnum.TYPE.getElementName()).toString());
4729                                         }
4730
4731                                         if (((Map<String, Object>) propValue).containsKey(ToscaTagNamesEnum.GET_INPUT.getElementName())
4732                                                         || ImportUtils.getPropertyJsonStringValue(propValue, ToscaPropertyType.MAP.getType()).contains(ToscaTagNamesEnum.GET_INPUT.getElementName())) {
4733                                                 createGetInputModuleFromMap(propName, (Map<String, Object>) propValue, propertyDef);
4734                                         }
4735
4736                                         if (((Map<String, Object>) propValue).containsKey(ToscaTagNamesEnum.DESCRIPTION.getElementName())) {
4737                                                 propertyDef.setDescription(((Map<String, Object>) propValue).get(ToscaTagNamesEnum.DESCRIPTION.getElementName()).toString());
4738                                         }
4739                                         if (((Map<String, Object>) propValue).containsKey(ToscaTagNamesEnum.DEFAULT_VALUE.getElementName())) {
4740                                                 propertyDef.setValue(((Map<String, Object>) propValue).get(ToscaTagNamesEnum.DEFAULT_VALUE.getElementName()));
4741                                         }
4742                                         if (((Map<String, Object>) propValue).containsKey(ToscaTagNamesEnum.IS_PASSWORD.getElementName())) {
4743                                                 propertyDef.setPassword(Boolean.getBoolean(((Map<String, Object>) propValue).get(ToscaTagNamesEnum.IS_PASSWORD.getElementName()).toString()));
4744                                         } else {
4745                                                 propertyDef.setValue(propValue);
4746                                         }
4747                                 } else if (propValue instanceof List) {
4748                                         List<Object> propValueList = (List<Object>) propValue;
4749
4750                                         createInputPropList(propertyDef, propValueList);
4751                                         propertyDef.setValue(propValue);
4752                                 }
4753
4754                                 if (moduleProp.containsKey(propName)) {
4755                                         moduleProp.get(propName).add(propertyDef);
4756                                 } else {
4757                                         List<UploadPropInfo> list = new ArrayList<UploadPropInfo>();
4758                                         list.add(propertyDef);
4759                                         moduleProp.put(propName, list);
4760                                 }
4761                         }
4762                 }
4763                 return response;
4764         }
4765
4766         @SuppressWarnings("unchecked")
4767         private void createInputPropList(UploadPropInfo propertyDef, List<Object> propValueList) {
4768                 for (Object objValue : propValueList) {
4769
4770                         if (objValue instanceof Map) {
4771                                 Map<String, Object> objMap = (Map<String, Object>) objValue;
4772                                 if (objMap.containsKey(ToscaTagNamesEnum.GET_INPUT.getElementName()))
4773                                         createGetInputModuleFromMap(propertyDef.getName(), objMap, propertyDef);
4774                                 else {
4775                                         Set<String> keys = objMap.keySet();
4776                                         for (String key : keys) {
4777                                                 Object value = objMap.get(key);
4778                                                 if (value instanceof Map) {
4779                                                         createGetInputModuleFromMap(key, (Map<String, Object>) value, propertyDef);
4780
4781                                                 } else if (value instanceof List) {
4782                                                         List<Object> propSubValueList = (List<Object>) value;
4783
4784                                                         createInputPropList(propertyDef, propSubValueList);
4785                                                 }
4786
4787                                         }
4788                                 }
4789
4790                         } else if (objValue instanceof List) {
4791                                 List<Object> propSubValueList = (List<Object>) objValue;
4792
4793                                 createInputPropList(propertyDef, propSubValueList);
4794
4795                         }
4796
4797                 }
4798         }
4799
4800         @SuppressWarnings("unchecked")
4801         private void createGetInputModuleFromMap(String propName, Map<String, Object> propValue, UploadPropInfo propertyDef) {
4802
4803                 if (propValue.containsKey(ToscaTagNamesEnum.GET_INPUT.getElementName())) {
4804                         Object getInput = propValue.get(ToscaTagNamesEnum.GET_INPUT.getElementName());
4805                         GetInputValueDataDefinition getInputInfo = new GetInputValueDataDefinition();
4806                         List<GetInputValueDataDefinition> getInputs = propertyDef.getGet_input();
4807                         if (getInputs == null) {
4808                                 getInputs = new ArrayList<GetInputValueDataDefinition>();
4809                         }
4810                         if (getInput instanceof String) {
4811
4812                                 getInputInfo.setInputName((String) getInput);
4813                                 getInputInfo.setPropName(propName);
4814
4815                         } else if (getInput instanceof List) {
4816                                 List<Object> getInputList = (List<Object>) getInput;
4817                                 getInputInfo.setPropName(propName);
4818                                 getInputInfo.setInputName((String) getInputList.get(0));
4819                                 if (getInputList.size() > 1) {
4820                                         Object indexObj = getInputList.get(1);
4821                                         if (indexObj instanceof Integer) {
4822                                                 getInputInfo.setIndexValue((Integer) indexObj);
4823                                         } else if (indexObj instanceof Float) {
4824                                                 int index = ((Float) indexObj).intValue();
4825                                                 getInputInfo.setIndexValue(index);
4826                                         } else if (indexObj instanceof Map && ((Map<String, Object>) indexObj).containsKey(ToscaTagNamesEnum.GET_INPUT.getElementName())) {
4827                                                 Object index = ((Map<String, Object>) indexObj).get(ToscaTagNamesEnum.GET_INPUT.getElementName());
4828                                                 GetInputValueDataDefinition getInputInfoIndex = new GetInputValueDataDefinition();
4829                                                 getInputInfoIndex.setInputName((String) index);
4830                                                 getInputInfoIndex.setPropName(propName);
4831                                                 getInputInfo.setGetInputIndex(getInputInfoIndex);
4832                                         }
4833                                         getInputInfo.setList(true);
4834                                 }
4835
4836                         }
4837                         getInputs.add(getInputInfo);
4838                         propertyDef.setGet_input(getInputs);
4839                         propertyDef.setValue(propValue);
4840                 } else {
4841                         Set<String> keys = propValue.keySet();
4842                         for (String key : keys) {
4843                                 Object value = propValue.get(key);
4844                                 if (value instanceof Map) {
4845                                         createGetInputModuleFromMap(key, (Map<String, Object>) value, propertyDef);
4846
4847                                 } else if (value instanceof List) {
4848                                         List<Object> valueList = (List<Object>) value;
4849                                         for (Object o : valueList) {
4850                                                 if (o instanceof Map) {
4851                                                         createGetInputModuleFromMap(key, (Map<String, Object>) o, propertyDef);
4852
4853                                                 }
4854                                         }
4855
4856                                 }
4857
4858                         }
4859
4860                 }
4861         }
4862
4863         /*
4864          * private boolean valueContainsStrReplace(Object propValue) {
4865          *
4866          * log.debug("valueContainsStrReplace value is {}", propValue); boolean result = false; if (propValue != null) { log.debug("valueContainsStrReplace value is {}", propValue.getClass()); Matcher matcher =
4867          * STR_REPLACE_PATTERN.matcher(propValue.toString()); result = matcher.find(); }
4868          *
4869          * return result; }
4870          *
4871          * private boolean valueContainsToken(Object propValue) {
4872          *
4873          * log.debug("valueContainsToken value is {}", propValue); boolean result = false; if (propValue != null) { log.debug("valueContainsToken value is {}", propValue.getClass()); Matcher matcher = TOKEN_PATTERN.matcher(propValue.toString()); result =
4874          * matcher.find(); }
4875          *
4876          * return result; }
4877          */
4878
4879         private boolean valueContainsPattern(Pattern pattern, Object propValue) {
4880
4881                 log.debug("valueContainsToken value is {}", propValue);
4882                 boolean result = false;
4883                 if (propValue != null) {
4884                         log.trace("valueContainspattern value is {}", propValue.getClass());
4885                         Matcher matcher = pattern.matcher(propValue.toString());
4886                         result = matcher.find();
4887                 }
4888
4889                 return result;
4890
4891         }
4892         @SuppressWarnings("unchecked")
4893         private Either<Map<String, List<UploadReqInfo>>, ResponseFormat> createReqModuleFromYaml(UploadComponentInstanceInfo nodeTemplateInfo, Map<String, Object> nodeTemplateJsonMap) {
4894                 Map<String, List<UploadReqInfo>> moduleRequirements = new HashMap<String, List<UploadReqInfo>>();
4895                 Either<Map<String, List<UploadReqInfo>>, ResponseFormat> response = Either.left(moduleRequirements);
4896                 Either<List<Object>, ResultStatusEnum> requirementsListRes = ImportUtils.findFirstToscaListElement(nodeTemplateJsonMap, ToscaTagNamesEnum.REQUIREMENTS);
4897                 
4898                 if (requirementsListRes.isLeft()) {
4899                         for (Object jsonReqObj : requirementsListRes.left().value()) {
4900                                 String reqName = ((Map<String, Object>) jsonReqObj).keySet().iterator().next();
4901                                 Object reqJson = ((Map<String, Object>) jsonReqObj).get(reqName);
4902                                 Either<UploadReqInfo, ResponseFormat> eitherCap = addModuleNodeTemplateReq(nodeTemplateInfo, moduleRequirements, reqJson, reqName);
4903                                 if (eitherCap.isRight()) {
4904                                         return Either.right(eitherCap.right().value());
4905                                 }
4906                         }
4907                 } else {
4908                         Either<Map<String,Object>, ResultStatusEnum> requirementsMapRes = ImportUtils.findFirstToscaMapElement(nodeTemplateJsonMap, ToscaTagNamesEnum.REQUIREMENTS);
4909                         if (requirementsMapRes.isLeft()) {
4910                                 for (Map.Entry<String, Object>  entry: requirementsMapRes.left().value().entrySet()) {
4911                                         String reqName = entry.getKey();
4912                                         Object reqJson = entry.getValue();
4913                                         Either<UploadReqInfo, ResponseFormat> eitherCap = addModuleNodeTemplateReq(nodeTemplateInfo, moduleRequirements, reqJson, reqName);
4914                                         if (eitherCap.isRight()) {
4915                                                 return Either.right(eitherCap.right().value());
4916                                         }
4917                                 }
4918                         }
4919                 }
4920                 return response;
4921         }
4922
4923         private Either<UploadReqInfo, ResponseFormat> addModuleNodeTemplateReq(UploadComponentInstanceInfo nodeTemplateInfo,Map<String, List<UploadReqInfo>> moduleRequirements, Object requirementJson, String requirementName) {
4924                 
4925                 Either<UploadReqInfo, ResponseFormat> eitherRequirement = createModuleNodeTemplateReg(requirementJson);
4926                 if (eitherRequirement.isRight()) {
4927                         log.info("error when creating Requirement:{}, for node:{}", requirementName, nodeTemplateInfo);
4928                         return Either.right(eitherRequirement.right().value());
4929                 } else {
4930                         UploadReqInfo requirementDef = eitherRequirement.left().value();
4931                         requirementDef.setName(requirementName);
4932                         if (moduleRequirements.containsKey(requirementName)) {
4933                                 moduleRequirements.get(requirementName).add(requirementDef);
4934                         } else {
4935                                 List<UploadReqInfo> list = new ArrayList<UploadReqInfo>();
4936                                 list.add(requirementDef);
4937                                 moduleRequirements.put(requirementName, list);
4938                         }
4939                 }
4940                 return Either.left(eitherRequirement.left().value());
4941         }
4942         
4943                 @SuppressWarnings("unchecked")
4944         private Either<Map<String, List<UploadCapInfo>>, ResponseFormat> createCapModuleFromYaml(UploadComponentInstanceInfo nodeTemplateInfo, Map<String, Object> nodeTemplateJsonMap) {
4945                 Map<String, List<UploadCapInfo>> moduleCap = new HashMap<>();
4946                 Either<Map<String, List<UploadCapInfo>>, ResponseFormat> response = Either.left(moduleCap);
4947                 Either<List<Object>, ResultStatusEnum> capabilitiesListRes = ImportUtils.findFirstToscaListElement(nodeTemplateJsonMap, ToscaTagNamesEnum.CAPABILITIES);
4948                 if (capabilitiesListRes.isLeft()) {
4949                         for (Object jsonCapObj : capabilitiesListRes.left().value()) {
4950                                 String key = ((Map<String, Object>) jsonCapObj).keySet().iterator().next();
4951                                 Object capJson = ((Map<String, Object>) jsonCapObj).get(key);
4952                                 Either<UploadCapInfo, ResponseFormat> eitherCap = addModuleNodeTemplateCap(nodeTemplateInfo, moduleCap, capJson, key);
4953                                 if (eitherCap.isRight()) {
4954                                         return Either.right(eitherCap.right().value());
4955                                 }
4956                         }
4957                 } else {
4958                         Either<Map<String,Object>, ResultStatusEnum> capabilitiesMapRes = ImportUtils.findFirstToscaMapElement(nodeTemplateJsonMap, ToscaTagNamesEnum.CAPABILITIES);
4959                         if (capabilitiesMapRes.isLeft()) {
4960                                 for (Map.Entry<String, Object>  entry: capabilitiesMapRes.left().value().entrySet()) {
4961                                         String capName = entry.getKey();
4962                                         Object capJson = entry.getValue();
4963                                         Either<UploadCapInfo, ResponseFormat> eitherCap = addModuleNodeTemplateCap(nodeTemplateInfo, moduleCap, capJson, capName);
4964                                         if (eitherCap.isRight()) {
4965                                                 return Either.right(eitherCap.right().value());
4966                                         }
4967                                 }
4968                         }
4969                 }
4970                 return response;
4971         }
4972
4973         private Either<UploadCapInfo, ResponseFormat> addModuleNodeTemplateCap(UploadComponentInstanceInfo nodeTemplateInfo, Map<String, List<UploadCapInfo>> moduleCap, Object capJson, String key) {
4974                 
4975                 Either<UploadCapInfo, ResponseFormat> eitherCap = createModuleNodeTemplateCap(capJson);
4976                 if (eitherCap.isRight()) {
4977                         log.info("error when creating Capability:{}, for node:{}", key, nodeTemplateInfo);
4978                         return Either.right(eitherCap.right().value());
4979                 } else {
4980                         UploadCapInfo capabilityDef = eitherCap.left().value();
4981                         capabilityDef.setKey(key);
4982                         if (moduleCap.containsKey(key)) {
4983                                 moduleCap.get(key).add(capabilityDef);
4984                         } else {
4985                                 List<UploadCapInfo> list = new ArrayList<UploadCapInfo>();
4986                                 list.add(capabilityDef);
4987                                 moduleCap.put(key, list);
4988                         }
4989                 }
4990                 return Either.left( eitherCap.left().value());
4991         }
4992
4993         @SuppressWarnings("unchecked")
4994         private Either<UploadCapInfo, ResponseFormat> createModuleNodeTemplateCap(Object capObject) {
4995                 UploadCapInfo capTemplateInfo = new UploadCapInfo();
4996                 Either<UploadCapInfo, ResponseFormat> result = Either.left(capTemplateInfo);
4997
4998                 if (capObject instanceof String) {
4999                         String nodeTemplateJsonString = (String) capObject;
5000                         capTemplateInfo.setNode(nodeTemplateJsonString);
5001                 } else if (capObject instanceof Map) {
5002                         Map<String, Object> nodeTemplateJsonMap = (Map<String, Object>) capObject;
5003                         // Type
5004                         if (nodeTemplateJsonMap.containsKey(ToscaTagNamesEnum.NODE.getElementName())) {
5005                                 capTemplateInfo.setNode((String) nodeTemplateJsonMap.get(ToscaTagNamesEnum.NODE.getElementName()));
5006                         }
5007                         if (nodeTemplateJsonMap.containsKey(ToscaTagNamesEnum.TYPE.getElementName())) {
5008                                 capTemplateInfo.setType((String) nodeTemplateJsonMap.get(ToscaTagNamesEnum.TYPE.getElementName()));
5009                         }
5010                         if (nodeTemplateJsonMap.containsKey(ToscaTagNamesEnum.VALID_SOURCE_TYPES.getElementName())) {
5011                                 Either<List<Object>, ResultStatusEnum> validSourceTypesRes = ImportUtils.findFirstToscaListElement(nodeTemplateJsonMap, ToscaTagNamesEnum.VALID_SOURCE_TYPES);
5012                                 if (validSourceTypesRes.isLeft()) {
5013                                         capTemplateInfo.setValidSourceTypes(validSourceTypesRes.left().value().stream().map(o -> o.toString()).collect(Collectors.toList()));
5014                                 }
5015                         }
5016                         if (nodeTemplateJsonMap.containsKey(ToscaTagNamesEnum.PROPERTIES.getElementName())) {
5017                                 Either<Map<String, List<UploadPropInfo>>, ResponseFormat> regResponse = createPropModuleFromYaml(nodeTemplateJsonMap);
5018                                 if (regResponse.isRight())
5019                                         return Either.right(regResponse.right().value());
5020                                 if (!regResponse.left().value().isEmpty()) {
5021                                         List<UploadPropInfo> properties = new ArrayList<UploadPropInfo>();
5022                                         regResponse.left().value().values().forEach(list -> properties.addAll(list));
5023                                         if (!properties.isEmpty())
5024                                                 capTemplateInfo.setProperties(properties);
5025                                 }
5026                         }
5027                 }
5028                 return result;
5029         }
5030
5031         @SuppressWarnings("unchecked")
5032         private Either<UploadReqInfo, ResponseFormat> createModuleNodeTemplateReg(Object regObject) {
5033
5034                 UploadReqInfo regTemplateInfo = new UploadReqInfo();
5035                 Either<UploadReqInfo, ResponseFormat> result = Either.left(regTemplateInfo);
5036
5037                 if (regObject instanceof String) {
5038                         String nodeTemplateJsonString = (String) regObject;
5039                         regTemplateInfo.setNode(nodeTemplateJsonString);
5040                 } else if (regObject instanceof Map) {
5041                         Map<String, Object> nodeTemplateJsonMap = (Map<String, Object>) regObject;
5042                         // Type
5043                         if (nodeTemplateJsonMap.containsKey(ToscaTagNamesEnum.NODE.getElementName())) {
5044                                 regTemplateInfo.setNode((String) nodeTemplateJsonMap.get(ToscaTagNamesEnum.NODE.getElementName()));
5045                         }
5046                         // US740820 Relate RIs according to capability name
5047                         if (nodeTemplateJsonMap.containsKey(ToscaTagNamesEnum.CAPABILITY.getElementName())) {
5048                                 regTemplateInfo.setCapabilityName((String) nodeTemplateJsonMap.get(ToscaTagNamesEnum.CAPABILITY.getElementName()));
5049                         }
5050                 }
5051                 return result;
5052         }
5053
5054         public Either<Resource, ResponseFormat> propagateStateToCertified(User user, Resource resource, LifecycleChangeInfoWithAction lifecycleChangeInfo, boolean inTransaction, boolean needLock, boolean forceCertificationAllowed) {
5055                 
5056                 Either<Resource, ResponseFormat> result = null;
5057                 try {
5058                         if(resource.getLifecycleState() != LifecycleStateEnum.CERTIFIED && forceCertificationAllowed && lifecycleBusinessLogic.isFirstCertification(resource.getVersion())){
5059                                 result = nodeForceCertification(resource, user, lifecycleChangeInfo, inTransaction, needLock);
5060                                 if(result.isRight()){
5061                                         return result;
5062                                 }
5063                                 resource = result.left().value();
5064                         }
5065                         if (resource.getLifecycleState() == LifecycleStateEnum.CERTIFIED) {
5066                                 Either<Either<ArtifactDefinition, Operation>, ResponseFormat> eitherPopulated = populateToscaArtifacts(resource, user, false, inTransaction, needLock);
5067                                 result = eitherPopulated.isLeft() ? Either.left(resource) : Either.right(eitherPopulated.right().value());
5068                                 return result;
5069                         }
5070                         return nodeFullCertification(resource.getUniqueId(), user, lifecycleChangeInfo, inTransaction, needLock);
5071                 } catch (Exception e) {
5072                         log.debug("The exception {} has occured upon certification of resource {}. ", e.getMessage(), resource.getName());
5073                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR));
5074                 } finally {
5075                         if (result == null || result.isRight()) {
5076                                 BeEcompErrorManager.getInstance().logBeSystemError("Change LifecycleState - Certify");
5077                                 if (inTransaction == false) {
5078                                         log.debug("operation failed. do rollback");
5079                                         titanDao.rollback();
5080                                 }
5081                         } else if (inTransaction == false) {
5082                                 log.debug("operation success. do commit");
5083                                 titanDao.commit();
5084                         }
5085                 }
5086         }
5087
5088         private Either<Resource, ResponseFormat> nodeFullCertification(String uniqueId, User user, LifecycleChangeInfoWithAction lifecycleChangeInfo, boolean inTransaction, boolean needLock) {
5089                 Either<Resource, ResponseFormat> result = lifecycleBusinessLogic.changeState(uniqueId, user, LifeCycleTransitionEnum.CERTIFICATION_REQUEST, lifecycleChangeInfo, inTransaction, needLock);
5090                 if (result.isLeft()) {
5091                         result = lifecycleBusinessLogic.changeState(uniqueId, user, LifeCycleTransitionEnum.START_CERTIFICATION, lifecycleChangeInfo, inTransaction, needLock);
5092                 }
5093                 if (result.isLeft()) {
5094                         result = lifecycleBusinessLogic.changeState(uniqueId, user, LifeCycleTransitionEnum.CERTIFY, lifecycleChangeInfo, inTransaction, needLock);
5095                 }
5096                 return result;
5097         }
5098
5099         private Either<Resource, ResponseFormat> nodeForceCertification(Resource resource, User user, LifecycleChangeInfoWithAction lifecycleChangeInfo, boolean inTransaction, boolean needLock) {
5100                 return lifecycleBusinessLogic.forceResourceCertification(resource, user, lifecycleChangeInfo, inTransaction, needLock);
5101         }
5102
5103         /*
5104          * /**
5105          *
5106          * @deprecated Use {@link #createOrUpdateResourceByImport(Resource,User,boolean, boolean,boolean)} instead
5107          */
5108         /*
5109          * public Either<ImmutablePair<Resource, ActionStatus>, ResponseFormat> createOrUpdateResourceByImport(Resource resource, User user, AuditingActionEnum auditingEnum, boolean isNormative, boolean needLock) { return
5110          * createOrUpdateResourceByImport(resource, user, isNormative, false, needLock); }
5111          */
5112
5113         public Either<ImmutablePair<Resource, ActionStatus>, ResponseFormat> createOrUpdateResourceByImport(Resource resource, User user, boolean isNormative, boolean isInTransaction, boolean needLock, CsarInfo csarInfo, String nodeName, boolean isNested) {
5114
5115                 // check if resource already exist
5116                 Either<Resource, StorageOperationStatus> latestByName = toscaOperationFacade.getLatestByName(resource.getName());
5117                 Either<ImmutablePair<Resource, ActionStatus>, ResponseFormat> result = null;
5118
5119                 // create
5120                 if (latestByName.isRight() && latestByName.right().value().equals(StorageOperationStatus.NOT_FOUND)) {
5121
5122                         Either<Resource, StorageOperationStatus> latestByToscaName = toscaOperationFacade.getLatestByToscaResourceName(resource.getToscaResourceName());
5123                         if (csarInfo!= null && csarInfo.isUpdate() && nodeName != null && latestByToscaName.isRight() && latestByToscaName.right().value().equals(StorageOperationStatus.NOT_FOUND)){
5124                                 latestByToscaName = toscaOperationFacade.getLatestByToscaResourceName(buildNestedToscaResourceName(resource.getResourceType().name(), csarInfo.getVfResourceName(), nodeName).getRight());
5125                                 // update
5126                                 if (latestByToscaName.isLeft()) {
5127                                         log.debug("validate derived before update");
5128                                         Either<Boolean, ResponseFormat> eitherValidation = validateNestedDerivedFromDuringUpdate(latestByToscaName.left().value(), resource, ValidationUtils.hasBeenCertified(latestByToscaName.left().value().getVersion()));
5129                                         if (eitherValidation.isRight()) {
5130                                                 result = createResourceByImport(resource, user, isNormative, isInTransaction, csarInfo);
5131                                         } else {
5132                                                 result = updateExistingResourceByImport(resource, latestByToscaName.left().value(), user, isNormative, needLock, isNested);
5133                                         }
5134                                 }
5135                         }
5136                         if (result == null && latestByToscaName.isRight() && latestByToscaName.right().value().equals(StorageOperationStatus.NOT_FOUND)){
5137                                 result = createResourceByImport(resource, user, isNormative, isInTransaction, csarInfo);
5138                         } else if (result == null){
5139                                 StorageOperationStatus status = latestByName.right().value();
5140                                 BeEcompErrorManager.getInstance().logBeComponentMissingError("Create / Update resource by import", ComponentTypeEnum.RESOURCE.getValue(), resource.getName());
5141                                 log.debug("resource already exist {}. status={}", resource.getName(), status);
5142                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.RESOURCE_ALREADY_EXISTS);
5143                                 componentsUtils.auditResource(responseFormat, user, resource, "", "", AuditingActionEnum.IMPORT_RESOURCE, null);
5144                                 result = Either.right(responseFormat);
5145                         }
5146
5147                 }
5148
5149                 // update
5150                 else if (latestByName.isLeft()) {
5151                         result = updateExistingResourceByImport(resource, latestByName.left().value(), user, isNormative, needLock, isNested);
5152                 }
5153
5154                 // error
5155                 else {
5156                         StorageOperationStatus status = latestByName.right().value();
5157                         log.debug("failed to get latest version of resource {}. status={}", resource.getName(), status);
5158                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(latestByName.right().value()), resource);
5159                         componentsUtils.auditResource(responseFormat, user, resource, "", "", AuditingActionEnum.IMPORT_RESOURCE, null);
5160                         result = Either.right(responseFormat);
5161                 }
5162                 return result;
5163
5164         }
5165
5166         private Either<ImmutablePair<Resource, ActionStatus>, ResponseFormat> createResourceByImport(Resource resource, User user, boolean isNormative, boolean isInTransaction, CsarInfo csarInfo) {
5167                 log.debug("resource with name {} does not exist. create new resource", resource.getName());
5168                 Either<Resource, ResponseFormat> response = validateResourceBeforeCreate(resource, user, AuditingActionEnum.IMPORT_RESOURCE, isInTransaction, csarInfo);
5169                 if (response.isRight()) {
5170                         return Either.right(response.right().value());
5171                 }
5172                 Either<Resource, ResponseFormat> createResponse = createResourceByDao(resource, user, AuditingActionEnum.IMPORT_RESOURCE, isNormative, isInTransaction, null);
5173                 if (createResponse.isRight()) {
5174                         return Either.right(createResponse.right().value());
5175                 } else {
5176                         ImmutablePair<Resource, ActionStatus> resourcePair = new ImmutablePair<>(createResponse.left().value(), ActionStatus.CREATED);
5177                         ASDCKpiApi.countImportResourcesKPI();
5178                         return Either.left(resourcePair);
5179
5180                 }
5181         }
5182
5183         public boolean isResourceExist(String resourceName) {
5184                 Either<Resource, StorageOperationStatus> latestByName = toscaOperationFacade.getLatestByName(resourceName);
5185                 return latestByName.isLeft();
5186         }
5187
5188         private Either<ImmutablePair<Resource, ActionStatus>, ResponseFormat> updateExistingResourceByImport(Resource newResource, Resource oldResource, User user, boolean inTransaction, boolean needLock, boolean isNested) {
5189                 String lockedResourceId = oldResource.getUniqueId();
5190                 log.debug("found resource: name={}, id={}, version={}, state={}", oldResource.getName(), lockedResourceId, oldResource.getVersion(), oldResource.getLifecycleState());
5191                 Either<ImmutablePair<Resource, ActionStatus>, ResponseFormat> result = null;
5192                 try {
5193                         if (needLock) {
5194                                 Either<Boolean, ResponseFormat> lockResult = lockComponent(lockedResourceId, oldResource, "Update Resource by Import");
5195                                 if (lockResult.isRight()) {
5196                                         return Either.right(lockResult.right().value());
5197                                 }
5198                         }
5199
5200                         Either<Resource, ResponseFormat> prepareResourceForUpdate = prepareResourceForUpdate(oldResource, user, inTransaction, false);
5201                         if (prepareResourceForUpdate.isRight()) {
5202                                 ResponseFormat responseFormat = prepareResourceForUpdate.right().value();
5203                                 log.info("resource {} cannot be updated. reason={}", lockedResourceId, responseFormat.getFormattedMessage());
5204                                 componentsUtils.auditResource(responseFormat, user, newResource, oldResource.getLifecycleState().name(), oldResource.getVersion(), AuditingActionEnum.IMPORT_RESOURCE, null);
5205                                 result = Either.right(prepareResourceForUpdate.right().value());
5206                                 return result;
5207                         }
5208                         oldResource = prepareResourceForUpdate.left().value();
5209
5210                         mergeOldResourceMetadataWithNew(oldResource, newResource);
5211
5212                         Either<Boolean, ResponseFormat> validateFieldsResponse = validateResourceFieldsBeforeUpdate(oldResource, newResource, inTransaction, isNested);
5213                         if (validateFieldsResponse.isRight()) {
5214                                 result = Either.right(validateFieldsResponse.right().value());
5215                                 return result;
5216                         }
5217                         
5218                         validateFieldsResponse = validateCapabilityTypesCreate(user, getCapabilityTypeOperation(), newResource, AuditingActionEnum.IMPORT_RESOURCE, inTransaction);
5219                         if (validateFieldsResponse.isRight()) {
5220                                 return Either.right(validateFieldsResponse.right().value());
5221                         }
5222
5223                         // contact info normalization
5224                         newResource.setContactId(newResource.getContactId().toLowerCase());
5225                         // non-updatable fields
5226                         newResource.setCreatorUserId(user.getUserId());
5227                         newResource.setCreatorFullName(user.getFullName());
5228                         newResource.setLastUpdaterUserId(user.getUserId());
5229                         newResource.setLastUpdaterFullName(user.getFullName());
5230                         newResource.setUniqueId(oldResource.getUniqueId());
5231                         newResource.setVersion(oldResource.getVersion());
5232                         newResource.setInvariantUUID(oldResource.getInvariantUUID());
5233                         newResource.setLifecycleState(oldResource.getLifecycleState());
5234                         newResource.setUUID(oldResource.getUUID());
5235                         newResource.setNormalizedName(oldResource.getNormalizedName());
5236                         newResource.setSystemName(oldResource.getSystemName());
5237                         if (oldResource.getCsarUUID() != null) {
5238                                 newResource.setCsarUUID(oldResource.getCsarUUID());
5239                         } 
5240                         if (oldResource.getImportedToscaChecksum() != null) {
5241                                 newResource.setImportedToscaChecksum(oldResource.getImportedToscaChecksum());
5242                         }
5243                         newResource.setAbstract(oldResource.isAbstract());
5244
5245                         if (newResource.getDerivedFrom() == null || newResource.getDerivedFrom().isEmpty()) {
5246                                 newResource.setDerivedFrom(oldResource.getDerivedFrom());
5247                         }
5248                         // TODO rhalili: handle artifacts here (delete from old resource and
5249                         // add for new)
5250                         // TODO rbetzer: remove after migration - in case of resources
5251                         // created without tosca artifacts - add the placeholders
5252                         if (newResource.getToscaArtifacts() == null || newResource.getToscaArtifacts().isEmpty()) {
5253                                 setToscaArtifactsPlaceHolders(newResource, user);
5254                         }
5255                         Either<Resource, StorageOperationStatus> overrideResource = toscaOperationFacade.overrideComponent(newResource, oldResource);
5256
5257                         if (overrideResource.isRight()) {
5258                                 ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(overrideResource.right().value()), newResource);
5259                                 componentsUtils.auditResource(responseFormat, user, newResource, newResource.getLifecycleState().name(), newResource.getVersion(), AuditingActionEnum.IMPORT_RESOURCE, null);
5260                                 result = Either.right(responseFormat);
5261                                 return result;
5262                         }
5263
5264                         log.debug("Resource updated successfully!!!");
5265                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.OK);
5266                         componentsUtils.auditResource(responseFormat, user, newResource, oldResource.getLifecycleState().name(), oldResource.getVersion(), AuditingActionEnum.IMPORT_RESOURCE, null);
5267
5268                         ImmutablePair<Resource, ActionStatus> resourcePair = new ImmutablePair<>(overrideResource.left().value(), ActionStatus.OK);
5269                         result = Either.left(resourcePair);
5270                         return result;
5271                 } finally {
5272                         if (result == null || result.isRight()) {
5273                                 BeEcompErrorManager.getInstance().logBeSystemError("Change LifecycleState - Certify");
5274                                 log.debug("operation failed. do rollback");
5275                                 titanDao.rollback();
5276                         } else if (inTransaction == false) {
5277                                 log.debug("operation success. do commit");
5278                                 titanDao.commit();
5279                         }
5280                         if (needLock == true) {
5281                                 log.debug("unlock resource {}", lockedResourceId);
5282                                 graphLockOperation.unlockComponent(lockedResourceId, NodeTypeEnum.Resource);
5283                         }
5284                 }
5285
5286         }
5287
5288         /**
5289          * Merge old resource with new. Keep old category and vendor name without change
5290          *
5291          * @param oldResource
5292          * @param newResource
5293          */
5294         private void mergeOldResourceMetadataWithNew(Resource oldResource, Resource newResource) {
5295
5296                 // keep old category and vendor name without change
5297                 // merge the rest of the resource metadata
5298                 if (newResource.getTags() == null || newResource.getTags().isEmpty()) {
5299                         newResource.setTags(oldResource.getTags());
5300                 }
5301
5302                 if (newResource.getDescription() == null) {
5303                         newResource.setDescription(oldResource.getDescription());
5304                 }
5305
5306                 if (newResource.getVendorRelease() == null) {
5307                         newResource.setVendorRelease(oldResource.getVendorRelease());
5308                 }
5309
5310                 if (newResource.getResourceVendorModelNumber() == null) {
5311                         newResource.setResourceVendorModelNumber(oldResource.getResourceVendorModelNumber());
5312                 }
5313
5314                 if (newResource.getContactId() == null) {
5315                         newResource.setContactId(oldResource.getContactId());
5316                 }
5317
5318                 newResource.setCategories(oldResource.getCategories());
5319                 newResource.setVendorName(oldResource.getVendorName());
5320         }
5321
5322         private Either<Resource, ResponseFormat> prepareResourceForUpdate(Resource latestResource, User user, boolean inTransaction, boolean needLock) {
5323
5324                 Either<Resource, ResponseFormat> result = Either.left(latestResource);
5325                 // check if user can edit resource
5326                 if (!ComponentValidationUtils.canWorkOnResource(latestResource, user.getUserId())) {
5327                         // checkout
5328                         Either<Resource, ResponseFormat> changeState = lifecycleBusinessLogic.changeState(latestResource.getUniqueId(), user, LifeCycleTransitionEnum.CHECKOUT, new LifecycleChangeInfoWithAction("update by import"), inTransaction, needLock);
5329                         result = changeState;
5330                 }
5331
5332                 return result;
5333         }
5334
5335         public Either<Resource, ResponseFormat> validateResourceBeforeCreate(Resource resource, User user, AuditingActionEnum actionEnum, boolean inTransaction, CsarInfo csarInfo) {
5336
5337                 Either<Boolean, ResponseFormat> eitherValidation = validateResourceFieldsBeforeCreate(user, resource, actionEnum, inTransaction);
5338                 if (eitherValidation.isRight()) {
5339                         return Either.right(eitherValidation.right().value());
5340                 }
5341
5342                 eitherValidation = validateCapabilityTypesCreate(user, getCapabilityTypeOperation(), resource, actionEnum, inTransaction);
5343                 if (eitherValidation.isRight()) {
5344                         return Either.right(eitherValidation.right().value());
5345                 }
5346                 eitherValidation = validateLifecycleTypesCreate(user, resource, actionEnum);
5347                 if (eitherValidation.isRight()) {
5348                         return Either.right(eitherValidation.right().value());
5349                 }
5350                 eitherValidation = validateResourceType(user, resource, actionEnum);
5351                 if (eitherValidation.isRight()) {
5352                         return Either.right(eitherValidation.right().value());
5353                 }
5354
5355                 resource.setCreatorUserId(user.getUserId());
5356                 resource.setCreatorFullName(user.getFirstName() + " " + user.getLastName());
5357                 resource.setContactId(resource.getContactId().toLowerCase());
5358                 if (StringUtils.isEmpty(resource.getToscaResourceName()) && !ModelConverter.isAtomicComponent(resource)) {
5359                         String resourceSystemName;
5360                         if(csarInfo != null && StringUtils.isNotEmpty(csarInfo.getVfResourceName())){
5361                                 resourceSystemName = ValidationUtils.convertToSystemName(csarInfo.getVfResourceName());
5362                         } else {
5363                                 resourceSystemName = resource.getSystemName();
5364                         }
5365                         resource.setToscaResourceName(CommonBeUtils.generateToscaResourceName(resource.getResourceType().name().toLowerCase(), resourceSystemName));
5366                 }
5367
5368                 // Generate invariant UUID - must be here and not in operation since it
5369                 // should stay constant during clone
5370                 // TODO
5371                 String invariantUUID = UniqueIdBuilder.buildInvariantUUID();
5372                 resource.setInvariantUUID(invariantUUID);
5373
5374                 return Either.left(resource);
5375         }
5376
5377         private Either<Boolean, ResponseFormat> validateResourceType(User user, Resource resource, AuditingActionEnum actionEnum) {
5378                 Either<Boolean, ResponseFormat> eitherResult = Either.left(true);
5379                 if (resource.getResourceType() == null) {
5380                         log.debug("Invalid resource type for resource");
5381                         ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.INVALID_CONTENT);
5382                         eitherResult = Either.right(errorResponse);
5383                         componentsUtils.auditResource(errorResponse, user, resource, "", "", actionEnum, null);
5384                 }
5385                 return eitherResult;
5386         }
5387
5388         private Either<Boolean, ResponseFormat> validateLifecycleTypesCreate(User user, Resource resource, AuditingActionEnum actionEnum) {
5389                 Either<Boolean, ResponseFormat> eitherResult = Either.left(true);
5390                 if (resource.getInterfaces() != null && resource.getInterfaces().size() > 0) {
5391                         log.debug("validate interface lifecycle Types Exist");
5392                         Iterator<InterfaceDefinition> intItr = resource.getInterfaces().values().iterator();
5393                         while (intItr.hasNext() && eitherResult.isLeft()) {
5394                                 InterfaceDefinition interfaceDefinition = intItr.next();
5395                                 String intType = interfaceDefinition.getUniqueId();
5396                                 Either<InterfaceDefinition, StorageOperationStatus> eitherCapTypeFound = interfaceTypeOperation.getInterface(intType);
5397                                 if (eitherCapTypeFound.isRight()) {
5398                                         if (eitherCapTypeFound.right().value() == StorageOperationStatus.NOT_FOUND) {
5399                                                 BeEcompErrorManager.getInstance().logBeGraphObjectMissingError("Create Resource - validateLifecycleTypesCreate", "Interface", intType);
5400                                                 log.debug("Lifecycle Type: {} is required by resource: {} but does not exist in the DB", intType, resource.getName());
5401                                                 BeEcompErrorManager.getInstance().logBeDaoSystemError("Create Resource - validateLifecycleTypesCreate");
5402                                                 log.debug("request to data model failed with error: {}", eitherCapTypeFound.right().value().name());
5403                                         }
5404
5405                                         ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.MISSING_LIFECYCLE_TYPE, intType);
5406                                         eitherResult = Either.right(errorResponse);
5407                                         componentsUtils.auditResource(errorResponse, user, resource, "", "", actionEnum, null);
5408                                 }
5409
5410                         }
5411                 }
5412                 return eitherResult;
5413         }
5414
5415         private Either<Boolean, ResponseFormat> validateCapabilityTypesCreate(User user, ICapabilityTypeOperation capabilityTypeOperation, Resource resource, AuditingActionEnum actionEnum, boolean inTransaction) {
5416
5417                 Either<Boolean, ResponseFormat> eitherResult = Either.left(true);
5418                 if (resource.getCapabilities() != null && resource.getCapabilities().size() > 0) {
5419                         log.debug("validate capability Types Exist - capabilities section");
5420
5421                         for (Entry<String, List<CapabilityDefinition>> typeEntry : resource.getCapabilities().entrySet()) {
5422
5423                                 eitherResult = validateCapabilityTypeExists(user, capabilityTypeOperation, resource, actionEnum, eitherResult, typeEntry, inTransaction);
5424                                 if (eitherResult.isRight()) {
5425                                         return Either.right(eitherResult.right().value());
5426                                 }
5427                         }
5428                 }
5429
5430                 if (resource.getRequirements() != null && resource.getRequirements().size() > 0) {
5431                         log.debug("validate capability Types Exist - requirements section");
5432                         for (String type : resource.getRequirements().keySet()) {
5433                                 eitherResult = validateCapabilityTypeExists(user, capabilityTypeOperation, resource, resource.getRequirements().get(type), actionEnum, eitherResult, type, inTransaction);
5434                                 if (eitherResult.isRight()) {
5435                                         return Either.right(eitherResult.right().value());
5436                                 }
5437                         }
5438                 }
5439
5440                 return eitherResult;
5441         }
5442
5443         // @param typeObject- the object to which the validation is done
5444         private Either<Boolean, ResponseFormat> validateCapabilityTypeExists(User user, ICapabilityTypeOperation capabilityTypeOperation, Resource resource, List<?> validationObjects, AuditingActionEnum actionEnum, Either<Boolean, ResponseFormat> eitherResult, String type,
5445                                                                                                                                                  boolean inTransaction) {
5446                 Either<CapabilityTypeDefinition, StorageOperationStatus> eitherCapTypeFound = capabilityTypeOperation.getCapabilityType(type, inTransaction);
5447                 if (eitherCapTypeFound.isRight()) {
5448                         if (eitherCapTypeFound.right().value() == StorageOperationStatus.NOT_FOUND) {
5449                                 BeEcompErrorManager.getInstance().logBeGraphObjectMissingError("Create Resource - validateCapabilityTypesCreate", "Capability Type", type);
5450                                 log.debug("Capability Type: {} is required by resource: {} but does not exist in the DB", type, resource.getName());
5451                                 BeEcompErrorManager.getInstance().logBeDaoSystemError("Create Resource - validateCapabilityTypesCreate");
5452                         }
5453                         log.debug("Trying to get capability type {} failed with error: {}", type, eitherCapTypeFound.right().value().name());
5454                         ResponseFormat errorResponse = null;
5455                         if (type != null)
5456                                 errorResponse = componentsUtils.getResponseFormat(ActionStatus.MISSING_CAPABILITY_TYPE, type);
5457                         else
5458                                 errorResponse = componentsUtils.getResponseFormatByElement(ActionStatus.MISSING_CAPABILITY_TYPE, validationObjects);
5459                         eitherResult = Either.right(errorResponse);
5460                         componentsUtils.auditResource(errorResponse, user, resource, "", "", actionEnum, null);
5461                 }
5462                 return eitherResult;
5463         }
5464
5465         private Either<Boolean, ResponseFormat> validateCapabilityTypeExists(User user, ICapabilityTypeOperation capabilityTypeOperation, Resource resource, AuditingActionEnum actionEnum, Either<Boolean, ResponseFormat> eitherResult,
5466                         Entry<String, List<CapabilityDefinition>> typeEntry, boolean inTransaction) {
5467                 Either<CapabilityTypeDefinition, StorageOperationStatus> eitherCapTypeFound = capabilityTypeOperation.getCapabilityType(typeEntry.getKey(), inTransaction);
5468                 if (eitherCapTypeFound.isRight()) {
5469                         if (eitherCapTypeFound.right().value() == StorageOperationStatus.NOT_FOUND) {
5470                                 BeEcompErrorManager.getInstance().logBeGraphObjectMissingError("Create Resource - validateCapabilityTypesCreate", "Capability Type", typeEntry.getKey());
5471                                 log.debug("Capability Type: {} is required by resource: {} but does not exist in the DB", typeEntry.getKey(), resource.getName());
5472                                 BeEcompErrorManager.getInstance().logBeDaoSystemError("Create Resource - validateCapabilityTypesCreate");
5473                         }
5474                         log.debug("Trying to get capability type {} failed with error: {}", typeEntry.getKey(), eitherCapTypeFound.right().value().name());
5475                         ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.MISSING_CAPABILITY_TYPE, typeEntry.getKey());
5476                         eitherResult = Either.right(errorResponse);
5477                         componentsUtils.auditResource(errorResponse, user, resource, "", "", actionEnum, null);
5478                 }
5479                 CapabilityTypeDefinition capabilityTypeDefinition = eitherCapTypeFound.left().value();
5480                 if (capabilityTypeDefinition.getProperties() != null) {
5481                         for (CapabilityDefinition capDef : typeEntry.getValue()) {
5482                                 List<ComponentInstanceProperty> properties = capDef.getProperties();
5483                                 if (properties == null || properties.isEmpty()) {
5484                                         properties = new ArrayList<ComponentInstanceProperty>();
5485                                         for (Entry<String, PropertyDefinition> prop : capabilityTypeDefinition.getProperties().entrySet()) {
5486                                                 ComponentInstanceProperty newProp = new ComponentInstanceProperty(prop.getValue());
5487                                                 properties.add(newProp);
5488                                         }
5489                                 } else {
5490                                         for (Entry<String, PropertyDefinition> prop : capabilityTypeDefinition.getProperties().entrySet()) {
5491                                                 PropertyDefinition porpFromDef = prop.getValue();
5492                                                 List<ComponentInstanceProperty> propsToAdd = new ArrayList<>();
5493                                                 for (ComponentInstanceProperty cip : properties) {
5494                                                         if (!cip.getName().equals(porpFromDef.getName())) {
5495                                                                 ComponentInstanceProperty newProp = new ComponentInstanceProperty(porpFromDef);
5496                                                                 propsToAdd.add(newProp);
5497                                                         }
5498                                                 }
5499                                                 if (!propsToAdd.isEmpty()) {
5500                                                         properties.addAll(propsToAdd);
5501                                                 }
5502                                         }
5503                                 }
5504                                 capDef.setProperties(properties);
5505                         }
5506                 }
5507                 return eitherResult;
5508         }
5509
5510         public Either<Resource, ResponseFormat> createResourceByDao(Resource resource, User user, AuditingActionEnum actionEnum, boolean isNormative, boolean inTransaction, EnumMap<AuditingFieldsKeysEnum, Object> additionalParams) {
5511                 // create resource
5512
5513                 // lock new resource name in order to avoid creation resource with same
5514                 // name
5515                 if (inTransaction == false) {
5516                         Either<Boolean, ResponseFormat> lockResult = lockComponentByName(resource.getSystemName(), resource, "Create Resource");
5517                         if (lockResult.isRight()) {
5518                                 ResponseFormat responseFormat = lockResult.right().value();
5519                                 componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, additionalParams);
5520                                 return Either.right(responseFormat);
5521                         }
5522
5523                         log.debug("name is locked {} status = {}", resource.getSystemName(), lockResult);
5524                 }
5525                 try {
5526                         if (resource.deriveFromGeneric()) {
5527                                 Either<Resource, ResponseFormat> genericResourceEither = handleResourceGenericType(resource);
5528                                 if (genericResourceEither.isRight())
5529                                         return genericResourceEither;
5530                         }
5531
5532                         Either<Resource, ResponseFormat> respStatus = createResourceTransaction(resource, user, isNormative, inTransaction);
5533                         if (respStatus.isLeft()) {
5534                                 auditCreateResource(user, respStatus.left().value(), actionEnum, additionalParams);
5535                                 ASDCKpiApi.countCreatedResourcesKPI();
5536                         } else
5537                                 componentsUtils.auditResource(respStatus.right().value(), user, resource, "", "", actionEnum, additionalParams);
5538                         return respStatus;
5539
5540                 } finally {
5541                         if (inTransaction == false) {
5542                                 graphLockOperation.unlockComponentByName(resource.getSystemName(), resource.getUniqueId(), NodeTypeEnum.Resource);
5543                         }
5544                 }
5545         }
5546
5547         private void auditCreateResource(User user, Resource persistedResource, AuditingActionEnum actionEnum, EnumMap<AuditingFieldsKeysEnum, Object> additionalParams) {
5548                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.CREATED);
5549                 componentsUtils.auditResource(responseFormat, user, persistedResource, "", "", actionEnum, additionalParams);
5550         }
5551
5552         private Either<Resource, ResponseFormat> createResourceTransaction(Resource resource, User user, boolean isNormative, boolean inTransaction) {
5553                 // validate resource name uniqueness
5554                 log.debug("validate resource name");
5555                 Either<Boolean, StorageOperationStatus> eitherValidation = toscaOperationFacade.validateComponentNameExists(resource.getName(), resource.getResourceType(), resource.getComponentType());
5556                 if (eitherValidation.isRight()) {
5557                         log.debug("Failed to validate component name {}. Status is {}. ", resource.getName(), eitherValidation.right().value());
5558                         ResponseFormat errorResponse = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(eitherValidation.right().value()));
5559                         return Either.right(errorResponse);
5560                 }
5561                 if (eitherValidation.left().value()) {
5562                         log.debug("resource with name: {}, already exists", resource.getName());
5563                         ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.COMPONENT_NAME_ALREADY_EXIST, ComponentTypeEnum.RESOURCE.getValue(), resource.getName());
5564                         return Either.right(errorResponse);
5565                 }
5566
5567                 log.debug("send resource {} to dao for create", resource.getName());
5568
5569                 createArtifactsPlaceHolderData(resource, user);
5570
5571                 //
5572
5573                 // enrich object
5574                 if (!isNormative) {
5575                         log.debug("enrich resource with creator, version and state");
5576                         resource.setLifecycleState(LifecycleStateEnum.NOT_CERTIFIED_CHECKOUT);
5577                         resource.setVersion(INITIAL_VERSION);
5578                         resource.setHighestVersion(true);
5579                         if (resource.getResourceType() != null && resource.getResourceType() != ResourceTypeEnum.CVFC)
5580                                 resource.setAbstract(false);
5581                 }
5582
5583                 Either<Resource, StorageOperationStatus> createToscaElement = toscaOperationFacade.createToscaComponent(resource);
5584                 if (createToscaElement.isLeft()) {
5585                         return Either.left(createToscaElement.left().value());
5586                 }
5587
5588                 ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(createToscaElement.right().value()), resource);
5589
5590                 return Either.right(responseFormat);
5591         }
5592
5593         private void createArtifactsPlaceHolderData(Resource resource, User user) {
5594                 // create mandatory artifacts
5595
5596                 // TODO it must be removed after that artifact uniqueId creation will be
5597                 // moved to ArtifactOperation
5598                 // String resourceUniqueId =
5599                 // UniqueIdBuilder.buildResourceUniqueId(resource.getResourceName(),
5600                 // resource.getResourceVersion());
5601
5602                 setInformationalArtifactsPlaceHolder(resource, user);
5603                 setDeploymentArtifactsPlaceHolder(resource, user);
5604                 setToscaArtifactsPlaceHolders(resource, user);
5605         }
5606
5607         @SuppressWarnings("unchecked")
5608         @Override
5609         public void setDeploymentArtifactsPlaceHolder(Component component, User user) {
5610                 Resource resource = (Resource) component;
5611                 Map<String, ArtifactDefinition> artifactMap = resource.getDeploymentArtifacts();
5612                 if (artifactMap == null) {
5613                         artifactMap = new HashMap<String, ArtifactDefinition>();
5614                 }
5615                 Map<String, Object> deploymentResourceArtifacts = ConfigurationManager.getConfigurationManager().getConfiguration().getDeploymentResourceArtifacts();
5616                 if (deploymentResourceArtifacts != null) {
5617                         Iterator<Entry<String, Object>> iterator = deploymentResourceArtifacts.entrySet().iterator();
5618                         while (iterator.hasNext()) {
5619                                 Entry<String, Object> currEntry = iterator.next();
5620                                 boolean shouldCreateArtifact = true;
5621                                 Map<String, Object> artifactDetails = (Map<String, Object>) currEntry.getValue();
5622                                 Object object = artifactDetails.get(PLACE_HOLDER_RESOURCE_TYPES);
5623                                 if (object != null) {
5624                                         List<String> artifactTypes = (List<String>) object;
5625                                         if (!artifactTypes.contains(resource.getResourceType().name())) {
5626                                                 shouldCreateArtifact = false;
5627                                                 continue;
5628                                         }
5629                                 } else {
5630                                         log.info("resource types for artifact placeholder {} were not defined. default is all resources", currEntry.getKey());
5631                                 }
5632                                 if (shouldCreateArtifact) {
5633                                         if (artifactsBusinessLogic != null) {
5634                                                 ArtifactDefinition artifactDefinition = artifactsBusinessLogic.createArtifactPlaceHolderInfo(resource.getUniqueId(), currEntry.getKey(), (Map<String, Object>) currEntry.getValue(), user, ArtifactGroupTypeEnum.DEPLOYMENT);
5635                                                 if (artifactDefinition != null && !artifactMap.containsKey(artifactDefinition.getArtifactLabel()))
5636                                                         artifactMap.put(artifactDefinition.getArtifactLabel(), artifactDefinition);
5637                                         }
5638                                 }
5639                         }
5640                 }
5641                 resource.setDeploymentArtifacts(artifactMap);
5642         }
5643
5644         @SuppressWarnings("unchecked")
5645         private void setInformationalArtifactsPlaceHolder(Resource resource, User user) {
5646                 Map<String, ArtifactDefinition> artifactMap = resource.getArtifacts();
5647                 if (artifactMap == null) {
5648                         artifactMap = new HashMap<String, ArtifactDefinition>();
5649                 }
5650                 String resourceUniqueId = resource.getUniqueId();
5651                 List<String> exludeResourceCategory = ConfigurationManager.getConfigurationManager().getConfiguration().getExcludeResourceCategory();
5652                 List<String> exludeResourceType = ConfigurationManager.getConfigurationManager().getConfiguration().getExcludeResourceType();
5653                 Map<String, Object> informationalResourceArtifacts = ConfigurationManager.getConfigurationManager().getConfiguration().getInformationalResourceArtifacts();
5654                 List<CategoryDefinition> categories = resource.getCategories();
5655                 boolean isCreateArtifact = true;
5656                 if (exludeResourceCategory != null) {
5657                         String category = categories.get(0).getName();
5658                         for (String exlude : exludeResourceCategory) {
5659                                 if (exlude.equalsIgnoreCase(category)) {
5660                                         isCreateArtifact = false;
5661                                         break;
5662                                 }
5663                         }
5664
5665                 }
5666                 if (isCreateArtifact && exludeResourceType != null) {
5667                         String resourceType = resource.getResourceType().name();
5668                         for (String type : exludeResourceType) {
5669                                 if (type.equalsIgnoreCase(resourceType)) {
5670                                         isCreateArtifact = false;
5671                                         break;
5672                                 }
5673                         }
5674
5675                 }
5676
5677                 if (informationalResourceArtifacts != null && isCreateArtifact) {
5678                         Set<String> keys = informationalResourceArtifacts.keySet();
5679                         for (String informationalResourceArtifactName : keys) {
5680                                 Map<String, Object> artifactInfoMap = (Map<String, Object>) informationalResourceArtifacts.get(informationalResourceArtifactName);
5681                                 ArtifactDefinition artifactDefinition = artifactsBusinessLogic.createArtifactPlaceHolderInfo(resourceUniqueId, informationalResourceArtifactName, artifactInfoMap, user, ArtifactGroupTypeEnum.INFORMATIONAL);
5682                                 artifactMap.put(artifactDefinition.getArtifactLabel(), artifactDefinition);
5683
5684                         }
5685                 }
5686                 resource.setArtifacts(artifactMap);
5687         }
5688
5689         /**
5690          * deleteResource
5691          *
5692          * @param resourceId
5693          * @param user
5694          * @return
5695          */
5696         public ResponseFormat deleteResource(String resourceId, User user) {
5697                 ResponseFormat responseFormat;
5698                 Either<User, ResponseFormat> eitherCreator = validateUserExists(user, "Delete Resource", false);
5699                 if (eitherCreator.isRight()) {
5700                         return eitherCreator.right().value();
5701                 }
5702
5703                 Either<Resource, StorageOperationStatus> resourceStatus = toscaOperationFacade.getToscaElement(resourceId);
5704                 if (resourceStatus.isRight()) {
5705                         log.debug("failed to get resource {}", resourceId);
5706                         return componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(resourceStatus.right().value()), "");
5707                 }
5708
5709                 Resource resource = resourceStatus.left().value();
5710
5711                 StorageOperationStatus result = StorageOperationStatus.OK;
5712                 Either<Boolean, ResponseFormat> lockResult = lockComponent(resourceId, resource, "Mark resource to delete");
5713                 if (lockResult.isRight()) {
5714                         result = StorageOperationStatus.GENERAL_ERROR;
5715                         return componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR);
5716                 }
5717
5718                 try {
5719
5720                         result = markComponentToDelete(resource);
5721                         if (result.equals(StorageOperationStatus.OK)) {
5722                                 responseFormat = componentsUtils.getResponseFormat(ActionStatus.NO_CONTENT);
5723                         } else {
5724                                 ActionStatus actionStatus = componentsUtils.convertFromStorageResponse(result);
5725                                 responseFormat = componentsUtils.getResponseFormatByResource(actionStatus, resource.getName());
5726                         }
5727                         return responseFormat;
5728
5729                 } finally {
5730                         if (result == null || !result.equals(StorageOperationStatus.OK)) {
5731                                 log.warn("operation failed. do rollback");
5732                                 titanDao.rollback();
5733                         } else {
5734                                 log.debug("operation success. do commit");
5735                                 titanDao.commit();
5736                         }
5737                         graphLockOperation.unlockComponent(resourceId, NodeTypeEnum.Resource);
5738                 }
5739
5740         }
5741
5742         public ResponseFormat deleteResourceByNameAndVersion(String resourceName, String version, User user) {
5743                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.NO_CONTENT);
5744                 Either<User, ResponseFormat> eitherCreator = validateUserExists(user, "Delete Resource", false);
5745                 if (eitherCreator.isRight()) {
5746                         return eitherCreator.right().value();
5747                 }
5748
5749                 // Resource resource = null;
5750                 Resource resource = null;
5751                 StorageOperationStatus result = StorageOperationStatus.OK;
5752                 try {
5753
5754                         Either<Resource, StorageOperationStatus> resourceStatus = toscaOperationFacade.getComponentByNameAndVersion(ComponentTypeEnum.RESOURCE, resourceName, version);
5755                         if (resourceStatus.isRight()) {
5756                                 log.debug("failed to get resource {} version {}", resourceName, version);
5757                                 return componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(resourceStatus.right().value()), resourceName);
5758                         }
5759
5760                         resource = resourceStatus.left().value();
5761
5762                 } finally {
5763                         if (result == null || !result.equals(StorageOperationStatus.OK)) {
5764                                 log.warn("operation failed. do rollback");
5765                                 titanDao.rollback();
5766                                 ActionStatus actionStatus = componentsUtils.convertFromStorageResponse(result);
5767                                 responseFormat = componentsUtils.getResponseFormatByResource(actionStatus, resourceName);
5768                         } else {
5769                                 log.debug("operation success. do commit");
5770                                 titanDao.commit();
5771                         }
5772                 }
5773                 if (resource != null) {
5774                         Either<Boolean, ResponseFormat> lockResult = lockComponent(resource.getUniqueId(), resource, "Delete Resource");
5775                         if (lockResult.isRight()) {
5776                                 result = StorageOperationStatus.GENERAL_ERROR;
5777                                 return componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR);
5778                         }
5779                         try {
5780                                 result = markComponentToDelete(resource);
5781                                 if (!result.equals(StorageOperationStatus.OK)) {
5782                                         ActionStatus actionStatus = componentsUtils.convertFromStorageResponse(result);
5783                                         responseFormat = componentsUtils.getResponseFormatByResource(actionStatus, resource.getName());
5784                                         return responseFormat;
5785                                 }
5786
5787                         } finally {
5788                                 if (result == null || !result.equals(StorageOperationStatus.OK)) {
5789                                         log.warn("operation failed. do rollback");
5790                                         titanDao.rollback();
5791                                 } else {
5792                                         log.debug("operation success. do commit");
5793                                         titanDao.commit();
5794                                 }
5795                                 graphLockOperation.unlockComponent(resource.getUniqueId(), NodeTypeEnum.Resource);
5796                         }
5797                 }
5798                 return responseFormat;
5799         }
5800
5801         public Either<Resource, ResponseFormat> getResource(String resourceId, User user) {
5802
5803                 if (user != null) {
5804                         Either<User, ResponseFormat> eitherCreator = validateUserExists(user, "Create Resource", false);
5805                         if (eitherCreator.isRight()) {
5806                                 return Either.right(eitherCreator.right().value());
5807                         }
5808                 }
5809
5810                 // IResourceOperation dataModel = getResourceOperation();
5811                 Either<Resource, StorageOperationStatus> storageStatus = toscaOperationFacade.getToscaElement(resourceId);
5812                 if (storageStatus.isRight()) {
5813                         log.debug("failed to get resource by id {}", resourceId);
5814                         return Either.right(componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(storageStatus.right().value()), resourceId));
5815                 }
5816                 if(!(storageStatus.left().value() instanceof Resource)){
5817                         return Either.right(componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(StorageOperationStatus.NOT_FOUND), resourceId));
5818                 }
5819                 return Either.left(storageStatus.left().value());
5820
5821         }
5822
5823         public Either<Resource, ResponseFormat> getResourceByNameAndVersion(String resourceName, String resourceVersion, String userId) {
5824
5825                 Either<User, ResponseFormat> resp = validateUserExists(userId, "get Resource By Name And Version", false);
5826                 if (resp.isRight()) {
5827                         return Either.right(resp.right().value());
5828                 }
5829
5830                 Either<Resource, StorageOperationStatus> getResource = toscaOperationFacade.getComponentByNameAndVersion(ComponentTypeEnum.RESOURCE, resourceName, resourceVersion);
5831                 if (getResource.isRight()) {
5832                         log.debug("failed to get resource by name {} and version {}", resourceName, resourceVersion);
5833                         return Either.right(componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(getResource.right().value()), resourceName));
5834                 }
5835                 return Either.left(getResource.left().value());
5836         }
5837
5838         /**
5839          * updateResourceMetadata
5840          *
5841          * @param user               - modifier data (userId)
5842          * @param inTransaction      TODO
5843          * @param resourceIdToUpdate - the resource identifier
5844          * @param newResource
5845          * @return Either<Resource, responseFormat>
5846          */
5847         public Either<Resource, ResponseFormat> updateResourceMetadata(String resourceIdToUpdate, Resource newResource, Resource currentResource, User user, boolean inTransaction) {
5848
5849                 Either<User, ResponseFormat> resp = validateUserExists(user.getUserId(), "update Resource Metadata", false);
5850                 if (resp.isRight()) {
5851                         return Either.right(resp.right().value());
5852                 }
5853
5854                 // IResourceOperation dataModel = getResourceOperation();
5855                 log.debug("Get resource with id {}", resourceIdToUpdate);
5856                 boolean needToUnlock = false;
5857                 boolean rollbackNeeded = true;
5858
5859                 try {
5860                         // Either<Resource, StorageOperationStatus> storageStatus =
5861                         // dataModel.getResource_tx(resourceIdToUpdate, false);
5862                         if (currentResource == null) {
5863                                 Either<Resource, StorageOperationStatus> storageStatus = toscaOperationFacade.getToscaElement(resourceIdToUpdate);
5864                                 if (storageStatus.isRight()) {
5865                                         return Either.right(componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(storageStatus.right().value()), ""));
5866                                 }
5867
5868                                 currentResource = storageStatus.left().value();
5869                         }
5870                         // verify that resource is checked-out and the user is the last
5871                         // updater
5872                         if (!ComponentValidationUtils.canWorkOnResource(currentResource, user.getUserId())) {
5873                                 return Either.right(componentsUtils.getResponseFormat(ActionStatus.RESTRICTED_OPERATION));
5874                         }
5875
5876                         // lock resource
5877                         StorageOperationStatus lockResult = graphLockOperation.lockComponent(resourceIdToUpdate, NodeTypeEnum.Resource);
5878                         if (!lockResult.equals(StorageOperationStatus.OK)) {
5879                                 BeEcompErrorManager.getInstance().logBeFailedLockObjectError("Upload Artifact - lock ", NodeTypeEnum.Resource.getName(), resourceIdToUpdate);
5880                                 log.debug("Failed to lock resource: {}, error - {}", resourceIdToUpdate, lockResult);
5881                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(lockResult));
5882                                 return Either.right(responseFormat);
5883                         }
5884
5885                         needToUnlock = true;
5886
5887                         // critical section starts here
5888                         // convert json to object
5889
5890                         // Update and updated resource must have a non-empty "derivedFrom"
5891                         // list
5892                         // This code is not called from import resources, because of root
5893                         // VF "derivedFrom" should be null (or ignored)
5894                         if (ModelConverter.isAtomicComponent(currentResource)) {
5895                                 Either<Boolean, ResponseFormat> derivedFromNotEmptyEither = validateDerivedFromNotEmpty(null, newResource, null);
5896                                 if (derivedFromNotEmptyEither.isRight()) {
5897                                         log.debug("for updated resource {}, derived from field is empty", newResource.getName());
5898                                         return Either.right(derivedFromNotEmptyEither.right().value());
5899                                 }
5900
5901                                 derivedFromNotEmptyEither = validateDerivedFromNotEmpty(null, currentResource, null);
5902                                 if (derivedFromNotEmptyEither.isRight()) {
5903                                         log.debug("for current resource {}, derived from field is empty", currentResource.getName());
5904                                         return Either.right(derivedFromNotEmptyEither.right().value());
5905                                 }
5906                         } else {
5907                                 newResource.setDerivedFrom(null);
5908                         }
5909
5910                         Either<Resource, ResponseFormat> dataModelResponse = updateResourceMetadata(resourceIdToUpdate, newResource, user, currentResource, false, true);
5911                         if (dataModelResponse.isRight()) {
5912                                 log.debug("failed to update resource metadata!!!");
5913                                 rollbackNeeded = true;
5914                                 return Either.right(dataModelResponse.right().value());
5915                         }
5916
5917                         log.debug("Resource metadata updated successfully!!!");
5918                         rollbackNeeded = false;
5919                         return Either.left(dataModelResponse.left().value());
5920
5921                 } finally {
5922                         if (!inTransaction) {
5923                                 if (rollbackNeeded) {
5924                                         titanDao.rollback();
5925                                 } else {
5926                                         titanDao.commit();
5927                                 }
5928                         }
5929
5930                         if (needToUnlock) {
5931                                 graphLockOperation.unlockComponent(resourceIdToUpdate, NodeTypeEnum.Resource);
5932                         }
5933                 }
5934         }
5935
5936         private Either<List<GroupDefinition>,Boolean> updateComponentGroupName(String replacePattern , String with ,List<GroupDefinition> oldGroup){
5937                 if ( oldGroup==null || with==null || replacePattern==null || with.isEmpty() || replacePattern.isEmpty()){
5938                         if (log.isInfoEnabled())
5939                                 log.info("cannot update group name , invalid args -> replacePattern:{} , with:{} , oldGroup:{}" , replacePattern, with, oldGroup == null ? null : " < size : "+oldGroup.size()+" >" );
5940                         return Either.right(false);
5941                 }
5942                 List<GroupDefinition> list = oldGroup.stream().map( group -> new GroupDefinition(group)).collect(Collectors.toList());
5943                 for ( GroupDefinition group : list) {
5944                         if ( group!=null && group.isSamePrefix( replacePattern ) ){
5945                                 String prefix = group.getName().substring( 0, replacePattern.length() );
5946                                 String newGroupName = group.getName().replaceFirst(prefix , with);
5947                                 group.setName(newGroupName);
5948                                 //String newUid = group.getUniqueId().replaceFirst(prefix , with); //removing this will also change the unique id
5949                                 //group.setUniqueId(newUid);
5950                         }
5951                 }
5952                 return Either.left(list);
5953         }
5954
5955         private boolean isComponentNameChanged(Resource newResource,Resource oldResource){
5956                 if (newResource!=null &&  oldResource!=null){   //TODO - must protect all chain against null , use optional
5957                         String futureName = newResource.getComponentMetadataDefinition().getMetadataDataDefinition().getName();
5958                         String oldName = oldResource.getComponentMetadataDefinition().getMetadataDataDefinition().getName();
5959                         return !oldName.equals(futureName);
5960                 }
5961                 return false;
5962         }
5963
5964         private Either<Resource, ResponseFormat> updateResourceMetadata(String resourceIdToUpdate, Resource newResource, User user, Resource currentResource, boolean shouldLock, boolean inTransaction) {
5965                 //region -> Update groups name for newResource
5966                 if ( isComponentNameChanged( currentResource , newResource) ){
5967                         String replacePattern = Optional.ofNullable(    //get currentResource name from metadata
5968                                         Optional.ofNullable( Optional.ofNullable( currentResource )
5969                                                         .orElse(null).getComponentMetadataDefinition() )
5970                                                         .orElse(null).getMetadataDataDefinition() )
5971                                         .orElse(null).getName();
5972                         String with = Optional.ofNullable(                              //get newResource name from metadata
5973                                         Optional.ofNullable( Optional.ofNullable( newResource )
5974                                                         .orElse(null).getComponentMetadataDefinition() )
5975                                                         .orElse(null).getMetadataDataDefinition() )
5976                                         .orElse(null).getName();
5977                         if ( with != null  && replacePattern != null ){
5978                                 Either<List<GroupDefinition>,Boolean> result = updateComponentGroupName( replacePattern , with  ,currentResource.getGroups());
5979                                 if (result.isLeft())
5980                                         newResource.setGroups( (List<GroupDefinition>)result.left().value() );
5981                         }
5982                 }
5983                 //endregion
5984
5985                 Either<Boolean, ResponseFormat> validateResourceFields = validateResourceFieldsBeforeUpdate(currentResource, newResource, inTransaction, false);
5986                 if (validateResourceFields.isRight()) {
5987                         return Either.right(validateResourceFields.right().value());
5988                 }
5989                 // Setting last updater and uniqueId
5990                 newResource.setContactId(newResource.getContactId().toLowerCase());
5991                 newResource.setLastUpdaterUserId(user.getUserId());
5992                 newResource.setUniqueId(resourceIdToUpdate);
5993                 // Cannot set highest version through UI
5994                 newResource.setHighestVersion(currentResource.isHighestVersion());
5995                 newResource.setCreationDate(currentResource.getCreationDate());
5996
5997                 Either<Boolean, ResponseFormat> processUpdateOfDerivedFrom = processUpdateOfDerivedFrom(currentResource, newResource, user.getUserId(), shouldLock, inTransaction);
5998
5999                 if (processUpdateOfDerivedFrom.isRight()) {
6000                         log.debug("Couldn't update derived from for resource {}", resourceIdToUpdate);
6001                         return Either.right(processUpdateOfDerivedFrom.right().value());
6002                 }
6003
6004                 log.debug("send resource {} to dao for update", newResource.getUniqueId());
6005                 if (newResource!=null && newResource.getGroups()!=null){
6006                         for ( GroupDefinition group : newResource.getGroups() ){
6007                                 if (newResource.getComponentMetadataDefinition()!=null && newResource.getComponentMetadataDefinition().getMetadataDataDefinition()!=null)
6008                                 groupBusinessLogic.validateAndUpdateGroupMetadata(
6009                                                 newResource.getComponentMetadataDefinition().getMetadataDataDefinition().getUniqueId() ,
6010                                                 user,
6011                                                 ComponentTypeEnum.RESOURCE_INSTANCE,
6012                                                 group,
6013                                                 true ,
6014                                                 false) ;
6015                         }
6016                 }
6017                 Either<Resource, StorageOperationStatus> dataModelResponse = toscaOperationFacade.updateToscaElement(newResource);
6018
6019                 if (dataModelResponse.isRight()) {
6020                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(dataModelResponse.right().value()), newResource);
6021                         return Either.right(responseFormat);
6022                 } else if (dataModelResponse.left().value() == null) {
6023                         log.debug("No response from updateResource");
6024                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR));
6025                 }
6026                 return Either.left(dataModelResponse.left().value());
6027         }
6028
6029         /**
6030          * validateResourceFieldsBeforeCreate
6031          *
6032          * @param user      - modifier data (userId)
6033          * @param dataModel - IResourceOperation for resource crud
6034          * @param resource  - Resource object to validate
6035          * @return Either<Boolean, ErrorResponse>
6036          */
6037         private Either<Boolean, ResponseFormat> validateResourceFieldsBeforeCreate(User user, Resource resource, AuditingActionEnum actionEnum, boolean inTransaction) {
6038                 Either<Boolean, ResponseFormat> componentsFieldsValidation = validateComponentFieldsBeforeCreate(user, resource, actionEnum);
6039                 if (componentsFieldsValidation.isRight()) {
6040                         return componentsFieldsValidation;
6041                 }
6042
6043                 // validate name
6044
6045                 /*
6046                  * log.debug("validate resource name"); Either<Boolean, ResponseFormat> eitherValidation = validateComponentName(user, resource, actionEnum); if (eitherValidation.isRight()) { return eitherValidation; }
6047                  *
6048                  * // validate description log.debug("validate description"); eitherValidation = validateDescriptionAndCleanup(user, resource, actionEnum); if (eitherValidation.isRight()) { return eitherValidation; }
6049                  */
6050
6051                 // validate icon
6052                 /*
6053                  * log.debug("validate icon"); eitherValidation = validateIcon(user, resource, actionEnum); if (eitherValidation.isRight()) { return eitherValidation; }
6054                  */
6055
6056                 // validate tags
6057                 /*
6058                  * log.debug("validate tags"); eitherValidation = validateTagsListAndRemoveDuplicates(user, resource, actionEnum); if (eitherValidation.isRight()) { return eitherValidation; }
6059                  */
6060
6061                 // validate category
6062                 log.debug("validate category");
6063                 Either<Boolean, ResponseFormat> eitherValidation = validateCategory(user, resource, actionEnum, inTransaction);
6064                 if (eitherValidation.isRight()) {
6065                         return eitherValidation;
6066                 }
6067
6068                 // validate vendor name & release & model number
6069                 log.debug("validate vendor name");
6070                 eitherValidation = validateVendorName(user, resource, actionEnum);
6071                 if (eitherValidation.isRight()) {
6072                         return eitherValidation;
6073                 }
6074
6075                 log.debug("validate vendor release");
6076                 eitherValidation = validateVendorReleaseName(user, resource, actionEnum);
6077                 if (eitherValidation.isRight()) {
6078                         return eitherValidation;
6079                 }
6080
6081                 log.debug("validate resource vendor model number");
6082                 eitherValidation = validateResourceVendorModelNumber(user, resource, actionEnum);
6083                 if (eitherValidation.isRight()) {
6084                         return eitherValidation;
6085                 }
6086
6087                 // validate contact info
6088                 /*
6089                  * log.debug("validate contact info"); eitherValidation = validateContactIdContactId(user, resource, actionEnum); if (eitherValidation.isRight()) { return eitherValidation; }
6090                  */
6091
6092                 // validate cost
6093                 log.debug("validate cost");
6094                 eitherValidation = validateCost(user, resource, actionEnum);
6095                 if (eitherValidation.isRight()) {
6096                         return eitherValidation;
6097                 }
6098
6099                 // validate licenseType
6100                 log.debug("validate licenseType");
6101                 eitherValidation = validateLicenseType(user, resource, actionEnum);
6102                 if (eitherValidation.isRight()) {
6103                         return eitherValidation;
6104                 }
6105
6106                 // validate template (derived from)
6107                 log.debug("validate derived from");
6108                 if (!ModelConverter.isAtomicComponent(resource) && resource.getResourceType() != ResourceTypeEnum.CVFC) {
6109                         resource.setDerivedFrom(null);
6110                 }
6111                 eitherValidation = validateDerivedFromExist(user, resource, actionEnum);
6112                 if (eitherValidation.isRight()) {
6113                         return Either.right(eitherValidation.right().value());
6114                 }
6115
6116                 // warn about non-updatable fields
6117                 checkComponentFieldsForOverrideAttempt(resource);
6118                 String currentCreatorFullName = resource.getCreatorFullName();
6119                 if (currentCreatorFullName != null) {
6120                         log.warn("Resource Creator fullname is automatically set and cannot be updated");
6121                 }
6122
6123                 String currentLastUpdaterFullName = resource.getLastUpdaterFullName();
6124                 if (currentLastUpdaterFullName != null) {
6125                         log.warn("Resource LastUpdater fullname is automatically set and cannot be updated");
6126                 }
6127
6128                 Long currentLastUpdateDate = resource.getLastUpdateDate();
6129                 if (currentLastUpdateDate != null) {
6130                         log.warn("Resource last update date is automatically set and cannot be updated");
6131                 }
6132
6133                 Boolean currentAbstract = resource.isAbstract();
6134                 if (currentAbstract != null) {
6135                         log.warn("Resource abstract is automatically set and cannot be updated");
6136                 }
6137
6138                 return Either.left(true);
6139         }
6140
6141         /**
6142          * validateResourceFieldsBeforeUpdate
6143          *
6144          * @param currentResource - Resource object to validate
6145          * @param isNested 
6146          * @return Either<Boolean, ErrorResponse>
6147          */
6148         private Either<Boolean, ResponseFormat> validateResourceFieldsBeforeUpdate(Resource currentResource, Resource updateInfoResource, boolean inTransaction, boolean isNested) {
6149
6150                 boolean hasBeenCertified = ValidationUtils.hasBeenCertified(currentResource.getVersion());
6151
6152                 // validate resource name
6153                 log.debug("validate resource name before update");
6154                 Either<Boolean, ResponseFormat> eitherValidation = validateResourceName(currentResource, updateInfoResource, hasBeenCertified, isNested);
6155                 if (eitherValidation.isRight()) {
6156                         return eitherValidation;
6157                 }
6158
6159                 // validate description
6160                 log.debug("validate description before update");
6161                 eitherValidation = validateDescriptionAndCleanup(null, updateInfoResource, null);
6162                 if (eitherValidation.isRight()) {
6163                         return eitherValidation;
6164                 }
6165
6166                 log.debug("validate icon before update");
6167                 eitherValidation = validateIcon(currentResource, updateInfoResource, hasBeenCertified);
6168                 if (eitherValidation.isRight()) {
6169                         return eitherValidation;
6170                 }
6171
6172                 log.debug("validate tags before update");
6173                 eitherValidation = validateTagsListAndRemoveDuplicates(null, updateInfoResource, null);
6174                 if (eitherValidation.isRight()) {
6175                         return eitherValidation;
6176                 }
6177
6178                 log.debug("validate vendor name before update");
6179                 eitherValidation = validateVendorName(currentResource, updateInfoResource, hasBeenCertified);
6180                 if (eitherValidation.isRight()) {
6181                         return eitherValidation;
6182                 }
6183
6184                 log.debug("validate resource vendor model number before update");
6185                 eitherValidation = validateResourceVendorModelNumber(currentResource, updateInfoResource);
6186                 if (eitherValidation.isRight()) {
6187                         return eitherValidation;
6188                 }
6189
6190
6191                 log.debug("validate vendor release before update");
6192                 eitherValidation = validateVendorReleaseName(null, updateInfoResource, null);
6193                 if (eitherValidation.isRight()) {
6194                         return eitherValidation;
6195                 }
6196
6197                 log.debug("validate contact info before update");
6198                 eitherValidation = validateContactId(null, updateInfoResource, null);
6199                 if (eitherValidation.isRight()) {
6200                         return eitherValidation;
6201                 }
6202
6203                 log.debug("validate derived before update");
6204                 eitherValidation = validateDerivedFromDuringUpdate(currentResource, updateInfoResource, hasBeenCertified);
6205                 if (eitherValidation.isRight()) {
6206                         return eitherValidation;
6207                 }
6208
6209                 log.debug("validate category before update");
6210                 eitherValidation = validateCategory(currentResource, updateInfoResource, hasBeenCertified, inTransaction);
6211                 if (eitherValidation.isRight()) {
6212                         return eitherValidation;
6213                 }
6214
6215                 // warn about non-updatable fields
6216                 String currentResourceVersion = currentResource.getVersion();
6217                 String updatedResourceVersion = updateInfoResource.getVersion();
6218
6219                 if ((updatedResourceVersion != null) && (!updatedResourceVersion.equals(currentResourceVersion))) {
6220                         log.warn("Resource version is automatically set and cannot be updated");
6221                 }
6222
6223                 String currentCreatorUserId = currentResource.getCreatorUserId();
6224                 String updatedCreatorUserId = updateInfoResource.getCreatorUserId();
6225
6226                 if ((updatedCreatorUserId != null) && (!updatedCreatorUserId.equals(currentCreatorUserId))) {
6227                         log.warn("Resource Creator UserId is automatically set and cannot be updated");
6228                 }
6229
6230                 String currentCreatorFullName = currentResource.getCreatorFullName();
6231                 String updatedCreatorFullName = updateInfoResource.getCreatorFullName();
6232
6233                 if ((updatedCreatorFullName != null) && (!updatedCreatorFullName.equals(currentCreatorFullName))) {
6234                         log.warn("Resource Creator fullname is automatically set and cannot be updated");
6235                 }
6236
6237                 String currentLastUpdaterUserId = currentResource.getLastUpdaterUserId();
6238                 String updatedLastUpdaterUserId = updateInfoResource.getLastUpdaterUserId();
6239
6240                 if ((updatedLastUpdaterUserId != null) && (!updatedLastUpdaterUserId.equals(currentLastUpdaterUserId))) {
6241                         log.warn("Resource LastUpdater userId is automatically set and cannot be updated");
6242                 }
6243
6244                 String currentLastUpdaterFullName = currentResource.getLastUpdaterFullName();
6245                 String updatedLastUpdaterFullName = updateInfoResource.getLastUpdaterFullName();
6246
6247                 if ((updatedLastUpdaterFullName != null) && (!updatedLastUpdaterFullName.equals(currentLastUpdaterFullName))) {
6248                         log.warn("Resource LastUpdater fullname is automatically set and cannot be updated");
6249                 }
6250
6251                 Long currentCreationDate = currentResource.getCreationDate();
6252                 Long updatedCreationDate = updateInfoResource.getCreationDate();
6253
6254                 if ((updatedCreationDate != null) && (!updatedCreationDate.equals(currentCreationDate))) {
6255                         log.warn("Resource Creation date is automatically set and cannot be updated");
6256                 }
6257
6258                 Long currentLastUpdateDate = currentResource.getLastUpdateDate();
6259                 Long updatedLastUpdateDate = updateInfoResource.getLastUpdateDate();
6260
6261                 if ((updatedLastUpdateDate != null) && (!updatedLastUpdateDate.equals(currentLastUpdateDate))) {
6262                         log.warn("Resource last update date is automatically set and cannot be updated");
6263                 }
6264
6265                 LifecycleStateEnum currentLifecycleState = currentResource.getLifecycleState();
6266                 LifecycleStateEnum updatedLifecycleState = updateInfoResource.getLifecycleState();
6267
6268                 if ((updatedLifecycleState != null) && (!updatedLifecycleState.equals(currentLifecycleState))) {
6269                         log.warn("Resource lifecycle state date is automatically set and cannot be updated");
6270                 }
6271
6272                 Boolean currentAbstract = currentResource.isAbstract();
6273                 Boolean updatedAbstract = updateInfoResource.isAbstract();
6274
6275                 if ((updatedAbstract != null) && (!updatedAbstract.equals(currentAbstract))) {
6276                         log.warn("Resource abstract is automatically set and cannot be updated");
6277                 }
6278
6279                 Boolean currentHighestVersion = currentResource.isHighestVersion();
6280                 Boolean updatedHighestVersion = updateInfoResource.isHighestVersion();
6281
6282                 if ((updatedHighestVersion != null) && (!updatedHighestVersion.equals(currentHighestVersion))) {
6283                         log.warn("Resource highest version is automatically set and cannot be updated");
6284                 }
6285
6286                 String currentUuid = currentResource.getUUID();
6287                 String updatedUuid = updateInfoResource.getUUID();
6288
6289                 if ((updatedUuid != null) && (!updatedUuid.equals(currentUuid))) {
6290                         log.warn("Resource UUID is automatically set and cannot be updated");
6291                 }
6292
6293                 ResourceTypeEnum currentResourceType = currentResource.getResourceType();
6294                 ResourceTypeEnum updatedResourceType = updateInfoResource.getResourceType();
6295
6296                 if ((updatedResourceType != null) && (!updatedResourceType.equals(currentResourceType))) {
6297                         log.warn("Resource Type  cannot be updated");
6298
6299                 }
6300                 updateInfoResource.setResourceType(currentResource.getResourceType());
6301
6302                 String currentInvariantUuid = currentResource.getInvariantUUID();
6303                 String updatedInvariantUuid = updateInfoResource.getInvariantUUID();
6304
6305                 if ((updatedInvariantUuid != null) && (!updatedInvariantUuid.equals(currentInvariantUuid))) {
6306                         log.warn("Resource invariant UUID is automatically set and cannot be updated");
6307                         updateInfoResource.setInvariantUUID(currentInvariantUuid);
6308                 }
6309                 return Either.left(true);
6310         }
6311
6312         /*
6313          * private Either<Boolean, ResponseFormat> validateResourceName(User user, Resource resource, AuditingActionEnum actionEnum) { log.debug("validate resource name is not empty"); String resourceName = resource.getResourceName();
6314          *
6315          * if (!ValidationUtils.validateStringNotEmpty(resourceName)) { log.debug("Resource name is empty"); ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.MISSING_COMPONENT_NAME, ComponentTypeEnum.RESOURCE.getValue());
6316          * componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null); return Either.right(responseFormat); }
6317          *
6318          * if (!ValidationUtils.validateResourceNameLength(resourceName)) { log.debug("Resource name is exceeds max length {} ", ValidationUtils.RESOURCE_NAME_MAX_LENGTH); ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.
6319          * COMPONENT_NAME_EXCEEDS_LIMIT, ComponentTypeEnum.RESOURCE.getValue(), "" + ValidationUtils.RESOURCE_NAME_MAX_LENGTH); componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null); return Either.right(responseFormat);
6320          * }
6321          *
6322          * if (!ValidationUtils.validateResourceName(resourceName)) { log.debug("Resource name {} has invalid format", resourceName); ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.INVALID_COMPONENT_NAME,
6323          * ComponentTypeEnum.RESOURCE.getValue()); componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null); return Either.right(responseFormat); } resource.setNormalizedName(ValidationUtils.normaliseComponentName(
6324          * resourceName)); resource.setSystemName(ValidationUtils.convertToSystemName(resourceName)) ;
6325          *
6326          * return Either.left(true); }
6327          */
6328
6329         private boolean isResourceNameEquals(Resource currentResource, Resource updateInfoResource) {
6330                 String resourceNameUpdated = updateInfoResource.getName();
6331                 String resourceNameCurrent = currentResource.getName();
6332                 if (resourceNameCurrent.equals(resourceNameUpdated))
6333                         return true;
6334                 // In case of CVFC type we should support the case of old VF with CVFC instances that were created without the "Cvfc" suffix
6335                 return (currentResource.getResourceType().equals(ResourceTypeEnum.CVFC)
6336                                 && resourceNameUpdated.equals(addCvfcSuffixToResourceName(resourceNameCurrent)));
6337         }
6338
6339         private String addCvfcSuffixToResourceName(String resourceName) {
6340                 return resourceName+"Cvfc";
6341         }
6342
6343         private Either<Boolean, ResponseFormat> validateResourceName(Resource currentResource, Resource updateInfoResource, boolean hasBeenCertified, boolean isNested) {
6344                 String resourceNameUpdated = updateInfoResource.getName();
6345                 if (!isResourceNameEquals(currentResource, updateInfoResource)) {
6346                         if (isNested || !hasBeenCertified) {
6347                                 Either<Boolean, ResponseFormat> validateResourceNameResponse = validateComponentName(null, updateInfoResource, null);
6348                                 if (validateResourceNameResponse.isRight()) {
6349                                         ResponseFormat errorResponse = validateResourceNameResponse.right().value();
6350                                         return Either.right(errorResponse);
6351                                 }
6352                                 validateResourceNameResponse = validateResourceNameExists(updateInfoResource);
6353                                 if (validateResourceNameResponse.isRight()) {
6354                                         ResponseFormat errorResponse = validateResourceNameResponse.right().value();
6355                                         return Either.right(errorResponse);
6356                                 }
6357                                 currentResource.setName(resourceNameUpdated);
6358                                 currentResource.setNormalizedName(ValidationUtils.normaliseComponentName(resourceNameUpdated));
6359                                 currentResource.setSystemName(ValidationUtils.convertToSystemName(resourceNameUpdated));
6360
6361                         } else {
6362                                 log.info("Resource name: {}, cannot be updated once the resource has been certified once.", resourceNameUpdated);
6363                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.RESOURCE_NAME_CANNOT_BE_CHANGED);
6364                                 return Either.right(errorResponse);
6365                         }
6366                 }
6367                 return Either.left(true);
6368         }
6369
6370         private Either<Boolean, ResponseFormat> validateIcon(Resource currentResource, Resource updateInfoResource, boolean hasBeenCertified) {
6371                 String iconUpdated = updateInfoResource.getIcon();
6372                 String iconCurrent = currentResource.getIcon();
6373                 if (!iconCurrent.equals(iconUpdated)) {
6374                         if (!hasBeenCertified) {
6375                                 Either<Boolean, ResponseFormat> validateIcon = validateIcon(null, updateInfoResource, null);
6376                                 if (validateIcon.isRight()) {
6377                                         ResponseFormat errorResponse = validateIcon.right().value();
6378                                         return Either.right(errorResponse);
6379                                 }
6380                         } else {
6381                                 log.info("Icon {} cannot be updated once the resource has been certified once.", iconUpdated);
6382                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.RESOURCE_ICON_CANNOT_BE_CHANGED);
6383                                 return Either.right(errorResponse);
6384                         }
6385                 }
6386                 return Either.left(true);
6387         }
6388
6389         private Either<Boolean, ResponseFormat> validateVendorName(Resource currentResource, Resource updateInfoResource, boolean hasBeenCertified) {
6390                 String vendorNameUpdated = updateInfoResource.getVendorName();
6391                 String vendorNameCurrent = currentResource.getVendorName();
6392                 if (!vendorNameCurrent.equals(vendorNameUpdated)) {
6393                         if (!hasBeenCertified) {
6394                                 Either<Boolean, ResponseFormat> validateVendorName = validateVendorName(null, updateInfoResource, null);
6395                                 if (validateVendorName.isRight()) {
6396                                         ResponseFormat errorResponse = validateVendorName.right().value();
6397                                         return Either.right(errorResponse);
6398                                 }
6399                         } else {
6400                                 log.info("Vendor name {} cannot be updated once the resource has been certified once.", vendorNameUpdated);
6401                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.RESOURCE_VENDOR_NAME_CANNOT_BE_CHANGED);
6402                                 return Either.right(errorResponse);
6403                         }
6404                 }
6405                 return Either.left(true);
6406         }
6407
6408         private Either<Boolean, ResponseFormat> validateResourceVendorModelNumber(Resource currentResource, Resource updateInfoResource) {
6409                 String updatedResourceVendorModelNumber = updateInfoResource.getResourceVendorModelNumber();
6410                 String currentResourceVendorModelNumber = currentResource.getResourceVendorModelNumber();
6411                 if (!currentResourceVendorModelNumber.equals(updatedResourceVendorModelNumber)) {
6412                         Either<Boolean, ResponseFormat> validateResourceVendorModelNumber = validateResourceVendorModelNumber(null, updateInfoResource, null);
6413                         if (validateResourceVendorModelNumber.isRight()) {
6414                                 ResponseFormat errorResponse = validateResourceVendorModelNumber.right().value();
6415                                 return Either.right(errorResponse);
6416                         }
6417                 }
6418                 return Either.left(true);
6419         }
6420
6421         private Either<Boolean, ResponseFormat> validateCategory(Resource currentResource, Resource updateInfoResource, boolean hasBeenCertified, boolean inTransaction) {
6422                 Either<Boolean, ResponseFormat> validateCategoryName = validateCategory(null, updateInfoResource, null, inTransaction);
6423                 if (validateCategoryName.isRight()) {
6424                         ResponseFormat errorResponse = validateCategoryName.right().value();
6425                         return Either.right(errorResponse);
6426                 }
6427                 if (hasBeenCertified) {
6428                         CategoryDefinition currentCategory = currentResource.getCategories().get(0);
6429                         SubCategoryDefinition currentSubCategory = currentCategory.getSubcategories().get(0);
6430                         CategoryDefinition updateCategory = updateInfoResource.getCategories().get(0);
6431                         SubCategoryDefinition updtaeSubCategory = updateCategory.getSubcategories().get(0);
6432                         if (!currentCategory.getName().equals(updateCategory.getName()) || !currentSubCategory.getName().equals(updtaeSubCategory.getName())) {
6433                                 log.info("Category {} cannot be updated once the resource has been certified once.", currentResource.getCategories());
6434                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.RESOURCE_CATEGORY_CANNOT_BE_CHANGED);
6435                                 return Either.right(errorResponse);
6436                         }
6437                 }
6438                 return Either.left(true);
6439         }
6440
6441         private Either<Boolean, ResponseFormat> validateDerivedFromDuringUpdate(Resource currentResource, Resource updateInfoResource, boolean hasBeenCertified) {
6442
6443                 List<String> currentDerivedFrom = currentResource.getDerivedFrom();
6444                 List<String> updatedDerivedFrom = updateInfoResource.getDerivedFrom();
6445                 if (currentDerivedFrom == null || currentDerivedFrom.isEmpty() || updatedDerivedFrom == null || updatedDerivedFrom.isEmpty()) {
6446                         log.trace("Update normative types");
6447                         return Either.left(true);
6448                 }
6449
6450                 String derivedFromCurrent = currentDerivedFrom.get(0);
6451                 String derivedFromUpdated = updatedDerivedFrom.get(0);
6452
6453                 if (!derivedFromCurrent.equals(derivedFromUpdated)) {
6454                         if (!hasBeenCertified) {
6455                                 Either<Boolean, ResponseFormat> validateDerivedFromExistsEither = validateDerivedFromExist(null, updateInfoResource, null);
6456                                 if (validateDerivedFromExistsEither.isRight()) {
6457                                         return validateDerivedFromExistsEither;
6458                                 }
6459                         } else {
6460                                 Either<Boolean, ResponseFormat> validateDerivedFromExtending = validateDerivedFromExtending(null, currentResource, updateInfoResource, null);
6461
6462                                 if (validateDerivedFromExtending.isRight() || !validateDerivedFromExtending.left().value()) {
6463                                         log.debug("Derived from cannot be updated if it doesnt inherits directly or extends inheritance");
6464                                         return validateDerivedFromExtending;
6465                                 }
6466                         }
6467                 } else {
6468                         // For derived from, we must know whether it was actually changed,
6469                         // otherwise we must do no action.
6470                         // Due to changes it inflicts on data model (remove artifacts,
6471                         // properties...), it's not like a flat field which can be
6472                         // overwritten if not changed.
6473                         // So we must indicate that derived from is not changed
6474                         updateInfoResource.setDerivedFrom(null);
6475                 }
6476                 return Either.left(true);
6477         }
6478         
6479         private Either<Boolean, ResponseFormat> validateNestedDerivedFromDuringUpdate(Resource currentResource, Resource updateInfoResource, boolean hasBeenCertified) {
6480
6481                 List<String> currentDerivedFrom = currentResource.getDerivedFrom();
6482                 List<String> updatedDerivedFrom = updateInfoResource.getDerivedFrom();
6483                 if (currentDerivedFrom == null || currentDerivedFrom.isEmpty() || updatedDerivedFrom == null || updatedDerivedFrom.isEmpty()) {
6484                         log.trace("Update normative types");
6485                         return Either.left(true);
6486                 }
6487
6488                 String derivedFromCurrent = currentDerivedFrom.get(0);
6489                 String derivedFromUpdated = updatedDerivedFrom.get(0);
6490
6491                 if (!derivedFromCurrent.equals(derivedFromUpdated)) {
6492                         if (!hasBeenCertified) {
6493                                 Either<Boolean, ResponseFormat> validateDerivedFromExistsEither = validateDerivedFromExist(null, updateInfoResource, null);
6494                                 if (validateDerivedFromExistsEither.isRight()) {
6495                                         return validateDerivedFromExistsEither;
6496                                 }
6497                         } else {
6498                                 Either<Boolean, ResponseFormat> validateDerivedFromExtending = validateDerivedFromExtending(null, currentResource, updateInfoResource, null);
6499
6500                                 if (validateDerivedFromExtending.isRight() || !validateDerivedFromExtending.left().value()) {
6501                                         log.debug("Derived from cannot be updated if it doesnt inherits directly or extends inheritance");
6502                                         return validateDerivedFromExtending;
6503                                 }
6504                         }
6505                 }
6506                 return Either.left(true);
6507         }
6508
6509         private Either<Boolean, ResponseFormat> validateDerivedFromExist(User user, Resource resource, AuditingActionEnum actionEnum) {
6510
6511                 if (resource.getDerivedFrom() == null || resource.getDerivedFrom().isEmpty()) {
6512                         return Either.left(true);
6513                 }
6514
6515                 // IResourceOperation resourceOperation = getResourceOperation();
6516
6517                 String templateName = resource.getDerivedFrom().get(0);
6518
6519                 Either<Boolean, StorageOperationStatus> dataModelResponse = toscaOperationFacade.validateToscaResourceNameExists(templateName);
6520                 if (dataModelResponse.isRight()) {
6521                         StorageOperationStatus storageStatus = dataModelResponse.right().value();
6522                         BeEcompErrorManager.getInstance().logBeDaoSystemError("Create Resource - validateDerivedFromExist");
6523                         log.debug("request to data model failed with error: {}", storageStatus.name());
6524                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(storageStatus), resource);
6525                         log.trace("audit before sending response");
6526                         componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null);
6527                         return Either.right(responseFormat);
6528                 } else if (!dataModelResponse.left().value()) {
6529                         log.info("resource template with name: {}, does not exists", templateName);
6530                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.PARENT_RESOURCE_NOT_FOUND);
6531                         componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null);
6532
6533                         return Either.right(responseFormat);
6534
6535                 }
6536                 return Either.left(true);
6537         }
6538
6539         // Tal G for extending inheritance US815447
6540         private Either<Boolean, ResponseFormat> validateDerivedFromExtending(User user, Resource currentResource, Resource updateInfoResource, AuditingActionEnum actionEnum) {
6541                 // If updated resource is not deriving, should fail validation
6542                 /*
6543                  * if (currentResource.getDerivedFrom() == null || currentResource.getDerivedFrom().isEmpty()) { return Either.left(false); }
6544                  */
6545                 // If current resource is deriving from certain type and it is updated to not deriving, should fail validation
6546                 /*
6547                  * if (updateInfoResource.getDerivedFrom() == null || updateInfoResource.getDerivedFrom().isEmpty()) { return Either.left(false); }
6548                  */
6549                 String currentTemplateName = currentResource.getDerivedFrom().get(0);
6550                 String updatedTemplateName = updateInfoResource.getDerivedFrom().get(0);
6551
6552                 Either<Boolean, StorageOperationStatus> dataModelResponse = toscaOperationFacade.validateToscaResourceNameExtends(currentTemplateName, updatedTemplateName);
6553                 if (dataModelResponse.isRight()) {
6554                         StorageOperationStatus storageStatus = dataModelResponse.right().value();
6555                         BeEcompErrorManager.getInstance().logBeDaoSystemError("Create/Update Resource - validateDerivingFromExtendingType");
6556                         log.debug("request to data model failed with error: {}", storageStatus.name());
6557                         ResponseFormat responseFormat = componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(storageStatus), currentResource);
6558                         log.trace("audit before sending response");
6559                         componentsUtils.auditResource(responseFormat, user, currentResource, "", "", actionEnum, null);
6560                         return Either.right(responseFormat);
6561                 }
6562
6563                 if (!dataModelResponse.left().value()) {
6564                         log.info("resource template with name {} does not inherit as original {}", updatedTemplateName, currentTemplateName);
6565                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.PARENT_RESOURCE_DOES_NOT_EXTEND);
6566                         componentsUtils.auditResource(responseFormat, user, currentResource, "", "", actionEnum, null);
6567
6568                         return Either.right(responseFormat);
6569
6570                 }
6571                 return Either.left(true);
6572         }
6573
6574         public Either<Boolean, ResponseFormat> validateDerivedFromNotEmpty(User user, Resource resource, AuditingActionEnum actionEnum) {
6575                 log.debug("validate resource derivedFrom field");
6576                 if ((resource.getDerivedFrom() == null) || (resource.getDerivedFrom().isEmpty()) || (resource.getDerivedFrom().get(0)) == null || (resource.getDerivedFrom().get(0).trim().isEmpty())) {
6577                         log.info("derived from (template) field is missing for the resource");
6578                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.MISSING_DERIVED_FROM_TEMPLATE);
6579                         componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null);
6580
6581                         return Either.right(responseFormat);
6582                 }
6583                 return Either.left(true);
6584         }
6585
6586         private Either<Boolean, ResponseFormat> validateResourceNameExists(Resource resource) {
6587
6588                 Either<Boolean, StorageOperationStatus> resourceOperationResponse = toscaOperationFacade.validateComponentNameExists(resource.getName(), resource.getResourceType(), resource.getComponentType());
6589                 if (resourceOperationResponse.isLeft()) {
6590                         if (!resourceOperationResponse.left().value()) {
6591                                 return Either.left(false);
6592                         } else {
6593                                 log.debug("resource with name: {}, already exists", resource.getName());
6594                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.COMPONENT_NAME_ALREADY_EXIST, ComponentTypeEnum.RESOURCE.getValue(), resource.getName());
6595                                 return Either.right(errorResponse);
6596                         }
6597                 }
6598                 log.debug("error while validateResourceNameExists for resource: {}", resource.getName());
6599                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(resourceOperationResponse.right().value()));
6600                 return Either.right(errorResponse);
6601         }
6602
6603         /*
6604          * private Either<Boolean, ResponseFormat> validateTagsListAndRemoveDuplicates(User user, Resource resource, AuditingActionEnum actionEnum) { List<String> tagsList = resource.getTags();
6605          * 
6606          * Either<Boolean, ResponseFormat> validateTags = validateResourceTags(tagsList, resource.getResourceName()); if (validateTags.isRight()) { ResponseFormat responseFormat = validateTags.right().value();
6607          * componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null); return Either.right(responseFormat); } ValidationUtils.removeDuplicateFromList(tagsList); return Either.left(true);
6608          * 
6609          * }
6610          * 
6611          * private Either<Boolean, ResponseFormat> validateResourceTags(List<String> tags, String resourceName) { log.debug("validate resource tags"); boolean includesResourceName = false; int tagListSize = 0; if (tags != null && !tags.isEmpty()) { for
6612          * (String tag : tags) { if (!ValidationUtils.validateTagLength(tag)) { log.debug("tag length exceeds limit {}", ValidationUtils.TAG_MAX_LENGTH); return Either.right(componentsUtils.getResponseFormat(ActionStatus.
6613          * COMPONENT_SINGLE_TAG_EXCEED_LIMIT, "" + ValidationUtils.TAG_MAX_LENGTH)); } if (ValidationUtils.validateComponentNamePattern(tag)) { if (!includesResourceName) { includesResourceName = resourceName.equals(tag); } } else {
6614          * log.debug("invalid tag {}", tag); return Either.right(componentsUtils.getResponseFormat(ActionStatus. COMPONENT_INVALID_TAG)); } tagListSize += tag.length() + 1; } if (!includesResourceName) { log.debug( "tags must include resource name");
6615          * return Either.right(componentsUtils.getResponseFormat(ActionStatus. COMPONENT_INVALID_TAGS_NO_COMP_NAME)); } if (!ValidationUtils.validateTagListLength(tagListSize)) { log.debug( "overall tags length {}, exceeds limit {}", tagListSize,
6616          * ValidationUtils.TAG_LIST_MAX_LENGTH); return Either.right(componentsUtils.getResponseFormat(ActionStatus. COMPONENT_TAGS_EXCEED_LIMIT, "" + ValidationUtils.TAG_LIST_MAX_LENGTH)); } return Either.left(true); }
6617          * 
6618          * return Either.right(componentsUtils.getResponseFormat(ActionStatus. COMPONENT_MISSING_TAGS)); }
6619          */
6620
6621         private Either<Boolean, ResponseFormat> validateCategory(User user, Resource resource, AuditingActionEnum actionEnum, boolean inTransaction) {
6622
6623                 List<CategoryDefinition> categories = resource.getCategories();
6624                 if (categories == null || categories.size() == 0) {
6625                         log.debug("Resource category is empty");
6626                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.COMPONENT_MISSING_CATEGORY, ComponentTypeEnum.RESOURCE.getValue());
6627                         componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null);
6628                         return Either.right(responseFormat);
6629                 }
6630                 if (categories.size() > 1) {
6631                         log.debug("Must be only one category for resource");
6632                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.COMPONENT_TOO_MUCH_CATEGORIES, ComponentTypeEnum.RESOURCE.getValue());
6633                         return Either.right(responseFormat);
6634                 }
6635                 CategoryDefinition category = categories.get(0);
6636                 List<SubCategoryDefinition> subcategories = category.getSubcategories();
6637                 if (subcategories == null || subcategories.size() == 0) {
6638                         log.debug("Missinig subcategory for resource");
6639                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.COMPONENT_MISSING_SUBCATEGORY);
6640                         return Either.right(responseFormat);
6641                 }
6642                 if (subcategories.size() > 1) {
6643                         log.debug("Must be only one sub category for resource");
6644                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.RESOURCE_TOO_MUCH_SUBCATEGORIES);
6645                         return Either.right(responseFormat);
6646                 }
6647
6648                 SubCategoryDefinition subcategory = subcategories.get(0);
6649
6650                 if (!ValidationUtils.validateStringNotEmpty(category.getName())) {
6651                         log.debug("Resource category is empty");
6652                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.COMPONENT_MISSING_CATEGORY, ComponentTypeEnum.RESOURCE.getValue());
6653                         componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null);
6654                         return Either.right(responseFormat);
6655                 }
6656                 if (!ValidationUtils.validateStringNotEmpty(subcategory.getName())) {
6657                         log.debug("Resource category is empty");
6658                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.COMPONENT_MISSING_SUBCATEGORY, ComponentTypeEnum.RESOURCE.getValue());
6659                         componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null);
6660                         return Either.right(responseFormat);
6661                 }
6662
6663                 Either<Boolean, ResponseFormat> validateCategory = validateCategoryListed(category, subcategory, inTransaction);
6664                 if (validateCategory.isRight()) {
6665                         ResponseFormat responseFormat = validateCategory.right().value();
6666                         componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null);
6667                         return Either.right(responseFormat);
6668                 }
6669
6670                 return Either.left(true);
6671         }
6672
6673         private Either<Boolean, ResponseFormat> validateCategoryListed(CategoryDefinition category, SubCategoryDefinition subcategory, boolean inTransaction) {
6674                 if (category != null && subcategory != null) {
6675                         log.debug("validating resource category {} against valid categories list", category);
6676                         Either<List<CategoryDefinition>, ActionStatus> categories = elementDao.getAllCategories(NodeTypeEnum.ResourceNewCategory, inTransaction);
6677                         if (categories.isRight()) {
6678                                 log.debug("failed to retrive resource categories from Titan");
6679                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(categories.right().value());
6680                                 return Either.right(responseFormat);
6681                         }
6682                         List<CategoryDefinition> categoryList = categories.left().value();
6683                         for (CategoryDefinition cat : categoryList) {
6684                                 if (cat.getName().equals(category.getName())) {
6685                                         for (SubCategoryDefinition subcat : cat.getSubcategories()) {
6686                                                 if (subcat.getName().equals(subcategory.getName())) {
6687                                                         return Either.left(true);
6688                                                 }
6689                                         }
6690                                         log.debug("SubCategory {} is not part of resource category group. Resource subcategory valid values are {}", subcategory, cat.getSubcategories());
6691                                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.COMPONENT_INVALID_CATEGORY, ComponentTypeEnum.RESOURCE.getValue()));
6692                                 }
6693                         }
6694                         log.debug("Category {} is not part of resource category group. Resource category valid values are {}", category, categoryList);
6695                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.COMPONENT_INVALID_CATEGORY, ComponentTypeEnum.RESOURCE.getValue()));
6696                 }
6697                 return Either.left(false);
6698         }
6699
6700         public Either<Boolean, ResponseFormat> validateVendorReleaseName(User user, Resource resource, AuditingActionEnum actionEnum) {
6701                 String vendorRelease = resource.getVendorRelease();
6702
6703                 log.debug("validate vendor relese name");
6704                 if (!ValidationUtils.validateStringNotEmpty(vendorRelease)) {
6705                         log.info("vendor relese name is missing.");
6706                         ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.MISSING_VENDOR_RELEASE);
6707                         componentsUtils.auditResource(errorResponse, user, resource, "", "", actionEnum, null);
6708                         return Either.right(errorResponse);
6709                 }
6710
6711                 Either<Boolean, ResponseFormat> validateVendorReleaseResponse = validateVendorReleaseName(vendorRelease);
6712                 if (validateVendorReleaseResponse.isRight()) {
6713                         ResponseFormat responseFormat = validateVendorReleaseResponse.right().value();
6714                         componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null);
6715                 }
6716                 return validateVendorReleaseResponse;
6717         }
6718
6719         public Either<Boolean, ResponseFormat> validateVendorReleaseName(String vendorRelease) {
6720                 if (vendorRelease != null) {
6721                         if (!ValidationUtils.validateVendorReleaseLength(vendorRelease)) {
6722                                 log.info("vendor release exceds limit.");
6723                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.VENDOR_RELEASE_EXCEEDS_LIMIT, "" + ValidationUtils.VENDOR_RELEASE_MAX_LENGTH);
6724                                 return Either.right(errorResponse);
6725                         }
6726
6727                         if (!ValidationUtils.validateVendorRelease(vendorRelease)) {
6728                                 log.info("vendor release  is not valid.");
6729                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.INVALID_VENDOR_RELEASE);
6730                                 return Either.right(errorResponse);
6731                         }
6732                         return Either.left(true);
6733                 }
6734                 return Either.left(false);
6735
6736         }
6737
6738         private Either<Boolean, ResponseFormat> validateVendorName(User user, Resource resource, AuditingActionEnum actionEnum) {
6739                 String vendorName = resource.getVendorName();
6740                 if (!ValidationUtils.validateStringNotEmpty(vendorName)) {
6741                         log.info("vendor name is missing.");
6742                         ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.MISSING_VENDOR_NAME);
6743                         componentsUtils.auditResource(errorResponse, user, resource, "", "", actionEnum, null);
6744                         return Either.right(errorResponse);
6745                 }
6746
6747                 Either<Boolean, ResponseFormat> validateVendorNameResponse = validateVendorName(vendorName);
6748                 if (validateVendorNameResponse.isRight()) {
6749                         ResponseFormat responseFormat = validateVendorNameResponse.right().value();
6750                         componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null);
6751                 }
6752                 return validateVendorNameResponse;
6753
6754         }
6755
6756         private Either<Boolean, ResponseFormat> validateResourceVendorModelNumber(User user, Resource resource, AuditingActionEnum actionEnum) {
6757                 String resourceVendorModelNumber = resource.getResourceVendorModelNumber();
6758                 Either<Boolean, ResponseFormat> validateResourceVendorModelNumber = validateResourceVendorModelNumber(resourceVendorModelNumber);
6759                 if (validateResourceVendorModelNumber.isRight()) {
6760                         ResponseFormat responseFormat = validateResourceVendorModelNumber.right().value();
6761                         componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null);
6762                 }
6763                 return validateResourceVendorModelNumber;
6764
6765         }
6766
6767
6768         private Either<Boolean, ResponseFormat> validateVendorName(String vendorName) {
6769                 if (vendorName != null) {
6770                         if (!ValidationUtils.validateVendorNameLength(vendorName)) {
6771                                 log.info("vendor name exceds limit.");
6772                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.VENDOR_NAME_EXCEEDS_LIMIT, "" + ValidationUtils.VENDOR_NAME_MAX_LENGTH);
6773                                 return Either.right(errorResponse);
6774                         }
6775
6776                         if (!ValidationUtils.validateVendorName(vendorName)) {
6777                                 log.info("vendor name  is not valid.");
6778                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.INVALID_VENDOR_NAME);
6779                                 return Either.right(errorResponse);
6780                         }
6781                         return Either.left(true);
6782
6783                 }
6784                 return Either.left(false);
6785
6786         }
6787
6788         private Either<Boolean, ResponseFormat> validateResourceVendorModelNumber(String resourceVendorModelNumber) {
6789                 if (resourceVendorModelNumber.equals("")) {
6790                         return Either.left(true);
6791                 } else {
6792                         if (!ValidationUtils.validateResourceVendorModelNumberLength(resourceVendorModelNumber)) {
6793                                 log.info("resource vendor model number exceeds limit.");
6794                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.RESOURCE_VENDOR_MODEL_NUMBER_EXCEEDS_LIMIT, "" + ValidationUtils.RESOURCE_VENDOR_MODEL_NUMBER_MAX_LENGTH);
6795                                 return Either.right(errorResponse);
6796                         }
6797                         // resource vendor model number is currently validated as vendor name
6798                         if (!ValidationUtils.validateVendorName(resourceVendorModelNumber)) {
6799                                 log.info("resource vendor model number  is not valid.");
6800                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.INVALID_RESOURCE_VENDOR_MODEL_NUMBER);
6801                                 return Either.right(errorResponse);
6802                         }
6803                         return Either.left(true);
6804                 }
6805         }
6806
6807         
6808         /*
6809          * private Either<Boolean, ResponseFormat> validateDescriptionAndCleanup(User user, Resource resource, AuditingActionEnum actionEnum) { String description = resource.getDescription(); if (!ValidationUtils.validateStringNotEmpty(description)) {
6810          * log.debug("Resource description is empty"); ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus. COMPONENT_MISSING_DESCRIPTION, ComponentTypeEnum.RESOURCE.getValue()); componentsUtils.auditResource(errorResponse,
6811          * user, resource, "", "", actionEnum, null); return Either.right(errorResponse); }
6812          * 
6813          * description = ValidationUtils.removeNoneUtf8Chars(description); description = ValidationUtils.removeHtmlTags(description); description = ValidationUtils.normaliseWhitespace(description); description = ValidationUtils.stripOctets(description);
6814          * 
6815          * Either<Boolean, ResponseFormat> validatDescription = validateResourceDescription(description); if (validatDescription.isRight()) { ResponseFormat responseFormat = validatDescription.right().value();
6816          * componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null); return Either.right(responseFormat); } resource.setDescription(description); return Either.left(true); }
6817          * 
6818          * private Either<Boolean, ResponseFormat> validateResourceDescription(String description) { if (description != null) { if (!ValidationUtils.validateDescriptionLength(description)) { return
6819          * Either.right(componentsUtils.getResponseFormat(ActionStatus. COMPONENT_DESCRIPTION_EXCEEDS_LIMIT, ComponentTypeEnum.RESOURCE.getValue(), "" + ValidationUtils.COMPONENT_DESCRIPTION_MAX_LENGTH)); }
6820          * 
6821          * if (!ValidationUtils.validateIsEnglish(description)) { return Either.right(componentsUtils.getResponseFormat(ActionStatus. COMPONENT_INVALID_DESCRIPTION, ComponentTypeEnum.RESOURCE.getValue())); } return Either.left(true); } return
6822          * Either.left(false); }
6823          */
6824
6825         /*
6826          * private Either<Boolean, ResponseFormat> validateContactId(User user, Resource resource, AuditingActionEnum actionEnum) { String contactId = resource.getContactId();
6827          * 
6828          * if (!ValidationUtils.validateStringNotEmpty(contactId)) { log.info("contact info is missing."); ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus. COMPONENT_MISSING_CONTACT, ComponentTypeEnum.RESOURCE.getValue());
6829          * componentsUtils.auditResource(errorResponse, user, resource, "", "", actionEnum, null); return Either.right(errorResponse); }
6830          * 
6831          * Either<Boolean, ResponseFormat> validateContactIdResponse = validateContactId(contactId); if (validateContactIdResponse.isRight()) { ResponseFormat responseFormat = validateContactIdResponse.right().value();
6832          * componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null); } return validateContactIdResponse; }
6833          * 
6834          * private Either<Boolean, ResponseFormat> validateContactId(String contactId) { if (contactId != null) { if (!ValidationUtils.validateContactId(contactId)) { log.debug("contact {} is invalid.", contactId); ResponseFormat errorResponse =
6835          * componentsUtils.getResponseFormat(ActionStatus. COMPONENT_INVALID_CONTACT, ComponentTypeEnum.RESOURCE.getValue()); return Either.right(errorResponse); } return Either.left(true); } return Either.left(false);
6836          * 
6837          * }
6838          */
6839
6840         /*
6841          * private Either<Boolean, ResponseFormat> validateIcon(User user, Resource resource, AuditingActionEnum actionEnum) { String icon = resource.getIcon();
6842          * 
6843          * if (!ValidationUtils.validateStringNotEmpty(icon)) { log.debug("icon is missing."); ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.COMPONENT_MISSING_ICON, ComponentTypeEnum.RESOURCE.getValue());
6844          * componentsUtils.auditResource(errorResponse, user, resource, "", "", actionEnum, null); return Either.right(errorResponse); }
6845          * 
6846          * Either<Boolean, ResponseFormat> validateIcon = validateIcon(icon); if (validateIcon.isRight()) { ResponseFormat responseFormat = validateIcon.right().value(); componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum,
6847          * null); } return validateIcon;
6848          * 
6849          * }
6850          * 
6851          * public Either<Boolean, ResponseFormat> validateIcon(String icon) { if (icon != null) { if (!ValidationUtils.validateIconLength(icon)) { log.debug("icon exceeds max length"); return Either.right(componentsUtils.getResponseFormat(ActionStatus.
6852          * COMPONENT_ICON_EXCEEDS_LIMIT, ComponentTypeEnum.RESOURCE.getValue(), "" + ValidationUtils.ICON_MAX_LENGTH)); } if (!ValidationUtils.validateIcon(icon)) { log.debug("icon is invalid." ); ResponseFormat errorResponse =
6853          * componentsUtils.getResponseFormat(ActionStatus.COMPONENT_INVALID_ICON, ComponentTypeEnum.RESOURCE.getValue()); return Either.right(errorResponse); } return Either.left(true); } return Either.left(false);
6854          * 
6855          * }
6856          */
6857
6858         private Either<Boolean, ResponseFormat> validateCost(User user, Resource resource, AuditingActionEnum actionEnum) {
6859                 String cost = resource.getCost();
6860                 if (cost != null) {
6861
6862                         if (!ValidationUtils.validateCost(cost)) {
6863                                 log.debug("resource cost is invalid.");
6864                                 ResponseFormat errorResponse = componentsUtils.getResponseFormat(ActionStatus.INVALID_CONTENT);
6865                                 return Either.right(errorResponse);
6866                         }
6867                 }
6868                 return Either.left(true);
6869         }
6870
6871         private Either<Boolean, ResponseFormat> validateLicenseType(User user, Resource resource, AuditingActionEnum actionEnum) {
6872                 log.debug("validate licenseType");
6873                 String licenseType = resource.getLicenseType();
6874                 if (licenseType != null) {
6875                         List<String> licenseTypes = ConfigurationManager.getConfigurationManager().getConfiguration().getLicenseTypes();
6876                         if (!licenseTypes.contains(licenseType)) {
6877                                 log.debug("License type {} isn't configured");
6878                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.INVALID_CONTENT);
6879                                 if (actionEnum != null) {
6880                                         // In update case, no audit is required
6881                                         componentsUtils.auditResource(responseFormat, user, resource, "", "", actionEnum, null);
6882                                 }
6883                                 return Either.right(responseFormat);
6884                         }
6885                 }
6886                 return Either.left(true);
6887         }
6888
6889         private Either<Boolean, ResponseFormat> processUpdateOfDerivedFrom(Resource currentResource, Resource updatedResource, String userId, boolean shouldLock, boolean inTransaction) {
6890                 Either<Operation, ResponseFormat> deleteArtifactByInterface = null;
6891                 if (updatedResource.getDerivedFrom() != null) {
6892                         log.debug("Starting derived from update for resource {}", updatedResource.getUniqueId());
6893                         log.debug("1. Removing interface artifacts from graph");
6894                         // Remove all interface artifacts of resource
6895                         String resourceId = updatedResource.getUniqueId();
6896                         Map<String, InterfaceDefinition> interfaces = currentResource.getInterfaces();
6897
6898                         if (interfaces != null) {
6899                                 Collection<InterfaceDefinition> values = interfaces.values();
6900                                 for (InterfaceDefinition interfaceDefinition : values) {
6901                                         String interfaceType = interfaceTypeOperation.getShortInterfaceName(interfaceDefinition);
6902
6903                                         log.trace("Starting interface artifacts removal for interface type {}", interfaceType);
6904                                         Map<String, Operation> operations = interfaceDefinition.getOperationsMap();
6905                                         if (operations != null) {
6906                                                 for (Entry<String, Operation> operationEntry : operations.entrySet()) {
6907                                                         Operation operation = operationEntry.getValue();
6908                                                         ArtifactDefinition implementation = operation.getImplementationArtifact();
6909                                                         if (implementation != null) {
6910                                                                 String uniqueId = implementation.getUniqueId();
6911                                                                 log.debug("Removing interface artifact definition {}, operation {}, interfaceType {}", uniqueId, operationEntry.getKey(), interfaceType);
6912                                                                 // only thing that transacts and locks here
6913                                                                 deleteArtifactByInterface = artifactsBusinessLogic.deleteArtifactByInterface(resourceId, interfaceType, operationEntry.getKey(), userId, uniqueId, null, shouldLock, true);
6914                                                                 if (deleteArtifactByInterface.isRight()) {
6915                                                                         log.debug("Couldn't remove artifact definition with id {}", uniqueId);
6916                                                                         if (!inTransaction) {
6917                                                                                 titanDao.rollback();
6918                                                                         }
6919                                                                         return Either.right(deleteArtifactByInterface.right().value());
6920                                                                 }
6921                                                         } else {
6922                                                                 log.trace("No implementation found for operation {} - nothing to delete", operationEntry.getKey());
6923                                                         }
6924                                                 }
6925                                         } else {
6926                                                 log.trace("No operations found for interface type {}", interfaceType);
6927                                         }
6928                                 }
6929                         }
6930                         log.debug("2. Removing properties");
6931                         Either<Map<String, PropertyDefinition>, StorageOperationStatus> findPropertiesOfNode = propertyOperation.deleteAllPropertiesAssociatedToNode(NodeTypeEnum.Resource, resourceId);
6932
6933                         if (findPropertiesOfNode.isRight() && !findPropertiesOfNode.right().value().equals(StorageOperationStatus.OK)) {
6934                                 log.debug("Failed to remove all properties of resource");
6935                                 if (!inTransaction)
6936                                         titanDao.rollback();
6937                                 return Either.right(componentsUtils.getResponseFormat(componentsUtils.convertFromStorageResponse(findPropertiesOfNode.right().value())));
6938                         }
6939
6940                 } else {
6941                         log.debug("Derived from wasn't changed during update");
6942                 }
6943
6944                 if (!inTransaction)
6945                         titanDao.commit();
6946                 return Either.left(true);
6947
6948         }
6949
6950         /**** Auditing *******************/
6951
6952         protected static IElementOperation getElementDao(Class<IElementOperation> class1, ServletContext context) {
6953                 WebAppContextWrapper webApplicationContextWrapper = (WebAppContextWrapper) context.getAttribute(Constants.WEB_APPLICATION_CONTEXT_WRAPPER_ATTR);
6954
6955                 WebApplicationContext webApplicationContext = webApplicationContextWrapper.getWebAppContext(context);
6956
6957                 return webApplicationContext.getBean(class1);
6958         }
6959
6960         public ICapabilityTypeOperation getCapabilityTypeOperation() {
6961                 return capabilityTypeOperation;
6962         }
6963
6964         public void setCapabilityTypeOperation(ICapabilityTypeOperation capabilityTypeOperation) {
6965                 this.capabilityTypeOperation = capabilityTypeOperation;
6966         }
6967
6968         public Either<Boolean, ResponseFormat> validatePropertiesDefaultValues(Resource resource) {
6969                 log.debug("validate resource properties default values");
6970                 Either<Boolean, ResponseFormat> eitherResult = Either.left(true);
6971                 List<PropertyDefinition> properties = resource.getProperties();
6972                 String type = null;
6973                 String innerType = null;
6974                 if (properties != null) {
6975                         for (PropertyDefinition property : properties) {
6976                                 if (!propertyOperation.isPropertyTypeValid(property)) {
6977                                         log.info("Invalid type for property");
6978                                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.INVALID_PROPERTY_TYPE, property.getType(), property.getName());
6979                                         eitherResult = Either.right(responseFormat);
6980                                         break;
6981                                 }
6982
6983                                 Either<Map<String, DataTypeDefinition>, ResponseFormat> allDataTypes = getAllDataTypes(applicationDataTypeCache);
6984                                 if (allDataTypes.isRight()) {
6985                                         return Either.right(allDataTypes.right().value());
6986                                 }
6987
6988                                 type = property.getType();
6989                                 if (type.equals(ToscaPropertyType.LIST.getType()) || type.equals(ToscaPropertyType.MAP.getType())) {
6990                                         ImmutablePair<String, Boolean> propertyInnerTypeValid = propertyOperation.isPropertyInnerTypeValid(property, allDataTypes.left().value());
6991                                         innerType = propertyInnerTypeValid.getLeft();
6992                                         if (!propertyInnerTypeValid.getRight().booleanValue()) {
6993                                                 log.info("Invalid inner type for property");
6994                                                 ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.INVALID_PROPERTY_INNER_TYPE, innerType, property.getName());
6995                                                 eitherResult = Either.right(responseFormat);
6996                                                 break;
6997                                         }
6998                                 }
6999
7000                                 if (!propertyOperation.isPropertyDefaultValueValid(property, allDataTypes.left().value())) {
7001                                         log.info("Invalid default value for property");
7002                                         ResponseFormat responseFormat;
7003                                         if (type.equals(ToscaPropertyType.LIST.getType()) || type.equals(ToscaPropertyType.MAP.getType())) {
7004                                                 responseFormat = componentsUtils.getResponseFormat(ActionStatus.INVALID_COMPLEX_DEFAULT_VALUE, property.getName(), type, innerType, property.getDefaultValue());
7005                                         } else {
7006                                                 responseFormat = componentsUtils.getResponseFormat(ActionStatus.INVALID_DEFAULT_VALUE, property.getName(), type, property.getDefaultValue());
7007                                         }
7008                                         eitherResult = Either.right(responseFormat);
7009                                         break;
7010
7011                                 }
7012                         }
7013                 }
7014                 return eitherResult;
7015         }
7016
7017         @Override
7018         public Either<List<String>, ResponseFormat> deleteMarkedComponents() {
7019                 return deleteMarkedComponents(ComponentTypeEnum.RESOURCE);
7020         }
7021
7022         @Override
7023         public ComponentInstanceBusinessLogic getComponentInstanceBL() {
7024                 return vfComponentInstanceBusinessLogic;
7025         }
7026
7027         private String getComponentTypeForResponse(Component component) {
7028                 String componentTypeForResponse = "SERVICE";
7029                 if (component instanceof Resource) {
7030                         componentTypeForResponse = ((Resource) component).getResourceType().name();
7031                 }
7032                 return componentTypeForResponse;
7033         }
7034
7035         private Either<Map<String, GroupDefinition>, ResponseFormat> createGroupsFromYaml(String yamlFileName, Map<String, Object> toscaJson, Resource resource) {
7036
7037                 Map<String, GroupDefinition> groups = new HashMap<String, GroupDefinition>();
7038                 Either<Map<String, GroupDefinition>, ResponseFormat> result = Either.left(groups);
7039
7040                 Either<Map<String, Object>, ResultStatusEnum> eitherNodesTemlates = ImportUtils.findFirstToscaMapElement(toscaJson, ToscaTagNamesEnum.GROUPS);
7041                 if (eitherNodesTemlates.isLeft()) {
7042                         Map<String, Object> jsonNodeTemplates = eitherNodesTemlates.left().value();
7043
7044                         if (jsonNodeTemplates != null && false == jsonNodeTemplates.isEmpty()) {
7045                                 Iterator<Entry<String, Object>> nodesNameValue = jsonNodeTemplates.entrySet().iterator();
7046                                 while (nodesNameValue.hasNext()) {
7047                                         Entry<String, Object> groupNameValue = nodesNameValue.next();
7048
7049                                         String groupName = groupNameValue.getKey();
7050                                         Either<GroupDefinition, ResponseFormat> eitherNode = createGroupInfo(groupName, groupNameValue.getValue());
7051                                         if (eitherNode.isRight()) {
7052                                                 String message = "Failed when creating group: " + groupNameValue.getKey() + " for resource:" + resource.getName();
7053                                                 BeEcompErrorManager.getInstance().logInternalFlowError("ImportResource", message, ErrorSeverity.INFO);
7054                                                 return Either.right(eitherNode.right().value());
7055                                         } else {
7056                                                 GroupDefinition groupDefinition = eitherNode.left().value();
7057                                                 groups.put(groupName, groupDefinition);
7058                                         }
7059                                 }
7060                         }
7061                 }
7062
7063                 return result;
7064         }
7065
7066         private Either<Map<String, InputDefinition>, ResponseFormat> createInputsFromYaml(String yamlFileName, Map<String, Object> toscaJson, Resource resource) {
7067
7068                 Either<Map<String, InputDefinition>, ResultStatusEnum> inputs = ImportUtils.getInputs(toscaJson);
7069                 if (inputs.isRight()) {
7070                         String message = "Failed when creating inputs:  for resource:" + resource.getName();
7071                         BeEcompErrorManager.getInstance().logInternalFlowError("ImportResource", message, ErrorSeverity.INFO);
7072                         Map<String, InputDefinition> resultMap = new HashMap<>();
7073                         return Either.left(resultMap);
7074
7075                 }
7076
7077                 Either<Map<String, InputDefinition>, ResponseFormat> result = Either.left(inputs.left().value());
7078
7079                 return result;
7080         }
7081
7082         @SuppressWarnings("unchecked")
7083         private Either<GroupDefinition, ResponseFormat> createGroupInfo(String groupName, Object groupTemplateJson) {
7084
7085                 GroupDefinition groupInfo = new GroupDefinition();
7086                 groupInfo.setName(groupName);
7087                 Either<GroupDefinition, ResponseFormat> result = Either.left(groupInfo);
7088
7089                 try {
7090                         if (groupTemplateJson != null && groupTemplateJson instanceof Map) {
7091                                 Map<String, Object> groupTemplateJsonMap = (Map<String, Object>) groupTemplateJson;
7092                                 String groupType = (String) groupTemplateJsonMap.get(ToscaTagNamesEnum.TYPE.getElementName());
7093                                 if (!StringUtils.isEmpty(groupType)) {
7094                                         groupInfo.setType(groupType);
7095                                 } else {
7096                                         log.debug("The 'type' member is not found under group {}", groupName);
7097                                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.GROUP_MISSING_GROUP_TYPE, groupName));
7098                                 }
7099
7100                                 if (groupTemplateJsonMap.containsKey(ToscaTagNamesEnum.DESCRIPTION.getElementName())) {
7101                                         groupInfo.setDescription((String) groupTemplateJsonMap.get(ToscaTagNamesEnum.DESCRIPTION.getElementName()));
7102                                 }
7103
7104                                 if (groupTemplateJsonMap.containsKey(ToscaTagNamesEnum.MEMBERS.getElementName())) {
7105                                         Object members = groupTemplateJsonMap.get(ToscaTagNamesEnum.MEMBERS.getElementName());
7106                                         if (members != null) {
7107                                                 if (members instanceof List) {
7108                                                         Map<String, String> membersLoaded = new HashMap<>();
7109                                                         List<?> membersAsList = (List<?>) members;
7110                                                         for (Object member : membersAsList) {
7111                                                                 membersLoaded.put(member.toString(), "");
7112                                                         }
7113                                                         groupInfo.setMembers(membersLoaded);
7114                                                 } else {
7115                                                         log.debug("The 'members' member is not of type list under group {}", groupName);
7116                                                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE));
7117                                                 }
7118                                         }
7119                                 }
7120
7121                                 if (groupTemplateJsonMap.containsKey(ToscaTagNamesEnum.PROPERTIES.getElementName())) {
7122                                         Object properties = groupTemplateJsonMap.get(ToscaTagNamesEnum.PROPERTIES.getElementName());
7123
7124                                         Either<List<GroupProperty>, ResponseFormat> regResponse = createPropertiesValueModuleFromYaml(properties, groupName, groupType);
7125                                         if (regResponse.isRight())
7126                                                 return Either.right(regResponse.right().value());
7127                                         if (regResponse.left().value().size() > 0) {
7128                                                 groupInfo.convertFromGroupProperties(regResponse.left().value());
7129                                         }
7130                                 }
7131
7132                         } else {
7133                                 result = Either.right(componentsUtils.getResponseFormat(ActionStatus.NOT_TOPOLOGY_TOSCA_TEMPLATE));
7134                         }
7135                 } catch (Exception e) {
7136                         BeEcompErrorManager.getInstance().logBeSystemError("Import Resource - create group");
7137                         log.debug("error when creating group, message:{}", e.getMessage(), e);
7138                         result = Either.right(componentsUtils.getResponseFormat(ActionStatus.INVALID_YAML));
7139                 }
7140
7141                 return result;
7142         }
7143
7144         @SuppressWarnings("unchecked")
7145         private Either<List<GroupProperty>, ResponseFormat> createPropertiesValueModuleFromYaml(Object properties, String groupName, String groupType) {
7146
7147                 List<GroupProperty> result = new ArrayList<>();
7148
7149                 if (properties == null) {
7150                         return Either.left(result);
7151                 }
7152
7153                 Either<GroupTypeDefinition, StorageOperationStatus> groupTypeRes = groupTypeOperation.getLatestGroupTypeByType(groupType, true);
7154
7155                 if (groupTypeRes.isRight()) {
7156                         return Either.right(componentsUtils.getResponseFormat(ActionStatus.GROUP_TYPE_IS_INVALID, groupType));
7157                 }
7158
7159                 Map<String, PropertyDefinition> gtProperties = new HashMap<>();
7160                 GroupTypeDefinition groupTypeDefinition = groupTypeRes.left().value();
7161
7162                 List<PropertyDefinition> propertiesDef = groupTypeDefinition.getProperties();
7163
7164                 if (propertiesDef != null) {
7165                         gtProperties = propertiesDef.stream().collect(Collectors.toMap(p -> p.getName(), p -> p));
7166                 }
7167
7168                 if (properties != null) {
7169
7170                         if (properties instanceof Map) {
7171
7172                                 Map<String, Object> props = (Map<String, Object>) properties;
7173                                 for (Entry<String, Object> entry : props.entrySet()) {
7174
7175                                         String propName = entry.getKey();
7176                                         Object value = entry.getValue();
7177
7178                                         PropertyDefinition gtDefinition = gtProperties.get(propName);
7179                                         if (gtDefinition == null) {
7180                                                 return Either.right(componentsUtils.getResponseFormat(ActionStatus.GROUP_PROPERTY_NOT_FOUND, propName, groupName, groupType));
7181                                         }
7182
7183                                         ToscaPropertyType type = ToscaPropertyType.isValidType(gtDefinition.getType());
7184
7185                                         String convertedValue = null;
7186                                         if (value != null) {
7187                                                 if (type == null || value instanceof Map || value instanceof List) {
7188                                                         convertedValue = gson.toJson(value);
7189                                                 } else {
7190                                                         convertedValue = value.toString();
7191                                                 }
7192                                         }
7193
7194                                         GroupProperty groupProperty = new GroupProperty();
7195                                         groupProperty.setValue(convertedValue);
7196                                         groupProperty.setName(propName);
7197
7198                                         log.trace("After building group property {}", groupProperty);
7199
7200                                         result.add(groupProperty);
7201                                 }
7202
7203                         }
7204
7205                 }
7206
7207                 return Either.left(result);
7208         }
7209
7210         public Either<Resource, ResponseFormat> getLatestResourceFromCsarUuid(String csarUuid, User user) {
7211
7212                 // validate user
7213                 if (user != null) {
7214                         Either<User, ResponseFormat> userValidation = validateUserExists(user, "Get resource from csar UUID", false);
7215                         if (userValidation.isRight()) {
7216                                 return Either.right(userValidation.right().value());
7217                         }
7218                 }
7219
7220                 // get resource from csar uuid
7221                 Either<Resource, StorageOperationStatus> either = toscaOperationFacade.getLatestComponentByCsarOrName(ComponentTypeEnum.RESOURCE, csarUuid, "");
7222                 if (either.isRight()) {
7223                         ResponseFormat resp = componentsUtils.getResponseFormat(ActionStatus.RESOURCE_FROM_CSAR_NOT_FOUND, csarUuid);
7224                         return Either.right(resp);
7225                 }
7226
7227                 return Either.left(either.left().value());
7228         }
7229
7230         @Override
7231         public Either<List<ComponentInstance>, ResponseFormat> getComponentInstancesFilteredByPropertiesAndInputs(String componentId, ComponentTypeEnum componentTypeEnum, String userId, String searchText) {
7232                 return null;
7233         }
7234
7235         private Either<Map<String, List<CapabilityDefinition>>, ResponseFormat> getValidComponentInstanceCapabilities(String resourceId, Map<String, List<CapabilityDefinition>> defaultCapabilities, Map<String, List<UploadCapInfo>> uploadedCapabilities) {
7236                 ResponseFormat responseFormat;
7237                 Map<String, List<CapabilityDefinition>> validCapabilitiesMap = new HashMap<>();
7238
7239                 for (Entry<String, List<UploadCapInfo>> uploadedCapabilitiesEntry : uploadedCapabilities.entrySet()) {
7240                         String capabilityType = uploadedCapabilitiesEntry.getValue().get(0).getType();
7241                         if (!defaultCapabilities.containsKey(capabilityType)) {
7242                                 responseFormat = componentsUtils.getResponseFormat(ActionStatus.MISSING_CAPABILITY_TYPE, capabilityType);
7243                                 return Either.right(responseFormat);
7244                         } else {
7245                                 CapabilityDefinition defaultCapability;
7246                                 if(CollectionUtils.isNotEmpty(defaultCapabilities.get(capabilityType).get(0).getProperties())){
7247                                         defaultCapability = defaultCapabilities.get(capabilityType).get(0);
7248                                 } else {
7249                                         Either<Component, StorageOperationStatus> getFullComponentRes = toscaOperationFacade.getToscaFullElement(resourceId);
7250                                         if(getFullComponentRes.isRight()){
7251                                                 log.debug("Failed to get full component {}. Status is {}. ", resourceId, getFullComponentRes.right().value());
7252                                                 responseFormat = componentsUtils.getResponseFormat(ActionStatus.COMPONENT_NOT_FOUND, resourceId);
7253                                                 return Either.right(responseFormat);
7254                                         }
7255                                         defaultCapability = getFullComponentRes.left().value().getCapabilities().get(capabilityType).get(0);
7256                                 }
7257                                 if(CollectionUtils.isEmpty(defaultCapability.getProperties()) && CollectionUtils.isNotEmpty(uploadedCapabilitiesEntry.getValue().get(0).getProperties())){
7258                                         log.debug("Failed to validate capability {} of component {}. Property list is empty. ", defaultCapability.getName(), resourceId);
7259                                         log.debug("Failed to update capability property values. Property list of fetched capability {} is empty. ", defaultCapability.getName());
7260                                         responseFormat = componentsUtils.getResponseFormat(ActionStatus.PROPERTY_NOT_FOUND, resourceId);
7261                                         return Either.right(responseFormat);
7262                                 }
7263                                 if(CollectionUtils.isNotEmpty(defaultCapability.getProperties()) && CollectionUtils.isNotEmpty(uploadedCapabilitiesEntry.getValue().get(0).getProperties())){
7264                                         Either<Boolean, String> validationRes = validateUniquenessUpdateUploadedComponentInstanceCapability(defaultCapability, uploadedCapabilitiesEntry.getValue().get(0));
7265                                         if (validationRes.isRight()) {
7266                                                 responseFormat = componentsUtils.getResponseFormat(ActionStatus.PROPERTY_NAME_ALREADY_EXISTS, validationRes.right().value());
7267                                                 return Either.right(responseFormat);
7268                                         }
7269                                 }
7270                                 List<CapabilityDefinition> validCapabilityList = new ArrayList<>();
7271                                 validCapabilityList.add(defaultCapability);
7272                                 validCapabilitiesMap.put(uploadedCapabilitiesEntry.getKey(), validCapabilityList);
7273                         }
7274                 }
7275                 return Either.left(validCapabilitiesMap);
7276         }
7277
7278         private Either<Boolean, String> validateUniquenessUpdateUploadedComponentInstanceCapability(CapabilityDefinition defaultCapability, UploadCapInfo uploadedCapability) {
7279                 List<ComponentInstanceProperty> validProperties = new ArrayList<>();
7280                 Map<String, PropertyDefinition> defaultProperties = defaultCapability.getProperties().stream().collect(Collectors.toMap(PropertyDefinition::getName, Function.identity()));
7281                 List<UploadPropInfo> uploadedProperties = uploadedCapability.getProperties();
7282                 for (UploadPropInfo property : uploadedProperties) {
7283                         String propertyName = property.getName().toLowerCase();
7284                         String propertyType = property.getType();
7285                         ComponentInstanceProperty validProperty;
7286                         if (defaultProperties.containsKey(propertyName)) {
7287                                 if (propertyType != null && !defaultProperties.get(propertyName).getType().equals(propertyType)) {
7288                                         return Either.right(propertyName);
7289                                 }
7290                         }
7291                         validProperty = new ComponentInstanceProperty();
7292                         validProperty.setName(propertyName);
7293                         if (property.getValue() != null)
7294                                 validProperty.setValue(property.getValue().toString());
7295                         validProperty.setDescription(property.getDescription());
7296                         validProperty.setPassword(property.isPassword());
7297                         validProperties.add(validProperty);
7298                 }
7299                 defaultCapability.setProperties(validProperties);
7300                 return Either.left(true);
7301         }
7302
7303         private Either<EnumMap<ArtifactOperationEnum, List<NonMetaArtifactInfo>>, ResponseFormat> organizeVfCsarArtifactsByArtifactOperation(List<NonMetaArtifactInfo> artifactPathAndNameList, List<ArtifactDefinition> existingArtifactsToHandle,
7304                         Resource resource, User user) {
7305
7306                 EnumMap<ArtifactOperationEnum, List<NonMetaArtifactInfo>> nodeTypeArtifactsToHandle = new EnumMap<>(ArtifactOperationEnum.class);
7307                 Wrapper<ResponseFormat> responseWrapper = new Wrapper<>();
7308                 Either<EnumMap<ArtifactOperationEnum, List<NonMetaArtifactInfo>>, ResponseFormat> nodeTypeArtifactsToHandleRes = Either.left(nodeTypeArtifactsToHandle);
7309                 ;
7310                 try {
7311                         // add all found Csar artifacts to list to upload
7312                         List<NonMetaArtifactInfo> artifactsToUpload = new ArrayList<>(artifactPathAndNameList);
7313                         List<NonMetaArtifactInfo> artifactsToUpdate = new ArrayList<>();
7314                         List<NonMetaArtifactInfo> artifactsToDelete = new ArrayList<>();
7315                         for (NonMetaArtifactInfo currNewArtifact : artifactPathAndNameList) {
7316                                 ArtifactDefinition foundArtifact;
7317
7318                                 if (!existingArtifactsToHandle.isEmpty()) {
7319                                         foundArtifact = existingArtifactsToHandle.stream().filter(a -> a.getArtifactName().equals(currNewArtifact.getArtifactName())).findFirst().orElse(null);
7320                                         if (foundArtifact != null) {
7321                                                 if (ArtifactTypeEnum.findType(foundArtifact.getArtifactType()) == currNewArtifact.getArtifactType()) {
7322                                                         if (!foundArtifact.getArtifactChecksum().equals(currNewArtifact.getArtifactChecksum())) {
7323                                                                 currNewArtifact.setArtifactUniqueId(foundArtifact.getUniqueId());
7324                                                                 // if current artifact already exists, but has different content, add him to the list to update
7325                                                                 artifactsToUpdate.add(currNewArtifact);
7326                                                         }
7327                                                         // remove found artifact from the list of existing artifacts to handle, because it was already handled
7328                                                         existingArtifactsToHandle.remove(foundArtifact);
7329                                                         // and remove found artifact from the list to upload, because it should either be updated or be ignored
7330                                                         artifactsToUpload.remove(currNewArtifact);
7331                                                 } else {
7332                                                         log.debug("Can't upload two artifact with the same name {}.", currNewArtifact.getArtifactName());
7333                                                         ResponseFormat responseFormat = ResponseFormatManager.getInstance().getResponseFormat(ActionStatus.ARTIFACT_ALRADY_EXIST_IN_DIFFERENT_TYPE_IN_CSAR, currNewArtifact.getArtifactName(),
7334                                                                         currNewArtifact.getArtifactType().name(), foundArtifact.getArtifactType());
7335                                                         AuditingActionEnum auditingAction = artifactsBusinessLogic.detectAuditingType(artifactsBusinessLogic.new ArtifactOperationInfo(false, false, ArtifactOperationEnum.Create), foundArtifact.getArtifactChecksum());
7336                                                         artifactsBusinessLogic.handleAuditing(auditingAction, resource, resource.getUniqueId(), user, null, null, foundArtifact.getUniqueId(), responseFormat, resource.getComponentType(), null);
7337                                                         responseWrapper.setInnerElement(responseFormat);
7338                                                         break;
7339                                                 }
7340                                         }
7341                                 }
7342                         }
7343                         if (responseWrapper.isEmpty()) {
7344                                 existingArtifactsToHandle.stream()
7345                                                 // add all artifacts which was not detected as artifact to update or to ignore to the list to delete
7346                                                 .forEach(a -> artifactsToDelete.add(new NonMetaArtifactInfo(a.getArtifactName(), null, ArtifactTypeEnum.findType(a.getArtifactType()), a.getArtifactGroupType(), null, a.getUniqueId())));
7347                         }
7348                         if (responseWrapper.isEmpty()) {
7349                                 if (!artifactsToUpload.isEmpty())
7350                                         nodeTypeArtifactsToHandle.put(ArtifactOperationEnum.Create, artifactsToUpload);
7351                                 if (!artifactsToUpdate.isEmpty())
7352                                         nodeTypeArtifactsToHandle.put(ArtifactOperationEnum.Update, artifactsToUpdate);
7353                                 if (!artifactsToDelete.isEmpty())
7354                                         nodeTypeArtifactsToHandle.put(ArtifactOperationEnum.Delete, artifactsToDelete);
7355                         }
7356                         if (!responseWrapper.isEmpty()) {
7357                                 nodeTypeArtifactsToHandleRes = Either.right(responseWrapper.getInnerElement());
7358                         }
7359                 } catch (Exception e) {
7360                         ResponseFormat responseFormat = componentsUtils.getResponseFormat(ActionStatus.GENERAL_ERROR);
7361                         responseWrapper.setInnerElement(responseFormat);
7362                         log.debug("Exception occured when findNodeTypeArtifactsToHandle, error is:{}", e.getMessage(), e);
7363                 }
7364                 return nodeTypeArtifactsToHandleRes;
7365         }
7366
7367
7368         private ImmutablePair<String, String> buildNestedToscaResourceName(String nodeResourceType, String vfResourceName, String nodeTypeFullName) {
7369                 String actualType;
7370                 String actualVfName;
7371                 String actualPreviousVfName;
7372                 if(ResourceTypeEnum.CVFC.name().equals(nodeResourceType)){
7373                         actualVfName = vfResourceName + ResourceTypeEnum.CVFC.name();
7374                         actualType = ResourceTypeEnum.VFC.name();
7375                 } else {
7376                         actualVfName = vfResourceName;
7377                         actualType = nodeResourceType;
7378                 }
7379                 
7380                 StringBuilder toscaResourceName = new StringBuilder(Constants.USER_DEFINED_RESOURCE_NAMESPACE_PREFIX);
7381                 String nameWithouNamespacePrefix = nodeTypeFullName.substring(Constants.USER_DEFINED_RESOURCE_NAMESPACE_PREFIX.length());
7382                 String[] findTypes = nameWithouNamespacePrefix.split("\\.");
7383                 String resourceType = findTypes[0];
7384                 String actualName =  nameWithouNamespacePrefix.substring(resourceType.length());        
7385                 
7386                 if (actualName.startsWith(Constants.ABSTRACT)) {
7387                         toscaResourceName.append(resourceType.toLowerCase()).append('.').append(ValidationUtils.convertToSystemName(actualVfName));
7388                 } else {
7389                         toscaResourceName.append(actualType.toLowerCase()).append('.').append(ValidationUtils.convertToSystemName(actualVfName)).append('.').append(Constants.ABSTRACT);
7390                 }
7391                 StringBuilder previousToscaResourceName = new StringBuilder(toscaResourceName);
7392                 return new ImmutablePair<>(toscaResourceName.append(actualName.toLowerCase()).toString(), previousToscaResourceName.append(actualName.substring(actualName.split("\\.")[1].length() + 1).toLowerCase()).toString());
7393         }
7394
7395         public ICacheMangerOperation getCacheManagerOperation() {
7396                 return cacheManagerOperation;
7397         }
7398
7399         public void setCacheManagerOperation(ICacheMangerOperation cacheManagerOperation) {
7400                 this.cacheManagerOperation = cacheManagerOperation;
7401         }
7402
7403         ///////////////////////////////////////// DataModel refactoring/////////////////////////////////////////////
7404         @Override
7405         public Either<UiComponentDataTransfer, ResponseFormat> getUiComponentDataTransferByComponentId(String resourceId, List<String> dataParamsToReturn) {
7406
7407                 ComponentParametersView paramsToRetuen = new ComponentParametersView(dataParamsToReturn);
7408                 Either<Resource, StorageOperationStatus> resourceResultEither = toscaOperationFacade.getToscaElement(resourceId, paramsToRetuen);
7409
7410                 if (resourceResultEither.isRight()) {
7411                         if (resourceResultEither.right().value().equals(StorageOperationStatus.NOT_FOUND)) {
7412                                 log.debug("Failed to found resource with id {} ", resourceId);
7413                                 Either.right(componentsUtils.getResponseFormat(ActionStatus.RESOURCE_NOT_FOUND, resourceId));
7414                         }
7415
7416                         log.debug("failed to get resource by id {} with filters {}", resourceId, dataParamsToReturn.toString());
7417                         return Either.right(componentsUtils.getResponseFormatByResource(componentsUtils.convertFromStorageResponse(resourceResultEither.right().value()), ""));
7418                 }
7419
7420                 Resource resource = resourceResultEither.left().value();
7421                 UiComponentDataTransfer dataTransfer = UiComponentDataConverter.getUiDataTransferFromResourceByParams(resource, dataParamsToReturn);
7422                 return Either.left(dataTransfer);
7423         }
7424         @Override
7425         public Either<Component, ActionStatus> shouldUpgradeToLatestDerived(Component clonedComponent) {
7426                 Resource resource = (Resource) clonedComponent;
7427                 if (ModelConverter.isAtomicComponent(resource.getResourceType())) {
7428                         Either<Component, StorageOperationStatus> shouldUpgradeToLatestDerived = toscaOperationFacade.shouldUpgradeToLatestDerived(resource);
7429                         if (shouldUpgradeToLatestDerived.isRight()) {
7430                                 return Either.right(componentsUtils.convertFromStorageResponse(shouldUpgradeToLatestDerived.right().value()));
7431                         }
7432                         return Either.left(shouldUpgradeToLatestDerived.left().value());
7433                 } else {
7434                         return super.shouldUpgradeToLatestDerived(clonedComponent);
7435                 }
7436         }
7437
7438
7439
7440 }