`

osworkflow descriptor 解析片断

阅读更多
Osworkflow定义工作流是通过一个xml文件来完成的,你可以把它取成任何你想要的名字。大致框架如下:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE workflow PUBLIC

  "-//OpenSymphony Group//DTD OSWorkflow 2.7//EN"

  "http://www.opensymphony.com/osworkflow/workflow_2_7.dtd">

<workflow>

  <initial-actions>

    ...

  </initial-actions>

  <steps>

    ...

  </steps>

</workflow>

都是按照标准xml指定。通过指定的dtd来校验xml文件。一般需要辅助工具如xmlspy来自动校验xml文件里的错误,这样会方便大家检测xml文件中的错误。

Step和actions

理解这个xml文件的第一个重点在于理解step和actions的在工作流系统中的概念。一个step就是这样的一个概念:一个工作流中所处的不同位置。如在一个文档管理系统中。可以是起草、编辑阶段、发布等等。

Actions指定不同step中的变迁。还是用例子来理解更为形象一些。在一个文档管理系统当中如在“第一个起草”中的“开始第一个起草”和“结束第一个起草”就是actions。

Initial actions 是一个action的特殊类型。在工作流开始时候,是没有状态的,也没有任何step。用户必须利用某个action来开始流程,这个用来开始工作流的action就被指定为initial-actions。

例如,我们假定我们只有一个initial-action,非常简单,如下面:

<action id="1" name="Start Workflow">

  <results>

    <unconditional-result old-status="Finished" status="Queued" step="1"/>

  </results>

</action>

这个action是个action的最简单的例子。他只是简单定义我们需要走想的step。

工作流status

Status用来描述特定step中的一个工作流的状态。如在文档管理系统当中,我们的“第一次起草”step可以有两个statuses,“underway”和“queued”

用“queued”来指示此条已经在“first draft”中排队。没有安排谁来处理此文档,但是已经发出请求。而“underway”是指示一个作者已经从队列中取出此文档并且或许已经上锁。表明正在first draft上工作。

Step实例:在这个例子中有两个actions。第一个action(开始第一个起草)是在一个step中进行。但是,更改状态为underway,第二个action是工作流流转到下一个step,我们假定下一个工作流step为“finish”。

<step id="1" name="First Draft">

  <actions>

    <action id="1" name="Start First Draft">

      <results>

        <unconditional-result old-status="Finished" status="Underway" step="1"/>

      </results>

    </action>

    <action id="2" name="Finish First Draft">

      <results>

        <unconditional-result old-status="Finished" status="Queued" step="2"/>

      </results>

    </action>

  </actions>

</step>

<step id="2" name="finished" />

Old-status这个属性用来指示对于当前state(结束)将要进入哪个history table。在绝大多数情况下,被写为“finished”。

Conditions

Osworkflow有一些内建的conditon。请参看javadocs,如果需要一个特定的condition。Condition可以接收参数。如本例就接收了一个参数“status”用来指定status

<action id="1" name="Start First Draft">

  <restrict-to>

    <conditions>

      <condition type="class">

        <arg name="class.name">

          com.opensymphony.workflow.util.StatusCondition

        </arg>

        <arg name="status">Queued</arg>

      </condition>

    </conditions>

  </restrict-to>

  <results>

    <unconditional-result old-status="Finished" status="Underway" step="1"/>

  </results>

</action>

这样就能保证在initial action被调用后才可以正确执行。因为它需要确信当前status是“queued”。

Functions

接下来,如果我们希望指定一个用户开始first draft,他们变为“owner”为了达到这样的目的,我们需要这样做:

1、在当前context中防止一个“caller”变量

2、  设置result的“owner”属性为call变量。

function是osworkflow的一个非常强大的特征,一个function基本上是一个系列在工作流变迁之间执行的工作,并不影响工作流本身。例如,你能够有个sendmail功能,它的职责就是当一个特定的变迁发生后发送邮件通知。

Functions能够给当前context添加变量。可以在其他functions或者scripts中使用。

Osworkflow 有自己内建function。其中一个比较有用的就是“caller”。这个function的作用就是通过查找当前的能够调用工作流的用户,把该用户以字符串形式命名为caller变量的值。

<action id="1" name="Start First Draft">

  <pre-functions>

    <function type="class">

      <arg name="class.name">com.opensymphony.workflow.util.Caller</arg>

    </function>

  </pre-functions>

  <results>

    <unconditional-result old-status="Finished" status="Underway"

                                       step="1" owner="${caller}"/>

  </results>

</action>

整合后的结果:

<action id="1" name="Start First Draft">

  <restrict-to>

    <conditions>

      <condition type="class">

        <arg name="class.name">

                com.opensymphony.workflow.util.StatusCondition

        </arg>

        <arg name="status">Queued</arg>

      </condition>

    </conditions>

  </restrict-to>

  <pre-functions>

    <function type="class">

      <arg name="class.name">

              com.opensymphony.workflow.util.Caller

      </arg>

    </function>

  </pre-functions>

  <results>

    <unconditional-result old-status="Finished" status="Underway"

                                       step="1"  owner="${caller}"/>

  </results>

</action>

<action id="2" name="Finish First Draft">

  <restrict-to>

    <conditions type="AND">

      <condition type="class">

        <arg

        name="class.name">com.opensymphony.workflow.util.StatusCondition

        </arg>

        <arg name="status">Underway</arg>

      </condition>

      <condition type="class">

        <arg name="class.name">

              com.opensymphony.workflow.util.AllowOwnerOnlyCondition

       </arg>

      </condition>

    </conditions>

  </restrict-to>

  <results>

    <unconditional-result old-status="Finished" status="Queued" step="2"/>

  </results>

</action>

如果我们想要确保仅仅当用户开始first draft才能完成它(我们在以前的result的owner属性中指定)。Status condition同样确保“finish first draft” action只能在状态为“underway”的情况下才可以被执行。这就确保必须得有一个用户已经开始第一个起草工作。

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE workflow PUBLIC

                 "-//OpenSymphony Group//DTD OSWorkflow 2.7//EN"

                 "http://www.opensymphony.com/osworkflow/workflow_2_7.dtd">

<workflow>

  <initial-actions>

    <action id="1" name="Start Workflow">

      <results>

        <unconditional-result old-status="Finished" status="Queued" step="1"/>

      </results>

    </action>

  </initial-actions>

  <steps>

    <step id="1" name="First Draft">

      <actions>

        <action id="1" name="Start First Draft">

          <restrict-to>

            <conditions>

              <condition type="class">

                <arg name="class.name">

                   com.opensymphony.workflow.util.StatusCondition

                </arg>

                <arg name="status">Queued</arg>

              </condition>

            </conditions>

          </restrict-to>

          <pre-functions>

            <function type="class">

              <arg name="class.name">

                 com.opensymphony.workflow.util.Caller

              </arg>

            </function>

          </pre-functions>

          <results>

            <unconditional-result old-status="Finished" status="Underway"

                                           step="1"  owner="${caller}"/>

          </results>

        </action>

        <action id="2" name="Finish First Draft">

          <restrict-to>

            <conditions type="AND">

              <condition type="class">

                <arg name="class.name">

                    com.opensymphony.workflow.util.StatusCondition

                </arg>

                <arg name="status">Underway</arg>

              </condition>

              <condition type="class">

                <arg name="class.name">

                  com.opensymphony.workflow.util.AllowOwnerOnlyCondition

                </arg>

              </condition>

            </conditions>

          </restrict-to>

          <results>

            <unconditional-result old-status="Finished" status="Queued" step="2"/>

          </results>

        </action>

      </actions>

    </step>

    <step id="2" name="finished" />

  </steps>

</workflow>

创建osworkflow.xml,例子如下:

<osworkflow>

  <persistence class="com.opensymphony.workflow.spi.memory.MemoryWorkflowStore"/>

  <factory class="com.opensymphony.workflow.loader.XMLWorkflowFactory">

    <property name="resource" value="workflows.xml" />

  </factory>

</osworkflow>

指定使用内存数据库。即非永久保存性质。用做测试目的,这样做足够了。

Factory概念

上面的xml 文件同时指定了xml workflowfactory。Workflow factory是用来管理workflowworkflow描述符。Xml workflow factory有一个特定属性叫做“resource”它用来指定在哪里可以找到xml文件,这个resource必须从classpath中加载,所以对于上面的例子,你将要创建一个文件名为workflows.xml的文件追加到classpath中。文件样本如下;

<workflows>

  <workflow name="mytest" type="resource" location="myworkflow.xml"/>

</workflows>

所以,你还需要一个myworkflow.xml,

到此,我们完成了配置,首先初始化然后调用我们的workflow。

Initializing osworkflow:

Osworkflow有一个相对简单的的调用模式,有一个main入口,这个main入口点是workflow的接口,经常是作为实现AbstractWorkflow的子类。

首先,我们创建我们自己的工作流。这个对象应该存储在一个通用区域,并且能够被重复使用。这样做的一个办法就是做一个static。BasicWorkflow的构造器参数是一个当前调用者的。

需要初始化和配置工作流的session,

Workflow workflow = new BasicWorkflow("testuser");

DefaultConfiguration config = new DefaultConfiguration();

workflow.setConfiguration(config);

调用初始化方法:

long workflowId = workflow.initialize("mytest", 1, null);

参数含义:工作流名字,action的id,action。

校验工作流:

现在我们完成初始化工作流实例,我们期待着他的表现是我们所期待那样的。

Collection currentSteps = workflow.getCurrentSteps(workflowId);

//verify we only have one current step

assertEquals("Unexpected number of current steps", 1, currentSteps.size());

//verify it's step 1

Step currentStep = (Step)currentSteps.iterator().next();

assertEquals("Unexpected current step", 1, currentStep.getStepId());

int[] availableActions = workflow.getAvailableActions(workflowId);

//verify we only have one available action

assertEquals("Unexpected number of available actions", 1, availableActions.length);

//verify it's action 1

assertEquals("Unexpected available action", 1, availableActions[0]);

调用action

workflow.doAction(workflowId, 1, null);
分享到:
评论

相关推荐

    OSWorkflow

    OSWorkflow

    OSWorkflow中文手册 OSWorkflow中文手册

    工作流引擎是实现业务流程自动化的核心组件,它负责解析流程定义,驱动流程实例的执行,并管理流程的状态变化。OSWorkflow提供了这样的平台,支持动态流程修改,使得在运行时可以更新流程模型。 2. **OSWorkflow...

    OSWorkFlow

    OSWorkFlow是一个基于Java的工作流引擎,用于在企业级应用中实现复杂的业务流程自动化。它提供了灵活的流程定义和执行模型,使得开发者可以方便地设计、实施和管理各种工作流。下面将详细介绍OSWorkFlow的核心概念、...

    用OSWorkFlow和JBPM开发工作流异同点解析

    【工作流引擎选择:OSWorkflow vs JBPM】 工作流管理系统(Workflow Management System,WfMS)在企业级应用中扮演着重要角色,用于自动化业务流程。OSWorkflow 和 JBPM 是两个广泛使用的开源工作流引擎,它们各有...

    flex解析osworkflow定义文件生成流程图

    花了两天时间写了个demo作用是通过flex解析osworkflow定义文件生成流程图,下载需要五个积分。辛苦费 还望谅解 不骗分 此附近效果图在http://huqingyun69.iteye.com/admin/blogs/1930123这个链接上有解说 大家可以先...

    osworkflow中文入门指南,osworkflow+hibernate+spring集成配置,osworkflow-2.8.0.jar

    **osworkflow** 是一个开源的工作流管理系统,专为Java应用程序设计,用于管理复杂的工作流程。在本入门指南中,我们将深入探讨如何使用osworkflow,并将其与流行的数据持久化框架Hibernate和依赖注入容器Spring进行...

    osworkflow指导文档 + 源码

    本指导文档结合源码将深入解析 osWorkflow 的核心概念和实现方式。 ### 一、osWorkflow 简介 osWorkflow 是由 James Helzer 开发的,其设计目标是为 Java 应用程序提供一个轻量级、易于使用的流程管理框架。...

    osworkflow

    **osWorkflow 概述** osWorkflow 是一个开源的工作流管理系统,专为 Java 应用程序设计,用于处理复杂的业务流程。这个系统的核心功能是管理、跟踪和执行一系列步骤,这些步骤构成了一个工作流程。osWorkflow 提供...

    osworkflow学习笔记

    通过osworkflow项目的学习和实践,总结出的一套osworkflow工作流引擎的学习笔记,供需要使用osworkflow系统的同学们借鉴,谢谢!

    Osworkflow10份资料

    OSWorkflow中文手册OSWorkflow-chinese-manual-2.8.pdf Packt.Publishing.OSWorkflow.A.Guide.for.Java.Developers.and.Architects.Aug.2007.pdf 工作流普及风暴—基础概念.doc 用osworkflow写一个请假例子.rar

    osworkflow-2.8.0.zip

    `lib`目录下是一些osWorkflow运行所依赖的第三方库,比如数据库连接池、XML解析库等。了解这些库可以帮助开发者更好地理解和配置osWorkflow的运行环境,确保其正常运行。 总的来说,osworkflow-2.8.0.zip提供了一...

    osworkflow_bundle2

    OSWorkflow 是一个开源的工作流引擎,它允许开发者在应用程序中实现复杂的业务流程。"osworkflow_bundle2" 是一个专门用于学习 OSWorkflow 的示例集合,它包含了一系列的资源和实例,帮助用户理解并掌握如何使用这个...

    osworkflow2.8

    OSWorkflow 是一个开源的工作流引擎,它允许开发者在应用程序中实现复杂的业务流程管理。这个"osworkflow2.8"版本是OSWorkflow的一个特定发行版,包含了一整套用于设计、执行和管理工作流程的工具和资源。下面我们将...

    OsWorkflow工作流实例

    OsWorkflow是一款开源的工作流引擎,它为应用程序提供了一种灵活且可扩展的方式来管理业务流程。在本实例中,我们将深入探讨OsWorkflow的核心概念、主要功能以及如何创建和测试一个工作流实例。 工作流引擎是软件...

    画流程图的例子(源码)OsWorkFlow.rar

    《使用OsWorkFlow绘制流程图的实践与源码解析》 流程图,作为一种直观的图形化表示方式,广泛应用于IT领域的各种系统设计、业务流程分析和软件开发中。OsWorkFlow,作为一款开源的工作流引擎,它提供了强大的流程图...

    OSWorkflow源码及电子书

    OSWorkflow,全称为OpenSymphony Workflow,是一款轻量级、高度灵活的开源工作流引擎,专为满足各类组织和企业的工作流程管理需求而设计。它提供了丰富的API和配置选项,使得开发者可以轻松地将工作流集成到自己的...

    目前osworkflow最新最全的资料合集

    **osworkflow** 是一个强大的开源工作流引擎,主要用于在Java应用程序中实现业务流程管理。它提供了灵活的工作流定义,使得开发者能够轻松地设计和实施复杂的业务流程。osworkflow的最新和最全的资料集合,包括了...

    osworkflow2.8.pdf

    ### OSWorkflow 2.8 知识点概览 #### 一、OSWorkflow 简介与特性 **OSWorkflow** 是一款灵活的工作流管理工具,适用于需要高度定制化流程的应用场景。它与大多数商用或开源工作流软件的不同之处在于其高度的灵活性...

Global site tag (gtag.js) - Google Analytics