UseScopeBaseNewModel.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360
  1. <?php
  2. namespace App\Model;
  3. use App\Service\RangeService;
  4. use Illuminate\Database\Eloquent\Model;
  5. use Illuminate\Support\Facades\DB;
  6. class UseScopeBaseNewModel extends Model
  7. {
  8. const range_function = '';
  9. const is_check_function = '';
  10. //部门和顶级部门(公司)过滤
  11. public function scopeClear1($query, $user, $search)
  12. {
  13. //是否所有部门
  14. $is_all_depart = $user['is_all_depart'] ?? 0;
  15. //权限范围内的部门
  16. $depart_range = $user['depart_range'] ?? [];
  17. //我可见的
  18. $is_see = ! empty($search['is_see']);
  19. //全部 待审 待我审核
  20. $is_check = ! empty($search['is_check']);
  21. //个人 部门 所有
  22. $auth_type = $this->getQx($search,$user);
  23. // 获取模型的实例
  24. $model = $query->getModel();
  25. // 获取模型类名
  26. $className = get_class($model);
  27. //可见范围方法
  28. $range_function = "";
  29. if (defined($className . '::range_function')) $range_function = $className::range_function;
  30. $function_range_bool = $this->hasMethod(new RangeService(),$range_function);
  31. //全部 待审 已审
  32. $is_check_function = "";
  33. if (defined($className . '::is_check_function')) $is_check_function = $className::is_check_function;
  34. $is_check_function_bool = $this->hasMethod(new RangeService(),$is_check_function);
  35. //外部传入的
  36. $search_depart_id = $search['top_depart_id'] ?? 0;
  37. //自身的
  38. $my_top_depart_id = $user['depart_top'][0] ?? [];
  39. $my_top_depart_id = $my_top_depart_id['depart_id'] ?? 0;
  40. if(empty($search_depart_id)){
  41. $top_depart_id = $my_top_depart_id;
  42. }else{
  43. if($is_all_depart){
  44. //顶级公司
  45. $top_depart_id = $search_depart_id;
  46. }else{
  47. $top_depart_id = $my_top_depart_id;
  48. }
  49. }
  50. $id = [];
  51. //可见范围 以及单据里面填写人员 (状态类 是全部时检索)
  52. if($function_range_bool) $id = RangeService::$range_function($user,$search);
  53. $tmpTable = null;
  54. if(! empty($id)){
  55. $tmpTable = RangeService::createTemporaryIdTable($id);
  56. }
  57. //全部0 待审1 已审2 (状态类 是全部时检索)
  58. $check_search = "";
  59. if($is_check_function_bool && $is_check) $check_search = RangeService::$is_check_function($user,$search);
  60. if($is_see){
  61. //我可见的
  62. $query->whereIn('id', $id);
  63. }elseif($is_all_depart){
  64. //所有权限
  65. $this->allDepart($query, $is_check, $auth_type, $user, $depart_range, $search_depart_id, $top_depart_id, $id, $check_search);
  66. }else{
  67. //非所有权限
  68. $this->notAllDepart($query, $is_check, $auth_type, $user, $depart_range, $top_depart_id, $id, $check_search);
  69. }
  70. if(! empty($search['get_my_top_depart_data'])) $query->where('top_depart_id', $my_top_depart_id);
  71. }
  72. //最高权限
  73. private function allDepart1(&$query, $is_check, $auth_type, $user, $depart_range, $search_depart_id, $top_depart_id, $id, $check_search){
  74. if(empty($search_depart_id)){
  75. if ($is_check){
  76. if(! $auth_type){
  77. //全部
  78. $query->when(! empty($check_search), function ($query) use ($check_search) {
  79. return $query->whereRaw($check_search);
  80. });
  81. }elseif($auth_type == 1){
  82. //我创建的 且加上可见
  83. $query->where('crt_id',$user['id'])
  84. ->when(! empty($check_search), function ($query) use ($check_search) {
  85. return $query->whereRaw($check_search);
  86. })
  87. ->when(! empty($id), function ($query) use ($id) {
  88. return $query->orWhereIn('id', $id);
  89. });
  90. }elseif ($auth_type == 2 || $auth_type == 3){
  91. //自己权限范围内的部门 或 所有
  92. $query->whereIn('depart_id', $depart_range)
  93. ->when(! empty($check_search), function ($query) use ($check_search) {
  94. return $query->whereRaw($check_search);
  95. });
  96. }
  97. }else{
  98. if($auth_type == 1) { //我创建的 且加上可见
  99. $query->where('crt_id',$user['id'])
  100. ->when(! empty($id), function ($query) use ($id) {
  101. return $query->orWhereIn('id', $id);
  102. });
  103. }elseif ($auth_type == 2 || $auth_type == 3){
  104. //自己权限范围内的部门 或 所有
  105. $query->whereIn('depart_id', $depart_range);
  106. }
  107. }
  108. }else{
  109. if ($is_check){
  110. if(! $auth_type){
  111. //查看指定公司
  112. $query->where('top_depart_id', $top_depart_id)
  113. ->when(! empty($check_search), function ($query) use ($check_search) {
  114. return $query->whereRaw($check_search);
  115. });
  116. }elseif($auth_type == 1) { //指定公司下 且 我创建的 且加上可见
  117. $query->where('top_depart_id', $top_depart_id)
  118. ->where('crt_id',$user['id'])
  119. ->when(! empty($check_search), function ($query) use ($check_search) {
  120. return $query->whereRaw($check_search);
  121. })
  122. ->when(! empty($id), function ($query) use ($id) {
  123. return $query->orWhereIn('id', $id);
  124. });
  125. }elseif ($auth_type == 2 || $auth_type == 3){
  126. // (指定公司下的 且 自己权限范围内的部门 或 所有) 且加上可见
  127. $query->where('top_depart_id', $top_depart_id)
  128. ->whereIn('depart_id', $depart_range)
  129. ->when(! empty($check_search), function ($query) use ($check_search) {
  130. return $query->whereRaw($check_search);
  131. })
  132. ->when(! empty($id), function ($query) use ($id) {
  133. return $query->orWhereIn('id', $id);
  134. });
  135. }
  136. }else{
  137. if(! $auth_type){
  138. //查看指定公司
  139. $query->where('top_depart_id', $top_depart_id);
  140. }elseif($auth_type == 1) { //指定公司下 且 我创建的 且加上可见
  141. $query->where('top_depart_id', $top_depart_id)
  142. ->where('crt_id',$user['id'])
  143. ->when(! empty($id), function ($query) use ($id) {
  144. return $query->orWhereIn('id', $id);
  145. });
  146. }elseif ($auth_type == 2 || $auth_type == 3){
  147. // (指定公司下的 且 自己权限范围内的部门 或 所有) 且加上可见
  148. $query->where('top_depart_id', $top_depart_id)
  149. ->whereIn('depart_id', $depart_range)
  150. ->when(! empty($id), function ($query) use ($id) {
  151. return $query->orWhereIn('id', $id);
  152. });
  153. }
  154. }
  155. }
  156. }
  157. //非所有权限
  158. private function notAllDepart1(&$query, $is_check, $auth_type, $user, $depart_range, $top_depart_id, $id, $check_search){
  159. if ($is_check){
  160. if(! $auth_type || $auth_type == 3){
  161. //指定公司下全部 且加上可见
  162. $query->where('top_depart_id', $top_depart_id)
  163. ->when(! empty($check_search), function ($query) use ($check_search) {
  164. return $query->whereRaw($check_search);
  165. })
  166. ->when(! empty($id), function ($query) use ($id) {
  167. return $query->orWhereIn('id', $id);
  168. });
  169. }else if($auth_type == 1) {
  170. //指定公司下 且 我创建的 且加上可见
  171. $query->where('top_depart_id', $top_depart_id)
  172. ->where('crt_id',$user['id'])
  173. ->when(! empty($check_search), function ($query) use ($check_search) {
  174. return $query->whereRaw($check_search);
  175. })
  176. ->when(! empty($id), function ($query) use ($id) {
  177. return $query->orWhereIn('id', $id);
  178. });
  179. }elseif ($auth_type == 2) {
  180. //指定公司下 且 自己权限范围内的部门 且加上可见
  181. $query->where('top_depart_id', $top_depart_id)
  182. ->whereIn('depart_id', $depart_range)
  183. ->when(! empty($check_search), function ($query) use ($check_search) {
  184. return $query->whereRaw($check_search);
  185. })
  186. ->when(! empty($id), function ($query) use ($id) {
  187. return $query->orWhereIn('id', $id);
  188. });
  189. }
  190. }else{
  191. if(! $auth_type || $auth_type == 3){
  192. //指定公司下全部|所有 且加上可见
  193. $query->where('top_depart_id', $top_depart_id)
  194. ->when(! empty($id), function ($query) use ($id) {
  195. return $query->orWhereIn('id', $id);
  196. });
  197. }elseif($auth_type == 1) {
  198. //指定公司下 且 我创建的 且加上可见
  199. $query->where('top_depart_id', $top_depart_id)
  200. ->where('crt_id',$user['id'])
  201. ->when(! empty($id), function ($query) use ($id) {
  202. return $query->orWhereIn('id', $id);
  203. });
  204. }elseif ($auth_type == 2) {
  205. //指定公司下 且 自己权限范围内的部门 且加上可见
  206. $query->where('top_depart_id', $top_depart_id)
  207. ->whereIn('depart_id', $depart_range)
  208. ->when(! empty($id), function ($query) use ($id) {
  209. return $query->orWhereIn('id', $id);
  210. });
  211. }
  212. }
  213. }
  214. public function scopeClear($query, $user, $search)
  215. {
  216. $is_all_depart = $user['is_all_depart'] ?? 0;
  217. $depart_range = $user['depart_range'] ?? [];
  218. $is_see = ! empty($search['is_see']);
  219. $is_check = ! empty($search['is_check']);
  220. $auth_type = $this->getQx($search, $user);
  221. $model = $query->getModel();
  222. $className = get_class($model);
  223. $range_function = "";
  224. if (defined($className . '::range_function')) $range_function = $className::range_function;
  225. $function_range_bool = $this->hasMethod(new RangeService(), $range_function);
  226. $is_check_function = "";
  227. if (defined($className . '::is_check_function')) $is_check_function = $className::is_check_function;
  228. $is_check_function_bool = $this->hasMethod(new RangeService(), $is_check_function);
  229. $search_depart_id = $search['top_depart_id'] ?? 0;
  230. $my_top_depart_id = $user['depart_top'][0]['depart_id'] ?? 0;
  231. $top_depart_id = ($is_all_depart && !empty($search_depart_id)) ? $search_depart_id : $my_top_depart_id;
  232. // --- 核心修改:处理临时表 ---
  233. $id = [];
  234. $tmpTable = null;
  235. if ($function_range_bool) {
  236. $id = RangeService::$range_function($user, $search);
  237. if (!empty($id)) {
  238. // 调用你已经实现的创建临时表方法
  239. $tmpTable = RangeService::createTemporaryIdTable($id, $user['id']);
  240. }
  241. }
  242. $check_search = "";
  243. if ($is_check_function_bool && $is_check) $check_search = RangeService::$is_check_function($user, $search);
  244. if ($is_see) {
  245. // 如果是“我可见的”,直接关联临时表或 whereIn
  246. if ($tmpTable) {
  247. $query->whereExists(function ($q) use ($tmpTable) {
  248. $q->select(DB::raw(1))->from($tmpTable)->whereRaw("{$tmpTable}.range_allowed_id = id");
  249. });
  250. } else {
  251. $query->whereIn('id', $id);
  252. }
  253. } elseif ($is_all_depart) {
  254. // 传递 $tmpTable 代替 $id
  255. $this->allDepart($query, $is_check, $auth_type, $user, $depart_range, $search_depart_id, $top_depart_id, $tmpTable, $check_search);
  256. } else {
  257. $this->notAllDepart($query, $is_check, $auth_type, $user, $depart_range, $top_depart_id, $tmpTable, $check_search);
  258. }
  259. if (!empty($search['get_my_top_depart_data'])) $query->where('top_depart_id', $my_top_depart_id);
  260. }
  261. private function allDepart(&$query, $is_check, $auth_type, $user, $depart_range, $search_depart_id, $top_depart_id, $tmpTable, $check_search) {
  262. $query->where(function ($q) use ($search_depart_id, $top_depart_id, $is_check, $auth_type, $user, $depart_range, $check_search, $tmpTable) {
  263. // 1. 设置顶级部门基础过滤
  264. if (!empty($search_depart_id)) {
  265. $q->where('top_depart_id', $top_depart_id);
  266. }
  267. // 2. 权限与可见范围(OR 关系)
  268. $q->where(function ($sub) use ($auth_type, $user, $depart_range, $tmpTable) {
  269. if ($auth_type == 1) {
  270. $sub->where('crt_id', $user['id']);
  271. } elseif ($auth_type == 2 || $auth_type == 3) {
  272. $sub->whereIn('depart_id', $depart_range);
  273. }
  274. // 关键:合并可见范围临时表
  275. if ($tmpTable) {
  276. $sub->orWhereExists(function ($exists) use ($tmpTable) {
  277. $exists->select(DB::raw(1))
  278. ->from($tmpTable)
  279. ->whereRaw("{$tmpTable}.range_allowed_id = id");
  280. });
  281. }
  282. });
  283. // 3. 审核过滤
  284. if ($is_check && !empty($check_search)) {
  285. $q->whereRaw($check_search);
  286. }
  287. });
  288. }
  289. private function notAllDepart(&$query, $is_check, $auth_type, $user, $depart_range, $top_depart_id, $tmpTable, $check_search) {
  290. $query->where(function ($q) use ($top_depart_id, $auth_type, $user, $depart_range, $is_check, $check_search, $tmpTable) {
  291. $q->where('top_depart_id', $top_depart_id);
  292. $q->where(function ($sub) use ($auth_type, $user, $depart_range, $tmpTable) {
  293. if ($auth_type == 1) {
  294. $sub->where('crt_id', $user['id']);
  295. } elseif ($auth_type == 2) {
  296. $sub->whereIn('depart_id', $depart_range);
  297. }
  298. // 关键:合并可见范围临时表
  299. if ($tmpTable) {
  300. $sub->orWhereExists(function ($exists) use ($tmpTable) {
  301. $exists->select(DB::raw(1))
  302. ->from($tmpTable)
  303. ->whereRaw("{$tmpTable}.range_allowed_id = id");
  304. });
  305. }
  306. });
  307. if ($is_check && !empty($check_search)) {
  308. $q->whereRaw($check_search);
  309. }
  310. });
  311. }
  312. public function getQx($data, $user)
  313. {
  314. if (empty($data['menu_id'])) return 0;
  315. // 假设 Employee 常量在此可用,若不可用请自行调整
  316. if ($user['id'] == 1) return 0; // 这里的1代表超级管理员ID
  317. return $user['role_authority'][$data['menu_id']] ?? 0;
  318. }
  319. function hasMethod($class, $methodName)
  320. {
  321. if (empty($methodName)) return false;
  322. return method_exists($class, $methodName);
  323. }
  324. }