BlindBoxItemController.java 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. package com.izouma.nineth.web;
  2. import com.izouma.nineth.domain.BlindBoxItem;
  3. import com.izouma.nineth.dto.PageQuery;
  4. import com.izouma.nineth.exception.BusinessException;
  5. import com.izouma.nineth.repo.BlindBoxItemRepo;
  6. import com.izouma.nineth.service.BlindBoxItemService;
  7. import com.izouma.nineth.utils.ObjUtils;
  8. import com.izouma.nineth.utils.excel.ExcelUtils;
  9. import lombok.AllArgsConstructor;
  10. import org.springframework.data.domain.Page;
  11. import org.springframework.security.access.prepost.PreAuthorize;
  12. import org.springframework.web.bind.annotation.*;
  13. import javax.servlet.http.HttpServletResponse;
  14. import java.io.IOException;
  15. import java.util.HashMap;
  16. import java.util.List;
  17. @RestController
  18. @RequestMapping("/blindBoxItem")
  19. @AllArgsConstructor
  20. public class BlindBoxItemController extends BaseController {
  21. private BlindBoxItemService blindBoxItemService;
  22. private BlindBoxItemRepo blindBoxItemRepo;
  23. @PreAuthorize("hasRole('ADMIN')")
  24. @PostMapping("/save")
  25. public BlindBoxItem save(@RequestBody BlindBoxItem record) {
  26. if (record.getId() != null) {
  27. BlindBoxItem orig = blindBoxItemRepo.findById(record.getId()).orElseThrow(new BusinessException("无记录"));
  28. ObjUtils.merge(orig, record);
  29. return blindBoxItemRepo.save(orig);
  30. }
  31. return blindBoxItemRepo.save(record);
  32. }
  33. //@PreAuthorize("hasRole('ADMIN')")
  34. @PostMapping("/all")
  35. public Page<BlindBoxItem> all(@RequestBody PageQuery pageQuery) {
  36. return blindBoxItemService.all(pageQuery).toPage();
  37. }
  38. @GetMapping("/get/{id}")
  39. public BlindBoxItem get(@PathVariable Long id) {
  40. return blindBoxItemRepo.findById(id).orElseThrow(new BusinessException("无记录"));
  41. }
  42. // @PostMapping("/del/{id}")
  43. // public void del(@PathVariable Long id) {
  44. // blindBoxItemRepo.softDelete(id);
  45. // }
  46. @GetMapping("/excel")
  47. @ResponseBody
  48. public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
  49. List<BlindBoxItem> data = all(pageQuery).getContent();
  50. ExcelUtils.export(response, data);
  51. }
  52. @GetMapping("/rare/{blindBoxId}")
  53. public HashMap<String, String> getBlindBoxRare(@PathVariable Long blindBoxId) {
  54. return blindBoxItemService.getBlindBoxRare(blindBoxId);
  55. }
  56. }