工作流程中的某些状态处于一个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)? 
|