PayCodeOrderServiceImpl.java 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. package com.izouma.awesomeadmin.service.impl;
  2. import java.util.*;
  3. import com.izouma.awesomeadmin.dao.PayCodeStockMapper;
  4. import com.izouma.awesomeadmin.dto.Result;
  5. import com.izouma.awesomeadmin.model.MemberTicket;
  6. import com.izouma.awesomeadmin.model.PayCodeStock;
  7. import com.izouma.awesomeadmin.service.MemberTicketService;
  8. import com.izouma.awesomeadmin.util.MbappUtil;
  9. import org.apache.log4j.Logger;
  10. import org.springframework.beans.factory.annotation.Autowired;
  11. import org.springframework.stereotype.Service;
  12. import com.izouma.awesomeadmin.constant.AppConstant;
  13. import com.izouma.awesomeadmin.dto.Page;
  14. import com.izouma.awesomeadmin.model.PayCodeOrder;
  15. import com.izouma.awesomeadmin.service.PayCodeOrderService;
  16. import com.izouma.awesomeadmin.dao.PayCodeOrderMapper;
  17. /**
  18. * service接口实现类
  19. */
  20. @Service
  21. public class PayCodeOrderServiceImpl implements PayCodeOrderService {
  22. /*generatedStart*/
  23. private static Logger logger = Logger.getLogger(PayCodeOrderServiceImpl.class);
  24. @Autowired
  25. private PayCodeOrderMapper payCodeOrderMapper;
  26. /*generatedEnd*/
  27. @Autowired
  28. private PayCodeStockMapper payCodeStockMapper;
  29. @Autowired
  30. private MemberTicketService memberTicketService;
  31. /*generatedStart*/
  32. @Override
  33. public List<PayCodeOrder> getPayCodeOrderList(PayCodeOrder record) {
  34. logger.info("getPayCodeOrderList");
  35. try {
  36. return payCodeOrderMapper.queryAllPayCodeOrder(record);
  37. } catch (Exception e) {
  38. logger.error("getPayCodeOrderList", e);
  39. }
  40. return null;
  41. }
  42. @Override
  43. public List<PayCodeOrder> getPayCodeOrderByPage(Page page, PayCodeOrder record) {
  44. logger.info("getPayCodeOrderByPage");
  45. try {
  46. Map<String, Object> parameter = new HashMap<String, Object>();
  47. parameter.put("record", record);
  48. parameter.put(AppConstant.PAGE, page);
  49. return payCodeOrderMapper.queryPayCodeOrderByPage(parameter);
  50. } catch (Exception e) {
  51. logger.error("getPayCodeOrderByPage", e);
  52. }
  53. return null;
  54. }
  55. @Override
  56. public PayCodeOrder getPayCodeOrderById(String id) {
  57. logger.info("getPayCodeOrderyId");
  58. try {
  59. return payCodeOrderMapper.selectByPrimaryKey(Integer.valueOf(id));
  60. } catch (Exception e) {
  61. logger.error("getPayCodeOrderById", e);
  62. }
  63. return null;
  64. }
  65. @Override
  66. public PayCodeOrder getPayCodeOrder(PayCodeOrder record) {
  67. logger.info("getPayCodeOrder");
  68. try {
  69. return payCodeOrderMapper.queryPayCodeOrder(record);
  70. } catch (Exception e) {
  71. logger.error("getPayCodeOrder", e);
  72. }
  73. return null;
  74. }
  75. @Override
  76. public boolean createPayCodeOrder(PayCodeOrder record) {
  77. logger.info("createPayCodeOrder");
  78. try {
  79. int updates = payCodeOrderMapper.insertSelective(record);
  80. if (updates > 0) {
  81. return true;
  82. }
  83. } catch (Exception e) {
  84. logger.error("createPayCodeOrder", e);
  85. }
  86. return false;
  87. }
  88. @Override
  89. public boolean deletePayCodeOrder(PayCodeOrder record) {
  90. logger.info("deletePayCodeOrder");
  91. try {
  92. int updates = payCodeOrderMapper.delete(record);
  93. if (updates > 0) {
  94. return true;
  95. }
  96. } catch (Exception e) {
  97. logger.error("deletePayCodeOrder", e);
  98. }
  99. return false;
  100. }
  101. @Override
  102. public boolean updatePayCodeOrder(PayCodeOrder record) {
  103. logger.info("updatePayCodeOrder");
  104. try {
  105. int updates = payCodeOrderMapper.updateByPrimaryKeySelective(record);
  106. if (updates > 0) {
  107. return true;
  108. }
  109. } catch (Exception e) {
  110. logger.error("updatePayCodeOrder", e);
  111. }
  112. return false;
  113. }
  114. /*generatedEnd*/
  115. @Override
  116. public Result submit(PayCodeOrder record) {
  117. logger.info("submit");
  118. try {
  119. record.setOrderCode(MbappUtil.getOrderIdByUUId());
  120. if (record.getStockId() == null) {
  121. return new Result(false, "付款码库存为空");
  122. }
  123. PayCodeStock payCodeStock = new PayCodeStock();
  124. payCodeStock.setId(record.getStockId());
  125. payCodeStock = payCodeStockMapper.queryPayCodeStock(payCodeStock);
  126. if (payCodeStock == null) {
  127. return new Result(false, "付款码库存不存在");
  128. }
  129. if (payCodeStock.getAmount() <= 0) {
  130. return new Result(false, "付款码库存不足");
  131. }
  132. record.setPayType(payCodeStock.getPayType());
  133. record.setCodeId(payCodeStock.getCodeId());
  134. record.setMoney(payCodeStock.getMoney());
  135. int updates = payCodeOrderMapper.insertSelective(record);
  136. if (updates > 0) {
  137. payCodeStock.setAmount(payCodeStock.getAmount() - 1);
  138. payCodeStockMapper.updateByPrimaryKeySelective(payCodeStock);
  139. return new Result(true, record.getId());
  140. }
  141. } catch (Exception e) {
  142. logger.error("submit", e);
  143. }
  144. return new Result(false, "下单失败");
  145. }
  146. @Override
  147. public Result pay(PayCodeOrder record) {
  148. logger.info("pay 付款码付款");
  149. try {
  150. PayCodeOrder payCodeOrder = payCodeOrderMapper.selectByPrimaryKey(record.getId());
  151. if (payCodeOrder == null) {
  152. return new Result(false, "订单不存在");
  153. }
  154. if (payCodeOrder.getMoney().compareTo(record.getPayMoney()) > 0) {
  155. return new Result(false, "支付金额小于订单金额");
  156. }
  157. if (payCodeOrder.getStatusFlag() != AppConstant.PayCodeOrderStatus.wait_pay) {
  158. return new Result(false, "订单状态不能付款");
  159. }
  160. MemberTicket memberTicket = new MemberTicket();
  161. memberTicket.setMoney(record.getPayMoney());
  162. memberTicket.setUserId(payCodeOrder.getUserId());
  163. memberTicket.setRemark("充值" + record.getPayMoney() + " 门票");
  164. memberTicket.setRechargeType(AppConstant.RechargeType.OTHER);
  165. memberTicketService.recharge(memberTicket);
  166. record.setStatusFlag(AppConstant.PayCodeOrderStatus.success);
  167. payCodeOrderMapper.updateByPrimaryKeySelective(record);
  168. return new Result(true, "付款成功");
  169. } catch (Exception e) {
  170. logger.error("pay", e);
  171. }
  172. return new Result(false, "付款失败");
  173. }
  174. @Override
  175. public Result cancel(PayCodeOrder record) {
  176. logger.info("cancel 付款码取消");
  177. try {
  178. PayCodeOrder payCodeOrder = payCodeOrderMapper.selectByPrimaryKey(record.getId());
  179. if (payCodeOrder == null) {
  180. return new Result(false, "订单不存在");
  181. }
  182. if (payCodeOrder.getStatusFlag() != AppConstant.PayCodeOrderStatus.wait_pay) {
  183. return new Result(false, "订单状态不能取消");
  184. }
  185. record.setStatusFlag(AppConstant.PayCodeOrderStatus.cancel);
  186. payCodeOrderMapper.updateByPrimaryKeySelective(record);
  187. PayCodeStock payCodeStock = new PayCodeStock();
  188. payCodeStock.setId(record.getStockId());
  189. payCodeStock = payCodeStockMapper.queryPayCodeStock(payCodeStock);
  190. if (payCodeStock != null) {
  191. payCodeStock.setAmount(payCodeStock.getAmount() + 1);
  192. payCodeStockMapper.updateByPrimaryKeySelective(payCodeStock);
  193. }
  194. return new Result(true, "付款码取消成功");
  195. } catch (Exception e) {
  196. logger.error("cancel 付款码取消", e);
  197. }
  198. return new Result(false, "付款码取消失败");
  199. }
  200. }