jbpm2.0中swimlane ,actorid,role在实际项目的演绎:

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

工作流程中的某些状态处于一个swimlane(泳道)中,参与工作流程的具体人如果具备涉足

这个泳道的能力,就可以对这些状态进行处理。如何在计算机系统表示个体的能力度?

在工作流系统中通过组织建模,从组织模型数据中取得一定属性赋给个体,比如通过role角色、

职务(或职务)来表示个体具有的能力度。

在工作流程定义中,很少会把具体的个体定义进流程审批环节中。大多数系统会定义一个

角色(静态和动态)、职位,只要满足这些条件个体都可以处理这些环节(也即具备这些能力个体

进入系统后,系统会把他可以处理的工作全部列出来)。

jbpm2.0通过swimlane这种抽象的能力度对象,把定义的swimlane赋给某些审批环节,系统

在实际运行中,根据swimlane的代理类计算出流程参与者(actorid),需注意一点是这个参与者

和系统用户登录id有所区别,他可以是用户登录id,也可以是role或position。jbpm2.0在这点

设计考虑很周到,仅提供流程引擎,不绑定任何组织模型。用户可以根据各自的组织定义自己

的流程。

如示例:

public class ChiefHandle implements AssignmentHandler {

public ChiefHandle() {

}

public String selectActor(AssignmentContext parm1) {

String actorid=parm1.getPreviousActorId();//比如可以通过前一步的actorid计算出流程参与者

System.out.println("---previous actor id="+actorid);

//userid是在流程发启时,赋的用户登录名,根据登录名可以从组织模型找到相关的数据

//比如要求上级领导等

String firstactorid=(String)parm1.getVariable("userid");

System.out.println("---root actor id="+firstactorid);

if(actorid.equals("US010101"))

return "POS0102";//返回职位代码或登录id等

else

return "POS0103";

}

}

所以用户登录系统中,工作列表不仅仅是根据登录id查找,而且需根据此用户具备的角色或职位等

相关信息查找。

我在实际项目中也碰到一些问题,提出来大家一起讨论,主要是在一些动态角色计算方面没有找到

一个切实可行办法。比如怎样定义:处理上一个状态环节的个体的同事这样的角色等,我想是否可以通过

登录用户的单位代码、部门或项目组代码(selectActor)?

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航