IposFeignController.java 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. package com.poteviohealth.ym.ipos.controller.feign;
  2. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  3. import com.google.common.collect.Lists;
  4. import com.poteviohealth.cgp.common.controller.BaseFeignController;
  5. import com.poteviohealth.cgp.common.integrated.ipos.model.*;
  6. import com.poteviohealth.cgp.common.integrated.order.model.PayBefor;
  7. import com.poteviohealth.cgp.common.integrated.order.model.PayInfoAppOutDTO;
  8. import com.poteviohealth.cgp.common.integrated.order.model.RefundReceive;
  9. import com.poteviohealth.cgp.common.model.VaultsResponse;
  10. import com.poteviohealth.cgp.common.utils.CgpTool;
  11. import com.poteviohealth.cgp.common.utils.DateUtils;
  12. import com.poteviohealth.ym.ipos.model.payment.PaymentRecords;
  13. import com.poteviohealth.ym.ipos.model.split.SplitRecords;
  14. import com.poteviohealth.ym.ipos.model.split.SplitRecordsDetail;
  15. import com.poteviohealth.ym.ipos.service.*;
  16. import com.poteviohealth.ym.ipos.utils.YmUtil;
  17. import io.swagger.annotations.Api;
  18. import io.swagger.annotations.ApiOperation;
  19. import jodd.util.StringUtil;
  20. import org.apache.commons.lang3.StringUtils;
  21. import org.apache.commons.lang3.time.DateFormatUtils;
  22. import org.springframework.beans.factory.annotation.Value;
  23. import org.springframework.stereotype.Controller;
  24. import org.springframework.web.bind.annotation.RequestBody;
  25. import org.springframework.web.bind.annotation.RequestMapping;
  26. import org.springframework.web.bind.annotation.RequestMethod;
  27. import org.springframework.web.bind.annotation.ResponseBody;
  28. import javax.annotation.Resource;
  29. import java.math.BigDecimal;
  30. import java.util.Date;
  31. import java.util.List;
  32. import java.util.Map;
  33. import java.util.stream.Collectors;
  34. /**
  35. * 第三方支付
  36. * @author Qin
  37. */
  38. @Controller
  39. @RequestMapping("/ipos/feign")
  40. @Api(tags = {"第三方-支付相关接口"})
  41. public class IposFeignController extends BaseFeignController {
  42. @Resource
  43. private IPaymentRecordsService paymentRecordsService;
  44. @Resource
  45. private IPaymentService paymentService;
  46. @Resource
  47. private ISplitRecordsService splitRecordsService;
  48. @Resource
  49. private ISplitRecordsDetailService splitRecordsDetailService;
  50. @Resource
  51. private ISplitService splitService;
  52. @Value("${pay.field.split}")
  53. private String split;
  54. @ApiOperation(value = "第三方支付信息")
  55. @RequestMapping(value = "/returnPay", method = RequestMethod.POST)
  56. @ResponseBody
  57. public VaultsResponse<PayInfoAppOutDTO> returnPay(@RequestBody PayBefor payBefor){
  58. PaymentRecords pr = new PaymentRecords();
  59. pr.setPayId(CgpTool.generateKey());
  60. pr.setPaySn(payBefor.getPaySn());
  61. pr.setTxAmt(payBefor.getPrice());
  62. pr.setOpenid(payBefor.getOpenid());
  63. pr.setAppId(payBefor.getAppId());
  64. pr.setOperatorId(payBefor.getOperatorId());
  65. pr.setPlanSplitDate(DateFormatUtils.format(DateUtils.caculDays(new Date(),17),"yyyyMMdd"));
  66. paymentRecordsService.save(pr);
  67. return paymentService.unifiedOrder(pr);
  68. }
  69. @ApiOperation(value = "退款信息")
  70. @RequestMapping(value = "/barcodeReverse", method = RequestMethod.POST)
  71. @ResponseBody
  72. public VaultsResponse barcodeReverse(@RequestBody RefundReceive refundReceive){
  73. return paymentService.barcodeReverse(refundReceive);
  74. }
  75. @ApiOperation(value = "退款信息查询")
  76. @RequestMapping(value = "/refundQuery", method = RequestMethod.POST)
  77. @ResponseBody
  78. public VaultsResponse<List<String>> refundQuery(@RequestBody List<RefundQuery> list){
  79. List<String> returnList = Lists.newArrayList();
  80. for (RefundQuery refundQuery : list) {
  81. VaultsResponse vaultsResponse = paymentService.barcodeRefundQuery(refundQuery.getTransactionId(),refundQuery.getOperatorId().toString());
  82. if(vaultsResponse.validate()){
  83. if(YmUtil.SUCCESS.equals(vaultsResponse.getData().toString())){
  84. returnList.add(refundQuery.getSn());
  85. }
  86. }
  87. }
  88. return VaultsResponse.success(returnList);
  89. }
  90. @ApiOperation(value = "分账信息")
  91. @RequestMapping(value = "/splitOrder", method = RequestMethod.POST)
  92. @ResponseBody
  93. public VaultsResponse<List<SplitPay>> splitOrder(@RequestBody List<SplitInfo> list) {
  94. final BigDecimal proportion= new BigDecimal("0.2");
  95. List<SplitPay> returnList = Lists.newArrayList();
  96. List<SplitRecords> splitRecordsList = Lists.newArrayList();
  97. List<SplitRecordsDetail> details = Lists.newArrayList();
  98. for (SplitInfo splitInfo : list) {
  99. SplitRecords records = new SplitRecords();
  100. records.setOperatorId(splitInfo.getOperatorId());
  101. records.setSplitId(CgpTool.generateKey());
  102. records.setPayId(splitInfo.getPayId());
  103. records.setPaySn(splitInfo.getPaySn());
  104. records.setSumPrice(splitInfo.getSumPrice());
  105. SplitPay sp = new SplitPay();
  106. sp.setPayId(records.getPayId());
  107. sp.setSplitId(records.getSplitId());
  108. //平台分成
  109. SplitRecordsDetail pt = new SplitRecordsDetail();
  110. pt.setSplitId(records.getSplitId());
  111. pt.setSourceId(0);
  112. BigDecimal ptAmount = BigDecimal.ZERO;
  113. BigDecimal tzAmount = BigDecimal.ZERO;
  114. BigDecimal ptyysAmount = BigDecimal.ZERO;
  115. BigDecimal supplierOneAmount = BigDecimal.ZERO;
  116. BigDecimal supplierTwoAmount = BigDecimal.ZERO;
  117. BigDecimal supplierAmount = BigDecimal.ZERO;
  118. //团长分成
  119. SplitRecordsDetail tz = new SplitRecordsDetail();
  120. tz.setSplitId(records.getSplitId());
  121. tz.setSourceId(3);
  122. for (SplitDetail detail : splitInfo.getDetails()) {
  123. //运算价格
  124. BigDecimal price = new BigDecimal(detail.getPrice()).multiply(proportion);
  125. //平台金额
  126. BigDecimal ptDecimal = new BigDecimal(split).multiply(new BigDecimal(detail.getPrice()));
  127. BigDecimal valDecimal = new BigDecimal(1);
  128. if(ptDecimal.longValue() > 0){
  129. valDecimal = ptDecimal;
  130. }
  131. price = price.subtract(valDecimal);
  132. ptAmount.add(valDecimal);
  133. //团长金额
  134. if (StringUtil.isNotEmpty(detail.getGroupLeaderMerchantId())) {
  135. tz.setMerchantId(detail.getGroupLeaderMerchantId());
  136. BigDecimal tbd = detail.getGroupCommission().multiply(new BigDecimal(detail.getPrice()));
  137. price = price.subtract(tbd);
  138. tzAmount.add(tbd);
  139. }
  140. detail.setPrice(price.longValue());
  141. }
  142. pt.setDivAmt(ptAmount.toString());
  143. details.add(pt);
  144. if (tzAmount.compareTo(BigDecimal.ZERO) == 1) {
  145. tz.setDivAmt(tzAmount.toString());
  146. details.add(tz);
  147. }
  148. //一级供应商
  149. Map<String, List<SplitDetail>> oneMaps = splitInfo.getDetails().stream().filter(s -> StringUtils.isNotEmpty(s.getSupplierOneMerchantId()) && s.getBelong().equals(1)).collect(Collectors.groupingBy(SplitDetail::getSupplierOneMerchantId));
  150. for (String s : oneMaps.keySet()) {
  151. SplitRecordsDetail supplierOne = new SplitRecordsDetail();
  152. supplierOne.setSplitId(records.getSplitId());
  153. supplierOne.setSourceId(2);
  154. supplierOne.setMerchantId(s);
  155. for (SplitDetail detail : oneMaps.get(s)) {
  156. supplierOneAmount = supplierOneAmount.add(new BigDecimal(detail.getConsignmentPrice()).multiply(proportion));
  157. detail.setPrice(detail.getPrice() - detail.getConsignmentPrice());
  158. }
  159. if (supplierOneAmount.compareTo(BigDecimal.ZERO) == 1) {
  160. supplierOne.setDivAmt(supplierOneAmount.toString());
  161. details.add(supplierOne);
  162. }
  163. }
  164. //二级供应商
  165. Map<String, List<SplitDetail>> twoMaps = splitInfo.getDetails().stream().filter(s -> StringUtils.isNotEmpty(s.getServiceStationMerchantId()) && s.getBelong().equals(2)).collect(Collectors.groupingBy(SplitDetail::getServiceStationMerchantId));
  166. for (String s : twoMaps.keySet()) {
  167. SplitRecordsDetail supplierTwo = new SplitRecordsDetail();
  168. supplierTwo.setSplitId(records.getSplitId());
  169. supplierTwo.setSourceId(2);
  170. supplierTwo.setMerchantId(s);
  171. for (SplitDetail detail : twoMaps.get(s)) {
  172. supplierTwoAmount = supplierTwoAmount.add(new BigDecimal(detail.getConsignmentPrice()).multiply(proportion));
  173. detail.setPrice(detail.getPrice() - detail.getConsignmentPrice());
  174. }
  175. if (supplierTwoAmount.compareTo(BigDecimal.ZERO) == 1) {
  176. supplierTwo.setDivAmt(supplierTwoAmount.toString());
  177. details.add(supplierTwo);
  178. }
  179. }
  180. //供应商
  181. Map<String, List<SplitDetail>> maps = splitInfo.getDetails().stream().filter(s -> StringUtils.isNotEmpty(s.getSupplierMerchantId()) && s.getBelong().equals(0)).collect(Collectors.groupingBy(SplitDetail::getSupplierMerchantId));
  182. for (String s : maps.keySet()) {
  183. SplitRecordsDetail supplier = new SplitRecordsDetail();
  184. supplier.setSplitId(records.getSplitId());
  185. supplier.setSourceId(2);
  186. supplier.setMerchantId(s);
  187. for (SplitDetail detail : maps.get(s)) {
  188. supplierAmount = supplierAmount.add(new BigDecimal(detail.getSettlementPrice()).multiply(proportion));
  189. detail.setPrice(detail.getPrice() - detail.getSettlementPrice());
  190. }
  191. if (supplierAmount.compareTo(BigDecimal.ZERO) == 1) {
  192. supplier.setDivAmt(supplierAmount.toString());
  193. details.add(supplier);
  194. }
  195. }
  196. //平台运营商
  197. SplitRecordsDetail ptyys = new SplitRecordsDetail();
  198. ptyys.setSplitId(records.getSplitId());
  199. ptyys.setSourceId(1);
  200. for (SplitDetail detail : splitInfo.getDetails()) {
  201. ptyysAmount = ptyysAmount.add(new BigDecimal(detail.getPrice()));
  202. }
  203. ptyys.setMerchantId(splitInfo.getOperatorMerchantId());
  204. ptyys.setDivAmt(ptyysAmount.toString());
  205. details.add(ptyys);
  206. VaultsResponse vaultsResponse = splitService.delayConfirm(records,details);
  207. if(!vaultsResponse.validate()){
  208. records.setComment(vaultsResponse.getMessage());
  209. }
  210. records.setStatus(2);
  211. splitRecordsList.add(records);
  212. splitRecordsService.saveBatch(splitRecordsList);
  213. splitRecordsDetailService.saveBatch(details);
  214. returnList.add(sp);
  215. }
  216. return VaultsResponse.success(returnList);
  217. }
  218. @ApiOperation(value = "延时交易确认查询")
  219. @RequestMapping(value = "/delayConfirmQuery", method = RequestMethod.POST)
  220. @ResponseBody
  221. public VaultsResponse<List<DelayConfirmQuery>> delayConfirmQuery(@RequestBody List<DelayConfirmQuery> list){
  222. for (DelayConfirmQuery dcfq : list) {
  223. VaultsResponse vaultsResponse = splitService.delayConfirmQuery(dcfq.getSplitId().toString(),dcfq.getOperatorId().toString());
  224. if(vaultsResponse.validate()){
  225. dcfq.setStatus(1);
  226. }
  227. SplitRecords splitRecords = new SplitRecords();
  228. splitRecords.setStatus(1);
  229. QueryWrapper<SplitRecords> queryWrapper = new QueryWrapper<>();
  230. queryWrapper.eq("split_id",dcfq.getSplitId());
  231. splitRecordsService.update(splitRecords,queryWrapper);
  232. }
  233. return VaultsResponse.success(list);
  234. }
  235. }