|
@@ -1,6 +1,8 @@
|
|
|
package com.qs.mp.admin.service.impl;
|
|
|
|
|
|
import com.alibaba.fastjson.JSONObject;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
import com.qs.mp.admin.domain.Coupon;
|
|
|
import com.qs.mp.admin.domain.Goods;
|
|
@@ -22,11 +24,13 @@ import com.qs.mp.admin.service.ITicketBoxSerialService;
|
|
|
import com.qs.mp.admin.service.ITicketBoxService;
|
|
|
import com.qs.mp.admin.service.ITicketPackageService;
|
|
|
import com.qs.mp.admin.service.ITicketService;
|
|
|
+import com.qs.mp.common.enums.MqTopicType;
|
|
|
import com.qs.mp.common.enums.TicketBoxStatusEnum;
|
|
|
import com.qs.mp.common.enums.TicketPkgStatusEnum;
|
|
|
import com.qs.mp.common.enums.TicketPrizeTypeEnum;
|
|
|
import com.qs.mp.common.enums.TicketStatusEnum;
|
|
|
import com.qs.mp.common.enums.TicketTypeEnum;
|
|
|
+import com.qs.mp.common.pulsar.PulsarClientService;
|
|
|
import com.qs.mp.common.utils.LogUtil;
|
|
|
import com.qs.mp.system.service.id.BizIdGenerator;
|
|
|
import java.math.BigDecimal;
|
|
@@ -40,6 +44,7 @@ import java.util.Map;
|
|
|
import java.util.Random;
|
|
|
import lombok.Data;
|
|
|
import ma.glasnost.orika.MapperFacade;
|
|
|
+import org.apache.pulsar.client.api.PulsarClientException;
|
|
|
import org.slf4j.Logger;
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
@@ -88,6 +93,9 @@ public class TicketBoxServiceImpl extends ServiceImpl<TicketBoxMapper, TicketBox
|
|
|
@Autowired
|
|
|
private ITicketPackageService ticketPackageService;
|
|
|
|
|
|
+ @Autowired
|
|
|
+ private PulsarClientService pulsarClientService;
|
|
|
+
|
|
|
@Override
|
|
|
@Transactional
|
|
|
public boolean createTicketBox(TicketBoxCreateParam param) {
|
|
@@ -96,7 +104,7 @@ public class TicketBoxServiceImpl extends ServiceImpl<TicketBoxMapper, TicketBox
|
|
|
if (ticketBox.getType() == TicketTypeEnum.OFFLINE) {
|
|
|
ticketBox.setPkgQty(ticketBox.getQuantity() / ticketBox.getPkgUnit());
|
|
|
}
|
|
|
- ticketBox.setStatus(TicketBoxStatusEnum.PUT_OFF);
|
|
|
+ ticketBox.setStatus(TicketBoxStatusEnum.WAIT);
|
|
|
ticketBox.setBoxNo(ticketBoxSerialService.generateSerial(ticketBox.getType()));
|
|
|
ticketBox.setBoxId(bizIdGenerator.newId());
|
|
|
save(ticketBox);
|
|
@@ -140,11 +148,23 @@ public class TicketBoxServiceImpl extends ServiceImpl<TicketBoxMapper, TicketBox
|
|
|
ticketAwardsService.saveBatch(ticketAwardsList);
|
|
|
ticketAwardsPrizeService.saveBatch(awardsPrizeList);
|
|
|
|
|
|
- generateTicket(ticketBox, ticketAwardsList);
|
|
|
+ try {
|
|
|
+ pulsarClientService.producer(MqTopicType.ticket_generate, ticketBox.getBoxId());
|
|
|
+ } catch (PulsarClientException e) {
|
|
|
+ LogUtil.error(logger, e, "盲票组保存成功,发送异步消息失败. {0}", JSONObject.toJSONString(ticketBox));
|
|
|
+ }
|
|
|
return true;
|
|
|
}
|
|
|
|
|
|
- private void generateTicket(TicketBox ticketBox, List<TicketAwards> ticketAwardsList) {
|
|
|
+ @Override
|
|
|
+ @Transactional
|
|
|
+ public void generateTicket(String boxId) {
|
|
|
+ TicketBox ticketBox = getById(boxId);
|
|
|
+ Assert.isTrue(ticketBox.getStatus() == TicketBoxStatusEnum.DOING,
|
|
|
+ "盲票生成时,票组状态不是出票中,boxId=" + boxId);
|
|
|
+ List<TicketAwards> ticketAwardsList = ticketAwardsService.list(
|
|
|
+ new LambdaQueryWrapper<TicketAwards>()
|
|
|
+ .eq(TicketAwards::getBoxId, ticketBox.getBoxId()));
|
|
|
// 分包
|
|
|
int pkgNum = ticketBox.getPkgQty();
|
|
|
int pkgUnit = ticketBox.getPkgUnit();
|
|
@@ -170,7 +190,7 @@ public class TicketBoxServiceImpl extends ServiceImpl<TicketBoxMapper, TicketBox
|
|
|
ticketPackageList.add(ticketPackage);
|
|
|
|
|
|
List<PkgAwards> pkgAwardsList = pkgAwardsMap.get(key);
|
|
|
- LogUtil.debug(logger, "第{0}包盲票奖项数量为{1}", new Object[]{pkgCnt, pkgAwardsList});
|
|
|
+ LogUtil.debug(logger, "第{0}包盲票奖项数量为{1}", pkgCnt, pkgAwardsList);
|
|
|
List<Ticket> ticketList = new ArrayList<>();
|
|
|
for (int j = 1; j <= pkgUnit; j++) {
|
|
|
ticketCnt += 1;
|
|
@@ -181,7 +201,7 @@ public class TicketBoxServiceImpl extends ServiceImpl<TicketBoxMapper, TicketBox
|
|
|
iterator.remove();
|
|
|
}
|
|
|
}
|
|
|
- LogUtil.debug(logger, "开始生成第{0}包、第{1}盲票", new Object[]{pkgCnt, j});
|
|
|
+ LogUtil.debug(logger, "开始生成第{0}包、第{1}盲票", pkgCnt, j);
|
|
|
int random = getPrizeIndex(pkgAwardsList);
|
|
|
PkgAwards pkgAwards = pkgAwardsList.get(random);
|
|
|
pkgAwards.setQuantity(pkgAwards.getQuantity() - 1);
|
|
@@ -203,7 +223,8 @@ public class TicketBoxServiceImpl extends ServiceImpl<TicketBoxMapper, TicketBox
|
|
|
continue;
|
|
|
}
|
|
|
int awardsNum = new Random().nextInt(ticketAwardsList.size());
|
|
|
- drawNumDTOList.add(new TicketDrawNumDTO(ticketAwardsList.get(awardsNum).getName(), drawNum));
|
|
|
+ drawNumDTOList.add(
|
|
|
+ new TicketDrawNumDTO(ticketAwardsList.get(awardsNum).getName(), drawNum));
|
|
|
}
|
|
|
ticket.setDrawNum(JSONObject.toJSONString(drawNumDTOList));
|
|
|
ticket.setIsPhysical(1);
|
|
@@ -213,6 +234,10 @@ public class TicketBoxServiceImpl extends ServiceImpl<TicketBoxMapper, TicketBox
|
|
|
ticketService.saveBatch(ticketList);
|
|
|
}
|
|
|
ticketPackageService.saveBatch(ticketPackageList);
|
|
|
+
|
|
|
+ boolean rst = update(new LambdaUpdateWrapper<TicketBox>().set(TicketBox::getStatus, TicketBoxStatusEnum.DONE)
|
|
|
+ .eq(TicketBox::getBoxId, boxId).eq(TicketBox::getStatus, TicketBoxStatusEnum.DOING));
|
|
|
+ Assert.isTrue(rst, "盲票生成完,更新盲票组状态失败。boxId:{0}" + ticketBox.getBoxId());
|
|
|
}
|
|
|
|
|
|
private Map<Integer, List<PkgAwards>> generatePkgAwards(TicketBox ticketBox,
|
|
@@ -235,9 +260,10 @@ public class TicketBoxServiceImpl extends ServiceImpl<TicketBoxMapper, TicketBox
|
|
|
excludePkgList.remove(excludePkgList.size() - 1);
|
|
|
}
|
|
|
}
|
|
|
- List<Integer> randomList = getRandomList(excludePkgList, ticketAwards.getQuantity(), pkgNum);
|
|
|
+ List<Integer> randomList = getRandomList(excludePkgList, ticketAwards.getQuantity(),
|
|
|
+ pkgNum);
|
|
|
excludePkgList.addAll(randomList);
|
|
|
- LogUtil.debug(logger, "随机分配到的包序号为:{0}", new Object[]{JSONObject.toJSONString(randomList)});
|
|
|
+ LogUtil.debug(logger, "随机分配到的包序号为:{0}", JSONObject.toJSONString(randomList));
|
|
|
for (Integer pkgId : randomList) {
|
|
|
pkgAwardsMap.get(pkgId).add(
|
|
|
new PkgAwards(ticketAwards.getAwardsId(), ticketAwards.getName(),
|
|
@@ -267,7 +293,8 @@ public class TicketBoxServiceImpl extends ServiceImpl<TicketBoxMapper, TicketBox
|
|
|
ticketAwards.getSort(), quantity));
|
|
|
}
|
|
|
}
|
|
|
- LogUtil.debug(logger, "奖级{0}分包结果:{1}", new Object[]{k, JSONObject.toJSONString(pkgAwardsMap)});
|
|
|
+ LogUtil.debug(logger, "奖级{0}分包结果:{1}",
|
|
|
+ k, JSONObject.toJSONString(pkgAwardsMap));
|
|
|
}
|
|
|
return pkgAwardsMap;
|
|
|
}
|
|
@@ -302,13 +329,14 @@ public class TicketBoxServiceImpl extends ServiceImpl<TicketBoxMapper, TicketBox
|
|
|
} else {
|
|
|
d1 += Double.parseDouble(String.valueOf(prizes.get(i - 1).getQuantity())) / sumWeight;
|
|
|
}
|
|
|
- LogUtil.debug(logger, "prize:{0},区间 d1:{1}, d2:{2}", new Object[]{JSONObject.toJSONString(prizes.get(i)), d1, d2} );
|
|
|
+ LogUtil.debug(logger, "prize:{0},区间 d1:{1}, d2:{2}",
|
|
|
+ JSONObject.toJSONString(prizes.get(i)), d1, d2);
|
|
|
if (randomNumber > d1 && randomNumber <= d2) {
|
|
|
random = i;
|
|
|
break;
|
|
|
}
|
|
|
}
|
|
|
- LogUtil.debug(logger, "抽中序号:{0}", new Object[]{random});
|
|
|
+ LogUtil.debug(logger, "抽中序号:{0}", random);
|
|
|
return random;
|
|
|
}
|
|
|
|
|
@@ -324,7 +352,7 @@ public class TicketBoxServiceImpl extends ServiceImpl<TicketBoxMapper, TicketBox
|
|
|
Random rand = new Random();
|
|
|
boolean[] bool = new boolean[total];
|
|
|
for (Integer exInt : excludeList) {
|
|
|
- bool[exInt-1] = true;
|
|
|
+ bool[exInt - 1] = true;
|
|
|
}
|
|
|
int randInt = 0;
|
|
|
for (int i = 0; i < n; i++) {
|