From 3033ccf3878fae2c204df53be2a283f29f5853ed Mon Sep 17 00:00:00 2001 From: liujie <1793218484@qq.com> Date: 星期五, 10 十月 2025 18:17:02 +0800 Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/haizhentong --- ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TSysLiveServiceImpl.java | 69 ++++++++++++++++++++++++++++++++-- 1 files changed, 65 insertions(+), 4 deletions(-) diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TSysLiveServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TSysLiveServiceImpl.java index 496e7eb..3b15301 100644 --- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TSysLiveServiceImpl.java +++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TSysLiveServiceImpl.java @@ -1,19 +1,32 @@ package com.ruoyi.system.service.impl; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.google.common.collect.ImmutableMap; import com.ruoyi.common.basic.PageInfo; +import com.ruoyi.common.constant.Constants; import com.ruoyi.common.core.domain.R; +import com.ruoyi.common.core.redis.RedisCache; +import com.ruoyi.common.utils.DateUtils; +import com.ruoyi.system.listener.PublishTopicLiveInfoEventListener; +import com.ruoyi.system.listener.event.PublishTopicLiveInfoEvent; import com.ruoyi.system.mapper.TSysLiveMapper; import com.ruoyi.system.model.TSysEducationalInfo; import com.ruoyi.system.model.TSysLive; import com.ruoyi.system.query.TSysLiveQuery; import com.ruoyi.system.service.TSysLiveService; +import com.ruoyi.system.task.base.QuartzManager; +import com.ruoyi.system.task.base.TimeJobType; +import com.ruoyi.system.task.jobs.LivePushJob; +import com.ruoyi.system.utils.util.TemplateMessageSendUtil; +import com.ruoyi.system.vo.TSysActivityVO; import com.ruoyi.system.vo.TSysLiveVO; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.context.ApplicationContext; import org.springframework.stereotype.Service; +import org.springframework.util.CollectionUtils; import java.time.LocalDateTime; -import java.util.List; -import java.util.Objects; +import java.util.*; /** * <p> @@ -26,14 +39,22 @@ @Service public class TSysLiveServiceImpl extends ServiceImpl<TSysLiveMapper, TSysLive> implements TSysLiveService { + @Autowired + private RedisCache redisCache; + @Autowired + private ApplicationContext applicationContext; @Override public R pushUser(String id, String pushType) { TSysLive sysLive = this.getById(id); if (Objects.nonNull(sysLive)){ + // 判断直播开始时间是否在当前时间之后 + if (sysLive.getStartTime().isBefore(LocalDateTime.now())){ + return R.fail("直播已开始,无法配置推送"); + } sysLive.setPushType(pushType); this.updateById(sysLive); - // TODO 添加定时推送 - + // 直播开始推送公众号消息 + applicationContext.publishEvent(new PublishTopicLiveInfoEvent(pushType+"_"+id)); } return R.ok(); } @@ -42,6 +63,9 @@ public PageInfo<TSysLiveVO> pageList(TSysLiveQuery query) { PageInfo<TSysLiveVO> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize()); List<TSysLiveVO> list = this.baseMapper.pageList(query,pageInfo); + if (CollectionUtils.isEmpty(list)){ + return pageInfo; + } // 判断状态 for (TSysLiveVO sysLive : list) { if(sysLive.getStartTime().isAfter(LocalDateTime.now())){ @@ -53,6 +77,43 @@ if(sysLive.getEndTime().isBefore(LocalDateTime.now())){ sysLive.setLiveStatus(3); } + // 查看是否包含该值 +// boolean memberInSet = redisCache.isMemberInSet(Constants.LIVE_APPOINTMENT_PUSH + sysLive.getId(), query.getAppUserId()); +// sysLive.setAppointmentStatus(memberInSet ? 2 : 1); + + if(query.getRoleType() == 5){ + Long userId = query.getUserId(); + Set<Long> cacheSet = redisCache.getCacheSet(Constants.SYS_ACTIVITY_CLICK_COUNT + sysLive.getId()); + if(cacheSet.contains(userId)){ + sysLive.setIsView(true); + } + } + + } + pageInfo.setRecords(list); + return pageInfo; + } + @Override + public PageInfo<TSysLiveVO> pageListApp(TSysLiveQuery query) { + PageInfo<TSysLiveVO> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize()); + List<TSysLiveVO> list = this.baseMapper.pageListApp(query,pageInfo); + if (CollectionUtils.isEmpty(list)){ + return pageInfo; + } + // 判断状态 + for (TSysLiveVO sysLive : list) { + if(sysLive.getStartTime().isAfter(LocalDateTime.now())){ + sysLive.setLiveStatus(1); + } + if(sysLive.getStartTime().isBefore(LocalDateTime.now()) && sysLive.getEndTime().isAfter(LocalDateTime.now())){ + sysLive.setLiveStatus(2); + } + if(sysLive.getEndTime().isBefore(LocalDateTime.now())){ + sysLive.setLiveStatus(3); + } + // 查看是否包含该值 + boolean memberInSet = redisCache.isMemberInSet(Constants.LIVE_APPOINTMENT_PUSH + sysLive.getId(), query.getAppUserId()); + sysLive.setAppointmentStatus(memberInSet ? 2 : 1); } pageInfo.setRecords(list); return pageInfo; -- Gitblit v1.7.1