`
zybing
  • 浏览: 446476 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

jBPM4.4:ForEach的使用--动态设置参与人数

阅读更多

流程确定的情况下,有时候完成一个步骤人数不确定,在任务发布的时候有领导确定参与完成的人员。

 

为了完成这样的情况,可以到了这一步,通过配置动态的生成一些subTask,通过subTask给每个人进行分派工作。

 

其实还可以通过jBPM4.4中的foreach的方式进行完成(注意:这个功能还在孵化器中)。

 

如:完成一个审核工作,有些工作需要2个人完成,有些工作需要3个人完成,在开启流程的时候,由生成流程的人员进行指定对应的工作人员。

 

拿jBPM4.4开发指南中的例子来解释:

<process name="ForEach" xmlns="http://jbpm.org/4.4/jpdl">

   <start g="28,61,48,48" name="start1">
      <transition to="foreach1"/>
   </start>

   <foreach var="department" in="#{departments}" g="111,60,48,48" name="foreach1">
      <transition to="Collect reports"/>
   </foreach>

   <task candidate-groups="#{department}" g="201,58,92,52" name="Collect reports">
      <transition to="join1"/>
   </task>

   <join g="343,59,48,48" multiplicity="#{quorum}" name="join1">
      <transition to="end1"/>
   </join>

   <end g="433,60,48,48" name="end1"/>

</process>

 

1. 启动流程后,到达foreach节点:

   <foreach var="department" in="#{departments}" g="111,60,48,48" name="foreach1">
      <transition to="Collect reports"/>
   </foreach>

 参数:

in:表示从外面传入的参数,foreach会读取这个参数,这个参数可以是string数组,也可以是通过逗号分隔的字符串

var:这个变量是foreach将in中的内容按照规则进行拆分,拆分的结果放在var定义的变量中,传递给下一步(每一步接收一个值)

 

进入到foreach,解析完这些参数,会根据join中的multiplicity参数的值,生成task(multiplicity定义为几,就生成几个Executiuon,几个task),这些Task的assignee都是空的

 

2. 进入到task

   <task candidate-groups="#{department}" g="201,58,92,52" name="Collect reports">
      <transition to="join1"/>
   </task>

进入到task,其实现在有多个task,是根据join中的multiplicity来确定的。

 

这些task任务安排的人员在candidate-groups(或者是candidate-users等)中定义。这个例子#{department},就是在foreach节点中,定义的var="department"中的变量名字;

 

这些任务不是直接分派到用户的,而是需要用户自己进行take的

(通过TaskService.createTaskQuery().candidate(userId).list 可以获得有哪些任务自己是候选者

   或者通过TaskService.findGroupTasks(userId)获取有哪些任务是自己加入的组需要完成的,

  或者在流程xml文件中,直接用assignee,分配给任务完成的人员

)。

 

3. foreach自动生成的这些Task都完成了,则流程进入到下一步;

   如果有部分人员完成,部分人员没有完成,还是可以查到foreach自动生成的所有Execution(通过processInstance.getExecutions()),不过根据任务完成的情况有不同的状态:

   如果任务已经完成,则在Task表中已经删除,得到的execution状态是:inactive-join

   没有完成的任务,在task中依旧存在,得到的execution状态是 active-concurrent

 

 

 

 

分享到:
评论
7 楼 tomcatmeng 2015-04-25  
请问候选用户是怎样task自己的任务,看网上说先根据任务id先把任务分给候选用户,但是taskid怎样获得的?processEngine.getTaskService().takeTask("任务id", "候选人");
6 楼 zybing 2012-07-12  
fatter 写道
yanghw6 写道
你好,请问一下,设置参与人员后启动,给相关人员发送任务,这时如果发现还有需要要新添加2个任务给其他的人,需要如何处理?

不知道动态去创建任务行不行?



动态任务指的是怎么样的动态任务?

在foreach中间增加动态任务,还是不使用foreach,完全就是自己创建的动态任务?

完全自己创建的动态任务,当然没问题,就是所有的流程都要自己控制, 稍显麻烦.

在foreach中间增加动态任务当然也是可以的,就是在收尾的地方,对于任务数量要控制一下, 修改一下multiplicity, 否则自己动态增加的任务不记录到系统控制的任务数量中去的
5 楼 fatter 2012-07-11  
yanghw6 写道
你好,请问一下,设置参与人员后启动,给相关人员发送任务,这时如果发现还有需要要新添加2个任务给其他的人,需要如何处理?

不知道动态去创建任务行不行?
4 楼 zybing 2011-08-27  
yanghw6 写道
你好,请问一下,设置参与人员后启动,给相关人员发送任务,这时如果发现还有需要要新添加2个任务给其他的人,需要如何处理?


可能有以下的方式:
1. 将这个任务回退,重新开始
   用这种方式,可能会造成有些人已经开始在做任务了,或者任务已经完成了;造成不必要的麻烦

2. 动态的增加任务:
   foreach是为每个要参与的人员分派一个任务,这样在执行过程中,如果要增加人员,则动态的增加任务,为要新参与该任务的人员动态添加此任务,同时修改multiplicity="#{quorum}" 的值


---------------------------------------------
以上方法只是通过概念提出的可能的方法,并未实践过。
3 楼 yanghw6 2011-08-26  
你好,请问一下,设置参与人员后启动,给相关人员发送任务,这时如果发现还有需要要新添加2个任务给其他的人,需要如何处理?
2 楼 zybing 2010-10-29  
回1楼:

我们来看上面实际的例子:
**************************
<foreach var="department" in="#{departments}" g="111,60,48,48" name="foreach1"> 
这句话的理解:
foreach中,产生一个变量department,这个变量带给后面的task;

departments:表示有多个组/部门:
department: 是departments中split出来的单个组/部门;


*****************************
再来看task:
<task candidate-groups="#{department}" g="201,58,92,52" name="Collect reports"> 
department:就是上面foreach中生成的变量;
这个变量表示一个组/部门,这个组/部门中的任何成员都可以完成这个task,谁来完成谁take这个任务。


***********************
再看结束点:
<join g="343,59,48,48" multiplicity="#{quorum}" name="join1"> 
multiplicity:这个是join完成的条件:
我们来看文档(http://docs.jboss.com/jbpm/v4/devguide/html_single/)中的说明:
2.3. Multiplicative split with foreach中:
引用
Important
When using foreach, the corresponding join must have the multiplicity attribute set. Without it, join continues execution based on its incoming transitions. In the preceding example, join has a single incoming transition. If multiplicity is not specified, the first execution that reaches the join activity will cause the parent execution to leave the join.


1 楼 zhang017 2010-10-21  
进入到foreach,解析完这些参数,会根据join中的multiplicity参数的值,生成task(multiplicity定义为几,就生成几个Executiuon,几个task)
---------------
不是这样,是根据departments中split出的department的个数来确定生成task的条数

相关推荐

Global site tag (gtag.js) - Google Analytics