IdentityAuthController.java 2.4 KB

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