Merge branch 'master' of gitee.com:beijing_hongye_huicheng/lilishop
This commit is contained in:
commit
69d712c4b1
@ -0,0 +1,61 @@
|
|||||||
|
package cn.lili.timetask.handler.impl.order;
|
||||||
|
|
||||||
|
import cn.hutool.core.date.DateTime;
|
||||||
|
import cn.hutool.core.date.DateUtil;
|
||||||
|
import cn.hutool.json.JSONUtil;
|
||||||
|
import cn.lili.modules.order.order.entity.enums.PayStatusEnum;
|
||||||
|
import cn.lili.modules.order.trade.entity.dos.Recharge;
|
||||||
|
import cn.lili.modules.order.trade.service.RechargeService;
|
||||||
|
import cn.lili.modules.system.entity.dos.Setting;
|
||||||
|
import cn.lili.modules.system.entity.dto.OrderSetting;
|
||||||
|
import cn.lili.modules.system.entity.enums.SettingEnum;
|
||||||
|
import cn.lili.modules.system.service.SettingService;
|
||||||
|
import cn.lili.timetask.handler.EveryMinuteExecute;
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 充值订单自动取消(每分钟执行)
|
||||||
|
*
|
||||||
|
* @author zhuhai
|
||||||
|
* @since 2021/3/11
|
||||||
|
**/
|
||||||
|
@Slf4j
|
||||||
|
@Component
|
||||||
|
public class RechargeOrderTaskExecute implements EveryMinuteExecute {
|
||||||
|
/**
|
||||||
|
* 充值
|
||||||
|
*/
|
||||||
|
@Autowired
|
||||||
|
private RechargeService rechargeService;
|
||||||
|
/**
|
||||||
|
* 设置
|
||||||
|
*/
|
||||||
|
@Autowired
|
||||||
|
private SettingService settingService;
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void execute() {
|
||||||
|
Setting setting = settingService.get(SettingEnum.ORDER_SETTING.name());
|
||||||
|
OrderSetting orderSetting = JSONUtil.toBean(setting.getSettingValue(), OrderSetting.class);
|
||||||
|
if (orderSetting != null && orderSetting.getAutoCancel() != null) {
|
||||||
|
//充值订单自动取消时间 = 当前时间 - 自动取消时间分钟数
|
||||||
|
DateTime cancelTime = DateUtil.offsetMinute(DateUtil.date(), -orderSetting.getAutoCancel());
|
||||||
|
LambdaQueryWrapper<Recharge> queryWrapper = new LambdaQueryWrapper<>();
|
||||||
|
queryWrapper.eq(Recharge::getPayStatus, PayStatusEnum.UNPAID.name());
|
||||||
|
//充值订单创建时间 <= 订单自动取消时间
|
||||||
|
queryWrapper.le(Recharge::getCreateTime, cancelTime);
|
||||||
|
List<Recharge> list = rechargeService.list(queryWrapper);
|
||||||
|
List<String> cancelSnList = list.stream().map(Recharge::getRechargeSn).collect(Collectors.toList());
|
||||||
|
for (String sn : cancelSnList) {
|
||||||
|
rechargeService.rechargeOrderCancel(sn);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -11,8 +11,9 @@ public enum PayStatusEnum {
|
|||||||
/**
|
/**
|
||||||
* 支付状态
|
* 支付状态
|
||||||
*/
|
*/
|
||||||
UNPAID("未付款"),
|
UNPAID("待付款"),
|
||||||
PAID("已付款");
|
PAID("已付款"),
|
||||||
|
CANCEL("已取消");
|
||||||
|
|
||||||
private final String description;
|
private final String description;
|
||||||
|
|
||||||
|
@ -35,11 +35,11 @@ public interface RechargeService extends IService<Recharge> {
|
|||||||
/**
|
/**
|
||||||
* 支付成功
|
* 支付成功
|
||||||
*
|
*
|
||||||
* @param sn 充值订单编号
|
* @param sn 充值订单编号
|
||||||
* @param receivableNo 流水no
|
* @param receivableNo 流水no
|
||||||
* @param paymentMethod 支付方式
|
* @param paymentMethod 支付方式
|
||||||
*/
|
*/
|
||||||
void paySuccess(String sn, String receivableNo,String paymentMethod);
|
void paySuccess(String sn, String receivableNo, String paymentMethod);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据充值订单号查询充值信息
|
* 根据充值订单号查询充值信息
|
||||||
@ -49,4 +49,11 @@ public interface RechargeService extends IService<Recharge> {
|
|||||||
*/
|
*/
|
||||||
Recharge getRecharge(String sn);
|
Recharge getRecharge(String sn);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 充值订单取消
|
||||||
|
*
|
||||||
|
* @param sn 充值订单sn
|
||||||
|
*/
|
||||||
|
void rechargeOrderCancel(String sn);
|
||||||
|
|
||||||
}
|
}
|
@ -77,7 +77,7 @@ public class RechargeServiceImpl extends ServiceImpl<RechargeMapper, Recharge> i
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void paySuccess(String sn, String receivableNo,String paymentMethod) {
|
public void paySuccess(String sn, String receivableNo, String paymentMethod) {
|
||||||
//根据sn获取支付账单
|
//根据sn获取支付账单
|
||||||
Recharge recharge = this.getOne(new QueryWrapper<Recharge>().eq("recharge_sn", sn));
|
Recharge recharge = this.getOne(new QueryWrapper<Recharge>().eq("recharge_sn", sn));
|
||||||
//如果支付账单不为空则进行一下逻辑
|
//如果支付账单不为空则进行一下逻辑
|
||||||
@ -103,4 +103,13 @@ public class RechargeServiceImpl extends ServiceImpl<RechargeMapper, Recharge> i
|
|||||||
throw new ServiceException(ResultCode.ORDER_NOT_EXIST);
|
throw new ServiceException(ResultCode.ORDER_NOT_EXIST);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void rechargeOrderCancel(String sn) {
|
||||||
|
Recharge recharge = this.getOne(new QueryWrapper<Recharge>().eq("recharge_sn", sn));
|
||||||
|
if (recharge != null) {
|
||||||
|
recharge.setPayStatus(PayStatusEnum.CANCEL.name());
|
||||||
|
this.updateById(recharge);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user