zxl
4 小时以前 362e79ed14f77f850f3397d225f3b1b897ca44d7
补偿领劵
3个文件已修改
50 ■■■■■ 已修改文件
framework/src/main/java/cn/lili/modules/lmk/service/PrizeRecordService.java 2 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
framework/src/main/java/cn/lili/modules/lmk/service/impl/PrizeRecordServiceImpl.java 43 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
manager-api/src/main/java/cn/lili/controller/lmk/PrizeRecordController.java 5 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
framework/src/main/java/cn/lili/modules/lmk/service/PrizeRecordService.java
@@ -73,4 +73,6 @@
    Result all();
    List<PrizeRecordTimeVO> getPrizeRecordListByTime(PrizeRecordTimeQuery query);
    Result push(String id);
}
framework/src/main/java/cn/lili/modules/lmk/service/impl/PrizeRecordServiceImpl.java
@@ -1,5 +1,6 @@
package cn.lili.modules.lmk.service.impl;
import cn.lili.common.properties.RocketmqCustomProperties;
import cn.lili.common.security.context.UserContext;
import cn.lili.common.utils.StringUtils;
import cn.lili.modules.lmk.domain.query.PrizeRecordTimeQuery;
@@ -8,7 +9,9 @@
import cn.lili.modules.lmk.enums.general.PrizeGrantStatusEnums;
import cn.lili.modules.lmk.enums.general.PrizeStatusEnum;
import cn.lili.modules.order.order.entity.dto.PrizeRecordExportDetailDTO;
import cn.lili.rocketmq.RocketmqSendCallbackBuilder;
import cn.lili.utils.COSUtil;
import com.alibaba.fastjson.JSON;
import com.baomidou.mybatisplus.core.metadata.IPage;
import cn.lili.modules.lmk.domain.entity.PrizeRecord;
import cn.lili.modules.lmk.mapper.PrizeRecordMapper;
@@ -22,10 +25,14 @@
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.apache.rocketmq.spring.core.RocketMQTemplate;
import org.springframework.stereotype.Service;
import lombok.RequiredArgsConstructor;
import cn.lili.utils.PageUtil;
import org.springframework.beans.BeanUtils;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.transaction.support.TransactionSynchronization;
import org.springframework.transaction.support.TransactionSynchronizationManager;
import org.springframework.util.Assert;
import javax.servlet.ServletOutputStream;
@@ -49,7 +56,8 @@
    private final PrizeRecordMapper prizeRecordMapper;
    private final COSUtil cosUtil;
    private final RocketmqCustomProperties rocketmqCustomProperties;
    private final RocketMQTemplate rocketMQTemplate;
    @Override
    public void queryExportStock(HttpServletResponse response, PrizeRecordQuery query){
        List<PrizeRecordVO> list = baseMapper.getExportData(query);
@@ -243,4 +251,37 @@
    public List<PrizeRecordTimeVO> getPrizeRecordListByTime(PrizeRecordTimeQuery query) {
        return baseMapper.getPrizeRecordListByTime(query);
    }
    @Override
    @Transactional(rollbackFor = Exception.class)
    public Result push(String id) {
        PrizeRecord prizeRecord = baseMapper.selectById(id);
        if (prizeRecord != null){
            String distributeStatus = prizeRecord.getDistributeStatus();
            String prizeStatus = prizeRecord.getPrizeStatus();
            if (StringUtils.isNotBlank(distributeStatus) &&
                    StringUtils.isNotBlank(prizeStatus) &&
                    PrizeStatusEnum.WIN.name().equals(prizeStatus) &&
                    PrizeDistributeStatusEnum.WAIT.name().equals(distributeStatus)){
                TransactionSynchronizationManager.registerSynchronization(new TransactionSynchronization() {
                    @Override
                    public void afterCommit() {
                        String destination = rocketmqCustomProperties.getPrizeTopic() + ":" + PrizeStatusEnum.WIN.name();
                        rocketMQTemplate.asyncSend(destination, JSON.toJSONString(prizeRecord), RocketmqSendCallbackBuilder.commonCallback());
                    }
                });
                return Result.ok().data("已发放补偿");
            }else {
                throw new RuntimeException("用户领取记录为null或错误状态,补偿发放失败:" +prizeRecord);
            }
        }else{
            return Result.error().data("补偿发放失败");
        }
    }
}
manager-api/src/main/java/cn/lili/controller/lmk/PrizeRecordController.java
@@ -10,6 +10,7 @@
import lombok.AllArgsConstructor;
import lombok.RequiredArgsConstructor;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@@ -38,4 +39,8 @@
    public void queryExport(PrizeRecordQuery searchParams) {
        HttpServletResponse response = ThreadContextHolder.getHttpResponse();
        prizeRecordService.queryExportStock(response,searchParams);}
    @GetMapping("{id}")
    public Result push(@PathVariable String id){
        return  prizeRecordService.push(id);
    }
}