项目作者: pvol

项目描述 :
基于laravel框架的PHP流程流转引擎-简化版
高级语言: PHP
项目地址: git://github.com/pvol/flow.git
创建时间: 2015-11-25T02:50:58Z
项目社区:https://github.com/pvol/flow

开源协议:MIT License

下载


pvol/flow

简介

基于laravel框架的PHP流程流转引擎。

功能与特点

  • 网状调度
    • 通过一个配置文件可以完成任意网状流程调度
    • 支持一个流程多条线执行
  • 多角色支持
    • 支持一个用户多角色执行
  • 多方式派单
    • 支持执行人主动接受、历史记录自动派单、派单员手动派单等多种执行人分发方式。
  • 多方向跳转
    • 支持流程create、agree、reject、next、back等多种操作
    • 支持自定义动作
  • 扩展
    • 支持添加hook,业务逻辑解耦处理

使用方法

1、配置数据库

  1. 如:src/demo/data/flows.sql

2、添加配置文件

  1. // 在config/flow/目录下添加如下配置文件:
  2. // 配置文件名:项目名称.php
  3. <?php
  4. return [
  5. 'hooks' => [
  6. 'after_step' => [ // 流程步骤执行完时执行
  7. 'App\Models\Zyd\Flow\Hook\PreOrder' // 需要是hook类的子类
  8. ],
  9. ],
  10. 'steps' => [
  11. 'step1'=>[
  12. 'title' => 'step1',
  13. 'action' => [ // 执行的动作,系统默认动作在Action中提供,也可以自定义
  14. 'App\Library\Flow\Action@create', // 新建
  15. 'App\Library\Flow\Action@storage', // 保存
  16. 'App\Library\Flow\Action@publish', // 发布
  17. ],
  18. 'roles' => [ // 什么角色可以执行
  19. 'channel'
  20. ],
  21. 'condition'=>[ // 流程执行到第几步可以执行
  22. ],
  23. 'createto'=>'step2',
  24. 'run_type'=>'', // 执行方式 现支持: accept(先接受后执行) history(历史执行人)
  25. ],
  26. 'step2'=>[
  27. 'title' => 'step2',
  28. 'action' => [ // 执行的动作,系统默认动作在Action中提供,也可以自定义
  29. 'App\Library\Flow\Action@accept', // 接受
  30. 'App\Library\Flow\Action@over', // 完成
  31. ],
  32. 'roles' => [ // 什么角色可以执行
  33. 'front_control'
  34. ],
  35. 'condition'=>[ // 流程执行到第几步可以执行
  36. 'step2'
  37. ],
  38. 'run_type'=>'accept', // 执行方式 现支持: accept(先接受后执行) history(历史执行人)
  39. ]
  40. ]
  41. ];

3、常用功能示例

  • 新建流程
  1. // 创建一个流程实例
  2. $flow = new Flow([
  3. 'project_name' => '', // 项目名称、配置文件名(不包含后缀)
  4. 'running_role' => '', // 以哪个角色执行
  5. ]);
  6. /*
  7. * step为需要执行的步骤
  8. * action_index为需要执行的步骤在配置文件中action的序列 0 1 2 ... ...
  9. * 如文档配置文件中的step1中的storage方法需要传参 $step='step1' $action_index=0
  10. */
  11. $flow->run($step, $action_index)
  • 流程流转
  1. // 创建一个流程实例
  2. $flow = new Flow([
  3. 'project_name' => '', // 项目名称、配置文件名(不包含后缀)
  4. 'running_role' => '', // 以哪个角色执行
  5. 'flow_id' => '', // 流程id
  6. ]);
  7. /*
  8. * step为需要执行的步骤
  9. * action_index为需要执行的步骤在配置文件中action的序列 0 1 2 ... ...
  10. * 如文档配置文件中的step1中的storage方法需要传参 $step='step1' $action_index=0
  11. */
  12. $flow->run($step, $action_index)