Your Name
2023-08-26 7958f1dddb8a7f4e70d232b07a7703955ecedae0
service-fee/src/main/java/com/java110/fee/cmd/payFeeBatch/UpdatePayFeeBatchCmd.java
@@ -17,18 +17,23 @@
import com.alibaba.fastjson.JSONObject;
import com.java110.core.annotation.Java110Cmd;
import com.java110.core.annotation.Java110Transactional;
import com.java110.core.context.ICmdDataFlowContext;
import com.java110.core.event.cmd.AbstractServiceCmdListener;
import com.java110.core.event.cmd.Cmd;
import com.java110.core.event.cmd.CmdEvent;
import com.java110.dto.meter.MeterWaterDto;
import com.java110.dto.payFee.PayFeeBatchDto;
import com.java110.intf.fee.IFeeInnerServiceSMO;
import com.java110.intf.fee.IMeterWaterV1InnerServiceSMO;
import com.java110.intf.fee.IPayFeeBatchV1InnerServiceSMO;
import com.java110.po.payFeeBatch.PayFeeBatchPo;
import com.java110.po.fee.PayFeePo;
import com.java110.po.payFee.PayFeeBatchPo;
import com.java110.utils.constant.StateConstant;
import com.java110.utils.exception.CmdException;
import com.java110.utils.util.Assert;
import com.java110.utils.util.BeanConvertUtil;
import com.java110.vo.ResultVo;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.java110.core.log.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
@@ -43,7 +48,7 @@
 * // modify by 张三 at 2021-09-12 第10行在某种场景下存在某种bug 需要修复,注释10至20行 加入 20行至30行
 */
@Java110Cmd(serviceCode = "payFeeBatch.updatePayFeeBatch")
public class UpdatePayFeeBatchCmd extends AbstractServiceCmdListener {
public class UpdatePayFeeBatchCmd extends Cmd {
    private static Logger logger = LoggerFactory.getLogger(UpdatePayFeeBatchCmd.class);
@@ -51,23 +56,54 @@
    @Autowired
    private IPayFeeBatchV1InnerServiceSMO payFeeBatchV1InnerServiceSMOImpl;
    @Autowired
    private IFeeInnerServiceSMO feeInnerServiceSMOImpl;
    @Autowired
    private IMeterWaterV1InnerServiceSMO meterWaterV1InnerServiceSMOImpl;
    @Override
    public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
        Assert.hasKeyAndValue(reqJson, "batchId", "batchId不能为空");
        Assert.hasKeyAndValue(reqJson, "communityId", "communityId不能为空");
        Assert.hasKeyAndValue(reqJson, "state", "状态不能为空");
        Assert.hasKeyAndValue(reqJson, "msg", "消息不能为空");
    }
    @Override
    @Java110Transactional
    //@Java110Transactional
    //这里不开启事务,删除可能几千条 事务压力太大
    public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
        PayFeeBatchPo payFeeBatchPo = BeanConvertUtil.covertBean(reqJson, PayFeeBatchPo.class);
        if (StateConstant.AGREE_AUDIT.equals(reqJson.getString("state"))) {
            payFeeBatchPo.setState(PayFeeBatchDto.STATE_SUCCESS);
        } else {
            payFeeBatchPo.setState(PayFeeBatchDto.STATE_FAIL);
        }
        int flag = payFeeBatchV1InnerServiceSMOImpl.updatePayFeeBatch(payFeeBatchPo);
        if (flag < 1) {
            throw new CmdException("更新数据失败");
        }
        if (PayFeeBatchDto.STATE_FAIL.equals(payFeeBatchPo.getState())) {
            cmdDataFlowContext.setResponseEntity(ResultVo.success());
            return;
        }
        PayFeePo feePo = new PayFeePo();
        feePo.setBatchId(payFeeBatchPo.getBatchId());
        feePo.setCommunityId(payFeeBatchPo.getCommunityId());
        feeInnerServiceSMOImpl.deleteFeesByBatch(feePo);
        //todo 删除抄表记录
        MeterWaterDto meterWaterDto = new MeterWaterDto();
        meterWaterDto.setCommunityId(payFeeBatchPo.getCommunityId());
        meterWaterDto.setBatchId(payFeeBatchPo.getBatchId());
        meterWaterV1InnerServiceSMOImpl.deleteMeterWaterByBatch(meterWaterDto);
        cmdDataFlowContext.setResponseEntity(ResultVo.success());
    }
}