# compileflow **Repository Path**: jsee/compileflow ## Basic Information - **Project Name**: compileflow - **Description**: compileflow是一个非常轻量、高性能、可集成、可扩展的流程引擎 - **Primary Language**: Java - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: https://www.oschina.net/p/compileflow - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 51 - **Created**: 2021-11-11 - **Last Updated**: 2021-11-11 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # 1. `compileflow`是什么 `compileflow`是一个非常轻量、高性能、可集成、可扩展的流程引擎。 `compileflow Process`引擎是淘宝工作流`TBBPM`引擎之一,是专注于纯内存执行,无状态的流程引擎,通过将流程文件转换生成`java`代码编译执行,简洁高效。 `compileflow`能让开发人员通过流程编辑器设计自己的业务流程,将复杂的业务逻辑可视化,为业务设计人员与开发工程师架起了一座桥梁。 # 2. Design Intention 1. 希望为业务开发提供端至端,从设计至实现的业务流程解决方案。 2. 提供多种流程引擎,实现从战略至商业能力,商业能力至业务流程,业务流程至系统,并最终实现业务的可视化全局架构。 3. 设计高效的执行引擎,实现对服务的快速组合或扩展,提升`idea`至`value`的研发响应与交互速度。 # 3. Features 1. 高性能:通过将流程文件转换生成`java`代码编译执行,简洁高效。 2. 丰富的应用场景:在阿里巴巴中台解决方案中广泛使用,支撑了导购、交易、履约、资金等多个业务场景。 3. 可集成:轻量、简洁的设计使得可以极其方便地集成到各个解决方案和业务场景中。 4. 完善的插件支持:流程设计目前有`IntelliJ IDEA`、`Eclipse`插件支持,可以在流程设计中实时动态生成`java`代码并预览,所见即所得。 5. 支持流程设计图导出`svg`文件和单元测试代码。 # 4. Quick Start ## Step1: 下载安装`IntelliJ IDEA`插件(可选) 插件下载地址:https://github.com/alibaba/compileflow-idea-designer *安装说明:请使用`IntelliJ IDEA`本地安装方法进行安装,重新启动`IntelliJ IDEA`就会生效。* ## Step2: 引入`POM`文件 ```xml com.alibaba.compileflow compileflow 1.0.0 ``` 注意: `compileflow`仅支持`JDK 1.8`及以上版本。 ## Step3: 流程设计 下面以ktv demo为例,通过demo的演示和实践了解节点及属性的配置和`API`的使用。 demo描述:N个人去ktv唱歌,每人唱首歌,ktv消费原价为30元/人,如果总价超过300打九折,小于300按原价付款。 ### S3.1 创建`bpm`文件,如下图: ![ktv_demo_s1](./doc/image/ktv_demo_s1.png) *注:`bpm`文件路径要和`code`保持一致,在文件加载模式下流程引擎执行时会根据`code`找到文件。* ### S3.2 通过插件进行流程设计或者直接编写流程`xml`文件。 ### S3.3 调用流程 编写如下单元测试: ```java @Test public void testProcessEngine() { final String code = "bpm.ktv.ktvExample"; final Map context = new HashMap<>(); final List pList = new ArrayList<>(); pList.add("wuxiang"); pList.add("xuan"); pList.add("yusu"); context.put("pList", pList); final ProcessEngine processEngine = ProcessEngineFactory.getProcessEngine(); final TbbpmModel tbbpmModel = (TbbpmModel)processEngine.load(code); final OutputStream outputStream = TbbpmModelConverter.getInstance().convertToStream(tbbpmModel); System.out.println(outputStream); System.out.println(processEngine.getTestCode(code)); processEngine.preCompile(code); System.out.println(processEngine.start(code, context)); } ``` **_`compileflow`原生只支持淘宝`BPM`规范,为兼容`BPMN 2.0`规范,做了一定适配,但仅支持部分`BPMN 2.0`元素,如需其他元素支持,可在原来基础上扩展。_** # 5. 更多资料 * [DEMO快速开始](https://github.com/alibaba/compileflow/wiki/%E5%BF%AB%E9%80%9F%E5%BC%80%E5%A7%8BDEMO) * [原始淘宝BPM规范详细说明](https://github.com/alibaba/compileflow/wiki/%E5%8D%8F%E8%AE%AE%E8%AF%A6%E8%A7%A3) # 6. 欢迎加入`compileflow`开发群 1. 请钉钉联系 @余苏 @徐工 @梵度 @哲良 @无相