OrderController.java 8.8 KB

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