activiti笔记

activiti笔记,第1张

当前版本为activiti6.0,与之前版本区别

assignee:任务执行人,设置系统中的“登录名”(loginName)。

candidateUsers:任务执行人,可以填写多个。

candidateGroups:任务执行组,可以填写多个,设置系统中的“角色英文名(enname)”。

assignee和candidateUsers的区别是:assignee不需要签收任务,直接可执行任务;candidateUsers为竞争方式分配任务,被指定人待办中都有一条任务,谁先签收谁就获得任务的执行权。

taskService.setAssignee(String taskId, String userId)

taskService.claim(String taskId, String userId)

taskService.setOwner(String taskId, String userId)

关于上面三个方法的区别:

setAssignee和claim两个的区别是在认领任务时,claim会检查该任务是否已经被认领,如果被认领则会抛出ActivitiTaskAlreadyClaimedException 而setAssignee不会进行这样的检查。其他方面两个方法效果一致。

setOwner和setAssignee的区别在于

setOwner实在代理任务时使用,代表着任务的归属者,而这时,setAssignee代表的时代理办理者,

举个例子来说,公司总经理现在有个任务taskA,去核实一下本年度的财务报表,他现在又很忙没时间,于是将该任务委托给其助理进行办理,此时,就应该这么做:

taskService.setOwner(taskA.getId(), 总经理.getId())

taskService.setAssignee/claim(taskA.getId(), 助理.getId())

act_hi_taskinst表两个字段:

DELEGATION_和OWENER_

DELEGATION_值变化为PENDING,表示此任务为正在执行的委托任务;

DELEGATION_值变化为 RESOLVED,表示此任务为被解决的委托任务;

所以任务在被委托人执行时必须

taskService.resolveTask(task.getId(),taskVariables)//解决委托

taskService.complete(task.getId(), taskVariables)//完成任务

否则容易报错A delegated task cannot be completed, but should be resolved instead.

OWENR_字段设置用于查询委任人的委托任务

在执行taskService.addComment前,需要设置批注的所属人Authentication.setAuthenticatedUserId(userId)

流程启动实例之前,设置启动者identityService.setAuthenticatedUserId(userId)

然后流程设计模型可在流程开始节点设置变量,以供之后的环节使用

级联删除会把流程实例流程历史全部物理清空。

非级联删除,必须保证没有流程实例

二者虽然都能查询到任务实例。但是前者只能查询历史环节,就算act_hi_taskinst有数据未完成当前环节也不能查出

Snaker是一个基于Java的开源工作流引擎,适用于企业应用中常见的业务流程。本着轻量、简单、灵巧理念设计,定位于简单集成,多环境支持

轻量:核心代码行数大约7000行,强大的扩展性,支持Spring、Jfinal、Nutz平台级框架;支持Jdbc、SpringJdbc、Hibernate3or4、Mybatis等orm框架

简单:表设计简单,流程组件简单[start/end/task/custom/subprocess/decision/fork/join]

灵巧:暴露大量可扩展接口,支持流程设计器、流程引擎的组件模型自定义[节点自定义、属性自定义、表单自定义]

2.0.0版本改进包括:

1.snakerflow重新规划,将第三方扩展支持以独立子模块发布

2.支持自动初始化脚本,只需要用户创建一个数据源即可

3.支持Web自定义表单、eclipse插件自定义表单[未体现在snaker-web演示项目中]

4.流程web设计器增强,支持绑定自定义表单、支持选择参与者

5.流程状态图增强,支持单击活动节点显示处理人,抵达时间,并且可动态添加参与者

6.增加jfinal支持,事务可统一由jfinal控制

7.增加nutz支持,事务可统一由nutz控制

8.增强:

TaskService增加根据taskId获取TaskModel的api

Order实体的orderNo支持由map传递运行时数据(key:SnakerEngine.ID)

增加IReminder接口,用于超时提醒

望采纳!!!


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11407860.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-15
下一篇 2023-05-15

发表评论

登录后才能评论

评论列表(0条)

保存