Snaker是一个基于Java的开源工作流引擎
,适用于企业应用中常见的业务流程。本着轻量、简单、灵巧理念设计,定位于简单集成,多环境支持。
流程引擎源码(oscgit):
http://git.oschina.net/yuqs/snakerflow
演示应用源码(oscgit):
http://git.oschina.net/yuqs/snaker-web
插件源码(oscgit):
http://git.oschina.net/yuqs/snaker-designer
如果了解activiti、jbpm,那么理解、使用snaker可以平滑过渡。API的使用方式和流程模型的定义基本相同。
如果没有接触过工作流,对于snaker 简洁的流程模型的定义格式,以及丰富的示例,也能很快入手。
snaker-core 源码工程test
主要提供流程引擎的组件和功能点的测试、API使用用例。
提供全部支持的流程模型测试用例,可以在 snakerflow\snaker-core\src\test\resources\test 路径下找到
snaker-spring 源码工程test
spring 集成示例
snaker-web 源码工程
完整的工作流程应用实例。业务使用、集成snaker,完全可以参考该工程配置。
技术栈:SpringMVC + shiro + Hibernate + snaker + raphael.js + mysql
snaker提供Eclipse 插件、web 流程设计器
。
web 流程设计器提供在线设计、编辑和保存流程模型。参考snaker-web,设计完的流程模型可以直接部署到应用中使用。
基于 raphael.js 开发
的web设计器和流程可视化显示。
拖拽工具栏,根据业务需求编制即可。需要注意的是,transaction 组件使用,先点击源节点,再点击目的节点,即可完成连接。
具体的节点属性配置,在弹出的表单配置即可。
也可以在生成的xml 流程模型文件中修改属性,重新上传即可实现刷新、覆盖。
应用开发主要使用流程引擎接口API,服务对象只用于流程引擎的调用,不应该直接调用低层的API。
// api集成方式,构造SnakerEngine对象
SnakerEngine engine = new Configuration().buildSnakerEngine();
// spring集成方法,通过配置注入的方式构造SnakerEngine对象
<bean class="org.snaker.engine.spring.SpringSnakerEngine">
<property name="processService" ref="processService"/>
<property name="orderService" ref="orderService"/>
<property name="taskService" ref="taskService"/>
<property name="queryService" ref="queryService"/>
<property name="managerService" ref="managerService"/>
</bean>
// 根据文件输入流,部署流程定义。
engine.process().deploy(StreamHelper.getStreamFromClasspath("test/task/simple/process.snaker"))
// 根据流程定义ID,操作人ID,参数列表启动流程实例
Order order = engine.startInstanceById(processId, operator, args);
// 根据流程名称启动流程实例
Order order = engine.startInstanceByName(name, version, operator);
// 历史任务查询
engine.query().getHistoryTasks(new Page<HistoryTask>(), new QueryFilter().setOperator("foo"));
// 查询当前责任人的任务
engine.query().getActiveTasks(new Page<Task>(), new QueryFilter().setOperator("foo"));
// 根据当前用户查询待办任务列表
engine.query().getWorkItems(page, new QueryFilter().setOperator("foo"));
// 根据流程定义ID,系统调用、执行任务
List<Task> tasks = engine.query().getActiveTasks(new QueryFilter().setOrderId(order.getId()));
for(Task task : tasks) {
engine.executeTask(task.getId(), "foo", args);
}
// 根据任务提交请求,执行任务。args 可以认同为提交的表单内容。
engine.executeTask(task.getId(), "foo", args);
web工程 内置提供了‘请假流程测试’、‘借款申请流程’,可以直接使用。
IDEA 添加jetty 运行配置,启动即可。
访问 http://localhost:8080/snaker-web/login ,使用admin 用户登录即可使用所有的功能。
业务流程如果简单,可以直接把业务数据存在流程实例的变量中。如果复杂业务,可以在业务表中增加order_id、task_id 来支持业务流引擎的集成。业务表属于应用层,流程表属于服务层,高层依赖底层,底层不能耦合高层
。表设计千万注意。
‘借款申请流程’发起申请,可以参考,作为样本代码使用。
整体的设计思路和activiti、jbpm 相似。snaker 基于轻量的方向,只有流程引擎驱动相关的表,只提供经典的工作流特性。
工作流管理系统(Workflow Management System, WfMS)是一个软件系统,它
完成工作量的定义和管理
,并按照在系统中预先定义好的工作流逻辑进行工作流实例的执行
。工作流管理系统不是企业的业务系统,而是为企业的业务系统的运行提供了一个软件的支撑环境。
###流程引擎
public List<Task> executeTask(String taskId, String operator, Map<String, Object> args) {
// 1.完成当前任务,并且构造执行对象
Execution execution = execute(taskId, operator, args);
ProcessModel model = execution.getProcess().getModel();
if(model != null) {
// 反查当前任务,对应在流程定义中的节点
NodeModel nodeModel = model.getNode(execution.getTask().getTaskName());
// 2.该任务对应的节点模型执行(根据路由策略,递归调用,驱动调用的核心设计!)
nodeModel.execute(execution);
}
return execution.getTasks();
}
snker 的流程模型是以字节码的形式存在数据库中的。
如果是根据processId 查询,那么对应的版本就是固定的。
如果是根据processName 查询,那么应该查询最新的版本的流程定义。
// 根据name获取process对象
public Process getProcessByVersion(String name, Integer version) {
if(version == null) {
// select max(version) from wf_process where name = ?
version = access().getLatestProcessVersion(name);
}
if(version == null) {
version = 0;
}
// select * from wf_process where 1=1 and name in(?) and version = ? order by name asc
List<Process> processs = access().getProcesss(null, new QueryFilter().setName(name).setVersion(version));
return processs.get(0);
}