From cfd0118ef446a66f91999afc7b1e46ca607adf50 Mon Sep 17 00:00:00 2001 From: jiangqs <jiangqs> Date: 星期四, 13 七月 2023 20:32:35 +0800 Subject: [PATCH] 定时任务 统计 --- ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/activity/ActivityServiceImpl.java | 109 ++++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 101 insertions(+), 8 deletions(-) diff --git a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/activity/ActivityServiceImpl.java b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/activity/ActivityServiceImpl.java index 77d46a1..584441d 100644 --- a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/activity/ActivityServiceImpl.java +++ b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/activity/ActivityServiceImpl.java @@ -24,10 +24,7 @@ import com.ruoyi.system.api.constant.AppErrorConstant; import com.ruoyi.system.api.constant.DelayTaskEnum; import com.ruoyi.system.api.constant.SecurityConstant; -import com.ruoyi.system.api.domain.dto.ActivityGoodsGetDto; -import com.ruoyi.system.api.domain.dto.MerPageDto; -import com.ruoyi.system.api.domain.dto.MgtBaseBathDto; -import com.ruoyi.system.api.domain.dto.MgtUserIdByKeywordDto; +import com.ruoyi.system.api.domain.dto.*; import com.ruoyi.system.api.domain.poji.activity.ActivityGoods; import com.ruoyi.system.api.domain.poji.config.DelayTask; import com.ruoyi.system.api.domain.vo.ActivityGoodsGetVo; @@ -37,6 +34,9 @@ import com.ruoyi.system.api.service.RemoteConfigService; import com.ruoyi.system.api.service.RemoteMemberService; import com.ruoyi.system.api.service.RemoteShopService; +import org.redisson.api.RLock; +import org.redisson.api.RedissonClient; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import javax.annotation.Resource; @@ -84,6 +84,8 @@ @Resource private RedisService redisService; + @Autowired + private RedissonClient redissonClient; /** * @param mgtActivityEditDto @@ -130,13 +132,12 @@ // 根据当前时间和活动时间判断活动状态 if (nowTime.compareTo(activityStartTime) < 0) { activity.setActivityStatus(0); - } else if (nowTime.compareTo(activityStartTime) >= 0 && nowTime.compareTo(activityEndTime) <= 0) { - activity.setActivityStatus(1); - } else if (nowTime.compareTo(activityEndTime) > 0) { - activity.setActivityStatus(2); + } else { + throw new ServiceException(AppErrorConstant.ACTIVITY_TIME_ERROR); } // 设置活动信息 activity.setActivityName(mgtActivityEditDto.getActivityName()); + activity.setActivityIntroduce(mgtActivityEditDto.getActivityIntroduce()); activity.setActivityStartTime(activityStartTime); activity.setActivityEndTime(activityEndTime); activity.setGroupBuyNumber(mgtActivityEditDto.getGroupBuyNumber()); @@ -164,6 +165,7 @@ activityGoods.setActivityPrice(dto.getActivityPrice()); activityGoods.setActivitySubscription(dto.getActivitySubscription()); activityGoods.setActivityNumber(dto.getActivityNumber()); + activityGoods.setSalesNumber(0); activityGoods.setActivityDeadline(activity.getActivityEndTime()); activityGoods.setSellOutFlag(0); activityGoods.setPurchaseLimitationFlag(activity.getPurchaseLimitationFlag()); @@ -173,6 +175,38 @@ ).collect(Collectors.toList()); if (!activityGoodsList.isEmpty()) { activityGoodsService.saveBatch(activityGoodsList); + } + } + //如果活动在1小时内生成自动开始任务的延时任务 + Date checkTime = DateUtils.addMinutes(new Date(),61); + if(checkTime.compareTo(activityStartTime)>0){ + String activityId = activity.getActivityId(); + long currentTimeMillis = System.currentTimeMillis(); + long startTimeDifference = currentTimeMillis - activityStartTime.getTime(); + long endTimeDifference = currentTimeMillis - activityEndTime.getTime(); + // 查询延时任务 + DelayTask startDelayTask = remoteConfigService.getDelayTask(DelayTaskEnum.ACTIVITY_START_TASK.getCode() + "-" + activityId).getData(); + // 如果延时任务为空,创建延时任务控制活动定时开始和结束 + if (startDelayTask == null) { + redisService.setCacheObject(DelayTaskEnum.ACTIVITY_START_TASK.getCode() + "-" + activityId, activityStartTime, startTimeDifference, TimeUnit.MILLISECONDS); + startDelayTask = new DelayTask(); + startDelayTask.setDelFlag(0); + startDelayTask.setCreateTime(new Date()); + startDelayTask.setEndTime(activityStartTime); + startDelayTask.setRedisKey(DelayTaskEnum.ACTIVITY_START_TASK.getCode() + "-" + activityId); + remoteConfigService.addDelayTask(startDelayTask); + } + // 查询延时任务 + DelayTask endDelayTask = remoteConfigService.getDelayTask(DelayTaskEnum.ACTIVITY_START_TASK.getCode() + "-" + activityId).getData(); + // 如果延时任务为空,创建延时任务控制活动定时开始和结束 + if (endDelayTask == null) { + redisService.setCacheObject(DelayTaskEnum.ACTIVITY_END_TASK.getCode() + "-" + activityId, activityEndTime, endTimeDifference, TimeUnit.MILLISECONDS); + endDelayTask = new DelayTask(); + endDelayTask.setDelFlag(0); + endDelayTask.setCreateTime(new Date()); + endDelayTask.setEndTime(activityEndTime); + endDelayTask.setRedisKey(DelayTaskEnum.ACTIVITY_END_TASK.getCode() + "-" + activityId); + remoteConfigService.addDelayTask(endDelayTask); } } } @@ -469,4 +503,63 @@ this.saveOrUpdate(activity); } } + + /** + * @description 活动商品库存变化 + * @author jqs + * @date 2023/7/13 13:53 + * @param + * @return void + */ + @Override + public void changeActivityTotal(ActivityTotalChangeDto activityTotalChangeDto){ + + RLock lock = redissonClient.getLock("activity_clock_"+activityTotalChangeDto.getActivityId()); + try { + lock.lock(30, TimeUnit.SECONDS); + //判断活动商品是否售罄,是则停止活动 + /*Integer noSellOut = activityMapper.checkSellOut(activityTotalChangeDto.getActivityId()); + if(noSellOut==0){ + endActivity(activityTotalChangeDto.getActivityId()); + }*/ + //更新活动统计 + ActivityTotal activityTotal = activityTotalService.getById(activityTotalChangeDto.getActivityId()); + if(activityTotalChangeDto.getChangeType()==1){ + activityTotal.setOrderTotal(activityTotal.getOrderTotal()+activityTotalChangeDto.getChangeNum()); + activityTotal.setPersonTotal(activityTotal.getPersonTotal()+activityTotalChangeDto.getPersonNum()); + activityTotal.setOrderMoneyTotal(activityTotal.getOrderMoneyTotal().add(activityTotalChangeDto.getMoney())); + }else{ + activityTotal.setOrderTotal(activityTotal.getOrderTotal()-activityTotalChangeDto.getChangeNum()); + activityTotal.setPersonTotal(activityTotal.getPersonTotal()-activityTotalChangeDto.getPersonNum()); + activityTotal.setRefundTotal(activityTotal.getRefundTotal()+activityTotalChangeDto.getRefundNum()); + activityTotal.setOrderMoneyTotal(activityTotal.getOrderMoneyTotal().subtract(activityTotalChangeDto.getMoney())); + } + activityTotalService.saveOrUpdate(activityTotal); + } finally { + lock.unlock(); + } + } + + /** + * @description 活动商品库存变化 + * @author jqs + * @date 2023/7/13 13:53 + * @param + * @return void + */ + @Override + public void changeActivityStock(AGStockChangeDto agStockChangeDto){ + RLock lock = redissonClient.getLock("stock_clock_"+agStockChangeDto.getActivityId()+"_"+agStockChangeDto.getGoodsId()); + try { + lock.lock(30, TimeUnit.SECONDS); + if(agStockChangeDto.getChangeType()==1){ + activityMapper.addActivityGoodsStock(agStockChangeDto); + }else{ + //更新库存 + activityMapper.subActivityGoodsStock(agStockChangeDto); + } + } finally { + lock.unlock(); + } + } } -- Gitblit v1.7.1