流程定义和部署管理——流程定义列表

来源:互联网 发布:java常用集合类详解 编辑:程序博客网 时间:2024/04/30 15:09

流程定义列表

spring mvc的请求相对路径为:workflow/process-list

注入RepositoryService,它管理发布资源的所有方法:

protected RepositoryService repositoryService;

    /**     * 流程定义列表     *     * @return     */    @RequestMapping(value = "/process-list")    public ModelAndView processList(HttpServletRequest request) {        ModelAndView mav = new ModelAndView("workflow/process-list");    /*     * 保存两个对象,一个是ProcessDefinition(流程定义),一个是Deployment(流程部署)     */        List<Object[]> objects = new ArrayList<Object[]>();        Page<Object[]> page = new Page<Object[]>(PageUtil.PAGE_SIZE);        int[] pageParams = PageUtil.init(page, request);        ProcessDefinitionQuery processDefinitionQuery = repositoryService.createProcessDefinitionQuery().orderByDeploymentId().desc();        List<ProcessDefinition> processDefinitionList = processDefinitionQuery.listPage(pageParams[0], pageParams[1]);        for (ProcessDefinition processDefinition : processDefinitionList) {            String deploymentId = processDefinition.getDeploymentId();            Deployment deployment = repositoryService.createDeploymentQuery().deploymentId(deploymentId).singleResult();            objects.add(new Object[]{processDefinition, deployment});        }        page.setTotalCount(processDefinitionQuery.count());        page.setResult(objects);        mav.addObject("page", page);        return mav;    }

要点:

1、查询流程定义

ProcessDefinitionQuery processDefinitionQuery = repositoryService.createProcessDefinitionQuery().orderByDeploymentId().desc();List<ProcessDefinition> processDefinitionList = processDefinitionQuery.listPage(pageParams[0], pageParams[1]);for (ProcessDefinition processDefinition : processDefinitionList) {}

其中listPage方法后才真正执行数据库查询,在mysql中如下sql:

SELECT DISTINCT RES.* FROM ACT_RE_PROCDEF RES ORDER BY RES.DEPLOYMENT_ID_ DESC LIMIT 15 OFFSET 0
结果:



关于流程部署,这个地方有几个比较重要的概念:

bpmn里有<process id="leave" name="请假流程">

KEY_对应的是bpmn里process id;(经常作为查询条件使用,不要和ID_混淆)

NAME_对应的是bpmn里process name;

VERSION_对应的是部署的版本号,因为这里spring自动部署了两次,所以同一个流程定义,版本号有1和2,以后默认会读版本号大的;

ID_是一个组合,NAME_ + VERSION_ + DEPLOYMENT_ID_;


2、关联查询流程部署

String deploymentId = processDefinition.getDeploymentId();Deployment deployment = repositoryService.createDeploymentQuery().deploymentId(deploymentId).singleResult();

在mysql中执行如下sql:

SELECT DISTINCT RES.* FROM ACT_RE_DEPLOYMENT RES WHERE RES.ID_ = 1 ORDER BY RES.ID_ ASC LIMIT 2147483647 OFFSET 0
结果:


3、返回给页面的是

List<Object[]> objects = new ArrayList<Object[]>();objects.add(new Object[]{processDefinition, deployment});page.setResult(objects);mav.addObject("page", page);

4、页面代码

<table width="100%" class="need-border"><thead><tr><th>ProcessDefinitionId</th><th>DeploymentId</th><th>名称</th><th>KEY</th><th>版本号</th><th>XML</th><th>图片</th><th>部署时间</th><th>是否挂起</th><th>操作</th></tr></thead><tbody><c:forEach items="${page.result }" var="object"><c:set var="process" value="${object[0] }" /><c:set var="deployment" value="${object[1] }" /><tr><td>${process.id }</td><td>${process.deploymentId }</td><td>${process.name }</td><td>${process.key }</td><td>${process.version }</td><td><a target="_blank" href='${ctx }/workflow/resource/read?processDefinitionId=${process.id}&resourceType=xml'>${process.resourceName }</a></td><td><a target="_blank" href='${ctx }/workflow/resource/read?processDefinitionId=${process.id}&resourceType=image'>${process.diagramResourceName }</a></td><td>${deployment.deploymentTime }</td><td>${process.suspended} |<c:if test="${process.suspended }"><a href="processdefinition/update/active/${process.id}">激活</a></c:if><c:if test="${!process.suspended }"><a href="processdefinition/update/suspend/${process.id}">挂起</a></c:if></td><td>                        <a href='${ctx }/workflow/process/delete?deploymentId=${process.deploymentId}'>删除</a>                        <a href='${ctx }/workflow/process/convert-to-model/${process.id}'>转换为Model</a>                    </td></tr></c:forEach></tbody></table>

从ProcessDefinition类的对象中得到流程定义的id、deploymentId、name、key、version、suspended;

从Deployment类的对象中得到流程部署的deploymentTime;


后续我们再介绍基于这个列表的一些操作,包括:查看流程的xml,图片,以及部署流程的激活、挂起、删除等操作。。。



2 0
原创粉丝点击