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("未付款"),
|
||||
PAID("已付款");
|
||||
UNPAID("待付款"),
|
||||
PAID("已付款"),
|
||||
CANCEL("已取消");
|
||||
|
||||
private final String description;
|
||||
|
||||
|
@ -49,4 +49,11 @@ public interface RechargeService extends IService<Recharge> {
|
||||
*/
|
||||
Recharge getRecharge(String sn);
|
||||
|
||||
/**
|
||||
* 充值订单取消
|
||||
*
|
||||
* @param sn 充值订单sn
|
||||
*/
|
||||
void rechargeOrderCancel(String sn);
|
||||
|
||||
}
|
@ -103,4 +103,13 @@ public class RechargeServiceImpl extends ServiceImpl<RechargeMapper, Recharge> i
|
||||
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