From 2873f1cd6ea6caac062740e05994a1f0a880ffde Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期二, 12 三月 2024 11:27:20 +0800
Subject: [PATCH] 一个用户只能是一个部门的管理员、创建随机试卷的时候人员只能选当前部门的人,试卷增加部门id

---
 src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java |   26 +++++++++++++++++---------
 1 files changed, 17 insertions(+), 9 deletions(-)

diff --git a/src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java b/src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java
index ded0bc5..103f7e8 100644
--- a/src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java
+++ b/src/main/java/com/mindskip/xzs/controller/admin/DepartmentController.java
@@ -10,28 +10,35 @@
 import com.mindskip.xzs.domain.vo.DepartmentVO;
 import com.mindskip.xzs.domain.vo.UpdateDeptAdminVO;
 import com.mindskip.xzs.domain.vo.UserVO;
+import com.mindskip.xzs.repository.DepartmentMapper;
 import com.mindskip.xzs.repository.UserDepartmentMapper;
 import com.mindskip.xzs.service.DepartmentService;
 import com.mindskip.xzs.service.UserService;
 import com.mindskip.xzs.utility.PageInfoHelper;
 import com.mindskip.xzs.viewmodel.admin.department.DepartmentResponseVM;
+import lombok.RequiredArgsConstructor;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
 
 import javax.validation.Valid;
 import java.util.ArrayList;
 import java.util.List;
+import java.util.Objects;
 import java.util.stream.Collectors;
 
 
 @RestController("AdminDepartmentController")
 @RequestMapping("/api/admin/department")
+@RequiredArgsConstructor
 public class DepartmentController extends BaseApiController {
 
 
     private final DepartmentService departmentService;
     private final UserService userService;
     private final UserDepartmentMapper userDepartmentMapper;
+    private final DepartmentMapper departmentMapper;
+
+
 
     /**
      * 鑾峰彇閮ㄩ棬涓嬬敤鎴峰垪琛�(涓嬫媺)
@@ -51,16 +58,9 @@
         return RestResponse.ok();
     }
 
-    @Autowired
-    public DepartmentController(DepartmentService departmentService, UserService userService, UserDepartmentMapper userDepartmentMapper) {
-        this.departmentService = departmentService;
-        this.userService = userService;
-        this.userDepartmentMapper = userDepartmentMapper;
-    }
-
     @RequestMapping(value = "/list", method = RequestMethod.POST)
     public RestResponse<List<Department>> getAll(){
-        List<Department> res = departmentService.gets();
+        List<Department> res = departmentService.gets(-1);
         return RestResponse.ok(res);
     }
 
@@ -93,7 +93,15 @@
 
     @RequestMapping(value = "/getDepartmentUser", method = RequestMethod.POST)
     public RestResponse<List<DepartmentVO>> getUserDepartment(){
-        List<DepartmentVO> res = departmentService.gets()
+        User currentUser = webContext.getCurrentUser();
+        Integer deptId = null;
+        if (Objects.nonNull(currentUser)) {
+            // 濡傛灉鏄儴闂ㄧ鐞嗗憳锛岄渶瑕佸仛鏁版嵁鏉冮檺
+            if ("1".equals(currentUser.getDeptAdmin())) {
+                deptId = departmentMapper.selectByAdminId(currentUser.getId());
+            }
+        }
+        List<DepartmentVO> res = departmentService.gets(deptId)
                 .stream().map(e->{
                     DepartmentVO departmentVO = new DepartmentVO();
                     List<UserDepartment> userDepartments = userDepartmentMapper.selectByDepartmentId(e.getId());

--
Gitblit v1.8.0