一个自带流程设计器的工作流引擎
终于迎来了这个激动人心的版本1.3.1,不需要在为引入设计器而烦恼了。按照以下四点,可以快速集成。 另外一直被吐槽的流程图不够清晰,也在此版本得到解决。
详细更新说明:更新日志
1. 引入依赖
<dependency> <groupId>org.dromaragroupId> <artifactId>warm-flow-plugin-ui-sb-webartifactId> <version>1.3.1version> dependency>
2. 后端放行部分路径
1、这个路径需要放行,否则无法访问,
/warm-flow-ui/**
2、以下是spring-security放行配置示例
@Bean protected SecurityFilterChain filterChain(HttpSecurity httpSecurity) throws Exception { return httpSecurity ....... // 注解标记允许匿名访问的url .authorizeHttpRequests((requests) -> { // 后端请求,静态资源,可匿名访问 requests.antMatchers("/warm-flow-ui/**").permitAll() // 除上面外的所有请求全部需要鉴权认证 .anyRequest().authenticated(); }) ...... .build(); }
3. 前端加载设计器
1、设计器页面入口是访问后端地址(前后端不分离):
ip:port/warm-flow-ui/index?id=${definitionId}?disabled=${disabled}
4. 设计器办理人权限数据接入
给任务节点设置哪些权限的人可以办理,实现接口提供给设计器
4.1 办理人权限选择弹框页面
4.2 实现接口获取以上页面办理人权限数据
4.2.1 HandlerSelectService接口
/** * 流程设计器-获取办理人权限设置列表接口 * * @author warm */ public interface HandlerSelectService { /** * 获取办理人权限设置列表tabs页签, 如:用户、角色和部门等 * @return tabs页签 */ List<String> getHandlerType(); /** * 获取办理人权限设置列表结果,如:用户列表、角色列表、部门列表等 * @param query 查询参数 * @return 结果 */ List<HandlerSelectVo> getHandlerSelect(HandlerQuery query); }
5、项目介绍
Warm-Flow国产工作流引擎🎉,其特点简洁轻量,五脏俱全,可扩展,是一个可通过jar引入设计器的工作流。
-
简洁易用:只有7张表,代码量少,可快速上手和集成
-
审批功能:支持通过、退回、任意跳转、转办、终止、会签、票签、委派和加减签、互斥和并行网关
-
监听器与流程变量:支持四种监听器,可应对不同场景,灵活可扩展,参数传递,动态权限
-
流程图:流程引擎自带流程图,可在不集成流程设计器情况下使用
-
流程设计器:可通过jar包形式快速集成到项目,减少繁琐代码搬运和适配
-
条件表达式:内置常见的和spel条件表达式,并且支持自定义扩展
-
办理人变量表达式:内置${handler}和spel格式的表达式,可满足不同场景,灵活可扩展
-
orm框架扩展:目前支持MyBatis、Mybatis-Plus、Mybatis-Flex和Jpa,后续会由社区提供其他支持,扩展方便
-
数据库支持:目前支持MySQL 、Oracle 和PostgreSQL,后续会继续支持其他数据库或者国产数据库
-
多租户与软删除:流程引擎自身维护多租户和软删除实现,也可使用对应orm框架的实现方式
-
同时支持spring和solon
-
兼容java8和java17,理论11也可以
-
官方提供基于ruoyi-vue封装实战项目,很实用
6、演示地址
-
admin/admin123
演示地址:http://www.hhzai.top