MetaQuestionController.java 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. package com.izouma.nineth.web;
  2. import com.izouma.nineth.domain.MetaQuestion;
  3. import com.izouma.nineth.dto.MetaRestResult;
  4. import com.izouma.nineth.dto.PageQuery;
  5. import com.izouma.nineth.exception.BusinessException;
  6. import com.izouma.nineth.repo.MetaQuestionRepo;
  7. import com.izouma.nineth.service.MetaQuestionService;
  8. import com.izouma.nineth.utils.ObjUtils;
  9. import com.izouma.nineth.utils.excel.ExcelUtils;
  10. import lombok.AllArgsConstructor;
  11. import org.springframework.data.domain.Page;
  12. import org.springframework.web.bind.annotation.*;
  13. import javax.servlet.http.HttpServletResponse;
  14. import java.io.IOException;
  15. import java.util.Collections;
  16. import java.util.List;
  17. @RestController
  18. @RequestMapping("/metaQuestion")
  19. @AllArgsConstructor
  20. public class MetaQuestionController extends BaseController {
  21. private MetaQuestionService metaQuestionService;
  22. private MetaQuestionRepo metaQuestionRepo;
  23. //@PreAuthorize("hasRole('ADMIN')")
  24. @PostMapping("/save")
  25. public MetaQuestion save(@RequestBody MetaQuestion record) {
  26. if (record.getId() != null) {
  27. MetaQuestion orig = metaQuestionRepo.findById(record.getId()).orElseThrow(new BusinessException("无记录"));
  28. ObjUtils.merge(orig, record);
  29. return metaQuestionRepo.save(orig);
  30. }
  31. return metaQuestionRepo.save(record);
  32. }
  33. //@PreAuthorize("hasRole('ADMIN')")
  34. @PostMapping("/all")
  35. public Page<MetaQuestion> all(@RequestBody PageQuery pageQuery) {
  36. return metaQuestionService.all(pageQuery);
  37. }
  38. @GetMapping("/get/{id}")
  39. public MetaQuestion get(@PathVariable Long id) {
  40. return metaQuestionRepo.findById(id).orElseThrow(new BusinessException("无记录"));
  41. }
  42. @PostMapping("/del/{id}")
  43. public void del(@PathVariable Long id) {
  44. metaQuestionRepo.softDelete(id);
  45. }
  46. @GetMapping("/excel")
  47. @ResponseBody
  48. public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
  49. List<MetaQuestion> data = all(pageQuery).getContent();
  50. ExcelUtils.export(response, data);
  51. }
  52. @GetMapping("/queryByApplication/{application}/{num}")
  53. public MetaRestResult<List<MetaQuestion>> queryByApplication(@PathVariable int application, @PathVariable int num) {
  54. List<MetaQuestion> metaQuestions = metaQuestionRepo.findAllByApplicationAndDel(application, false);
  55. // 乱序
  56. Collections.shuffle(metaQuestions);
  57. return MetaRestResult.returnSuccess(metaQuestions.subList(0, num));
  58. }
  59. }