yujian
2020-06-16 e7920b14a9baab97035a1a529da85d124a2bcacd
fanli/src/main/java/com/yeshi/fanli/service/impl/user/cloud/UserCloudServiceImpl.java
@@ -15,6 +15,7 @@
import com.aliyun.openservices.ons.api.Message;
import com.aliyun.openservices.ons.api.Producer;
import com.yeshi.fanli.dao.mybatis.user.cloud.UserCloudMapper;
import com.yeshi.fanli.dto.aitaoker.RobotInfoDTO;
import com.yeshi.fanli.dto.aitaoker.WeiXinGroupDTO;
import com.yeshi.fanli.dto.jd.JDCouponInfo;
import com.yeshi.fanli.dto.jd.JDPingouInfo;
@@ -216,7 +217,6 @@
   }
   @Override
   @Transactional(rollbackFor = Exception.class)
   public void openCloud(Long uid, Long orderId, CloudOrderMenuEnum menuEnum) throws UserCloudException {
      UserCloud existCloud = userCloudMapper.getByOrderId(orderId);
      if (existCloud != null) {
@@ -230,62 +230,60 @@
         if (userCloud.getEndTime().getTime() > java.lang.System.currentTimeMillis())
            renew = true;
         // 验证套餐是否相同
         if (renew && userCloud.getRobotType() != menuEnum.getType()) {
         if (renew && userCloud.getRobotType() != menuEnum.getRobotType()) {
            LogHelper.cloudInfo("方法openCloud: [uid=" + uid + "][订单ID=" + orderId + "]已有其他云发单套餐还未结束");
            throw new UserCloudException(1, "已有其他云发单套餐还未结束");
         }
      }
//      RobotInfoDTO dto = null;
//      if (renew) { // 续费
//         dto = AitaokerApiUtil.robotRenewals(userCloud.getRobotId(), menuEnum.getMonth());
//      } else { // 创建机器人
//         dto = AitaokerApiUtil.robotCreate(menuEnum.getMonth(), menuEnum.getType(), "wechatrobot", null);
//      }
//
//      if (dto == null) {
//         LogHelper.cloudInfo("方法openCloud: [uid=" + uid + "][订单ID=" + orderId + "]机器人失败: 返回空值");
//         throw new UserCloudException(1, "机器人获取失败");
//      }
//
//      String endTimeStr = dto.getEndTime();
//      if (StringUtil.isNullOrEmpty(endTimeStr)) {
//         LogHelper.cloudInfo("方法openCloud: [uid=" + uid + "][订单ID=" + orderId + "]机器人失败: 返回时间为空");
//         throw new UserCloudException(1, "机器人返回时间为空");
//      }
//
//      long endTime = 0;
//      try {
//         endTime = Long.parseLong(endTimeStr);
//      } catch (Exception e) {
//         LogHelper.cloudInfo("方法openCloud: [uid=" + uid + "][订单ID=" + orderId + "]机器人失败: 返回时间格式不正确");
//         throw new UserCloudException(1, "机器人返回时间格式不正确");
//      }
//
//      Integer robotId = dto.getId();
//      if (robotId == null) {
//         LogHelper.cloudInfo("方法openCloud: [uid=" + uid + "][订单ID=" + orderId + "]机器人失败: 机器人ID返回为空");
//         throw new UserCloudException(1, "机器人ID返回为空");
//      }
//
//      Integer groupNum = dto.getGroupNum();
//      if (groupNum == null) {
//         LogHelper.cloudInfo("方法openCloud: [uid=" + uid + "][订单ID=" + orderId + "]机器人失败: groupNum返回为空");
//         throw new UserCloudException(1, "groupNum返回为空");
//      }
      RobotInfoDTO dto = null;
      if (renew) { // 续费
         dto = AitaokerApiUtil.robotRenewals(userCloud.getRobotId(), menuEnum.getMonth());
      } else { // 创建机器人
         dto = AitaokerApiUtil.robotCreate(menuEnum.getMonth(), menuEnum.getRobotType(), "wechatrobot", null);
      }
      if (dto == null) {
         LogHelper.cloudInfo("方法openCloud: [uid=" + uid + "][订单ID=" + orderId + "]机器人失败: 机器人创建失败");
      }
      Integer robotId = dto.getId();
      if (robotId == null) {
         LogHelper.cloudInfo("方法openCloud: [uid=" + uid + "][订单ID=" + orderId + "]机器人失败: 机器人ID返回为空");
      }
      String endTimeStr = dto.getEndTime();
      if (StringUtil.isNullOrEmpty(endTimeStr)) {
         LogHelper.cloudInfo("方法openCloud: [uid=" + uid + "][订单ID=" + orderId + "]机器人失败: 返回时间为空");
      }
      long endTime = 0;
      try {
         endTime = Long.parseLong(endTimeStr);
      } catch (Exception e) {
         LogHelper.cloudInfo("方法openCloud: [uid=" + uid + "][订单ID=" + orderId + "]机器人失败: 返回时间格式不正确");
      }
      Integer groupNum = dto.getGroupNum();
      if (groupNum == null) {
         LogHelper.cloudInfo("方法openCloud: [uid=" + uid + "][订单ID=" + orderId + "]机器人失败: groupNum返回为空");
      }
      UserCloud newCloud = new UserCloud();
      newCloud.setUid(uid);
      newCloud.setOrderId(orderId);
//      newCloud.setGroupNum(groupNum);
//      newCloud.setRobotId(robotId);
      newCloud.setRobotType(menuEnum.getType());
//      if (renew) {
//         newCloud.setStartTime(userCloud.getStartTime());
//      } else {
//         newCloud.setStartTime(new Date());
//      }
//      newCloud.setEndTime(new Date(endTime * 1000)); // Unix 转换 普通时间
      newCloud.setGroupNum(groupNum);
      newCloud.setRobotId(robotId);
      newCloud.setRobotType(menuEnum.getRobotType());
      if (renew) {
         newCloud.setWxId(userCloud.getWxId());
         newCloud.setWxName(userCloud.getWxName());
         newCloud.setWxPortrait(userCloud.getPortrait());
         newCloud.setStartTime(userCloud.getStartTime());
      } else {
         newCloud.setStartTime(new Date());
      }
      newCloud.setEndTime(new Date(endTime * 1000)); // Unix 转换 普通时间
      newCloud.setCreateTime(new Date());
      userCloudMapper.insertSelective(newCloud);