aboutsummaryrefslogtreecommitdiffstats
path: root/bpmn/MSOInfrastructureBPMN/src/main/groovy/org/openecomp/mso/bpmn/infrastructure/scripts/DoCreateVFCNetworkServiceInstance.groovy
blob: 2029d15d5c243ffdc77857381fe2eef28d39ead3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
/*-
 * ============LICENSE_START=======================================================
 * OPENECOMP - SO
 * ================================================================================
 * Copyright (C) 2017 Huawei Technologies Co., Ltd. All rights reserved.
 * ================================================================================
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ============LICENSE_END=========================================================
 */

package org.openecomp.mso.bpmn.infrastructure.scripts;

import static org.apache.commons.lang3.StringUtils.*;
import groovy.xml.XmlUtil
import groovy.json.*
import org.openecomp.mso.bpmn.common.scripts.AbstractServiceTaskProcessor 
import org.openecomp.mso.bpmn.common.scripts.ExceptionUtil 
import org.openecomp.mso.bpmn.common.scripts.VidUtils 
import org.openecomp.mso.bpmn.core.WorkflowException 
import org.openecomp.mso.bpmn.core.json.JsonUtils 
import org.openecomp.mso.rest.APIResponse

import java.util.UUID;

import org.camunda.bpm.engine.delegate.BpmnError 
import org.camunda.bpm.engine.runtime.Execution
import org.apache.commons.lang3.*
import org.apache.commons.codec.binary.Base64;
import org.springframework.web.util.UriUtils

/**
 * This groovy class supports the <class>CreateGenericE2EServiceInstance.bpmn</class> process.
 * flow for E2E ServiceInstance Create
 */
public class CreateGenericE2EServiceInstance extends AbstractServiceTaskProcessor {

    ExceptionUtil exceptionUtil = new ExceptionUtil()

    JsonUtils jsonUtil = new JsonUtils()

    VidUtils vidUtils = new VidUtils()

    /**
     * Pre Process the BPMN Flow Request
     * Inclouds:
     * Deal with the parameters
     * generate the service instance id
     * generate the operation id
     */
    public void preProcessRequest (Execution execution) {
	  /* def isDebugEnabled=execution.getVariable("isDebugLogEnabled")
       String msg = ""
       utils.log("DEBUG", " *** preProcessRequest() *** ", isDebugEnabled)
       try {

           String siRequest = execution.getVariable("bpmnRequest")
           utils.logAudit(siRequest)

           String requestId = execution.getVariable("mso-request-id")
           execution.setVariable("msoRequestId", requestId)
           utils.log("DEBUG", "Input Request:" + siRequest + " reqId:" + requestId, isDebugEnabled)

           String serviceInstanceId = execution.getVariable("serviceInstanceId")
           if (isBlank(serviceInstanceId)) {
               serviceInstanceId = UUID.randomUUID().toString()
           }
           utils.log("DEBUG", "Generated new Service Instance:" + serviceInstanceId, isDebugEnabled)
           serviceInstanceId = UriUtils.encode(serviceInstanceId,"UTF-8")
           execution.setVariable("serviceInstanceId", serviceInstanceId)
           
           String operationId = execution.getVariable("operationId")
           if (isBlank(operationId)) {
               operationId = UUID.randomUUID().toString()
           }
           utils.log("DEBUG", "Generated new Service Instance Operation:" + operationId, isDebugEnabled)
           serviceInstanceId = UriUtils.encode(operationId,"UTF-8")
           execution.setVariable("operationId", operationId)
           //subscriberInfo, TBD , there is no globalSubscriberId in R1 for E2E Service.
           //requestInfo TBD , there is no requestDetails for R1 E2E service

           //TBD need to insert operationInfo to RequestDb
           
           //set service Instance Name
           execution.setVariable("serviceInstanceName", jsonUtil.getJsonValue(siRequest, "service.name"))
           execution.setVariable("serviceDescription", jsonUtil.getJsonValue(siRequest, "service.description"))
           execution.setVariable("templateId", jsonUtil.getJsonValue(siRequest, "service.templateId"))
     
           //serviceParamters
           String serviceParamters = jsonUtil.getJsonValue(siRequest, "service.parameters")
           if (isBlank(serviceParamters)) {
               msg = "Input service paramters is null"
               utils.log("DEBUG", msg, isDebugEnabled)
               exceptionUtil.buildAndThrowWorkflowException(execution, 500, msg)
           } else
           {
               execution.setVariable("serviceParamters", serviceParamters)
           }

           utils.log("DEBUG", "service parameters:" + serviceParamters,  isDebugEnabled)
       } catch (BpmnError e) {
           throw e;
       } catch (Exception ex){
           msg = "Exception in preProcessRequest " + ex.getMessage()
           utils.log("DEBUG", msg, isDebugEnabled)
           exceptionUtil.buildAndThrowWorkflowException(execution, 7000, msg)
       }
       utils.log("DEBUG"," ***** Exit preProcessRequest *****",  isDebugEnabled)*/
	}


    public void createNetworkService(Execution execution) {
    }

    public void instantiateNetworkService(Execution execution) {
    }

    public void queryNSProgress(Execution execution) {
    }

    public void timeDelay(Execution execution) {
    }

    public void finishNSCreate(Execution execution) {
    }
}