InstitutionController.java 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. package com.izouma.zhirongip.web;
  2. import cn.hutool.core.util.ObjectUtil;
  3. import com.izouma.zhirongip.domain.Institution;
  4. import com.izouma.zhirongip.domain.Personal;
  5. import com.izouma.zhirongip.domain.User;
  6. import com.izouma.zhirongip.dto.InstitutionDTO;
  7. import com.izouma.zhirongip.dto.UserRegister;
  8. import com.izouma.zhirongip.enums.ApplyStatus;
  9. import com.izouma.zhirongip.enums.AuthorityName;
  10. import com.izouma.zhirongip.repo.PersonalRepo;
  11. import com.izouma.zhirongip.repo.UserRepo;
  12. import com.izouma.zhirongip.security.Authority;
  13. import com.izouma.zhirongip.service.InstitutionService;
  14. import com.izouma.zhirongip.dto.PageQuery;
  15. import com.izouma.zhirongip.exception.BusinessException;
  16. import com.izouma.zhirongip.repo.InstitutionRepo;
  17. import com.izouma.zhirongip.service.UserService;
  18. import com.izouma.zhirongip.utils.ObjUtils;
  19. import com.izouma.zhirongip.utils.SecurityUtils;
  20. import com.izouma.zhirongip.utils.excel.ExcelUtils;
  21. import io.swagger.annotations.ApiOperation;
  22. import lombok.AllArgsConstructor;
  23. import org.apache.commons.lang3.RandomStringUtils;
  24. import org.springframework.data.domain.Page;
  25. import org.springframework.security.access.prepost.PreAuthorize;
  26. import org.springframework.web.bind.annotation.*;
  27. import javax.servlet.http.HttpServletResponse;
  28. import java.io.IOException;
  29. import java.util.Collections;
  30. import java.util.List;
  31. import java.util.Set;
  32. @RestController
  33. @RequestMapping("/institution")
  34. @AllArgsConstructor
  35. public class InstitutionController extends BaseController {
  36. private final InstitutionService institutionService;
  37. private final InstitutionRepo institutionRepo;
  38. private final PersonalRepo personalRepo;
  39. private final UserRepo userRepo;
  40. private final UserService userService;
  41. //@PreAuthorize("hasRole('ADMIN')")
  42. @PostMapping("/save")
  43. public Institution save(@RequestBody Institution record) {
  44. Long userId = SecurityUtils.getAuthenticatedUser().getId();
  45. if (record.getId() != null) {
  46. Institution orig = institutionRepo.findById(record.getId()).orElseThrow(new BusinessException("无记录"));
  47. orig.setUserId(userId);
  48. ObjUtils.merge(orig, record);
  49. orig.setStatus(ApplyStatus.PENDING);
  50. return institutionRepo.save(orig);
  51. }
  52. if (SecurityUtils.getAuthenticatedUser().getAuthorities().contains(Authority.get(AuthorityName.ROLE_ADMIN))) {
  53. User user = userService.create(UserRegister.builder()
  54. .authorities(Collections.singleton(Authority.get(AuthorityName.ROLE_INSTITUTION)))
  55. .username(RandomStringUtils.randomAlphanumeric(16))
  56. .nickname(RandomStringUtils.randomAlphanumeric(16))
  57. .build());
  58. record.setStatus(ApplyStatus.PASS);
  59. record.setUserId(user.getId());
  60. } else {
  61. Institution byUserId = institutionRepo.findByUserId(userId);
  62. if (ObjectUtil.isNotNull(byUserId)) {
  63. throw new BusinessException("已申请");
  64. }
  65. Personal personal = personalRepo.findByUserId(userId);
  66. if (ObjectUtil.isNotNull(personal)) {
  67. throw new BusinessException("已申请个人认证");
  68. }
  69. record.setUserId(userId);
  70. record.setStatus(ApplyStatus.PENDING);
  71. }
  72. return institutionRepo.save(record);
  73. }
  74. //@PreAuthorize("hasRole('ADMIN')")
  75. @PostMapping("/all")
  76. public Page<InstitutionDTO> all(@RequestBody PageQuery pageQuery) {
  77. return institutionService.all(pageQuery);
  78. }
  79. @GetMapping("/get/{id}")
  80. public Institution get(@PathVariable Long id) {
  81. return institutionRepo.findById(id).orElseThrow(new BusinessException("无记录"));
  82. }
  83. @PostMapping("/del/{id}")
  84. public void del(@PathVariable Long id) {
  85. Institution institution = institutionRepo.findById(id).orElseThrow(new BusinessException("无记录"));
  86. userRepo.findById(institution.getUserId()).ifPresent(user -> {
  87. Set<Authority> authoritySet = user.getAuthorities();
  88. authoritySet.remove(Authority.get(AuthorityName.ROLE_INSTITUTION));
  89. userRepo.save(user);
  90. });
  91. institutionRepo.softDelete(id);
  92. }
  93. @GetMapping("/excel")
  94. @ResponseBody
  95. public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
  96. List<InstitutionDTO> data = all(pageQuery).getContent();
  97. ExcelUtils.export(response, data);
  98. }
  99. @PreAuthorize("hasRole('ADMIN')")
  100. @ApiOperation("审核")
  101. @PostMapping("/audit")
  102. public void audit(@RequestParam Long id, @RequestParam boolean pass, String remark) {
  103. institutionService.audit(id, pass, remark);
  104. }
  105. @PreAuthorize("hasRole('INSTITUTION')")
  106. @GetMapping("/my")
  107. public Institution my() {
  108. return institutionRepo.findByUserId(SecurityUtils.getAuthenticatedUser().getId());
  109. }
  110. }