操作后事件
工作流:操作后事件社区版+介绍
系统中的所有用户产生的数据变动,通常都通过某项操作来完成,具体形式通常是点击某个按钮,按钮可能是表单中的提交按钮,也可能是数据区块中的操作按钮。操作后事件用于对这些按钮的操作绑定相关的工作流,以达成用户操作成功后触发特定流程的效果。
例如,在新增或更新数据时,用户可以通过配置按钮的“绑定工作流”选项,点击操作完成后,会触发绑定的工作流。
在实现层面,由于操作后事件的处理处于中间件层(Koa 的中间件),因此,对 NocoBase 的 HTTP API 调用也可以触发已定义的操作后事件。
安装
内置插件,无需安装。
触发器配置
创建工作流
创建工作流时,类型选择“操作后事件”:

执行模式
对于操作后事件,创建时还可以选择执行模式为“同步”或“异步”:

如果是需要在用户操作后立即执行并返回的流程,可以使用同步模式,否则默认为异步模式。异步模式下触发工作流后该操作即完成,工作流会在应用后台以队列的方式陆续执行。
配置数据表
进入工作流画布,点击触发器打开配置弹窗,首先需要选择要绑定的数据表:

选择触发模式
然后选择触发模式,有局部模式和全局模式两种:

其中:
- 局部模式只在绑定了该工作流的操作按钮上触发,未绑定该工作流的按钮点击后不会触发。可基于用途不同的表单,是否触发同一个流程的考虑,以决定是否绑定该工作流。
- 全局模式则是在数据表的所配置操作按钮上都会触发,不区分来自哪个表单,也无需绑定对应工作流。
局部模式下,目前支持绑定的操作按钮如下:
- 新增表单的“提交”和“保存”按钮。
- 更新表单的“提交”和“保存”按钮。
- 数据行(表格、列表、看板等)中的“更新数据”按钮。
选 择操作类型
如选择了全局模式,还需要选择操作类型,目前支持“创建数据操作”和“更新数据操作”。两种操作均在操作成功后触发工作流。
选择预加载关系数据
如需在后续流程中使用触发数据的关联数据,可以选择需要预加载的关系字段:

在触发后则可以在流程中直接使用这些关联数据。
操作配置
对于局部触发模式的操作,工作流配置完成后,需要回到用户界面,在对应数据区块的表单操作按钮上绑定该工作流。
针对“提交”按钮(含“保存数据”按钮)配置的工作流,将在用户提交对应表单且数据操作完成后被触发。

从按钮配置的菜单中选择“绑定工作流”,即可打开绑定配置弹窗。弹窗中可以配置任意多个要触发的工作流,如果一个都不配置,则代表无需触发。针对每一个工作流,需要先限定触发的数据是整个表单的数据还是表单中的某个关系字段的数据,之后再根据所选的数据模型对应的数据表,选择已配置了匹配该表模型的表单工作流。


工作流需要启用后,才可以在以上界面被选择。
示例
这里通过新增操作的方式进行演示。
假设一个“报销申请”的场景,我们需要在员工提交费用报销后,进行额度的自动审核和超出额度的人工审核,审核成功的才通过申请,并在之后交由财务处理。
首先,我们可以先创建一张“费用报销”数据表,有以下字段:
- 项目名称:单行文本
- 申请人:多对一(用户)
- 金额:数字
- 状态:单选(“审核通过”、“处理完成”)
之后先创建一个“操作后事件”类型的工作流,并且把触发器中的数据表模型配置为“费用报销”表:

将工作流设置为启用状态后,流程的具体处理节点稍后再回来配置。
然后我们在界面上创建“费用报销”数据表的表格区块,并且在工具栏增加一个“添加”按钮,配置对应的表单字段。并在表单“提交”操作按钮的配置项中打开按钮的“绑定工作流”配置对话框,选择整个表单数据作为上下文,以及工作流为我们之前创建的工作流:

表单配置完成后,再回到工作流的逻辑编排。比如我们需要金额大于 500 元时要求管理员进行人工审核,否则直接通过,审核通过后才创建报销记录,并由财务进一步处理(略)。

忽略后续财务的处理的话,这样就完成了申请报销流程的配置,当员工填写报销申请并提交后,会触发对应的工作流,如果费用金额小于 500,会自动创建记录并等待财务进一步处理,否则会由主管审核,审核通过后也是一样创建记录并交给财务处理。
该示例的流程也可以配置在普通“提交”按钮上,可以根据具体的业务场景决定是否需要先创建记录再执行后续的流程。
外部调用
操作后事件的触发不仅限于用户界面的操作,也可以通过 HTTP API 调用触发。
通过 HTTP API 调用触发操作后事件时,也需要注意工作流的启用状态,以及数据表配置是否匹配,否则可能不会调用成功,或出现错误。
针对局部绑定在操作按钮上的工作流,可以这样调用(以 posts 表创建按钮举例):
其中 URL 参数 triggerWorkflows 为工作流的 key,多个工作流用逗号分隔。该 key 可在工作流画布顶部工作流名称处鼠标悬浮后获得:

以上调用成功后,将触发对应 posts 表的操作后事件。
因为外部调用也需要基于用户身份,所以通过 HTTP API 调用时,和普通界面发送的请求一致,都需要提供认证信息,包括 Authorization 请求头或 token 参数(登录获得的 token),以及 X-Role 请求头(用户当前角色名)。
如果需要触发该操作中对一关系数据(对多暂不支持)的事件,可以在参数中使用 ! 来指定关系字段的触发数据:
以上调用成功后,将触发对应 categories 表的操作后事件。
如果事件配置为全局模式,则无需使用 URL 参数 triggerWorkflows 指定对应工作流,直接调用对应的数据表操作即可触发。
常见问题
与操作前事件的区别
- 操作前事件:在某项操作(如新增、更新等)执行前触发,在操作执行前,可以在流程中对请求的数据进行校验或处理,如果流程被终止(请求被拦截),该操作(新增、更新等)将不会被执行。
- 操作后事件:在用户某项操作成功后触发,此时数据已经提交成功,并已完成落库,可以根据成功的结果继续处理相关的流程。
如下图所示:


