IdentityAuthController.java 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. package com.izouma.nineth.web;
  2. import com.izouma.nineth.domain.IdentityAuth;
  3. import com.izouma.nineth.domain.User;
  4. import com.izouma.nineth.dto.PageQuery;
  5. import com.izouma.nineth.enums.AuthStatus;
  6. import com.izouma.nineth.exception.BusinessException;
  7. import com.izouma.nineth.repo.IdentityAuthRepo;
  8. import com.izouma.nineth.service.IdentityAuthService;
  9. import com.izouma.nineth.utils.SecurityUtils;
  10. import com.izouma.nineth.utils.excel.ExcelUtils;
  11. import io.swagger.annotations.ApiOperation;
  12. import lombok.AllArgsConstructor;
  13. import org.springframework.data.domain.Page;
  14. import org.springframework.security.access.prepost.PreAuthorize;
  15. import org.springframework.web.bind.annotation.*;
  16. import javax.servlet.http.HttpServletResponse;
  17. import java.io.IOException;
  18. import java.util.List;
  19. @RestController
  20. @RequestMapping("/identityAuth")
  21. @AllArgsConstructor
  22. public class IdentityAuthController extends BaseController {
  23. private IdentityAuthService identityAuthService;
  24. private IdentityAuthRepo identityAuthRepo;
  25. // @PreAuthorize("hasAnyRole('ADMIN','OPERATOR')")
  26. @PostMapping("/all")
  27. public Page<IdentityAuth> all(@RequestBody PageQuery pageQuery) {
  28. return identityAuthService.all(pageQuery);
  29. }
  30. @PreAuthorize("hasRole('ADMIN')")
  31. @GetMapping("/get/{id}")
  32. public IdentityAuth get(@PathVariable Long id) {
  33. return identityAuthRepo.findById(id).orElseThrow(new BusinessException("无记录"));
  34. }
  35. @PreAuthorize("hasRole('ADMIN')")
  36. @PostMapping("/del/{id}")
  37. public void del(@PathVariable Long id) {
  38. identityAuthRepo.softDelete(id);
  39. }
  40. @PreAuthorize("hasRole('ADMIN')")
  41. @GetMapping("/excel")
  42. @ResponseBody
  43. public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
  44. List<IdentityAuth> data = all(pageQuery).getContent();
  45. ExcelUtils.export(response, data);
  46. }
  47. @PostMapping("/apply")
  48. public void apply(IdentityAuth identityAuth) {
  49. identityAuth.setUserId(SecurityUtils.getAuthenticatedUser().getId());
  50. identityAuthService.apply(identityAuth);
  51. }
  52. @PreAuthorize("hasAnyRole('ADMIN', 'OPERATOR')")
  53. @PostMapping("/pass")
  54. public void audit(@RequestParam Long id) {
  55. identityAuthService.audit(id, AuthStatus.SUCCESS, null);
  56. }
  57. @PreAuthorize("hasAnyRole('ADMIN', 'OPERATOR')")
  58. @PostMapping("/deny")
  59. public void deny(@RequestParam Long id, @RequestParam(required = false) String reason) {
  60. identityAuthService.audit(id, AuthStatus.FAIL, reason);
  61. }
  62. @ApiOperation("查找重复身份证")
  63. @PostMapping("/repeat")
  64. public List<User> repeat(@RequestParam String idNo, @RequestParam Long userId) {
  65. return identityAuthService.repeat(idNo, userId);
  66. }
  67. @GetMapping("/removeDuplicated")
  68. public void removeDuplicated() {
  69. identityAuthService.removeDuplicated();
  70. }
  71. }