SchoolController.java 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. package com.ym.mec.web.controller;
  2. import io.swagger.annotations.Api;
  3. import io.swagger.annotations.ApiOperation;
  4. import io.swagger.annotations.ApiParam;
  5. import java.util.Arrays;
  6. import java.util.Date;
  7. import java.util.List;
  8. import org.apache.commons.lang3.StringUtils;
  9. import org.springframework.beans.factory.annotation.Autowired;
  10. import org.springframework.security.access.prepost.PreAuthorize;
  11. import org.springframework.web.bind.annotation.GetMapping;
  12. import org.springframework.web.bind.annotation.PathVariable;
  13. import org.springframework.web.bind.annotation.PostMapping;
  14. import org.springframework.web.bind.annotation.RequestMapping;
  15. import org.springframework.web.bind.annotation.RestController;
  16. import com.ym.mec.auth.api.client.SysUserFeignService;
  17. import com.ym.mec.auth.api.entity.SysUser;
  18. import com.ym.mec.biz.dal.dao.EmployeeDao;
  19. import com.ym.mec.biz.dal.dao.TeacherDao;
  20. import com.ym.mec.biz.dal.entity.Employee;
  21. import com.ym.mec.biz.dal.entity.School;
  22. import com.ym.mec.biz.dal.entity.Teacher;
  23. import com.ym.mec.biz.dal.page.SchoolQueryInfo;
  24. import com.ym.mec.biz.service.SchoolService;
  25. import com.ym.mec.common.controller.BaseController;
  26. @RequestMapping("school")
  27. @Api(tags = "学校(教学点)服务")
  28. @RestController
  29. public class SchoolController extends BaseController {
  30. @Autowired
  31. private SchoolService schoolService;
  32. @Autowired
  33. private EmployeeDao employeeDao;
  34. @Autowired
  35. private TeacherDao teacherDao;
  36. @Autowired
  37. private SysUserFeignService sysUserFeignService;
  38. @ApiOperation(value = "新增学校")
  39. @PostMapping("/add")
  40. @PreAuthorize("@pcs.hasPermissions('school/add')")
  41. public Object add(School school){
  42. schoolService.insert(school);
  43. return succeed();
  44. }
  45. @ApiOperation(value = "删除学校")
  46. @PostMapping("/del/{id}")
  47. @PreAuthorize("@pcs.hasPermissions('school/del')")
  48. public Object del(@ApiParam(value = "学校编号", required = true) @PathVariable("id") Integer id){
  49. schoolService.delete(id);
  50. return succeed();
  51. }
  52. @ApiOperation(value = "修改学校")
  53. @PostMapping("/update")
  54. @PreAuthorize("@pcs.hasPermissions('school/update')")
  55. public Object update(School school){
  56. school.setUpdateTime(new Date());
  57. schoolService.update(school);
  58. return succeed();
  59. }
  60. @ApiOperation(value = "根据学校编号查询学校")
  61. @GetMapping("/get/{id}")
  62. @PreAuthorize("@pcs.hasPermissions('school/get')")
  63. public Object get(@ApiParam(value = "学校编号", required = true) @PathVariable("id") Integer id){
  64. return succeed(schoolService.get(id));
  65. }
  66. @ApiOperation(value = "分页查询学校列表")
  67. @GetMapping("/queryPage")
  68. @PreAuthorize("@pcs.hasPermissions('school/queryPage')")
  69. public Object queryPage(SchoolQueryInfo queryInfo){
  70. SysUser sysUser = sysUserFeignService.queryUserInfo();
  71. if (sysUser == null) {
  72. return failed("用户信息获取失败");
  73. }
  74. if(!sysUser.getIsSuperAdmin()){
  75. Employee employee = employeeDao.get(sysUser.getId());
  76. if (StringUtils.isEmpty(queryInfo.getOrganId())) {
  77. queryInfo.setOrganId(employee.getOrganIdList());
  78. }else if(StringUtils.isEmpty(employee.getOrganIdList())){
  79. return failed("用户所在分部异常");
  80. }else {
  81. List<String> list = Arrays.asList(employee.getOrganIdList().split(","));
  82. if(!list.containsAll(Arrays.asList(queryInfo.getOrganId().split(",")))){
  83. return failed("非法请求");
  84. }
  85. }
  86. }
  87. return succeed(schoolService.queryPageDetail(queryInfo));
  88. }
  89. @ApiOperation(value = "根据机构编号获取学校列表")
  90. @GetMapping("/queryByOrganId")
  91. @PreAuthorize("@pcs.hasPermissions('school/queryByOrganId')")
  92. public Object queryByOrganId(String organId){
  93. SysUser sysUser = sysUserFeignService.queryUserInfo();
  94. if (sysUser == null) {
  95. return failed("用户信息获取失败");
  96. }
  97. if(!sysUser.getIsSuperAdmin()){
  98. Employee employee = employeeDao.get(sysUser.getId());
  99. if (StringUtils.isEmpty(organId)) {
  100. organId = employee.getOrganIdList();
  101. }else if(StringUtils.isEmpty(employee.getOrganIdList())){
  102. return failed("用户所在分部异常");
  103. }else {
  104. List<String> list = Arrays.asList(employee.getOrganIdList().split(","));
  105. if(!list.containsAll(Arrays.asList(organId.split(",")))){
  106. return failed("非法请求");
  107. }
  108. }
  109. }
  110. return succeed(schoolService.queryByOrganId(organId));
  111. }
  112. @ApiOperation(value = "获取教师vip课教学点")
  113. @GetMapping("/findVipSchoolByTeacher")
  114. public Object findVipSchoolByTeacher(@ApiParam(value = "教师编号", required = true) Integer userId){
  115. SysUser sysUser = sysUserFeignService.queryUserById(userId);
  116. if (sysUser == null) {
  117. return failed("用户信息获取失败");
  118. }
  119. StringBuffer sb = new StringBuffer();
  120. sb.append(sysUser.getOrganId());
  121. Teacher teacher = teacherDao.get(userId);
  122. if(teacher == null){
  123. return failed("老师信息不存在");
  124. }
  125. sb.append(",").append(teacher.getFlowOrganRange());
  126. return succeed(schoolService.findVipSchoolByTeacher(userId,sb.toString(),null));
  127. }
  128. }