`

bboss版activiti 5.12扩展动态

阅读更多
扩展Activiti-5.12轻松实现流程节点间自由跳转和任意驳回/撤回功能之后,bboss最近对Activiti-5.12这个版本做了以下功能扩展:
1.如果人工任务节点没有设置处理人,则自动完成当前节点跳转到下一环节,如果对应人工任务节点(没有设置处理人的人工任务节点节点)设置了自动处理类(实现org.activiti.engine.delegate.JavaDelegate接口)参数,则会执行自动处理类的接口方法:
void execute(DelegateExecution execution) throws Exception;
.
例如:流程中有a,b,c,d四个人工任务节点,其中b节点没有设置处理人,那么当a节点任务完成后,如果b节点没有设置自动处理类,那么直接忽略掉b,直接运行到c节点;如果b节点设置了自动处理类,那么流程引擎执行该处理类后再运行到c节点。

2.org.activiti.engine.impl.TaskServiceImpl组件增加一组带完成原因的completeTask接口,完成原因会直接填写到工作流的act_hi_task表的完成原因字段中。
例如:
public void completeWithDestReason(String taskId,String destinationTaskKey,String completeReason,String bussinessop,String bussinessRemark)
详情参考组件:
https://github.com/yin-bp/activiti-engine-5.12/blob/master/src/main/java/org/activiti/engine/impl/TaskServiceImpl.java
三个任务完成原因相关字段:
completeReason:流程引擎自身会填充的说明字段,业务程序也可自己填写这个字段,一般流程引擎会在字段中记录任务处理任意跳转,驳回等系统信息
bussinessop:由业务程序记录完成任务时的填写的业务操作码,可以填写,也可以不填写,流程引擎不会修改这个字段
bussinessRemark:由业务程序记录完成任务时填写的业务处理日志,可以填写,也可以不填写,流程引擎不会修改这个字段
同样也提供了一组带三个原因字段的驳回接口。

3.为了便于记录操作日志和提升系统性能,对流程活动历时表和任务历时表做了相应的扩展:
工作流任务表ACT_HI_ACTINST表中增加任务处理原因,任务业务操作类型,任务业务操作日志,签收时间,任务owner5个子段,同时ACT_HI_ACTINST记录任务kpi数据以及任务的节假日策略

工作流任务表ACT_HI_TASKINST表中增加任务业务操作类型,任务业务操作日志字段,同时ACT_HI_TASKINST记录任务kpi数据以及任务的节假日策略。
4.增加一组驳回接口,可以指定驳回的历史节点,驳回时可以指定驳回后,任务处理完毕可忽略后续节点直接跳转到驳回节点:
public boolean rejecttoTask(String taskId, Map<String, Object> variables,String desttaskkey )//处理完毕后,按照正常的流程流转到驳回点


处理完毕后,按照正常的流程流转到驳回点,例如:流程中有a,b,c,d四个节点,由d节点驳回到a节点,当a处理完毕后,还要流转b,c两个节点再到达d.

public boolean rejecttoTask(String taskId, Map<String, Object> variables,
		String desttaskkey, boolean returntoreject)//增加了处理任务后直接回到驳回点的控制变量

处理完毕后,直接回到驳回点,例如:流程中有a,b,c,d四个节点,由d节点驳回到a节点,当a处理完毕后,直接流转到d节点,忽略b,c两个节点.

5.改造单实例人工任务节点(非Multi Instance的UseTask节点,设置多个处理人时只产生一个任务,这个任务只能被其中的一个人处理)逻辑,可以根据控制变量在流程实例开启和运行阶段改变单实例人工任务节点的处理节点为多实例任务节点(也就是说,如果单实例人工任务节点设置了多个处理人,会为每个人生成一个任务,此时,这个在建模时被定义为单实例人工任务的节点的行为已经和多实例人工任务节点的行为一致),这样不仅可以大大降低我们流程建模的复杂度(画多实例人工任务节点是比较复杂的),同时可以在流程实例运行过程中灵活控制单实例人工任务节点的行为(在设置了多个处理人时,可以根据控制变量改变其到底是按单实例任务跑,还是按多实例任务跑)。具体工作原理看下图:




6.改变流程变量的校验规则。在流程运行过程中,如果变量没有设置值时,不抛出Exception,只在log4j日志文件中输出相应的警告日志。

7.userTask 类型节点的activiti:assignee属性也可以设置多个处理人,以逗号分隔,例如:
<userTask id="usertask2" name="单实例" activiti:assignee="zhangsan,lisi,wangwu"></userTask>

改造版的bboss中要求流程处理人变量必须是以下命名格式:
活动id+_+users
例如:
<userTask id="usertask2" name="单实例" activiti:assignee="${usertask2_users}"></userTask>

8.单实例人工任务节点,当只设置了一个处理人时,不再需要签收任务,任务直接被assignee个指定的这个人

9.在流程引擎级别记录驳回操作,撤销操作,驳回后回到驳回点操作,任意跳转操作日志,以便在处理任务时进行相应的处理操作
常量:
org.activiti.engine.TaskService定义了四个常量与上述四个操作对应
 public static final int  op_rejected = 3;//驳回操作
  public static final int  op_withdraw = 1;//撤销操作
  public static final int  op_jump = 2;//任意跳转操作
  public static final int  op_returntorejected = 0;//驳回后回到驳回点操作


10.定义了扩展归档机制,当流程实例结束时,用户可以在归档接口方法中将需要归档的实例运行时数据进行归档,流程引擎默认对流程引擎级别驳回操作、撤销操作、驳回后回到驳回点操作、任意跳转操作日志进行归档。
归档组件必须实现接口方法:
package org.activiti.engine
/**
 * 工作流
 * @author yinbp
 *
 */
public interface KPIService {
	//计算任务超时时间和任务预警时间接口方法
	public KPI buildKPI(DelegateExecution execution,Collection<String> candiates,Date taskCreateTime) throws ActivitiException;
        //获取任务处理节点控制变量方法
	public ControlParam getControlParam(DelegateExecution currentexecution,String taskKey) throws ActivitiException;
       //获取任务处理节点控制变量方法
	public ControlParam getControlParam(String processInstanceId,String activieKey) throws ActivitiException;
	/**
	 * 流程实例结束后,对实例相关的外围扩展信息实时归档操作
	 * @param currentexecution
	 * @param processInstanceID
	 * @throws ActivitiException
	 */
	public void archiveProcessRuntimedata(DelegateExecution currentexecution,String processInstanceID) throws ActivitiException;
}

在流程引擎配置文件中增加以下注入配置即可:
  <property name="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
....
<property name="KPIService" class="com.bboss.workflow.service.impl.PlatformKPIServiceImpl"/>
....
  </property>


11.由于我们可以直接在任务历史表和活动历史表中记录任务和活动处理日志和业务处理日志和业务处理操作,为了解决mysql下这些处理日志的排序问题,为ACT_HI_ACTINST 和ACT_HI_TASKINST 两个表分别增加了以下long形的排序时间字段:START_TIME_LONG,  END_TIME_LONG 

12.提供抄送/通知任务类型,支持抄送到人和部门,抄送任务不影响流程的正常流转,比如最后一个任务节点被设置为抄送任务节点后,抄送任务产生后流程立即结束,但是抄送任务仍然存在,知道相关人员阅读完抄送任务后结束

13.可自动跳过相同处理人的节点,为了便于业务逻辑的处理,可以在自动过的时候指定自动业务处理回调类。
14.最新的bboss版activiti 5.12对流程引擎数据库做了相应的调整,如果要升级需要执行的sql脚本如下:
mysql:
-- Create table
create table td_wf_rejectlog
(
  newtaskid    varchar(64) not null,
  rejecttaskid varchar(64) not null,
  rejectnode   varchar(100) not null,
   primary key (newtaskid)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE utf8_bin;

ALTER TABLE ACT_RU_TASK
ADD COLUMN DURATION_NODE decimal(19)   NULL DEFAULT 0;

ALTER TABLE ACT_RU_TASK
ADD COLUMN  ADVANCESEND decimal(1)  NULL DEFAULT 0;

ALTER TABLE ACT_RU_TASK
ADD COLUMN OVERTIMESEND decimal(1) NULL DEFAULT 0;

ALTER TABLE ACT_RU_TASK
ADD COLUMN (ALERTTIME TIMESTAMP   NULL DEFAULT NULL);

ALTER TABLE ACT_RU_TASK
ADD COLUMN (OVERTIME TIMESTAMP   NULL DEFAULT NULL);

ALTER TABLE ACT_HI_ACTINST
ADD COLUMN DURATION_NODE decimal(19) NULL DEFAULT 0;

ALTER TABLE ACT_HI_ACTINST
ADD COLUMN ADVANCESEND decimal(1) NULL DEFAULT 0;

ALTER TABLE ACT_HI_ACTINST
ADD COLUMN OVERTIMESEND decimal(1) NULL DEFAULT 0;

 

ALTER TABLE ACT_HI_ACTINST
ADD COLUMN (ALERTTIME TIMESTAMP   NULL DEFAULT NULL);

ALTER TABLE ACT_HI_ACTINST
ADD COLUMN (OVERTIME TIMESTAMP   NULL DEFAULT NULL);

 

ALTER TABLE ACT_HI_TASKINST
ADD COLUMN DURATION_NODE decimal(19) NULL DEFAULT 0;

ALTER TABLE ACT_HI_TASKINST
ADD COLUMN ADVANCESEND decimal(1) NULL DEFAULT 0;

ALTER TABLE ACT_HI_TASKINST
ADD COLUMN OVERTIMESEND decimal(1) NULL DEFAULT 0;

ALTER TABLE ACT_HI_TASKINST
ADD COLUMN (ALERTTIME TIMESTAMP   NULL DEFAULT NULL);
ALTER TABLE ACT_HI_TASKINST
ADD COLUMN (OVERTIME TIMESTAMP   NULL DEFAULT NULL);

ALTER TABLE ACT_HI_ACTINST
ADD COLUMN (NOTICERATE decimal(8));

ALTER TABLE ACT_HI_TASKINST
ADD COLUMN (NOTICERATE decimal(8));

ALTER TABLE ACT_RU_TASK
ADD COLUMN (NOTICERATE decimal(8)); 

ALTER TABLE ACT_HI_ACTINST
ADD COLUMN (IS_CONTAIN_HOLIDAY decimal(1));
ALTER TABLE ACT_HI_TASKINST
ADD COLUMN (IS_CONTAIN_HOLIDAY decimal(1));
ALTER TABLE ACT_RU_TASK
ADD COLUMN (IS_CONTAIN_HOLIDAY decimal(1) );

ALTER TABLE ACT_HI_ACTINST
ADD COLUMN IS_AUTO_COMPLETE decimal(1)  NULL DEFAULT 0;

ALTER TABLE ACT_HI_ACTINST
ADD COLUMN (AUTO_HANDLER  varchar(255));

ALTER TABLE ACT_HI_TASKINST
 ADD COLUMN (BUSSINESS_OP  varchar(255));
ALTER TABLE ACT_HI_TASKINST
 ADD COLUMN (BUSSINESS_REMARK  varchar(2000));
 
ALTER TABLE ACT_HI_ACTINST
 ADD COLUMN (BUSSINESS_OP  VARCHAR(255));
ALTER TABLE ACT_HI_ACTINST
 ADD COLUMN (BUSSINESS_REMARK  VARCHAR(2000)); 
ALTER TABLE ACT_HI_ACTINST
 ADD COLUMN (DELETE_REASON_  VARCHAR(2000)); 
ALTER TABLE ACT_HI_ACTINST
 ADD COLUMN (OWNER_  VARCHAR(255)); 
   ALTER TABLE ACT_HI_ACTINST
 ADD COLUMN (CLAIM_TIME_  TIMESTAMP   NULL DEFAULT NULL); 

   
    ALTER TABLE td_wf_rejectlog
 ADD COLUMN (optype  decimal(1)  NULL DEFAULT 0); 
 ALTER TABLE TD_WF_REJECTLOG
 ADD (PROCESS_ID  VARCHAR(100));
create table td_wf_hi_rejectlog
(
  newtaskid    varchar(64) not null,
  rejecttaskid varchar(64) not null,
  rejectnode   varchar(100) not null,
  BACKUPTIME   TIMESTAMP  NULL DEFAULT NULL, 
  optype  decimal(1)  NULL DEFAULT 0,
  PROCESS_ID  VARCHAR(100), 
   primary key (newtaskid)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE utf8_bin;
 ALTER TABLE ACT_HI_ACTINST ADD COLUMN (START_TIME_LONG  bigint ); 
 ALTER TABLE ACT_HI_ACTINST ADD COLUMN (END_TIME_LONG  bigint ); 
 
 ALTER TABLE ACT_HI_TASKINST ADD COLUMN (START_TIME_LONG  bigint ); 
 ALTER TABLE ACT_HI_TASKINST ADD COLUMN (END_TIME_LONG  bigint );


oracle:
-- Create table
create table td_wf_rejectlog
(
  newtaskid    nvarchar2(64),
  rejecttaskid nvarchar2(64),
  rejectnode   nvarchar2(100)
)
;
-- Create/Recreate primary, unique and foreign key constraints 
alter table td_wf_rejectlog
  add constraint rejectlog_pk primary key (NEWTASKID);
--流程引擎扩展表字段
ALTER TABLE ACT_RU_TASK
ADD (DURATION_NODE NUMBER(19));



ALTER TABLE ACT_RU_TASK
ADD (ADVANCESEND NUMBER(1) DEFAULT 0);



ALTER TABLE ACT_RU_TASK
ADD (OVERTIMESEND NUMBER(1));



ALTER TABLE ACT_RU_TASK
MODIFY(DURATION_NODE  DEFAULT 0);

ALTER TABLE ACT_RU_TASK
MODIFY(OVERTIMESEND  DEFAULT 0);

ALTER TABLE ACT_RU_TASK
ADD (ALERTTIME TIMESTAMP(7));



ALTER TABLE ACT_RU_TASK
ADD (OVERTIME TIMESTAMP(7));




ALTER TABLE ACT_HI_ACTINST
ADD (DURATION_NODE NUMBER(19));



ALTER TABLE ACT_HI_ACTINST
ADD (ADVANCESEND NUMBER(1) DEFAULT 0);




ALTER TABLE ACT_HI_ACTINST
ADD (OVERTIMESEND NUMBER(1));


ALTER TABLE ACT_HI_ACTINST
MODIFY(DURATION_NODE  DEFAULT 0);

ALTER TABLE ACT_HI_ACTINST
MODIFY(OVERTIMESEND  DEFAULT 0);

ALTER TABLE ACT_HI_ACTINST
ADD (ALERTTIME TIMESTAMP(7));



ALTER TABLE ACT_HI_ACTINST
ADD (OVERTIME TIMESTAMP(7));



----------------------------------------------------
ALTER TABLE ACT_HI_TASKINST
ADD (DURATION_NODE NUMBER(19));


ALTER TABLE ACT_HI_TASKINST
ADD (ADVANCESEND NUMBER(1) DEFAULT 0);




ALTER TABLE ACT_HI_TASKINST
ADD (OVERTIMESEND NUMBER(1));


ALTER TABLE ACT_HI_TASKINST
MODIFY(DURATION_NODE  DEFAULT 0);

ALTER TABLE ACT_HI_TASKINST
MODIFY(OVERTIMESEND  DEFAULT 0);

ALTER TABLE ACT_HI_TASKINST
ADD (ALERTTIME TIMESTAMP(7));



ALTER TABLE ACT_HI_TASKINST
ADD (OVERTIME TIMESTAMP(7));


---------------------
ALTER TABLE ACT_HI_ACTINST
ADD (NOTICERATE NUMBER(8));



ALTER TABLE ACT_HI_TASKINST
ADD (NOTICERATE NUMBER(8));



ALTER TABLE ACT_RU_TASK
ADD (NOTICERATE NUMBER(8));


-------------------------

ALTER TABLE ACT_HI_ACTINST
ADD (IS_CONTAIN_HOLIDAY NUMBER(1));



ALTER TABLE ACT_HI_TASKINST
ADD (IS_CONTAIN_HOLIDAY NUMBER(1));



ALTER TABLE ACT_RU_TASK
ADD (IS_CONTAIN_HOLIDAY NUMBER(1) );

ALTER TABLE ACT_HI_ACTINST
 ADD (IS_AUTO_COMPLETE  NUMBER(1)                   DEFAULT 0);

ALTER TABLE ACT_HI_ACTINST
 ADD (AUTO_HANDLER  NVARCHAR2(255));

ALTER TABLE ACT_HI_TASKINST
 ADD (BUSSINESS_OP  NVARCHAR2(255));
ALTER TABLE ACT_HI_TASKINST
 ADD (BUSSINESS_REMARK  NVARCHAR2(2000));
 
 ALTER TABLE ACT_HI_ACTINST
 ADD (BUSSINESS_OP  NVARCHAR2(255));
ALTER TABLE ACT_HI_ACTINST
 ADD (BUSSINESS_REMARK  NVARCHAR2(2000));
 ALTER TABLE ACT_HI_ACTINST
 ADD (DELETE_REASON_  NVARCHAR2(2000)); 
 
 ALTER TABLE ACT_HI_ACTINST
 ADD (OWNER_  NVARCHAR2(255)); 
 
  ALTER TABLE ACT_HI_ACTINST
 ADD (CLAIM_TIME_  TIMESTAMP(6));
ALTER TABLE td_wf_rejectlog
 ADD   (optype  NUMBER(1)   DEFAULT 0); 
ALTER TABLE TD_WF_REJECTLOG
 ADD (PROCESS_ID  NVARCHAR2(100));
 -- Create table
create table td_wf_hi_rejectlog
(
  newtaskid    nvarchar2(64),
  rejecttaskid nvarchar2(64),
  rejectnode   nvarchar2(100),
   BACKUPTIME  TIMESTAMP(6), 
  optype  NUMBER(1)  DEFAULT 0,
  PROCESS_ID  NVARCHAR2(100)
)
;

-- Create/Recreate primary, unique and foreign key constraints 
alter table td_wf_hi_rejectlog
  add constraint hi_rejectlog_pk primary key (NEWTASKID);
 ALTER TABLE ACT_HI_ACTINST ADD (START_TIME_LONG  NUMBER(19) ); 
 ALTER TABLE ACT_HI_ACTINST ADD (END_TIME_LONG  NUMBER(19) ); 
 
 ALTER TABLE ACT_HI_TASKINST ADD (START_TIME_LONG  NUMBER(19) ); 
 ALTER TABLE ACT_HI_TASKINST ADD (END_TIME_LONG  NUMBER(19) ); 


15.最新的bboss版activiti 5.12下载地址:
https://github.com/yin-bp/activiti-engine-5.12
  • 大小: 31.8 KB
分享到:
评论

相关推荐

    eclipse-activiti5.12插件

    Activiti 是一个轻量级、高效且可扩展的工作流引擎,它支持BPMN 2.0标准,可以处理复杂的工作流程和业务规则。Activiti 提供了一个强大的API和直观的模型定义语言(BPMN),使得开发者能够快速构建和部署业务流程...

    activiti系列jar包(含 5.12 、5.14、 5.15)

    这个压缩包包含了 Activiti 的不同版本,包括 5.12、5.14 和 5.15,这些都是 Java 开发人员在构建企业级应用时可能会用到的组件。每个版本的 Activiti 设计师都是一个图形化的流程建模工具,帮助用户设计和调试工作...

    activiti-engine-5.12:带有bboss的activiti-engine-5.12

    抄送和通知任务改造:AtomicOperationTransitionDestroyScope流程自动过,没有设置处理人时,根据配置执行业务处理回调函数,然后自动往前执行流程如果流程任务当前处理环境和下一个任务的处理人相同,则直接跳过...

    activiti工作流动态表单,外置表单,普通表单demo

    activiti三种表单的demo实现 运行方式: 1,修改连接的数据库 2,sql文件在resources\sql下 3,访问地址http://localhost:8080/activiti-demo/main/index

    工作流Activiti5.22.0扩展支持达梦数据库、

    Activiti5.22.0扩展支持达梦数据库

    activiti5.22.0支持达梦数据库

    activiti兼容达梦数据库,附件中是打包好的支持国产数据库达梦的activiti-engine-5.22.0.jar, 工作需要把数据库迁移到达梦数据库,发现activiti不支持达梦,花了几个小时修改了源码,并调试通过。 具体修改的类是: ...

    activiti7.0.0.Beta2扩展支持国产达梦数据库

    为了使activiti7工作流支持达梦数据库,修改源码扩展的时候,有很多编译不通过的地方,自己修改了一下,activiti-engine-7.0.0.Beta2.jar

    activiti-bpmn-converter-5.12

    activiti-bpmn-converter-5.12

    通用eclipse版activiti插件

    【通用eclipse版Activiti插件】是一款专为开发者设计的工具,旨在简化在Eclipse或MyEclipse环境中集成和使用Activiti工作流引擎的过程。Activiti是一个开源的业务流程管理(BPM)和工作流系统,它允许开发人员轻松地...

    activiti适配达梦数据库教程

    Activiti 适配达梦数据库教程 activiti 是一个开源的 Workflow 和 BPM system,它提供了强大的工作流引擎和业务流程管理功能。然而,activiti 默认支持的数据库只有 MySQL、 PostgreSQL、Oracle 等少数几种,而达梦...

    通用eclipse版activiti5.18插件

    【通用eclipse版activiti5.18插件】是一个专为开发人员设计的扩展工具,它使得在Eclipse集成开发环境中(IDE)使用Activiti工作流引擎变得更加便捷。Activiti是一个开源的业务流程管理(BPM)和工作流系统,它基于...

    Activiti实战_完整版 PDF电子书下载.rar

    8. Activiti的扩展与定制:包括自定义行为(如定时器、监听器)、表单(Form)和任务服务的扩展,以及流程引擎的日志、监控和调试。 9. 实战案例分析:书中通过一系列的实际案例,如请假审批流程、采购流程等,展示...

    activiti动态创建路径

    本篇将详细探讨"activiti动态创建路径"这一主题,以及如何借助源码和工具实现这一功能。 首先,理解"动态创建路径"在Activiti中的含义。在业务流程设计中,路径指的是流程实例在执行过程中的流转路径,如审批环节的...

    eclipse版本activiti设计器

    6. **扩展性**:除了基本的流程设计,Activiti Designer还允许通过自定义表单和事件处理器等来扩展功能,满足复杂业务需求。 7. **文档生成**:设计师可以导出流程图为PNG或其他图像格式,方便在报告或文档中使用。...

    activiti-5.22.0-中文用户手册.rar

    Activiti将是一种轻量级,可嵌入的BPM引擎,而且还设计适用于可扩展的云架构。 Activiti将提供宽松的Apache许可2.0,以便这个项目可以广泛被使用,同时促进Activiti BPM引擎和BPMN 2.0的匹配,该项目现正由OMG通过...

    Activiti7.0源码官方完整版

    5. **流程实例的动态修改**:在 Activiti7.0 中,你可以动态修改运行中的流程实例,无需停止或重启服务,提高了灵活性和适应性。 6. **增强的监控和日志记录**:新的版本提供了更强大的监控工具和日志记录,帮助...

    activiti modeler汉化文件

    Activiti Modeler是一款流行的工作流建模工具,用于设计和管理Activiti流程定义。它基于BPMN(Business Process Modeling Notation)标准,提供了一种图形化的用户界面,使得业务人员和技术人员能够协同设计和理解...

    activiti-选择代理人候选人候选组.rar

    这个压缩包提供的解决方案是扩展了Activiti的流程设计器,将人员和角色组的输入方式改为选择方式,这意味着设计者可以通过下拉菜单或类似的交互方式来选取参与者,极大地提高了设计效率和准确性。 实现这一功能的...

    Activiti5.4 用户指南-中文版

    总的来说,Activiti 5.4 用户指南-中文版是了解和掌握 Activiti 的重要资源,它将引导用户逐步了解如何使用 Activiti 设计、部署和管理业务流程,从而提升企业的业务自动化水平和运营效率。通过深入学习本指南,你...

    activiti6.0 用户指南中文版

    activiti6.0 用户指南中文版activiti6.0 用户指南中文版activiti6.0 用户指南中文版

Global site tag (gtag.js) - Google Analytics