j2ee绿洲

找到属于自己的一片天空
数据加载中……
OSWorkflow源码2
api-基本:
 
sworkflow提供了集中工作流实现方式:
   BasicWorkflow
   EJBWorkflow
   Ofbizworkflow
创建新的工作流实例,执行action
   Workflow workflow = new BasicWorkflow("testuser");
   DefaultConfiguration config = new DefaultConfiguration();
   workflow.setConfiguration(config);
   long workflowId = workflow.initialize("mytest", 1, null);
   workflow.doAction(workflowId, 1, null);
api-abstractworkflow:
 
osworkflow中有关工作流流转的所有核心代码都在AbstractWorkflow中,BasicWorkflow就是派生自它,可以从AbstractWorkflow派生自己的Workflow类以加入扩展功能
最重要的方法doAction
其他主要功能:Initialize、executeFunction、众多get方法、query、state相关、等等
api-配置文件相关:
 
Configuration实例负责系统配置的加载。AbstractWorkflow会调用其load方法,该方法内部会查找一个名为osworkflow.xml的配置文件,并对其解析。
WorkflowFactory包括XMLWorkflowFactory 、JDBCWorkflowFactory、URLWorkflowFactory,作用即是加载各个不同的工作流定义,维护一个map。
WorkflowLoader的作用实现配置文件的读取
WorkflowDescriptor的作用将平面的xml流转化为osworkflow内部所使用的具有真正意义的对象。
其他不同的descriptor,如(step、action…………)之间的关系。
其他不同的descriptor,如(step、action…………)之间的关系。
api-查询:
 
目的:希望了解流程当前的运行状况à查询
WorkflowQuery及其相关类(query包) 
WorkflowQuery queryLeft = new WorkflowQuery(
  WorkflowQuery.OWNER, WorkflowQuery.CURRENT, WorkflowQuery.EQUALS, “test");
WorkflowQuery queryRight = new WorkflowQuery(
  WorkflowQuery.STATUS, WorkflowQuery.CURRENT, WorkflowQuery.EQUALS, “Underway");
WorkflowQuery query = new WorkflowQuery(
  queryLeft, WorkflowQuery.AND, queryRight);
List workflows = wf.query(query);
for (Iterator iterator = workflows.iterator(); iterator.hasNext();)
  Long wfId = (Long) iterator.next();
}
AbstractWorkflow导向workflowstore进行实际查询,最后将查询结果存储与arraylist中
目的:希望了解流程当前的运行状况à查询
WorkflowQuery及其相关类(query包) 
WorkflowQuery queryLeft = new WorkflowQuery(
  WorkflowQuery.OWNER, WorkflowQuery.CURRENT, WorkflowQuery.EQUALS, “test");
WorkflowQuery queryRight = new WorkflowQuery(
  WorkflowQuery.STATUS, WorkflowQuery.CURRENT, WorkflowQuery.EQUALS, “Underway");
WorkflowQuery query = new WorkflowQuery(
  queryLeft, WorkflowQuery.AND, queryRight);
List workflows = wf.query(query);
for (Iterator iterator = workflows.iterator(); iterator.hasNext();)
  Long wfId = (Long) iterator.next();
}
AbstractWorkflow导向workflowstore进行实际查询,最后将查询结果存储与arraylist中
api-用户管理:
 
OSWorkflow在用户管理方面所提供的功能,主要包括用户的创建、群组的定义、用户验证、以及对step执行人的跟踪记录和执行权限的判断等等
用户/群组的管理是由UserManager来完成的
代码中详细讲解
代码中详细讲解
osworkflow任务管理:
 
OSWorkflow引擎只负责了“流程的运转”,当然这个运转会根据你所定义的Action和condtion来判断。
Condition—条件判断
Function(pre and post)--Step、action、result执行过程需要调用的功能
FunctionProvider接口、execute方法
<step id="4" name="Assign"> 
      <pre-functions> 
        <function type="class"> 
      <arg name="class.name">nucleus.assign.AssignmentFunction</arg> 
      <arg name="Participant">A</arg> 
      <arg name="ParticipantType">role</arg>
          <arg name="actionID">22</arg> 
        </function> 
      </pre-functions> 
      <actions> 
         ······ 
      </actions> 
    </step>
    </step>
osworkflow的schedule:
 
定时执行某项任务的功能,Quartz
<function type="class">
 <arg name="class.name">com.opensymphony.workflow.util.ScheduleJob</arg>
 <arg name="triggerId">1</arg>
 <arg name="jobName">testJob</arg>
 <arg name="triggerName">testTrigger</arg>
 <arg name="groupName">test</arg>
 <arg name="repeat">10</arg>
 <arg name="repeatDelay">2000</arg>
 <arg name="cronExpression">0,5,10,15,20,25,30,35,40,45,50,55 * * * * ?</arg>
 <arg name="username">test</arg>
 <arg name="password">test</arg>
 <arg name="local">true</arg>
 <arg name="schedulerStart">true</arg>
</function>
§Trigger和jobDetail,trigger触发条件满足后,则会激活真正的job实例,job实例真正执行的是trigger function(在配置文件中定义)
最后讲解osworkflow自带小例子,约1小时40分钟讲完。以上为ppt 的基本内容。

posted on 2007-07-03 11:47 心情经纬 阅读(561) 评论(0)  编辑  收藏 所属分类: OSWorkflow


只有注册用户登录后才能发表评论。


网站导航: