OrderController.java 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. package com.izouma.nineth.web;
  2. import com.izouma.nineth.domain.Order;
  3. import com.izouma.nineth.domain.User;
  4. import com.izouma.nineth.dto.OrderDTO;
  5. import com.izouma.nineth.dto.PageQuery;
  6. import com.izouma.nineth.enums.AuthorityName;
  7. import com.izouma.nineth.enums.CollectionType;
  8. import com.izouma.nineth.enums.OrderStatus;
  9. import com.izouma.nineth.enums.PayMethod;
  10. import com.izouma.nineth.exception.BusinessException;
  11. import com.izouma.nineth.repo.OrderRepo;
  12. import com.izouma.nineth.repo.UserRepo;
  13. import com.izouma.nineth.service.OrderService;
  14. import com.izouma.nineth.utils.DateTimeUtils;
  15. import com.izouma.nineth.utils.SecurityUtils;
  16. import com.izouma.nineth.utils.SnowflakeIdWorker;
  17. import com.izouma.nineth.utils.excel.ExcelUtils;
  18. import lombok.AllArgsConstructor;
  19. import org.springframework.beans.BeanUtils;
  20. import org.springframework.data.domain.Page;
  21. import org.springframework.security.access.prepost.PreAuthorize;
  22. import org.springframework.web.bind.annotation.*;
  23. import javax.servlet.http.HttpServletResponse;
  24. import java.io.IOException;
  25. import java.time.LocalDate;
  26. import java.time.LocalDateTime;
  27. import java.util.HashMap;
  28. import java.util.List;
  29. import java.util.Map;
  30. import java.util.Optional;
  31. import java.util.stream.Collectors;
  32. @RestController
  33. @RequestMapping("/order")
  34. @AllArgsConstructor
  35. public class OrderController extends BaseController {
  36. private OrderService orderService;
  37. private OrderRepo orderRepo;
  38. private UserRepo userRepo;
  39. //@PreAuthorize("hasRole('ADMIN')")
  40. // @PostMapping("/save")
  41. // public Order save(@RequestBody Order record) {
  42. // if (record.getId() != null) {
  43. // Order orig = orderRepo.findById(record.getId()).orElseThrow(new BusinessException("无记录"));
  44. // ObjUtils.merge(orig, record);
  45. // return orderRepo.save(orig);
  46. // }
  47. // return orderRepo.save(record);
  48. // }
  49. //@PreAuthorize("hasRole('ADMIN')")
  50. @PostMapping("/all")
  51. public Page<Order> all(@RequestBody PageQuery pageQuery) {
  52. if (!SecurityUtils.hasRole(AuthorityName.ROLE_ADMIN)) {
  53. pageQuery.getQuery().put("userId", SecurityUtils.getAuthenticatedUser().getId());
  54. }
  55. return orderService.all(pageQuery);
  56. }
  57. @PostMapping("/backAll")
  58. public Page<Order> backAll(@RequestBody PageQuery pageQuery) {
  59. Page<Order> all = orderService.all(pageQuery);
  60. List<Long> userIds = all.getContent().stream().map(Order::getUserId).distinct().collect(Collectors.toList());
  61. Map<Long, String> userMap = userRepo.findAllById(userIds)
  62. .stream()
  63. .collect(Collectors.toMap(User::getId, User::getNickname));
  64. return all.map(order -> {
  65. order.setNickname(userMap.get(order.getUserId()));
  66. return order;
  67. });
  68. }
  69. @GetMapping("/get/{id}")
  70. public Order get(@PathVariable Long id) {
  71. return orderRepo.findById(id).orElseThrow(new BusinessException("无记录"));
  72. }
  73. // @PostMapping("/del/{id}")
  74. // public void del(@PathVariable Long id) {
  75. // orderRepo.softDelete(id);
  76. // }
  77. @PostMapping("/excel")
  78. @ResponseBody
  79. public void excel(HttpServletResponse response, @RequestBody PageQuery pageQuery) throws IOException {
  80. List<Order> data = all(pageQuery).getContent();
  81. ExcelUtils.export(response, data.stream().map(order -> {
  82. OrderDTO dto = new OrderDTO();
  83. BeanUtils.copyProperties(order, dto);
  84. dto.setStatus(Optional.ofNullable(order.getStatus()).map(OrderStatus::getDescription).orElse(null));
  85. dto.setPayMethod(Optional.ofNullable(order.getPayMethod()).map(PayMethod::getDescription).orElse(null));
  86. dto.setType(Optional.ofNullable(order.getType()).map(CollectionType::getDescription).orElse(null));
  87. return dto;
  88. }).collect(Collectors.toList()));
  89. }
  90. @PostMapping("/create")
  91. public Order create(@RequestParam Long collectionId, @RequestParam int qty,
  92. @RequestParam(required = false) Long addressId,
  93. @RequestParam(required = false) Long couponId,
  94. @RequestParam(required = false) Long invitor,
  95. @RequestHeader(value = "User-Agent") String userAgent) {
  96. throw new BusinessException("iOS客户端暂时无法下单,请使用H5或Android客户端");
  97. }
  98. @PostMapping("/mqCreate")
  99. public HashMap<String, String> mqCreate(@RequestParam Long collectionId, @RequestParam int qty,
  100. @RequestParam(required = false) Long addressId,
  101. @RequestParam(required = false) Long couponId,
  102. @RequestParam(required = false) Long invitor,
  103. @RequestParam String sign,
  104. @RequestParam(defaultValue = "false") boolean vip) {
  105. final User user = SecurityUtils.getAuthenticatedUser();
  106. return new HashMap<>() {{
  107. put("id", orderService.mqCreate(user.getId(), collectionId, qty, addressId, couponId, invitor, sign,
  108. vip, user.getVipPurchase(), user.getVipPoint()));
  109. }};
  110. }
  111. @PostMapping("/hide")
  112. public void hide(@RequestParam Long id) {
  113. Order order = orderRepo.findById(id).orElseThrow(new BusinessException("订单不存在"));
  114. order.setHide(true);
  115. orderRepo.save(order);
  116. }
  117. @GetMapping("/{id}/status")
  118. public Object status(@PathVariable Long id) {
  119. Order order = orderRepo.findById(id).orElseThrow(new BusinessException("订单不存在"));
  120. return new HashMap<>() {{
  121. put("status", order.getStatus());
  122. }};
  123. }
  124. @PreAuthorize("hasRole('ADMIN')")
  125. @GetMapping("/setSales")
  126. public String setSales() {
  127. orderService.setSales();
  128. return "OK";
  129. }
  130. @PostMapping("/open")
  131. public void open(@RequestParam Long id) {
  132. orderRepo.findById(id).ifPresent(order -> {
  133. order.setOpened(true);
  134. orderRepo.save(order);
  135. });
  136. }
  137. @PostMapping("/testNotify")
  138. public void testNotify(@RequestParam Long id) {
  139. orderService.notifyOrder(id, PayMethod.ALIPAY, new SnowflakeIdWorker(0, 0).nextId() + "");
  140. }
  141. @GetMapping("/createResult")
  142. public Object createResult(@RequestParam String id) {
  143. return orderService.queryCreateOrder(id);
  144. }
  145. @GetMapping("/checkLimit")
  146. public Object checkLimit(@RequestParam Long collectionId) {
  147. return orderService.checkLimit(collectionId, SecurityUtils.getAuthenticatedUser().getId());
  148. }
  149. @PostMapping("/cancel")
  150. @PreAuthorize("hasRole('ADMIN')")
  151. public void cancel(@RequestParam Long id) {
  152. orderService.cancel(id);
  153. }
  154. @GetMapping(value = "/calcSettle")
  155. public void calcSettle(LocalDateTime start, LocalDateTime end, HttpServletResponse response) {
  156. if (start == null && end == null) {
  157. start = LocalDate.now().minusDays(1).atStartOfDay();
  158. end = LocalDate.now().minusDays(1).atTime(23, 59, 59, 99999);
  159. }
  160. try {
  161. response.setContentType("application/vnd.ms-excel");
  162. response.setCharacterEncoding("utf-8");
  163. response.setHeader("Content-Disposition", "attachment;filename=" + DateTimeUtils.format(LocalDateTime.now(), "MMdd") + ".xlsx");
  164. orderService.calcSettle(start, end, response.getOutputStream());
  165. } catch (IOException e) {
  166. e.printStackTrace();
  167. }
  168. }
  169. }