ActivityCollectionController.java 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. package com.izouma.nineth.web;
  2. import com.izouma.nineth.domain.ActivityCollection;
  3. import com.izouma.nineth.dto.PageQuery;
  4. import com.izouma.nineth.exception.BusinessException;
  5. import com.izouma.nineth.repo.ActivityCollectionRepo;
  6. import com.izouma.nineth.service.ActivityCollectionService;
  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.List;
  16. @RestController
  17. @RequestMapping("/activityCollection")
  18. @AllArgsConstructor
  19. public class ActivityCollectionController extends BaseController {
  20. private ActivityCollectionService activityCollectionService;
  21. private ActivityCollectionRepo activityCollectionRepo;
  22. @PreAuthorize("hasRole('ADMIN')")
  23. @PostMapping("/save")
  24. public ActivityCollection save(@RequestBody ActivityCollection record) {
  25. if (record.getCollectionId().equals(record.getAwardCollectionId())) {
  26. throw new BusinessException("兑换的藏品不能和领取的藏品相同");
  27. }
  28. if (record.getId() != null) {
  29. ActivityCollection orig = activityCollectionRepo.findById(record.getId())
  30. .orElseThrow(new BusinessException("无记录"));
  31. ObjUtils.merge(orig, record);
  32. return activityCollectionRepo.save(orig);
  33. }
  34. record.setStock(record.getStock());
  35. return activityCollectionRepo.save(record);
  36. }
  37. //@PreAuthorize("hasRole('ADMIN')")
  38. @PostMapping("/all")
  39. public Page<ActivityCollection> all(@RequestBody PageQuery pageQuery) {
  40. return activityCollectionService.all(pageQuery);
  41. }
  42. @GetMapping("/get/{id}")
  43. public ActivityCollection get(@PathVariable Long id) {
  44. return activityCollectionRepo.findById(id).orElseThrow(new BusinessException("无记录"));
  45. }
  46. @PostMapping("/del/{id}")
  47. public void del(@PathVariable Long id) {
  48. activityCollectionRepo.softDelete(id);
  49. }
  50. @GetMapping("/excel")
  51. @ResponseBody
  52. public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
  53. List<ActivityCollection> data = all(pageQuery).getContent();
  54. ExcelUtils.export(response, data);
  55. }
  56. }