收回:收回是
工作流参与者对自己“已办任务”(对已完成的工作项)的一种操作,即参与者主动对已办理过的工作项进行重新办理。
为什么要收回?
参与者完成任务后,发现自己办理有错误等情况后,需要将此任务收回重新办理。
工作项的参与方式
目前有四种方式:共同参与、竞争参与、顺序参与、基于角色的共同参与。
下面会针对这四种方式进行讨论。
工作项收回模式
1、未触发下一节点的工作项的收回
即当前任务节点并未完成,依旧处于执行状态
1.1共同参与
如图:在节点A未结束之前,workitem1、workitem2和workitem3正常完成后可以任意收回。在只产生一个workitem的情况下,不存在未触发下一节点的收回情况。
1.2顺序参与
如图:workitem1、workitem2和workitem3顺序完成,workitem1在workitem2签收(包括挂起和手工终止)前可以收回,同样,workitem2在workitem3签收(包括挂起和手工终止)前也可以收回。在只产生一个workitem的情况下,不存在未触发下一节点的收回情况。
1.3竞争参与
因为只会产生一个workitem,该workitem完成后会立刻触发下一节点,所以不存在未触发下一节点的收回情况。
1.4基于角色的共同参与
与1.1相同。
2、已触发下一节点的工作项的收回
2.1共同参与
问题1:多个工作项时谁可以执行收回操作?
workitem1、workitem2和workitem3都可以执行收回操作。第一个工作项的收回将会导致节点B实例的删除,同时节点A重新恢复执行状态。
问题2:节点B处于什么状态节点A的工作项可以执行收回操作?
由A触发的节点B处于正在执行的状态,节点B所产生的工作项:
a共同参与 工作项均未签收、挂起或手工终止
b顺序参与 第一个工作项未签收、挂起或手工终止
c 竞争参与 工作项均未签收、挂起或手工终止
d角色
同共同参与
问题3:工作项收回产生的影响?
节点A重新执行,收回的工作项重新执行。节点B重新恢复未触发状态,B所产生的工作项全部删除。
2.2顺序参与
问题1:多个工作项时谁可以执行收回操作?
workitem1、workitem2和workitem3根据顺序可以依次执行收回操作。
2.3竞争参与
情况简单,只有一个工作项,所以可以直接收回。
2.4基于角色的共同参与
同2.1
工作流收回模式
后续触发节点只能是人工节点(可以是多个,至少一个),否则不支持收回。目前不支持父子流程之间的收回。
一个典型的同步汇聚情况:
节点1首先执行完毕,但是因为是同步汇聚,所以它不会触发实际的流转;而节点2的完成则会触发节点3的执行。在这种情况下,节点2的工作项可以执行收回操作,而节点1的工作项因为后续没有触发节点而不能收回。