/**
* BladeX Commercial License Agreement
* Copyright (c) 2018-2099, https://bladex.cn. All rights reserved.
*
* Use of this software is governed by the Commercial License Agreement
* obtained after purchasing a license from BladeX.
*
* 1. This software is for development use only under a valid license
* from BladeX.
*
* 2. Redistribution of this software's source code to any third party
* without a commercial license is strictly prohibited.
*
* 3. Licensees may copyright their own code but cannot use segments
* from this software for such purposes. Copyright of this software
* remains with BladeX.
*
* Using this software signifies agreement to this License, and the software
* must not be used for illegal purposes.
*
* THIS SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY. The author is
* not liable for any claims arising from secondary or illegal development.
*
* Author: Chill Zhuang (bladejava@qq.com)
*/
package org.springblade.flow.engine.service;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.service.IService;
import jakarta.servlet.http.HttpServletResponse;
import org.springblade.flow.core.pojo.entity.BladeFlow;
import org.springblade.flow.engine.entity.FlowExecution;
import org.springblade.flow.engine.entity.FlowModel;
import org.springblade.flow.engine.entity.FlowProcess;
import org.springframework.web.multipart.MultipartFile;
import java.util.List;
import java.util.Map;
/**
* FlowEngineService
*
* @author Chill
*/
public interface FlowEngineService extends IService {
/**
* 自定义分页
*
* @param page 分页工具
* @param flowModel 流程模型
* @return
*/
IPage selectFlowPage(IPage page, FlowModel flowModel);
/**
* 流程管理列表
*
* @param page 分页工具
* @param category 分类
* @param mode 形态
* @return
*/
IPage selectProcessPage(IPage page, String category, Integer mode);
/**
* 流程管理列表
*
* @param page 分页工具
* @param processInstanceId 流程实例id
* @param processDefinitionKey 流程key
* @return
*/
IPage selectFollowPage(IPage page, String processInstanceId, String processDefinitionKey);
/**
* 获取流转历史列表
*
* @param processInstanceId 流程实例id
* @param startActivityId 开始节点id
* @param endActivityId 结束节点id
* @return
*/
List historyFlowList(String processInstanceId, String startActivityId, String endActivityId);
/**
* 变更流程状态
*
* @param state 状态
* @param processId 流程ID
* @return
*/
String changeState(String state, String processId);
/**
* 删除部署流程
*
* @param deploymentIds 部署流程id集合
* @return
*/
boolean deleteDeployment(String deploymentIds);
/**
* 上传部署流程
*
* @param files 流程配置文件
* @param category 流程分类
* @param tenantIdList 租户id集合
* @return
*/
boolean deployUpload(List files, String category, List tenantIdList);
/**
* 部署流程
*
* @param modelId 模型id
* @param category 分类
* @param tenantIdList 租户id集合
* @return
*/
boolean deployModel(String modelId, String category, List tenantIdList);
/**
* 删除流程实例
*
* @param processInstanceId 流程实例id
* @param deleteReason 删除原因
* @return
*/
boolean deleteProcessInstance(String processInstanceId, String deleteReason);
/**
* 保存/更新模型
*
* @param model 模型
* @return 模型
*/
FlowModel submitModel(FlowModel model);
/**
* 流程节点进程图
*
* @param processDefinitionId
* @param processInstanceId
* @return
*/
Map modelView(String processDefinitionId, String processInstanceId);
/**
* 流程节点进程图
*
* @param processInstanceId
* @param httpServletResponse
*/
void diagramView(String processInstanceId, HttpServletResponse httpServletResponse);
/**
* 流程图展示
*
* @param processDefinitionId
* @param processInstanceId
* @param resourceType
* @param response
*/
void resourceView(String processDefinitionId, String processInstanceId, String resourceType, HttpServletResponse response);
/**
* 获取XML
*
* @param model
* @return
*/
byte[] getModelEditorXML(FlowModel model);
}