com.opensymphony.workflow包研究

来源:互联网 发布:淘宝亲宝贝商家入口 编辑:程序博客网 时间:2024/06/05 18:54
 源:http://www.360doc.com/showWeb/0/0/5453.aspx

学习应用osworkflow 理解应用osworkflow-2.7.0.jar是必须的。下面我就个人理解谈谈对osworkflow-2.7.0.jar的认识。由于个人目前学习主要侧重于轻量级J2EE。所以对EJB这 部分认识不深也就不妄加评价了。而且每个包都是我自己所能理解或者自己认为比较能常用的类和接口进行初步说明。不足之处请见谅!另外此文也是搜索了大量了 网络资源融合个人理解所写。所以会出现此文中的某一部分与网上的其他文章类似的情况。最终目的在于大家共同学习共同进步,如果你看了此文,对osworkflow有了新认识,请不要感激我,先感激现在的网络资源吧~~GOOD LUCK

这个jar包主要包括如下几个大分类:

com.opensymphony.workflow

主要包括核心的工作流接口和类

先说最最核心的就是:

*的为我认为需要重点把握理解的方法。

AbstractWorkflow(类):AbstractWorkflow类是workflow接口的最基本的实现。

*1.public int[] getAvailableActions(long id, Map inputs)方法:

返回当前可以执行的Ation

  • 得到工作流流程实例。
  • 得到工作流实例的定义。
  • 得到工作流实例的PropertySet
  • 得到工作流的当前Step
  • 产生TransientVars
  • 得到Global Actions
  • 判断可以执行的Global Action增加到可执行Action列表中。
  • 获得当前Steps中的可执行Action并添加到可执行Action列表中。
  • 返回可执行Actions

2. public void setConfiguration(Configuration configuration)方法:

设置工作流配置方法。

3.public Configuration getConfiguration()方法:

返回工作流配置方法,如果没有获得配置信息,初始化配置信息。

4.public List getCurrentSteps(long id)

获得工作流当前所在步骤。

5.public int getEntryState(long id):

获得工作流的状态。

6.public List getHistorySteps(long id)

获得工作流的历史步骤。

7. public Properties getPersistenceProperties()

获得设置的持久化参数。

8.public PropertySet getPropertySet(long id)

得到工作流的PropertySet,调用store中的方法。

9.public List getSecurityPermissions(long id)

得到工作流当前Steppermissions

10.public WorkflowDescriptor getWorkflowDescriptor(String workflowName)

得到工作流的定义。

11.public String getWorkflowName(long id)

根据工作流实例返回工作流定义名。

12. public String[] getWorkflowNames()

返回系统中配置的所有工作流的名字。

13.public boolean canInitialize(String workflowName, int initialAction)public boolean canInitialize(String workflowName, int initialAction, Map inputs)private boolean canInitialize(String workflowName, int initialAction, Map transientVars, PropertySet ps) throws WorkflowException

判断指定的工作流初始化Action是不是可以执行。

14.public boolean canModifyEntryState(long id, int newState)

判断工作流是不是可以转换到指定状态。

  • 不可以转换到CREATED状态。
  • CREATEDSUSPENDED可以转换到ACTIVATED状态。
  • ACTIVATED可以转换到SUSPENDED状态。
  • CREATEDACTIVATEDSUSPENDED 可以转换到KILLED状态。

15.public void changeEntryState(long id, int newState) throws WorkflowException

转换工作流状态。

最最常用的方法,核心的方法doAction(这个方法一定要看好,要不就等于没学这个类了。)

*16.public void doAction(long id, int actionId, Map inputs) throws WorkflowException

执行Action

  • 获得工作流store,和流程实例entry
  • 判断是不是活动的工作流,不是就返回。
  • 获得工作流的定义。
  • 获得工作流当前所再Steps
  • 获得工作流PropertySet
  • 生成transientVars
  • GlobalActions中和当前Steps的普通Actions中判断执行的Action是否试可执行的。
  • 完成ActionTransition

17.public void executeTriggerFunction(long id, int triggerId) throws WorkflowException

调用工作流的Trigger Function

*18.public long initialize(String workflowName, int initialAction, Map inputs) throws InvalidRoleException, InvalidInputException, WorkflowException

初始化一个新的流程实例。返回流程实例id

*19.public List query(WorkflowQuery query)public List query(WorkflowExpressionQuery query)

查询流程实例。

20.public boolean removeWorkflowDescriptor(String workflowName) throws FactoryException

删除已经配置的工作流定义。

21.public boolean saveWorkflowDescriptor(String workflowName, WorkflowDescriptor descriptor, boolean replace) throws FactoryException

保存工作流定义。

22.protected List getAvailableActionsForStep(WorkflowDescriptor wf, Step step, Map transientVars, PropertySet ps) throws WorkflowException

获得指定步骤的可用Actions

23.protected int[] getAvailableAutoActions(long id, Map inputs)

返回可执行的AutoActions

24.protected List getAvailableAutoActionsForStep(WorkflowDescriptor wf, Step step, Map transientVars, PropertySet ps) throws WorkflowException

返回指定Step中可执行的AutoActions

25.protected WorkflowStore getPersistence() throws StoreException

返回配置的store

26.protected void checkImplicitFinish(long id) throws WorkflowException

判断工作流是不是还有可执行的Action,如果没有,完成此工作流实例。

27.protected void completeEntry(long id, Collection currentSteps) throws StoreException

结束工作流实例,就是把改变流程实例的状态并把当前的Steps都放入到历史表中。 

28.protected boolean passesCondition(ConditionDescriptor conditionDesc, Map transientVars, PropertySet ps, int currentStepId) throws WorkflowException

29.protected boolean passesCondition(ConditionDescriptor conditionDesc, Map transientVars, PropertySet ps, int currentStepId) throws WorkflowExceptionprotected boolean passesConditions(String conditionType, List conditions, Map transientVars, PropertySet ps, int currentStepId) throws WorkflowException

判断条件是不是符合。

30.protected void populateTransientMap(WorkflowEntry entry, Map transientVars, List registers, Integer actionId, Collection currentSteps) throws WorkflowException

产生临时变量transientVars,包含contextentrystoredescriptoractionIdcurrentSteps,以及定义的register和用户的输入变量。

31.protected void verifyInputs(WorkflowEntry entry, List validators, Map transientVars, PropertySet ps) throws WorkflowException

验证用户的输入。

*32.private boolean isActionAvailable(ActionDescriptor action, Map transientVars, PropertySet ps, int stepId) throws WorkflowException

判断Action是否可用。

33.private Step getCurrentStep(WorkflowDescriptor wfDesc, int actionId, List currentSteps, Map transientVars, PropertySet ps) throws WorkflowException

获得Action所在Step

34.private boolean canInitialize(String workflowName, int initialAction, Map transientVars, PropertySet ps) throws WorkflowException

判断工作流是不是可以实例化。

35.private Step createNewCurrentStep(ResultDescriptor theResult, WorkflowEntry entry, WorkflowStore store, int actionId, Step currentStep, long[] previousIds, Map transientVars, PropertySet ps) throws WorkflowException

产生新的当前Step

  • resulte中获得nextStep,如果为-1nextStep为当前Step
  • 获得定义中的owneroldStatusstatus
  • 完成当前Step,并且将当前Step保存到历史库中。
  • 生成新的Step

36.private void executeFunction(FunctionDescriptor function, Map transientVars, PropertySet ps) throws WorkflowException

执行Function

37.private boolean transitionWorkflow(WorkflowEntry entry, List currentSteps, WorkflowStore store, WorkflowDescriptor wf, ActionDescriptor action, Map transientVars, Map inputs, PropertySet ps) throws WorkflowException

完成工作流的transation

接口部分:

Register
RegisterRemote
Validator

Conditions

上面这几个定义了相应的基本方法,如register则定义了返回对象的方法registerVariable以及参数形式,Validator则定义了validate方法

FunctionProvider(接口):所有的function包括是prepost都必须实现的接口,它其中有个execute方法。

Workflow(接口):AbstractWorkflow, BasicSOAPWorkflow, EJBWorkflow, OfbizSOAPWorkflow这些类都是实现了这个接口,所以在初始化一个workflow对象的时候,就可以用它来做Workflow wf = new BasicWorkflow((String) session.getAttribute("username"));,这也算是个老祖宗接口了。呵呵^_^

JoinNodes(类):

只有一个方法,根据stepid返回step

public Step getStep(int stepId)

Exception部分:

包括各种exception

FactoryException
InternalWorkflowException
InvalidActionException
InvalidEntryStateException
InvalidInputException
InvalidRoleException
InvalidWorkflowDescriptorException
QueryNotSupportedException
StoreException
WorkflowException

这里workflowExeception是继承自Exception类的,而其他则继承自WorkflowException类。如InvalidInputException则是在Validator校验时候,如果是java-based类型则抛出此异常。