approval_permissions_update.sql 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. /*
  2. 审批流程权限增量更新SQL(基于现有sys_role_menu表)
  3. Date: 2025-09-06
  4. Author: simon lin
  5. */
  6. SET NAMES utf8mb4;
  7. SET FOREIGN_KEY_CHECKS = 0;
  8. -- 1. 首先添加审批流程相关菜单(如果不存在)
  9. INSERT IGNORE INTO `sys_menu` VALUES (2120, '审批流程', 0, 4, 'approval', NULL, NULL, '', 1, 0, 'M', '0', '0', NULL, 'validCode', 'admin', NOW(), '', NULL, '审批流程管理目录');
  10. -- 添加二级菜单
  11. INSERT IGNORE INTO `sys_menu` VALUES (2121, '我的待办', 2120, 1, 'pending', 'system/approval/pending/index', NULL, '', 1, 0, 'C', '0', '0', 'system:approval:pending:list', 'time-range', 'admin', NOW(), '', NULL, '我的待办任务菜单');
  12. INSERT IGNORE INTO `sys_menu` VALUES (2122, '我的已办', 2120, 2, 'completed', 'system/approval/completed/index', NULL, '', 1, 0, 'C', '0', '0', 'system:approval:completed:list', 'checkbox', 'admin', NOW(), '', NULL, '我的已办任务菜单');
  13. INSERT IGNORE INTO `sys_menu` VALUES (2123, '我的申请', 2120, 3, 'submitted', 'system/approval/submitted/index', NULL, '', 1, 0, 'C', '0', '0', 'system:approval:submitted:list', 'documentation', 'admin', NOW(), '', NULL, '我的申请列表菜单');
  14. INSERT IGNORE INTO `sys_menu` VALUES (2124, '发起申请', 2120, 4, 'submit', 'system/approval/submit/index', NULL, '', 1, 0, 'C', '0', '0', 'system:approval:submit', 'edit', 'admin', NOW(), '', NULL, '发起申请菜单');
  15. INSERT IGNORE INTO `sys_menu` VALUES (2125, '流程管理', 2120, 5, 'workflow', 'system/approval/workflow/index', NULL, '', 1, 0, 'C', '0', '0', 'system:approval:workflow:list', 'tree-table', 'admin', NOW(), '', NULL, '流程管理菜单');
  16. -- 添加审批功能权限按钮
  17. INSERT IGNORE INTO `sys_menu` VALUES (2130, '查看待办任务', 2121, 1, '#', '', NULL, '', 1, 0, 'F', '0', '0', 'system:approval:query', '#', 'admin', NOW(), '', NULL, '');
  18. INSERT IGNORE INTO `sys_menu` VALUES (2131, '审批任务', 2121, 2, '#', '', NULL, '', 1, 0, 'F', '0', '0', 'system:approval:approve', '#', 'admin', NOW(), '', NULL, '');
  19. INSERT IGNORE INTO `sys_menu` VALUES (2132, '驳回任务', 2121, 3, '#', '', NULL, '', 1, 0, 'F', '0', '0', 'system:approval:reject', '#', 'admin', NOW(), '', NULL, '');
  20. INSERT IGNORE INTO `sys_menu` VALUES (2133, '启动流程', 2124, 1, '#', '', NULL, '', 1, 0, 'F', '0', '0', 'system:approval:start', '#', 'admin', NOW(), '', NULL, '');
  21. INSERT IGNORE INTO `sys_menu` VALUES (2134, '取消流程', 2123, 1, '#', '', NULL, '', 1, 0, 'F', '0', '0', 'system:approval:cancel', '#', 'admin', NOW(), '', NULL, '');
  22. -- 添加流程管理功能权限按钮(管理员专用)
  23. INSERT IGNORE INTO `sys_menu` VALUES (2135, '流程定义查询', 2125, 1, '#', '', NULL, '', 1, 0, 'F', '0', '0', 'system:approval:workflow:query', '#', 'admin', NOW(), '', NULL, '');
  24. INSERT IGNORE INTO `sys_menu` VALUES (2136, '流程定义新增', 2125, 2, '#', '', NULL, '', 1, 0, 'F', '0', '0', 'system:approval:workflow:add', '#', 'admin', NOW(), '', NULL, '');
  25. INSERT IGNORE INTO `sys_menu` VALUES (2137, '流程定义修改', 2125, 3, '#', '', NULL, '', 1, 0, 'F', '0', '0', 'system:approval:workflow:edit', '#', 'admin', NOW(), '', NULL, '');
  26. INSERT IGNORE INTO `sys_menu` VALUES (2138, '流程定义删除', 2125, 4, '#', '', NULL, '', 1, 0, 'F', '0', '0', 'system:approval:workflow:remove', '#', 'admin', NOW(), '', NULL, '');
  27. -- 2. 删除可能存在的审批流程相关权限(防止重复)
  28. DELETE FROM `sys_role_menu` WHERE menu_id BETWEEN 2120 AND 2138;
  29. -- 3. 为各角色分配审批流程权限
  30. -- 超级管理员(role_id=1):拥有所有权限
  31. INSERT INTO `sys_role_menu` (role_id, menu_id) VALUES
  32. (1, 2120), (1, 2121), (1, 2122), (1, 2123), (1, 2124), (1, 2125),
  33. (1, 2130), (1, 2131), (1, 2132), (1, 2133), (1, 2134),
  34. (1, 2135), (1, 2136), (1, 2137), (1, 2138);
  35. -- 普通角色(role_id=2):基本查看和申请权限
  36. INSERT INTO `sys_role_menu` (role_id, menu_id) VALUES
  37. (2, 2120), -- 审批流程目录
  38. (2, 2121), -- 我的待办
  39. (2, 2122), -- 我的已办
  40. (2, 2123), -- 我的申请
  41. (2, 2124), -- 发起申请
  42. (2, 2130), -- 查看待办任务
  43. (2, 2133), -- 启动流程
  44. (2, 2134); -- 取消流程
  45. -- 站长(role_id=100):拥有业务功能权限,不能管理流程定义
  46. INSERT INTO `sys_role_menu` (role_id, menu_id) VALUES
  47. (100, 2120), -- 审批流程目录
  48. (100, 2121), -- 我的待办
  49. (100, 2122), -- 我的已办
  50. (100, 2123), -- 我的申请
  51. (100, 2124), -- 发起申请
  52. (100, 2130), -- 查看待办任务
  53. (100, 2131), -- 审批任务
  54. (100, 2132), -- 驳回任务
  55. (100, 2133), -- 启动流程
  56. (100, 2134); -- 取消流程
  57. -- 安检员(role_id=101):基本业务权限,重点是发起申请
  58. INSERT INTO `sys_role_menu` (role_id, menu_id) VALUES
  59. (101, 2120), -- 审批流程目录
  60. (101, 2121), -- 我的待办
  61. (101, 2122), -- 我的已办
  62. (101, 2123), -- 我的申请
  63. (101, 2124), -- 发起申请
  64. (101, 2130), -- 查看待办任务
  65. (101, 2131), -- 审批任务(个人级别确认)
  66. (101, 2133), -- 启动流程
  67. (101, 2134); -- 取消流程
  68. -- 班组长(role_id=102):拥有完整业务审批权限
  69. INSERT INTO `sys_role_menu` (role_id, menu_id) VALUES
  70. (102, 2120), -- 审批流程目录
  71. (102, 2121), -- 我的待办
  72. (102, 2122), -- 我的已办
  73. (102, 2123), -- 我的申请
  74. (102, 2124), -- 发起申请
  75. (102, 2130), -- 查看待办任务
  76. (102, 2131), -- 审批任务
  77. (102, 2132), -- 驳回任务
  78. (102, 2133), -- 启动流程
  79. (102, 2134); -- 取消流程
  80. -- 科长(role_id=103):拥有完整业务审批权限
  81. INSERT INTO `sys_role_menu` (role_id, menu_id) VALUES
  82. (103, 2120), -- 审批流程目录
  83. (103, 2121), -- 我的待办
  84. (103, 2122), -- 我的已办
  85. (103, 2123), -- 我的申请
  86. (103, 2124), -- 发起申请
  87. (103, 2130), -- 查看待办任务
  88. (103, 2131), -- 审批任务
  89. (103, 2132), -- 驳回任务
  90. (103, 2133), -- 启动流程
  91. (103, 2134); -- 取消流程
  92. SET FOREIGN_KEY_CHECKS = 1;
  93. -- 验证权限分配结果
  94. SELECT
  95. '权限分配完成,以下是各角色的审批流程权限分配情况:' as info;
  96. SELECT
  97. r.role_name AS '角色名称',
  98. r.role_key AS '角色标识',
  99. COUNT(rm.menu_id) AS '审批权限数量'
  100. FROM sys_role r
  101. LEFT JOIN sys_role_menu rm ON r.role_id = rm.role_id AND rm.menu_id BETWEEN 2120 AND 2138
  102. WHERE r.role_id IN (1, 2, 100, 101, 102, 103)
  103. GROUP BY r.role_id, r.role_name, r.role_key
  104. ORDER BY r.role_id;
  105. -- 添加批量更新抄送已读状态权限
  106. INSERT IGNORE INTO `sys_menu` VALUES (2156, '批量更新抄送状态', 2121, 4, '#', '', NULL, '', 1, 0, 'F', '0', '0', 'system:approval:update', '#', 'admin', NOW(), '', NULL, '批量更新抄送已读状态权限');
  107. -- 为各角色分配这个权限
  108. -- 超级管理员
  109. INSERT IGNORE INTO `sys_role_menu` (role_id, menu_id) VALUES (1, 2156);
  110. -- 普通角色
  111. INSERT IGNORE INTO `sys_role_menu` (role_id, menu_id) VALUES (2, 2156);
  112. -- 站长
  113. INSERT IGNORE INTO `sys_role_menu` (role_id, menu_id) VALUES (100, 2156);
  114. -- 安检员
  115. INSERT IGNORE INTO `sys_role_menu` (role_id, menu_id) VALUES (101, 2156);
  116. -- 班组长
  117. INSERT IGNORE INTO `sys_role_menu` (role_id, menu_id) VALUES (102, 2156);
  118. -- 科长
  119. INSERT IGNORE INTO `sys_role_menu` (role_id, menu_id) VALUES (103, 2156);