UserHoldCountController.java 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. package com.izouma.nineth.web;
  2. import com.alibaba.excel.util.CollectionUtils;
  3. import com.izouma.nineth.dto.PageQuery;
  4. import com.izouma.nineth.dto.UserHoldDTO;
  5. import com.izouma.nineth.service.UserHoldCountCache;
  6. import com.izouma.nineth.service.UserHoldCountService;
  7. import com.izouma.nineth.utils.excel.ExcelUtils;
  8. import lombok.AllArgsConstructor;
  9. import org.springframework.data.domain.Page;
  10. import org.springframework.web.bind.annotation.*;
  11. import javax.servlet.http.HttpServletResponse;
  12. import java.io.IOException;
  13. import java.util.Comparator;
  14. import java.util.List;
  15. @RestController
  16. @RequestMapping("/userHold")
  17. @AllArgsConstructor
  18. public class UserHoldCountController {
  19. private UserHoldCountService userHoldCountService;
  20. private UserHoldCountCache userHoldCountCache;
  21. @PostMapping("/all")
  22. public Page<UserHoldDTO> all(@RequestBody PageQuery pageQuery) {
  23. return userHoldCountService.all(pageQuery).toPage();
  24. }
  25. @GetMapping("/top")
  26. public List<UserHoldDTO> top() {
  27. PageQuery pageQuery = new PageQuery();
  28. pageQuery.setPage(0);
  29. pageQuery.setSize(50);
  30. List<UserHoldDTO> userHoldDTOs = userHoldCountService.all(pageQuery).getContent();
  31. userHoldDTOs.sort(Comparator.comparing(UserHoldDTO::getPrice).reversed());
  32. return userHoldDTOs;
  33. }
  34. @GetMapping("/app/top")
  35. public List<UserHoldDTO> appTop() {
  36. List<UserHoldDTO> top = top();
  37. if (CollectionUtils.isEmpty(top)) {
  38. return null;
  39. }
  40. top.forEach(userHoldDTO -> {
  41. userHoldDTO.setNum(0);
  42. userHoldDTO.setUsername(null);
  43. userHoldDTO.setPrefixName(null);
  44. userHoldDTO.setName(null);
  45. userHoldDTO.setPrice(null);
  46. userHoldDTO.setUserId(null);
  47. });
  48. return top;
  49. }
  50. @GetMapping("/excel")
  51. @ResponseBody
  52. public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
  53. List<UserHoldDTO> data = all(pageQuery).getContent();
  54. ExcelUtils.export(response, data);
  55. }
  56. @GetMapping("/refresh")
  57. public void refresh() {
  58. // 重新缓存
  59. userHoldCountCache.allUserHold();
  60. }
  61. }