在Alfresco需要有关工作流程的帮助

时间:2010-04-23 22:49:25

标签: workflow alfresco jbpm

你好SO社区,

我在Alfresco论坛上找不到任何运气,我希望能有更多帮助。我们正在构建一个基于Alfresco和jBPM的应用程序,我已经定义了一个工作流程,但是我已经定义了错误或者遗漏了某些东西,或者Alfresco与jBPM的集成中存在错误,我需要帮助找出哪些并修复它。这是问题所在:

我有一个高级工作流程,我正在尝试从JavaScript启动它。这是我用来启动工作流程的代码:

var nodeId = args.nodeid;
var document = search.findNode("workspace://SpacesStore/" + nodeId);
var workflowAction = actions.create("start-workflow");
workflowAction.parameters.workflowName = "jbpm$nmwf:MyWorkflow";
workflowAction.parameters["bpm:workflowDescription"] = "Please edit: " + document.name;
workflowAction.parameters["bpm:assignees"] = [people.getPerson("admin"), people.getPerson("andyg")];
var futureDate = new Date();
futureDate.setDate(futureDate.getDate() + 7);
workflowAction.parameters["bpm:workflowDueDate"] = futureDate;
workflowAction.execute(document);

这样运行正常,从起始节点的默认转换发送的电子邮件也很好。但是,当我在我的任务列表中查找工作流程时,它不存在,但它位于我的已完成的任务列表中。来自起始节点的默认转换(唯一转换)指向具有四个转换的任务节点。

工作流程中有8个任务和22个转换。当我使用工作流控制台启动工作流并结束启动任务时,它正确地遵循默认的开始节点转换到下一个任务。新任务显示在“显示任务”中但未显示在“显示我的任务”中(显然是因为任务因某种原因被标记为已完成,但它不在“结束”节点中)。任务是:

task id: jbpm$111 , name: nmwf:submitInEditing , properties: 18

如果我“显示过渡”,它看起来就像我期望的那样:

path: jbpm$62-@ , node: In Editing , active: true
 task id: jbpm$111 , name: nmwf:submitInEditing, title: submitInEditing title , desc: submitInEditing description , properties: 18
 transition id: Submit for Approval , title: Submit for Approval
 transition id: Request Copyediting Review , title: Request Copyediting Review
 transition id: Request Legal Review , title: Request Legal Review
 transition id: Request Review , title: Request Review

我不想发布整个工作流程,因为它很大,但这里是前两个节点:

首先是泳道:

<swimlane name="initiator"></swimlane>
<swimlane name="Content Providers">
  <assignment actor-id="Content Providers"  class="org.alfresco.repo.workflow.jbpm.AlfrescoAssignment">
     <actor>#{bpm_assignees}</actor>
  </assignment>
</swimlane>

现在节点:

<start-state name="start">
    <task name="nmwf:submitTask" swimlane="initiator"/>
    <transition name="" to="In Editing">
        <action>
            <runas>admin</runas>
            <script>
                /* Code to send e-mail that a new workflow was started.  I get this e-mail. */
            </script>
        </action>
    </transition>
</start-state>
<task-node name="In Editing">
    <task name="nmwf:submitInEditing" swimlane="Content Providers" />
    <!-- I put e-mail sending code in each of these transitions, but none are firing. -->
    <transition to="In Approval" name="Submit for Approval"></transition>
    <transition to="In Copyediting" name="Request Copyediting Review"></transition>
    <transition to="In Legal Review" name="Request Legal Review"></transition>
    <transition to="In Review" name="Request Review"></transition>
</task-node>

以下是这两个节点的模型:

 <type name="nmwf:submitTask">
    <parent>bpm:startTask</parent>


    <mandatory-aspects>
       <aspect>bpm:assignees</aspect>
    </mandatory-aspects>
 </type>


 <type name="nmwf:submitInEditing">
    <parent>bpm:workflowTask</parent>


    <mandatory-aspects>
       <aspect>bpm:assignees</aspect>
    </mandatory-aspects>
 </type>

以下是在工作流控制台中运行工作流的伪日志:

:: deploy alfresco/extension/workflow/processdefinition.xml

deployed definition id: jbpm$69 , name: jbpm$nmwf:MyWorkflow , title: nmwf:MyWorkflow , version: 28

:: var bpm:assignees* person admin,andyg

set var {http://www.alfresco.org/model/bpm/1.0}assignees = [workspace://SpacesStore/73cf1b28-21aa-40ca-9dde-1cff492d0268, workspace://SpacesStore/03297e91-0b89-4db6-b764-5ada2d167424]

:: var bpm:package package 1

set var {http://www.alfresco.org/model/bpm/1.0}package = workspace://SpacesStore/6e2bbbbd-b728-4403-be37-dfce55a83641

:: start bpm:assignees bpm:package

started workflow id: jbpm$63 , def: nmwf:MyWorkflow
path: jbpm$63-@ , node: start , active: true
 task id: jbpm$112 , name: nmwf:submitTask, title: submitTask title , desc: submitTask description , properties: 16
 transition id: [default] , title: Task Done

:: show transitions

path: jbpm$63-@ , node: start , active: true
 task id: jbpm$112 , name: nmwf:submitTask, title: submitTask title , desc: submitTask description , properties: 17
 transition id: [default] , title: Task Done

:: end task jbpm$112

signal sent - path id: jbpm$63-@
path: jbpm$63-@ , node: In Editing , active: true
 task id: jbpm$113 , name: nmwf:submitInEditing, title: submitInEditing title , desc: submitInEditing description , properties: 17
 transition id: Submit for Approval , title: Submit for Approval
 transition id: Request Copyediting Review , title: Request Copyediting Review
 transition id: Request Legal Review , title: Request Legal Review
 transition id: Request Review , title: Request Review

:: show tasks

task id: jbpm$113 , name: nmwf:submitInEditing , properties: 18

:: show my tasks

admin:
 [there is no output here]

我一直在假设我在开始工作流程之前设置的bpm:assignees最初被传递到第一个任务节点“In Editing”。显然,受让人是在任务对象上,而不在工作流对象上。我将assignees方面添加到启动状态任务中,以便它可以保存它们(在我遇到问题之后;最初它们不存在)并且可能它们仍然坐在那里,但启动状态已经在我获得控制之前结束从Web脚本返回(如果它没有结束则不会有帮助,我需要它在“In Editing”中,因为start-state仅用于记录工作流程已启动)。

总是让我感到困惑的是,在输入任务之前需要在每个任务上设置我需要设置的属性(当您选择转换时,您必须为下一个任务提供数据在您真正转移到下一个任务之前,您必须验证您是否拥有所有必需的数据首先,然后发出转换信号)。但是,启动工作流的代码是异步的,因此不返回已启动的工作流或当前任务(在我的情况下将是“在编辑中”)。因此,无论哪种方式,您都无法设置变量,如bpm:assignees和bpm:dueDate。

我想知道这是否是用户任务列表的问题。我正在设置属性列表中的受理人,但也许这些受让人将进入启动状态任务并且没有被传递到“编辑中”任务?

请注意, 是我的第一个jBPM工作流程,所以请不要认为我知道自己在做什么。如果你看到一些看起来很像的东西,它可能就是,我只是不知道它。

提前感谢任何建议或帮助,

2 个答案:

答案 0 :(得分:3)

所以,事实证明,我的问题是误解了如何做多个受让人,同时允许工作流程与任何一个受让人一起过渡。事实证明,jBPM在一个简单的模型中不支持这一点,你必须做更多的工作,而不仅仅是分配多个受让人。我曾经在一个糟糕的例子中找到了我在互联网上发现并做出了错误的假设的工作原理。

jBPM确实具有并行任务(使用分支)的概念,但正常操作要求所有受理人在工作流转换之前完成其任务。事实证明,解决这个问题的正确方法是将任务分配给所有受让人,但是当任何受让人完成任务时,我们会修补存储有多少受让人必须完成任务的变量(node.nOutOfM)愚弄jBPM在所有受让人完成任务之前完成任务(这也可以让只有x个y受让人必须完成任务)。

以下是我用来解决此问题的文章,而不是发布更新的代码:

http://forums.alfresco.com/en/viewtopic.php?f=30&t=8691

http://forums.alfresco.com/en/viewtopic.php?f=34&t=5189

http://dev.alfresco.com/resource/docs/java/repository/org/alfresco/repo/workflow/jbpm/ForEachFork.html

http://wiki.alfresco.com/wiki/WorkflowAdministration#For_Each_Fork

答案 1 :(得分:0)

我不确定,但我认为您需要<pooledactors>而不是<actor>

也许这就是为什么你的wf没有按预期工作的原因。

<actor>#{bpm_assignees}</actor>

另外,我认为任务应该在你的汇集任务中,而不是你的我的任务,因为它是一个汇集任务(因为你试图设置多个受让人)。