Sync Integ to Master
[sdc.git] / catalog-be / src / main / java / org / openecomp / sdc / be / components / lifecycle / CheckinTransition.java
index bfe51de..0d9631e 100644 (file)
@@ -20,8 +20,7 @@
 
 package org.openecomp.sdc.be.components.lifecycle;
 
-import java.util.Arrays;
-
+import fj.data.Either;
 import org.openecomp.sdc.be.components.impl.ComponentBusinessLogic;
 import org.openecomp.sdc.be.config.BeEcompErrorManager;
 import org.openecomp.sdc.be.dao.api.ActionStatus;
@@ -43,106 +42,106 @@ import org.openecomp.sdc.exception.ResponseFormat;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 
-import fj.data.Either;
+import java.util.Arrays;
 
 public class CheckinTransition extends LifeCycleTransition {
 
-       private static Logger log = LoggerFactory.getLogger(CheckinTransition.class.getName());
-
-       public CheckinTransition(ComponentsUtils componentUtils, ToscaElementLifecycleOperation lifecycleOperation, ToscaOperationFacade toscaOperationFacade, TitanDao titanDao) {
-               super(componentUtils, lifecycleOperation, toscaOperationFacade, titanDao);
-
-               // authorized roles
-               Role[] resourceServiceCheckoutRoles = { Role.ADMIN, Role.DESIGNER };
-               Role[] productCheckoutRoles = { Role.ADMIN, Role.PRODUCT_MANAGER };
-               addAuthorizedRoles(ComponentTypeEnum.RESOURCE, Arrays.asList(resourceServiceCheckoutRoles));
-               addAuthorizedRoles(ComponentTypeEnum.SERVICE, Arrays.asList(resourceServiceCheckoutRoles));
-               addAuthorizedRoles(ComponentTypeEnum.PRODUCT, Arrays.asList(productCheckoutRoles));
-
-       }
-
-       @Override
-       public LifeCycleTransitionEnum getName() {
-               return LifeCycleTransitionEnum.CHECKIN;
-       }
-
-       @Override
-       public AuditingActionEnum getAuditingAction() {
-               return AuditingActionEnum.CHECKIN_RESOURCE;
-       }
-
-       @Override
-       public Either<? extends Component, ResponseFormat> changeState(ComponentTypeEnum componentType, Component component, ComponentBusinessLogic componentBl, User modifier, User owner, boolean shouldLock, boolean inTransaction) {
-               log.debug("start performing checkin for {} {}", componentType.name(), component.getUniqueId());
-
-               Either<? extends Component, ResponseFormat> result = null;
-               try{
-                       Either<ToscaElement, StorageOperationStatus> checkinResourceResult = lifeCycleOperation.
-                                       checkinToscaELement(component.getLifecycleState(), component.getUniqueId(), modifier.getUserId(), owner.getUserId());
-                       
-                       if (checkinResourceResult.isRight()) {
-                               log.debug("checkout failed on graph");
-                               StorageOperationStatus response = checkinResourceResult.right().value();
-                               ActionStatus actionStatus = componentUtils.convertFromStorageResponse(response);
-       
-                               if (response.equals(StorageOperationStatus.ENTITY_ALREADY_EXISTS)) {
-                                       actionStatus = ActionStatus.COMPONENT_VERSION_ALREADY_EXIST;
-                               }
-                               ResponseFormat responseFormat = componentUtils.getResponseFormatByComponent(actionStatus, component, componentType);
-                               result =  Either.right(responseFormat);
-                       }
-                       else {
-                               result =  Either.left(ModelConverter.convertFromToscaElement(checkinResourceResult.left().value()));
-                       }
-               } finally {
-                       if (result == null || result.isRight()) {
-                               BeEcompErrorManager.getInstance().logBeDaoSystemError("Change LifecycleState");
-                               if (inTransaction == false) {
-                                       log.debug("operation failed. do rollback");
-                                       titanDao.rollback();
-                               }
-                       } else {
-                               if (inTransaction == false) {
-                                       log.debug("operation success. do commit");
-                                       titanDao.commit();
-                               }
-                       }
-               }
-               return result;
-       }
-
-       @Override
-       public Either<Boolean, ResponseFormat> validateBeforeTransition(Component component, ComponentTypeEnum componentType, User modifier, User owner, LifecycleStateEnum oldState, LifecycleChangeInfoWithAction lifecycleChangeInfo) {
-               String componentName = component.getComponentMetadataDefinition().getMetadataDataDefinition().getName();
-               log.debug("validate before checkin. component name={}, oldState={}, owner userId={}", componentName, oldState, owner.getUserId());
-
-               // validate user
-               Either<Boolean, ResponseFormat> userValidationResponse = userRoleValidation(modifier,component, componentType, lifecycleChangeInfo);
-               if (userValidationResponse.isRight()) {
-                       return userValidationResponse;
-               }
-
-               if (!oldState.equals(LifecycleStateEnum.READY_FOR_CERTIFICATION) && !oldState.equals(LifecycleStateEnum.NOT_CERTIFIED_CHECKOUT)) {
-                       ActionStatus action = ActionStatus.COMPONENT_ALREADY_CHECKED_IN;
-                       if (oldState.equals(LifecycleStateEnum.CERTIFICATION_IN_PROGRESS)){
-                               action = ActionStatus.COMPONENT_SENT_FOR_CERTIFICATION;
-                       } else if (oldState.equals(LifecycleStateEnum.CERTIFIED)){
-                               action = ActionStatus.COMPONENT_ALREADY_CERTIFIED;
-                       }
-                       ResponseFormat error = componentUtils.getResponseFormat(action, componentName, componentType.name().toLowerCase(), owner.getFirstName(), owner.getLastName(), owner.getUserId());
-                       return Either.right(error);
-               }
-
-               if (oldState.equals(LifecycleStateEnum.NOT_CERTIFIED_CHECKOUT) && !modifier.equals(owner) && !modifier.getRole().equals(Role.ADMIN.name())) {
-                       ResponseFormat error = componentUtils.getResponseFormat(ActionStatus.COMPONENT_CHECKOUT_BY_ANOTHER_USER, componentName, componentType.name().toLowerCase(), owner.getFirstName(), owner.getLastName(), owner.getUserId());
-                       return Either.right(error);
-               }
-
-               if (oldState.equals(LifecycleStateEnum.READY_FOR_CERTIFICATION) && !modifier.equals(owner) && !modifier.getRole().equals(Role.ADMIN.name())) {
-                       ResponseFormat error = componentUtils.getResponseFormat(ActionStatus.COMPONENT_SENT_FOR_CERTIFICATION, componentName, componentType.name().toLowerCase(), owner.getFirstName(), owner.getLastName(), owner.getUserId());
-                       return Either.right(error);
-               }
-
-               return Either.left(true);
-       }
+    private static final Logger log = LoggerFactory.getLogger(CheckinTransition.class);
+
+    public CheckinTransition(ComponentsUtils componentUtils, ToscaElementLifecycleOperation lifecycleOperation, ToscaOperationFacade toscaOperationFacade, TitanDao titanDao) {
+        super(componentUtils, lifecycleOperation, toscaOperationFacade, titanDao);
+
+        // authorized roles
+        Role[] resourceServiceCheckoutRoles = { Role.ADMIN, Role.DESIGNER };
+        Role[] productCheckoutRoles = { Role.ADMIN, Role.PRODUCT_MANAGER };
+        addAuthorizedRoles(ComponentTypeEnum.RESOURCE, Arrays.asList(resourceServiceCheckoutRoles));
+        addAuthorizedRoles(ComponentTypeEnum.SERVICE, Arrays.asList(resourceServiceCheckoutRoles));
+        addAuthorizedRoles(ComponentTypeEnum.PRODUCT, Arrays.asList(productCheckoutRoles));
+
+    }
+
+    @Override
+    public LifeCycleTransitionEnum getName() {
+        return LifeCycleTransitionEnum.CHECKIN;
+    }
+
+    @Override
+    public AuditingActionEnum getAuditingAction() {
+        return AuditingActionEnum.CHECKIN_RESOURCE;
+    }
+
+    @Override
+    public Either<? extends Component, ResponseFormat> changeState(ComponentTypeEnum componentType, Component component, ComponentBusinessLogic componentBl, User modifier, User owner, boolean shouldLock, boolean inTransaction) {
+        log.debug("start performing checkin for {} {}", componentType, component.getUniqueId());
+
+        Either<? extends Component, ResponseFormat> result = null;
+        try{
+            Either<ToscaElement, StorageOperationStatus> checkinResourceResult = lifeCycleOperation.
+                    checkinToscaELement(component.getLifecycleState(), component.getUniqueId(), modifier.getUserId(), owner.getUserId());
+
+            if (checkinResourceResult.isRight()) {
+                log.debug("checkout failed on graph");
+                StorageOperationStatus response = checkinResourceResult.right().value();
+                ActionStatus actionStatus = componentUtils.convertFromStorageResponse(response);
+
+                if (response.equals(StorageOperationStatus.ENTITY_ALREADY_EXISTS)) {
+                    actionStatus = ActionStatus.COMPONENT_VERSION_ALREADY_EXIST;
+                }
+                ResponseFormat responseFormat = componentUtils.getResponseFormatByComponent(actionStatus, component, componentType);
+                result =  Either.right(responseFormat);
+            }
+            else {
+                result =  Either.left(ModelConverter.convertFromToscaElement(checkinResourceResult.left().value()));
+            }
+        } finally {
+            if (result == null || result.isRight()) {
+                BeEcompErrorManager.getInstance().logBeDaoSystemError("Change LifecycleState");
+                if (inTransaction == false) {
+                    log.debug("operation failed. do rollback");
+                    titanDao.rollback();
+                }
+            } else {
+                if (inTransaction == false) {
+                    log.debug("operation success. do commit");
+                    titanDao.commit();
+                }
+            }
+        }
+        return result;
+    }
+
+    @Override
+    public Either<Boolean, ResponseFormat> validateBeforeTransition(Component component, ComponentTypeEnum componentType, User modifier, User owner, LifecycleStateEnum oldState, LifecycleChangeInfoWithAction lifecycleChangeInfo) {
+        String componentName = component.getComponentMetadataDefinition().getMetadataDataDefinition().getName();
+        log.debug("validate before checkin. component name={}, oldState={}, owner userId={}", componentName, oldState, owner.getUserId());
+
+        // validate user
+        Either<Boolean, ResponseFormat> userValidationResponse = userRoleValidation(modifier,component, componentType, lifecycleChangeInfo);
+        if (userValidationResponse.isRight()) {
+            return userValidationResponse;
+        }
+
+        if (!oldState.equals(LifecycleStateEnum.READY_FOR_CERTIFICATION) && !oldState.equals(LifecycleStateEnum.NOT_CERTIFIED_CHECKOUT)) {
+            ActionStatus action = ActionStatus.COMPONENT_ALREADY_CHECKED_IN;
+            if (oldState.equals(LifecycleStateEnum.CERTIFICATION_IN_PROGRESS)){
+                action = ActionStatus.COMPONENT_SENT_FOR_CERTIFICATION;
+            } else if (oldState.equals(LifecycleStateEnum.CERTIFIED)){
+                action = ActionStatus.COMPONENT_ALREADY_CERTIFIED;
+            }
+            ResponseFormat error = componentUtils.getResponseFormat(action, componentName, componentType.name().toLowerCase(), owner.getFirstName(), owner.getLastName(), owner.getUserId());
+            return Either.right(error);
+        }
+
+        if (oldState.equals(LifecycleStateEnum.NOT_CERTIFIED_CHECKOUT) && !modifier.equals(owner) && !modifier.getRole().equals(Role.ADMIN.name())) {
+            ResponseFormat error = componentUtils.getResponseFormat(ActionStatus.COMPONENT_CHECKOUT_BY_ANOTHER_USER, componentName, componentType.name().toLowerCase(), owner.getFirstName(), owner.getLastName(), owner.getUserId());
+            return Either.right(error);
+        }
+
+        if (oldState.equals(LifecycleStateEnum.READY_FOR_CERTIFICATION) && !modifier.equals(owner) && !modifier.getRole().equals(Role.ADMIN.name())) {
+            ResponseFormat error = componentUtils.getResponseFormat(ActionStatus.COMPONENT_SENT_FOR_CERTIFICATION, componentName, componentType.name().toLowerCase(), owner.getFirstName(), owner.getLastName(), owner.getUserId());
+            return Either.right(error);
+        }
+
+        return Either.left(true);
+    }
 }