Merge "Reorder modifiers"
[so.git] / bpmn / MSOInfrastructureBPMN / src / main / java / org / openecomp / mso / bpmn / infrastructure / DoCreateServiceInstance / RollbackAAIServiceInstance.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP - SO
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.mso.bpmn.infrastructure.DoCreateServiceInstance;\r
22 \r
23 import java.util.logging.Logger;\r
24 \r
25 import org.camunda.bpm.engine.delegate.BpmnError;\r
26 import org.camunda.bpm.engine.delegate.DelegateExecution;\r
27 import org.camunda.bpm.engine.delegate.JavaDelegate;\r
28 import org.openecomp.mso.bpmn.common.scripts.ExceptionUtil;\r
29 import org.openecomp.mso.bpmn.core.domain.ServiceDecomposition;\r
30 import org.openecomp.mso.client.orchestration.AAIOrchestrator;\r
31 \r
32 public class RollbackAAIServiceInstance implements JavaDelegate {\r
33         private static Logger LOGGER = Logger.getLogger("RollbackAAIServiceInstance");\r
34         ExceptionUtil exceptionUtil = new ExceptionUtil();\r
35         \r
36         public void execute(DelegateExecution execution) throws Exception {\r
37                 boolean aaiServiceInstanceRollback = (boolean) execution.getVariable("aaiServiceInstanceRollback");\r
38                 if (aaiServiceInstanceRollback) {\r
39                         LOGGER.info("**** Starting RollbackAAIServiceInstance ****");\r
40                         try {\r
41                                 ServiceDecomposition serviceDecomp = (ServiceDecomposition) execution.getVariable("ServiceDecomposition");\r
42                                 AAIOrchestrator aaiO = new AAIOrchestrator();\r
43                                 aaiO.deleteServiceInstance(serviceDecomp);\r
44                         } catch (Exception ex) {\r
45                                 String msg = "Error Response from AAI for aaiServiceInstanceRollback";\r
46                                 execution.setVariable("rollbackError", msg);\r
47                                 LOGGER.info(msg);\r
48                                 exceptionUtil.buildAndThrowWorkflowException(execution, 7000, msg);\r
49                         }\r
50                         LOGGER.info("**** Finished RollbackAAIServiceInstance ****");\r
51                 } else {\r
52                         LOGGER.info("**** Skipping RollbackAAIServiceInstance ****");\r
53                 }\r
54         }\r
55 \r
56 }\r