5cc33ea80c0ef6166a9b636f897295b6125a1d89
[appc.git] /
1 /*-
2  * ============LICENSE_START=======================================================
3  * APPC
4  * ================================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6  * Copyright (C) 2017 Amdocs
7  * ================================================================================
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  * 
12  *      http://www.apache.org/licenses/LICENSE-2.0
13  * 
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  * ============LICENSE_END=========================================================
20  * ECOMP is a trademark and service mark of AT&T Intellectual Property.
21  */
22
23 package org.openecomp.appc.workflow;
24
25 import org.openecomp.appc.workflow.objects.WorkflowExistsOutput;
26 import org.openecomp.appc.workflow.objects.WorkflowRequest;
27 import org.openecomp.appc.workflow.objects.WorkflowResponse;
28
29 public interface WorkFlowManager {
30         /**
31          * Execute workflow and return response.
32          * This method execute workflow with following steps.
33          * Retrieve workflow(DG) details - module, version and mode  from database based on command and vnf Type from incoming request.
34          * Execute workflow (DG) using SVC Logic Service reference
35          * Return response of workflow (DG) to caller.
36          * @param workflowRequest workflow execution request which contains vnfType, command, requestId, targetId, payload and (optional) confID;
37          * @return Workflow Response which contains execution status and payload from DG if any
38          */
39         WorkflowResponse  executeWorkflow(WorkflowRequest workflowRequest);
40
41         /**
42          * Check if workflow (DG) exists in database
43          * @param workflowQueryParams workflow request with command and vnf Type
44          * @return WorkflowExistsOutput.mappingExist True if workflow mapping exists else False. WorkflowExistsOutput.dgExist True if DG workflow exists else False.
45      */
46         WorkflowExistsOutput workflowExists(WorkflowRequest workflowQueryParams);
47
48 }