Merge branch 'master' of https://gitee.com/op-souls/ghy-all
This commit is contained in:
commit
0d43a7f274
|
|
@ -3,7 +3,7 @@
|
|||
<head>
|
||||
<meta charset="utf-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0">
|
||||
<title>登录叮咚工链系统</title>
|
||||
<title>追风者</title>
|
||||
<meta name="description" content="叮咚工链后台管理框架">
|
||||
<link href="../static/css/bootstrap.min.css" th:href="@{/css/bootstrap.min.css}" rel="stylesheet"/>
|
||||
<link href="../static/css/font-awesome.min.css" th:href="@{/css/font-awesome.min.css}" rel="stylesheet"/>
|
||||
|
|
@ -66,6 +66,7 @@
|
|||
<div class="signup-footer">
|
||||
<div class="pull-left">
|
||||
Copyright © 2018-2021 opsoul.com All Rights Reserved. <br>
|
||||
备案号 粤ICP备2021044349号-1
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
|
|
|||
|
|
@ -0,0 +1,6 @@
|
|||
package com.ghy.common.adapay;
|
||||
|
||||
public interface AdapayErrorCode {
|
||||
|
||||
String CONFIRM_AMT_OVER_LIMIT = "confirm_amt_over_limit";
|
||||
}
|
||||
|
|
@ -2,6 +2,7 @@ package com.ghy.order.service.impl;
|
|||
|
||||
import com.alibaba.fastjson.JSON;
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import com.ghy.common.adapay.AdapayErrorCode;
|
||||
import com.ghy.common.adapay.model.AdapayStatusEnum;
|
||||
import com.ghy.common.adapay.model.DivMember;
|
||||
import com.ghy.common.adapay.model.PaymentDTO;
|
||||
|
|
@ -13,7 +14,6 @@ import com.ghy.common.enums.PayStatus;
|
|||
import com.ghy.common.exception.base.BaseException;
|
||||
import com.ghy.common.utils.AdapayUtils;
|
||||
import com.ghy.common.utils.ObjectUtils;
|
||||
import com.ghy.common.utils.StringUtils;
|
||||
import com.ghy.order.domain.OrderDetail;
|
||||
import com.ghy.order.domain.OrderGoods;
|
||||
import com.ghy.order.domain.OrderMaster;
|
||||
|
|
@ -32,6 +32,7 @@ import com.ghy.payment.service.FinancialMasterService;
|
|||
import com.huifu.adapay.core.exception.BaseAdaPayException;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
import org.springframework.beans.factory.annotation.Value;
|
||||
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
|
@ -44,10 +45,7 @@ import java.math.RoundingMode;
|
|||
import java.time.LocalDateTime;
|
||||
import java.time.format.DateTimeFormatter;
|
||||
import java.time.format.DateTimeFormatterBuilder;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.*;
|
||||
import java.util.concurrent.atomic.AtomicLong;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
|
|
@ -84,6 +82,10 @@ public class OrderDetailServiceImpl implements OrderDetailService {
|
|||
@Resource
|
||||
private OrderGoodsService orderGoodsService;
|
||||
|
||||
// Adapay 手续费率 默认0.008
|
||||
@Value("${adapay.fee_rate:0.008}")
|
||||
private String feeRate;
|
||||
|
||||
@Override
|
||||
public int insertOrderDetail(OrderDetail orderDetail) {
|
||||
return orderDetailMapper.insertOrderDetail(orderDetail);
|
||||
|
|
@ -113,7 +115,7 @@ public class OrderDetailServiceImpl implements OrderDetailService {
|
|||
Integer masterServerGoodsNum = masterGoodsMap.get(orderGoods.getGoodsStandardId()).getServerGoodsNum();
|
||||
masterGoodsMap.get(orderGoods.getGoodsStandardId()).setServerGoodsNum(masterServerGoodsNum += orderGoods.getServerGoodsNum());
|
||||
});
|
||||
} else if (OrderStatus.FINISH_CHECK.code() == originOrderDetail.getOrderStatus() && orderDetail.getOrderStatus() < OrderStatus.FINISH_CHECK.code()){
|
||||
} else if (OrderStatus.FINISH_CHECK.code() == originOrderDetail.getOrderStatus() && orderDetail.getOrderStatus() < OrderStatus.FINISH_CHECK.code()) {
|
||||
List<OrderGoods> orderGoodsList = orderGoodsService.selectByOrderDetailId(orderDetail.getId());
|
||||
orderGoodsList.stream().forEach(orderGoods -> {
|
||||
orderGoods.setServerGoodsNum(0);
|
||||
|
|
@ -124,7 +126,7 @@ public class OrderDetailServiceImpl implements OrderDetailService {
|
|||
});
|
||||
}
|
||||
// 更新主单关联商品
|
||||
masterOrderGoodsList.stream().forEach(masterOrderGoods ->{
|
||||
masterOrderGoodsList.stream().forEach(masterOrderGoods -> {
|
||||
orderGoodsService.updateOrderGoods(masterOrderGoods);
|
||||
});
|
||||
|
||||
|
|
@ -321,7 +323,7 @@ public class OrderDetailServiceImpl implements OrderDetailService {
|
|||
* 子订单确认完成
|
||||
* 1.修改子订单状态为 OrderStatus.FINISH.code
|
||||
* 2.将子订单对应的子财务单确认分账
|
||||
* 3.异步提现至银行卡
|
||||
* 3.提现至银行卡
|
||||
*
|
||||
* @param orderDetailId 子订单ID
|
||||
*/
|
||||
|
|
@ -331,127 +333,193 @@ public class OrderDetailServiceImpl implements OrderDetailService {
|
|||
public synchronized void finish(Long orderDetailId) throws BaseAdaPayException {
|
||||
// 校验订单
|
||||
OrderDetail orderDetail = selectById(orderDetailId);
|
||||
if(orderDetail == null){
|
||||
if (orderDetail == null) {
|
||||
throw new BaseException("找不到对应的子订单");
|
||||
}
|
||||
String odCode = orderDetail.getCode();
|
||||
Assert.isTrue(!orderDetail.getOrderStatus().equals(OrderStatus.FINISH.code()), "订单已经是完成状态");
|
||||
FinancialMaster financialMaster = financialMasterService.selectByOrderMasterId(orderDetail.getOrderMasterId());
|
||||
if(financialMaster == null){
|
||||
if (financialMaster == null) {
|
||||
throw new BaseException("找不到主财务单");
|
||||
}
|
||||
PaymentDTO payment = financialMasterService.selectPaymentById(financialMaster.getPaymentId());
|
||||
if(payment == null){
|
||||
if (payment == null) {
|
||||
throw new BaseException("找不到支付记录");
|
||||
}
|
||||
List<FinancialDetail> financialDetail = financialDetailService.selectListByOrderDetailId(orderDetailId);
|
||||
if(financialDetail == null){
|
||||
List<FinancialDetail> financialDetails = financialDetailService.selectListByOrderDetailId(orderDetailId);
|
||||
if (CollectionUtils.isEmpty(financialDetails)) {
|
||||
throw new BaseException("找不到子财务单");
|
||||
}
|
||||
if(financialDetail.get(0).getPayStatus() != 1){
|
||||
// 子订单对应的子财务单只有一条 直接取出
|
||||
FinancialDetail financialDetail = financialDetails.get(0);
|
||||
if (financialDetail.getPayStatus() != 1) {
|
||||
throw new BaseException("订单不是“已支付”状态");
|
||||
}
|
||||
Long financialMasterId = financialDetail.getFinancialMasterId();
|
||||
// 找到 type=平台抽成 的子财务单 用来承担手续费
|
||||
List<FinancialDetail> details = financialDetailService.selectByFinancialMasterIdAndType(financialMasterId, 3);
|
||||
FinancialDetail platformFD = details.get(0);
|
||||
FinancialDetail update = new FinancialDetail();
|
||||
update.setId(platformFD.getId());
|
||||
|
||||
logger.debug("子订单[code={}]的完单流程开始", odCode);
|
||||
|
||||
// 更新订单状态
|
||||
orderDetailMapper.updateStatus(orderDetailId, OrderStatus.FINISH.code());
|
||||
// 找到所有的加价记录
|
||||
|
||||
// 加价单手续费补偿成功与否
|
||||
boolean compensate = false;
|
||||
// 加价单手续费
|
||||
BigDecimal feeAmt = null;
|
||||
// 待提现金额
|
||||
BigDecimal dtx = BigDecimal.ZERO;
|
||||
// 加价金额
|
||||
BigDecimal addPrice;
|
||||
// 子单收款人的memberId
|
||||
String memberId = AdapayUtils.getWorkerMemberId(financialDetail.getPayeeId(), financialDetail.getDeptId());
|
||||
|
||||
// --------------------- 改价单分账部分 start ---------------------
|
||||
// 查询子订单的加价记录
|
||||
List<FinancialChangeRecord> financialChangeRecords = financialChangeRecordService.selectByDetailIds(String.valueOf(orderDetailId));
|
||||
if(!CollectionUtils.isEmpty(financialChangeRecords)){
|
||||
if (!CollectionUtils.isEmpty(financialChangeRecords)) {
|
||||
ArrayList<DivMember> divMembers = new ArrayList<>();
|
||||
financialChangeRecords.forEach(financialChangeRecord -> {
|
||||
// 递增解决分账
|
||||
financialDetail.forEach(detail->{
|
||||
BigDecimal money;
|
||||
// 剩余金额足够本次分账
|
||||
if(financialChangeRecord.getLeftMoney().compareTo(detail.getPayMoney()) > 0){
|
||||
money = detail.getPayMoney();
|
||||
detail.setPayMoney(BigDecimal.ZERO);
|
||||
}else {
|
||||
// 剩余金额不够分账
|
||||
money = financialChangeRecord.getLeftMoney();
|
||||
detail.setPayMoney(detail.getPayMoney().subtract(money));
|
||||
}
|
||||
String memberId = AdapayUtils.getWorkerMemberId(detail.getPayeeId(), detail.getDeptId());
|
||||
DivMember divMember = new DivMember(memberId, AdapayUtils.bigDecimalToString(money), false);
|
||||
divMembers.add(divMember);
|
||||
});
|
||||
//调用分账
|
||||
logger.info("子订单[code={}]分账信息: {}", orderDetail.getCode(), JSON.toJSONString(divMembers));
|
||||
JSONObject response;
|
||||
try {
|
||||
response = adapayService.paymentConfirm(financialDetail.get(0).getDeptId(), financialChangeRecord.getRemark(), payment.getOrderNo() + "_" + System.currentTimeMillis(),
|
||||
String.valueOf(financialChangeRecord.getLeftMoney()), divMembers, null, null);
|
||||
logger.info("子订单[code={}]分账结果: {}", orderDetail.getCode(), response.toJSONString());
|
||||
} catch (BaseAdaPayException e) {
|
||||
throw new RuntimeException(e);
|
||||
// 改价记录只会有一条 直接取出
|
||||
FinancialChangeRecord fcRecord = financialChangeRecords.get(0);
|
||||
addPrice = fcRecord.getChangeMoney();
|
||||
// 待提现金额里加入改价单金额
|
||||
dtx = dtx.add(fcRecord.getChangeMoney());
|
||||
// 这里先自己承担手续费 后面再用平台抽成来补偿
|
||||
DivMember divMember = new DivMember(memberId, AdapayUtils.bigDecimalToString(fcRecord.getChangeMoney()), true);
|
||||
divMembers.add(divMember);
|
||||
//调用分账
|
||||
logger.info("子订单[code={}]的[改价单]的分账信息: {}", odCode, JSON.toJSONString(divMembers));
|
||||
JSONObject response = adapayService.paymentConfirm(financialDetail.getDeptId(), fcRecord.getRemark(),
|
||||
payment.getOrderNo() + "_" + System.currentTimeMillis(),
|
||||
AdapayUtils.bigDecimalToString(fcRecord.getChangeMoney()), divMembers, null, null);
|
||||
if (AdapayStatusEnum.succeeded.code.equals(response.getString("status"))) { // 分账成功
|
||||
logger.info("子订单[code={}]的[改价单]分账成功", odCode);
|
||||
// 这是被扣掉的手续费
|
||||
String fee_amt = response.getString("fee_amt");
|
||||
feeAmt = new BigDecimal(fee_amt);
|
||||
if (feeAmt.compareTo(platformFD.getPayMoney()) < 0 && !"0.00".equals(fee_amt)) {
|
||||
// 用平台抽成来补偿改价单的手续费 修改平台抽成子财务单金额
|
||||
update.setPayMoney(platformFD.getPayMoney().subtract(feeAmt));
|
||||
int i = financialDetailService.updateFinancialDetail(update);
|
||||
compensate = i > 0;
|
||||
} else {
|
||||
logger.warn("主订单[code={}]的平台抽成金额不足以承担子订单[code={}]的[改价单]的手续费",
|
||||
orderDetail.getOrderMasterCode(), odCode);
|
||||
// 平台抽成不足以承担改价单手续费了 那没办法了只能自己承担
|
||||
// 待提现金额里减去改价单手续费
|
||||
dtx = dtx.subtract(feeAmt);
|
||||
}
|
||||
});
|
||||
} else { // 分账失败
|
||||
if (AdapayErrorCode.CONFIRM_AMT_OVER_LIMIT.equals(response.getString("error_code"))) {
|
||||
// 当前确认金额 > 支付金额 - 已支付确认金额 - 已支付撤销金额
|
||||
// 这里有两种可能 1.可能是之前算错了手续费的旧订单
|
||||
// 2.可能是之前执行过完单流程 改价单分账成功了 但是子财务单分账失败了
|
||||
// 所以直接跳过
|
||||
logger.info("子订单[code={}] 跳过[改价单]分账", odCode);
|
||||
} else {
|
||||
logger.error("子订单[code={}]的[改价单 paymentId={}]分账失败: {}", odCode, fcRecord.getRemark(), response.toJSONString());
|
||||
// 其它错误抛异常
|
||||
throw new IllegalArgumentException(response.getString("error_msg"));
|
||||
}
|
||||
}
|
||||
} else {
|
||||
addPrice = BigDecimal.ZERO;
|
||||
}
|
||||
// --------------------- 改价单分账部分 end ---------------------
|
||||
|
||||
// --------------------- 子财务单分账部分 start ---------------------
|
||||
// 分账账户信息
|
||||
Map<String, DivMember> divMemberMap = new HashMap<>();
|
||||
|
||||
ArrayList<DivMember> divMembers = new ArrayList<>();
|
||||
BigDecimal feeAmount = BigDecimal.ZERO;
|
||||
for (FinancialDetail detail : financialDetail) {
|
||||
if (BigDecimal.ZERO.compareTo(detail.getPayMoney()) > -1) {
|
||||
logger.info("子财务单[code={}]支付金额<=0,不需要分账", detail.getCode());
|
||||
// 支付金额<=0的话 不需要走下面的流程了
|
||||
continue;
|
||||
// 子单的实际金额
|
||||
BigDecimal fdPayMoney = financialDetail.getPayMoney().subtract(addPrice);
|
||||
// 实际要分账的金额(子单的实际金额 + 平台补偿改价单手续费)
|
||||
BigDecimal payMoney;
|
||||
if (compensate) {
|
||||
// 平台补偿改价单手续费
|
||||
payMoney = fdPayMoney.add(feeAmt);
|
||||
} else {
|
||||
// 平台不补偿改价单手续费
|
||||
payMoney = fdPayMoney;
|
||||
}
|
||||
if (BigDecimal.ZERO.compareTo(payMoney) > -1) {
|
||||
logger.info("子财务单[code={}] 应支付金额={} 不需要分账", financialDetail.getCode(), payMoney);
|
||||
} else {
|
||||
// 接单师傅的分账信息
|
||||
String payMoneyS = AdapayUtils.bigDecimalToString(payMoney);
|
||||
DivMember divMember = new DivMember(memberId, payMoneyS, false);
|
||||
divMembers.add(divMember);
|
||||
|
||||
// 计算本次分账的手续费 保留两位小数(向上取整)
|
||||
BigDecimal fee = payMoney.multiply(new BigDecimal(feeRate)).setScale(2, RoundingMode.UP);
|
||||
// 平台的分账信息 用来承担手续费
|
||||
DivMember feeDivMember = new DivMember("0", fee.toString(), true);
|
||||
divMembers.add(feeDivMember);
|
||||
|
||||
logger.info("子订单[code={}]分账信息: {}", odCode, JSON.toJSONString(divMembers));
|
||||
JSONObject response = adapayService.paymentConfirm(financialDetail.getDeptId(), payment.getId(), payment.getOrderNo() + "_" + System.currentTimeMillis(),
|
||||
fee.add(payMoney).toString(), divMembers, null, null);
|
||||
logger.info("子订单[code={}]分账结果: {}", odCode, response.toJSONString());
|
||||
boolean status = AdapayStatusEnum.succeeded.code.equals(response.getString("status"));
|
||||
// 如果确认支付失败 这里抛出异常 回滚订单状态
|
||||
Assert.isTrue(status, response.getString("error_msg"));
|
||||
// 待提现金额里加入子财务单金额
|
||||
dtx = dtx.add(payMoney);
|
||||
// 修改平台抽成子财务单金额
|
||||
update.setPayMoney(platformFD.getPayMoney().subtract(fee));
|
||||
financialDetailService.updateFinancialDetail(update);
|
||||
}
|
||||
// --------------------- 子财务单分账部分 end ---------------------
|
||||
|
||||
// --------------------- 自动提现流程 start ---------------------
|
||||
// 走到这里确认分账成功了 进入自动提现流程
|
||||
logger.info("子订单[code={}]开始自动提现", odCode);
|
||||
if (BigDecimal.ZERO.compareTo(dtx) > -1) {
|
||||
logger.info("子订单[code={}] 待提现金额={} 无需提现", odCode, dtx);
|
||||
}
|
||||
try {
|
||||
String orderNo = AdapayUtils.createOrderNo(AdapayOrderType.DRAW_CASH);
|
||||
// 待提现金额
|
||||
String cashAmt = AdapayUtils.bigDecimalToString(dtx);
|
||||
JSONObject drawCashResponse = adapayService.drawCash(financialDetail.getDeptId(), orderNo, "T1",
|
||||
cashAmt, memberId, "订单结算", null);
|
||||
boolean drawCashStatus = AdapayStatusEnum.pending.code.equals(drawCashResponse.getString("status")) ||
|
||||
AdapayStatusEnum.succeeded.code.equals(drawCashResponse.getString("status"));
|
||||
if (drawCashStatus) {
|
||||
// 提现成功
|
||||
logger.info("子订单[code={}]自动提现成功", odCode);
|
||||
} else {
|
||||
// 提现失败 把信息记录到error日志里
|
||||
logger.error("自动发起提现失败: 子订单code={}, deptId={}, memberId={}, amount={}, 失败信息: {}", odCode,
|
||||
financialDetail.getDeptId(), memberId, cashAmt, drawCashResponse.toJSONString());
|
||||
}
|
||||
// 重复的数据一次提现
|
||||
String memberId = AdapayUtils.getWorkerMemberId(detail.getPayeeId(), detail.getDeptId());
|
||||
DivMember divMember;
|
||||
if(divMemberMap.containsKey(memberId)){
|
||||
divMember = divMemberMap.get(memberId);
|
||||
divMember.setAmount(AdapayUtils.bigDecimalToString(new BigDecimal(divMember.getAmount()).add(detail.getPayMoney())));
|
||||
}else {
|
||||
divMember = new DivMember(memberId, AdapayUtils.bigDecimalToString(detail.getPayMoney()), false);
|
||||
divMemberMap.put(memberId, divMember);
|
||||
}
|
||||
feeAmount = feeAmount.add(detail.getPayMoney());
|
||||
} catch (Exception e) {
|
||||
logger.error("自动发起提现失败: 子订单code={}, deptId={}, memberId={}", odCode, financialDetail.getDeptId(), memberId, e);
|
||||
}
|
||||
for (Map.Entry<String, DivMember> entry : divMemberMap.entrySet()) {
|
||||
divMembers.add(entry.getValue());
|
||||
}
|
||||
BigDecimal fee = BigDecimal.ZERO;
|
||||
if(feeAmount.multiply(BigDecimal.valueOf(0.004)).compareTo(BigDecimal.valueOf(0.01)) < 1){
|
||||
fee = fee.add(BigDecimal.valueOf(0.01));
|
||||
}else {
|
||||
fee = feeAmount.multiply(BigDecimal.valueOf(0.004));
|
||||
}
|
||||
DivMember feeDivMember = new DivMember("0", AdapayUtils.bigDecimalToString(fee), true);
|
||||
divMembers.add(feeDivMember);
|
||||
// --------------------- 自动提现流程 end ---------------------
|
||||
|
||||
BigDecimal totalMoney = feeAmount.add(fee.setScale(2, RoundingMode.CEILING));
|
||||
// 扣除交易费用
|
||||
String sureMoney = AdapayUtils.bigDecimalToString(totalMoney);
|
||||
|
||||
logger.info("子订单[code={}]分账信息: {}", orderDetail.getCode(), JSON.toJSONString(divMembers));
|
||||
JSONObject response = adapayService.paymentConfirm(financialDetail.get(0).getDeptId(), payment.getId(), payment.getOrderNo() + "_" + System.currentTimeMillis(),
|
||||
sureMoney, divMembers, null, null);
|
||||
logger.info("子订单[code={}]分账结果: {}", orderDetail.getCode(), response.toJSONString());
|
||||
|
||||
boolean status = AdapayStatusEnum.pending.code.equals(response.getString("status")) ||
|
||||
AdapayStatusEnum.succeeded.code.equals(response.getString("status"));
|
||||
// 如果确认支付失败 这里抛出异常 回滚订单状态
|
||||
Assert.isTrue(status, response.getString("error_msg"));
|
||||
// 走到这里确认分账成功了 异步进入自动提现流程
|
||||
logger.info("子订单[code={}]开始自动提现", orderDetail.getCode());
|
||||
divMembers.forEach(member -> {
|
||||
try {
|
||||
String orderNo = AdapayUtils.createOrderNo(AdapayOrderType.DRAW_CASH);
|
||||
JSONObject drawCashResponse = adapayService.drawCash(financialDetail.get(0).getDeptId(), orderNo, "T1",
|
||||
member.getAmount(), member.getMemberId(), "订单结算", null);
|
||||
|
||||
boolean drawCashStatus = AdapayStatusEnum.pending.code.equals(drawCashResponse.getString("status")) ||
|
||||
AdapayStatusEnum.succeeded.code.equals(drawCashResponse.getString("status"));
|
||||
|
||||
if (!drawCashStatus) {
|
||||
//如果提现失败 把信息记录到error日志里
|
||||
logger.error("自动发起提现失败: deptId={}, memberId={}, amount={}, 失败原因:{}", financialDetail.get(0).getDeptId(),
|
||||
member.getMemberId(), member.getAmount(), drawCashResponse.getString("error_msg"));
|
||||
// --------------------- 触发主订单完单流程 start ---------------------
|
||||
try {
|
||||
List<OrderDetail> orderDetails = orderDetailMapper.selectByOrderMasterId(orderDetail.getOrderMasterId());
|
||||
Set<Integer> statusSet = orderDetails.stream().map(OrderDetail::getOrderStatus).collect(Collectors.toSet());
|
||||
boolean allFinish = true;
|
||||
for (Integer integer : statusSet) {
|
||||
if (integer < 5) {
|
||||
allFinish = false;
|
||||
break;
|
||||
}
|
||||
} catch (BaseAdaPayException e) {
|
||||
logger.error("自动发起提现失败: orderDetailId={}, memberId={}, cashAmt={}", orderDetailId, member.getMemberId(), member.getAmount(), e);
|
||||
}
|
||||
});
|
||||
// 如果已经不存在"已完成"和"已取消"以外的子订单 就把主订单也改为完成
|
||||
if (allFinish) {
|
||||
orderMasterService.finish(orderDetail.getOrderMasterId());
|
||||
}
|
||||
} catch (Exception e) {
|
||||
logger.error(e.getMessage(), e);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
@ -463,7 +531,7 @@ public class OrderDetailServiceImpl implements OrderDetailService {
|
|||
@Transactional(rollbackFor = Exception.class)
|
||||
public int changePrice(Long orderDetailId, BigDecimal changeMoney, Integer type, String remark) throws Exception {
|
||||
OrderDetail orderDetail = orderDetailMapper.selectById(orderDetailId);
|
||||
if(orderDetail==null){
|
||||
if (orderDetail == null) {
|
||||
throw new BaseException("子单不存在!");
|
||||
}
|
||||
FinancialChangeRecord param = new FinancialChangeRecord();
|
||||
|
|
|
|||
|
|
@ -56,7 +56,8 @@ public class FinancialDetail extends BaseEntity {
|
|||
* 收款人ID
|
||||
* 当财务子单类型是师傅转派时 收款人ID是师傅或徒弟的workerId
|
||||
* 当财务子单类型是多级分销时 收款人ID是分销者的customerId
|
||||
* 当财务子单类型是4或5时 无需填写收款人ID
|
||||
* 当财务子单类型是4时 无需填写收款人ID
|
||||
* 当财务子单类型是3,5时 金额属于平台 无需填写收款人ID
|
||||
*/
|
||||
@Excel(name = "收款人ID", cellType = Excel.ColumnType.NUMERIC)
|
||||
private Long payeeId;
|
||||
|
|
|
|||
|
|
@ -70,6 +70,25 @@ public class AdapayService {
|
|||
* @param feeMode String(1) 手续费收取模式:O-商户手续费账户扣取手续费,I-交易金额中扣取手续费;值为空时,默认值为I;若为O时,分账对象列表中不支持传入手续费承担方
|
||||
* @param description String(128) 附加说明
|
||||
* @return 成功时同步返回一个包含 支付确认对象的JSON https://docs.adapay.tech/api/trade.html#id54
|
||||
* 成功示例:{
|
||||
* "order_no": "TEST18888888888_001",
|
||||
* "created_time": "1670932918",
|
||||
* "confirm_amt": "10.00",
|
||||
* "confirmed_amt": "0.00",
|
||||
* "reserved_amt": "0.00",
|
||||
* "div_members": [{
|
||||
* "member_id": "W7D888",
|
||||
* "amount": "10.00",
|
||||
* "fee_flag": "Y"
|
||||
* }],
|
||||
* "refunded_amt": "0.00",
|
||||
* "prod_mode": "true",
|
||||
* "id": "0021120221213200158990448709336858888888",
|
||||
* "app_id": "app_01af32e7-6173-414f-88e5-79cae64d5e24",
|
||||
* "fee_amt": "0.08",
|
||||
* "object": "payment_confirm",
|
||||
* "status": "succeeded"
|
||||
* }
|
||||
*/
|
||||
public JSONObject paymentConfirm(@NotNull Long deptId, @NotNull String paymentId, @NotNull String orderNo,
|
||||
@NotNull String confirmAmt, List<DivMember> divMembers,
|
||||
|
|
@ -278,6 +297,22 @@ public class AdapayService {
|
|||
* @param deviceInfo 前端设备信息 https://docs.adapay.tech/api/appendix.html#deviceinfo
|
||||
* @param divMembers 分账对象信息列表 https://docs.adapay.tech/api/appendix.html#divmembers
|
||||
* @return 同步返回一个 支付对象,详见 https://docs.adapay.tech/api/trade.html#id2
|
||||
* 成功示例: {
|
||||
* "order_no": "TEST18888888888_001",
|
||||
* "created_time": "1670932358",
|
||||
* "party_order_id": "02212212137155817188888",
|
||||
* "pay_amt": "10.00",
|
||||
* "expend": {
|
||||
* "qrcode_url": "https://qr.alipay.com/bax022139la4gqagxbti8888"
|
||||
* },
|
||||
* "prod_mode": "true",
|
||||
* "pay_channel": "alipay_qr",
|
||||
* "query_url": "https://api.adapay.tech/v1/expire/payments/1/cff1102a8a0d5d4be1d444acb7726fdd",
|
||||
* "id": "002112022121319523810448706986096888888",
|
||||
* "app_id": "app_01af32e7-6173-414f-88e5-79cae64d5e24",
|
||||
* "object": "payment",
|
||||
* "status": "succeeded"
|
||||
* }
|
||||
*/
|
||||
public JSONObject pay(@NotNull Long deptId, @NotNull String payChannel, @NotNull PayParam payParam,
|
||||
Expend expend, DeviceInfo deviceInfo,
|
||||
|
|
|
|||
|
|
@ -14,9 +14,9 @@ import java.util.Map;
|
|||
public interface FinancialDetailService {
|
||||
|
||||
/**
|
||||
* @param countTime 是否查询准确时间
|
||||
* @param countTime 是否查询准确时间
|
||||
* @param financialDetailTypes 子财务单类型
|
||||
* @param payeeId 收款人id
|
||||
* @param payeeId 收款人id
|
||||
* @return 月份集合
|
||||
*/
|
||||
List<FinancialCountResponse> count(String countTime, List<Integer> financialDetailTypes, Integer payeeId);
|
||||
|
|
@ -67,6 +67,7 @@ public interface FinancialDetailService {
|
|||
int deleteFinancialDetailByIds(String ids);
|
||||
|
||||
int deleteFinancialDetailByOrderDetailId(Long orderDetailId);
|
||||
|
||||
/**
|
||||
* 校验财务细单编码是否重复
|
||||
*
|
||||
|
|
@ -102,4 +103,12 @@ public interface FinancialDetailService {
|
|||
* @param financialDetail 子财务单
|
||||
*/
|
||||
void updateByFinancialMasterId(FinancialDetail financialDetail);
|
||||
|
||||
/**
|
||||
* 查询主财务单下指定类型的子财务单
|
||||
*
|
||||
* @param financialMasterId 主财务单id
|
||||
* @param type 子财务单类型 FinancialDetail.financialDetailType
|
||||
*/
|
||||
List<FinancialDetail> selectByFinancialMasterIdAndType(Long financialMasterId, int type);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -142,6 +142,14 @@ public class FinancialDetailServiceImpl implements FinancialDetailService {
|
|||
financialDetailMapper.updateByFinancialMasterId(financialDetail);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<FinancialDetail> selectByFinancialMasterIdAndType(Long financialMasterId, int type) {
|
||||
FinancialDetail financialDetail = new FinancialDetail();
|
||||
financialDetail.setFinancialMasterId(financialMasterId);
|
||||
financialDetail.setFinancialDetailType(type);
|
||||
return financialDetailMapper.selectFinancialDetailList(financialDetail);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Map<Long, FinancialDetail> byOrderIdInMap(List<Long> orderIdList) {
|
||||
Map<Long, FinancialDetail> longFinancialDetailHashMap = new HashMap<>();
|
||||
|
|
|
|||
|
|
@ -75,6 +75,9 @@
|
|||
<if test="payeeId != null">
|
||||
and payee_id = #{payeeId}
|
||||
</if>
|
||||
<if test="financialDetailType != null">
|
||||
and financial_detail_type = #{financialDetailType}
|
||||
</if>
|
||||
<if test="financialDetailTypes != null and financialDetailTypes.size > 0">
|
||||
and financial_detail_type in
|
||||
<foreach item="item" collection="financialDetailTypes" open="(" separator="," close=")">
|
||||
|
|
|
|||
|
|
@ -3,7 +3,6 @@ package com.ghy.quartz.service.impl;
|
|||
import com.ghy.common.enums.FinancialDetailType;
|
||||
import com.ghy.common.enums.OrderStatus;
|
||||
import com.ghy.order.domain.OrderDetail;
|
||||
import com.ghy.order.domain.OrderMaster;
|
||||
import com.ghy.order.service.OrderDetailService;
|
||||
import com.ghy.order.service.OrderMasterService;
|
||||
import com.ghy.payment.domain.FinancialDetail;
|
||||
|
|
@ -11,7 +10,6 @@ import com.ghy.payment.domain.OrderTimeoutRecord;
|
|||
import com.ghy.payment.mapper.OrderFineRecordMapper;
|
||||
import com.ghy.payment.service.FinancialDetailService;
|
||||
import com.ghy.quartz.service.OrderService;
|
||||
import com.huifu.adapay.core.exception.BaseAdaPayException;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
import org.springframework.beans.factory.annotation.Value;
|
||||
|
|
@ -137,7 +135,8 @@ public class OrderServiceImpl implements OrderService {
|
|||
// 查询出"待确认"状态的子订单
|
||||
List<OrderDetail> orderDetails = orderDetailService.selectByStatus(Collections.singletonList(OrderStatus.FINISH_CHECK.code()));
|
||||
long now = System.currentTimeMillis();
|
||||
long day14ago = now - (60 * 60 * 1000L);
|
||||
// long day14ago = now - (60 * 60 * 1000L);
|
||||
long day14ago = now - 10000L;
|
||||
for (OrderDetail orderDetail : orderDetails) {
|
||||
// 查询符合自动确认的订单
|
||||
if (day14ago > orderDetail.getUpdateTime().getTime()) {
|
||||
|
|
|
|||
Loading…
Reference in New Issue