关闭

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

1399人阅读 评论(0) 收藏 举报

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

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:2725次
    • 积分:54
    • 等级:
    • 排名:千里之外
    • 原创:2篇
    • 转载:0篇
    • 译文:0篇
    • 评论:0条
    文章存档