yujian
2020-05-09 7e7db2fa55a9a3af46d4fd8ede0dee147f101d64
fanli/src/main/java/com/yeshi/fanli/service/impl/order/msg/MsgOrderDetailServiceImpl.java
@@ -8,12 +8,16 @@
import org.springframework.stereotype.Service;
import com.yeshi.fanli.dao.mybatis.msg.MsgOrderDetailMapper;
import com.yeshi.fanli.entity.bus.msg.MsgExtra;
import com.yeshi.fanli.entity.bus.msg.MsgOrderDetail;
import com.yeshi.fanli.entity.bus.msg.MsgOrderDetail.MsgTypeOrderTypeEnum;
import com.yeshi.fanli.entity.order.CommonOrder;
import com.yeshi.fanli.exception.msg.MsgOrderDetailException;
import com.yeshi.fanli.service.inter.msg.MsgExtraService;
import com.yeshi.fanli.service.inter.msg.UserMsgReadStateService;
import com.yeshi.fanli.service.inter.order.msg.MsgOrderDetailService;
import com.yeshi.fanli.util.Constant;
import com.yeshi.fanli.util.StringUtil;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
@@ -29,14 +33,27 @@
   @Resource
   private JedisPool jedisPool;
   @Resource
   private MsgExtraService msgExtraService;
   @Override
   public void addMsgOrderDetail(MsgOrderDetail detail, boolean needNotify) throws MsgOrderDetailException {
      if (detail == null)
         throw new MsgOrderDetailException(1, "消息为空");
      if (detail.getOrderId() == null || detail.getType() == null || detail.getState() == null
            || detail.getUser() == null)
      if (detail.getOrderId() == null || detail.getType() == null   || detail.getUser() == null
            || StringUtil.isNullOrEmpty(detail.getExtraInfo()))
         throw new MsgOrderDetailException(2, "消息不完整");
      if (detail.getType() == MsgTypeOrderTypeEnum.businessRunning) {
         MsgOrderDetail msgOrderDetail = msgOrderDetailMapper.getByUniqueKey(detail.getUniquekey());
         if (msgOrderDetail != null) {
            return;
         }
      }
      // 锁住订单号
      Jedis jedis = jedisPool.getResource();
      try {
@@ -50,6 +67,8 @@
               detail.setUpdateTime(new Date());
               detail.setRead(false);
               msgOrderDetailMapper.insertSelective(detail);
               // 消息内容
               msgExtraService.addMsgExtra(detail.getId(), detail.getExtraInfo(), MsgExtra.MSG_TYPE_ORDER);
            } else {
               MsgOrderDetail update = new MsgOrderDetail();
               update.setId(old.getId());
@@ -60,6 +79,7 @@
               update.setRead(false);
               update.setBeiZhu(detail.getBeiZhu());
               msgOrderDetailMapper.updateByPrimaryKeySelective(update);
               msgExtraService.addMsgExtra(update.getId(), detail.getExtraInfo(), MsgExtra.MSG_TYPE_ORDER);
            }
            if (needNotify)
               userMsgReadStateService.addOrderMsgUnReadCount(detail.getUser().getId(), 1);
@@ -119,4 +139,15 @@
      return msgOrderDetailMapper.listByOrderId(orderId);
   }
   @Override
   public MsgOrderDetail selectByPrimaryKey(Long id) {
      return msgOrderDetailMapper.selectByPrimaryKey(id);
   }
   @Override
   public void deleteByPrimaryKey(Long id) {
      msgOrderDetailMapper.deleteByPrimaryKey(id);
      msgExtraService.deleteByPidAndType(id, MsgExtra.MSG_TYPE_ORDER);
   }
}