2  * ============LICENSE_START=======================================================
 
   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
 
  12  *      http://www.apache.org/licenses/LICENSE-2.0
 
  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.
 
  23 package org.openecomp.appc.workflow;
 
  25 import org.openecomp.appc.workflow.objects.WorkflowExistsOutput;
 
  26 import org.openecomp.appc.workflow.objects.WorkflowRequest;
 
  27 import org.openecomp.appc.workflow.objects.WorkflowResponse;
 
  29 public interface WorkFlowManager {
 
  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
 
  39         WorkflowResponse  executeWorkflow(WorkflowRequest workflowRequest);
 
  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.
 
  46         WorkflowExistsOutput workflowExists(WorkflowRequest workflowQueryParams);