ThemeService.java 11.3 KB
Newer Older
刘基明's avatar
刘基明 committed
1 2
package com.tanpu.community.service;

刘基明's avatar
刘基明 committed
3
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
刘基明's avatar
刘基明 committed
4
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
张辰's avatar
张辰 committed
5
import com.tanpu.biz.common.enums.community.ReportStatusEnum;
刘基明's avatar
刘基明 committed
6
import com.tanpu.common.exception.BizException;
张辰's avatar
张辰 committed
7
import com.tanpu.common.redis.RedisHelper;
刘基明's avatar
刘基明 committed
8
import com.tanpu.common.uuid.UuidGenHelper;
刘基明's avatar
刘基明 committed
9
import com.tanpu.community.api.enums.DeleteTagEnum;
刘基明's avatar
刘基明 committed
10
import com.tanpu.community.api.enums.ThemeTypeEnum;
刘基明's avatar
刘基明 committed
11
import com.tanpu.community.dao.entity.community.ThemeEntity;
刘基明's avatar
刘基明 committed
12
import com.tanpu.community.dao.entity.community.TimesCountEntity;
刘基明's avatar
刘基明 committed
13
import com.tanpu.community.dao.mapper.community.ThemeMapper;
刘基明's avatar
刘基明 committed
14
import com.tanpu.community.util.TimeUtils;
刘基明's avatar
刘基明 committed
15
import org.apache.commons.collections4.CollectionUtils;
刘基明's avatar
刘基明 committed
16
import org.apache.commons.lang3.StringUtils;
刘基明's avatar
刘基明 committed
17
import org.springframework.beans.factory.annotation.Autowired;
刘基明's avatar
刘基明 committed
18
import org.springframework.stereotype.Service;
刘基明's avatar
刘基明 committed
19
import org.springframework.transaction.annotation.Transactional;
刘基明's avatar
刘基明 committed
20

刘基明's avatar
刘基明 committed
21
import javax.annotation.Resource;
22 23 24 25 26 27
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
刘基明's avatar
刘基明 committed
28
import java.util.stream.Collectors;
刘基明's avatar
刘基明 committed
29

刘基明's avatar
刘基明 committed
30 31 32
@Service
public class ThemeService {

刘基明's avatar
刘基明 committed
33
    @Resource
刘基明's avatar
刘基明 committed
34
    private ThemeMapper themeMapper;
刘基明's avatar
刘基明 committed
35

刘基明's avatar
刘基明 committed
36 37 38
    @Autowired
    private UuidGenHelper uuidGenHelper;

张辰's avatar
张辰 committed
39 40 41
    @Autowired
    private RedisHelper redisHelper;

刘基明's avatar
刘基明 committed
42
    @Transactional
刘基明's avatar
刘基明 committed
43
    public void insertTheme(ThemeEntity themeEntity) {
刘基明's avatar
刘基明 committed
44 45 46 47
        if (StringUtils.isBlank(themeEntity.getThemeId())){
            themeEntity.setThemeId(uuidGenHelper.getUuidStr());
        }

刘基明's avatar
刘基明 committed
48 49 50
        themeMapper.insert(themeEntity);
    }

刘基明's avatar
刘基明 committed
51
    @Transactional
刘基明's avatar
刘基明 committed
52 53
    public void update(ThemeEntity themeEntity, String themeId) {
        themeMapper.update(themeEntity, new LambdaUpdateWrapper<ThemeEntity>().eq(ThemeEntity::getThemeId, themeId));
刘基明's avatar
刘基明 committed
54 55
    }

张辰's avatar
张辰 committed
56
    //n天内发表的所有主题
57
    public List<ThemeEntity> queryRecentdays(Integer days) {
刘基明's avatar
刘基明 committed
58
        LambdaQueryWrapper<ThemeEntity> queryWrapper = new LambdaQueryWrapper<ThemeEntity>()
刘基明's avatar
刘基明 committed
59
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED.getCode())
60 61 62 63 64 65 66 67 68 69 70 71
                .gt(ThemeEntity::getCreateTime, TimeUtils.getDaysBefore(days))
                .orderByDesc(ThemeEntity::getId);

        return themeMapper.selectList(queryWrapper);
    }

    //最新的n条主题
    public List<ThemeEntity> queryLatestThemes(Integer n) {
        LambdaQueryWrapper<ThemeEntity> queryWrapper = new LambdaQueryWrapper<ThemeEntity>()
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED.getCode())
                .last("limit " + n)
                .orderByDesc(ThemeEntity::getId);
刘基明's avatar
刘基明 committed
72 73 74 75

        return themeMapper.selectList(queryWrapper);
    }

刘基明's avatar
刘基明 committed
76
    //根据id返回主题详情(未删)
刘基明's avatar
刘基明 committed
77
    public ThemeEntity queryByThemeId(String themeId) {
刘基明's avatar
刘基明 committed
78
        return themeMapper.selectOne(new LambdaQueryWrapper<ThemeEntity>()
刘基明's avatar
刘基明 committed
79 80
                .eq(ThemeEntity::getThemeId, themeId)
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED.getCode()));
刘基明's avatar
刘基明 committed
81 82
    }

张辰's avatar
张辰 committed
83 84 85 86 87 88
    //根据id返回主题详情(未删)
    public ThemeEntity queryByThemeIdIgnoreDelete(String themeId) {
        return themeMapper.selectOne(new LambdaQueryWrapper<ThemeEntity>()
                .eq(ThemeEntity::getThemeId, themeId));
    }

89
    //根据用户id查询主题list
张辰's avatar
张辰 committed
90
    public List<ThemeEntity> queryThemesByUserIdCreateDesc(String userId, String lastId, Integer pageSize) {
刘基明's avatar
刘基明 committed
91 92
        LambdaQueryWrapper<ThemeEntity> queryWrapper = new LambdaQueryWrapper<ThemeEntity>()
                .eq(ThemeEntity::getAuthorId, userId)
93 94
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED.getCode())
                .orderByDesc(ThemeEntity::getCreateTime);
刘基明's avatar
刘基明 committed
95 96
        if (StringUtils.isNotEmpty(lastId)) {
            ThemeEntity lastEntity = queryByThemeId(lastId);
刘基明's avatar
刘基明 committed
97
            if (lastEntity == null) throw new BizException("主题未找到,id:" + lastId);
98
            queryWrapper.lt(ThemeEntity::getCreateTime, lastEntity.getCreateTime());
刘基明's avatar
刘基明 committed
99
        }
刘基明's avatar
刘基明 committed
100
        if (pageSize != null) {
张辰's avatar
张辰 committed
101
            queryWrapper.last("limit " + pageSize);
刘基明's avatar
刘基明 committed
102 103 104 105
        }
        return themeMapper.selectList(queryWrapper);
    }

刘基明's avatar
刘基明 committed
106
    //根据ids返回主题详情,带分页
刘基明's avatar
刘基明 committed
107
    public List<ThemeEntity> queryByThemeIds(List<String> themeIds, String lastId, Integer pageSize) {
108
        if (CollectionUtils.isEmpty(themeIds)) {
刘基明's avatar
刘基明 committed
109 110
            return Collections.emptyList();
        }
刘基明's avatar
刘基明 committed
111 112 113 114 115
        LambdaQueryWrapper<ThemeEntity> queryWrapper = new LambdaQueryWrapper<ThemeEntity>()
                .in(ThemeEntity::getThemeId, themeIds)
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED.getCode());
        if (StringUtils.isNotEmpty(lastId)) {
            ThemeEntity lastEntity = queryByThemeId(lastId);
刘基明's avatar
刘基明 committed
116
            if (lastEntity == null) throw new BizException("主题未找到,id:" + lastId);
117
            queryWrapper.lt(ThemeEntity::getCreateTime, lastEntity.getCreateTime());
刘基明's avatar
刘基明 committed
118
        }
刘基明's avatar
刘基明 committed
119 120
        if (pageSize != null) {
            queryWrapper.last("limit " + pageSize);
刘基明's avatar
刘基明 committed
121 122
        }
        return themeMapper.selectList(queryWrapper);
刘基明's avatar
刘基明 committed
123 124
    }

刘基明's avatar
刘基明 committed
125 126
    /**
     * 根据主题Id查询列表
127
     *
刘基明's avatar
刘基明 committed
128 129 130
     * @param themeIds
     * @return
     */
刘基明's avatar
刘基明 committed
131
    public List<ThemeEntity> queryByThemeIds(List<String> themeIds) {
132
        if (CollectionUtils.isEmpty(themeIds)) {
刘基明's avatar
刘基明 committed
133 134
            return Collections.emptyList();
        }
刘基明's avatar
刘基明 committed
135 136 137 138 139
        LambdaQueryWrapper<ThemeEntity> queryWrapper = new LambdaQueryWrapper<ThemeEntity>()
                .in(ThemeEntity::getThemeId, themeIds)
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED.getCode());

        return themeMapper.selectList(queryWrapper);
刘基明's avatar
刘基明 committed
140 141
    }

刘基明's avatar
刘基明 committed
142

刘基明's avatar
刘基明 committed
143

144

刘基明's avatar
刘基明 committed
145
    /**
刘基明's avatar
刘基明 committed
146
     * 根据话题查询最新主题(可分页)
刘基明's avatar
刘基明 committed
147 148
     *
     * @param topidId  话题Id
刘基明's avatar
刘基明 committed
149 150 151
     * @param pageSize 查询数量
     * @return
     */
张辰's avatar
张辰 committed
152
    public List<ThemeEntity> queryNewestByTopic(String topidId, Integer pageNo, Integer pageSize, List<String> excludeIds) {
刘基明's avatar
刘基明 committed
153
        LambdaQueryWrapper<ThemeEntity> queryWrapper = new LambdaQueryWrapper<ThemeEntity>()
张辰's avatar
张辰 committed
154 155 156 157 158
                .eq(ThemeEntity::getTopicId, topidId);
        if (!excludeIds.isEmpty()) {
            queryWrapper.notIn(ThemeEntity::getThemeId, excludeIds);
        }
        queryWrapper.last("limit " + pageNo + ", " + pageSize)
159 160
                .orderByDesc(ThemeEntity::getCreateTime)
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED.getCode());
刘基明's avatar
刘基明 committed
161
        return themeMapper.selectList(queryWrapper);
刘基明's avatar
刘基明 committed
162
    }
刘基明's avatar
刘基明 committed
163

刘基明's avatar
刘基明 committed
164
    //根据话题查询所有的主题Id,包括已删除的主题
刘基明's avatar
刘基明 committed
165
    public List<String> queryThemeIdsByTopic(String topidId) {
刘基明's avatar
刘基明 committed
166
        if (StringUtils.isEmpty(topidId)) {
刘基明's avatar
刘基明 committed
167 168
            return Collections.emptyList();
        }
刘基明's avatar
刘基明 committed
169 170 171 172 173 174
        LambdaQueryWrapper<ThemeEntity> queryWrapper = new LambdaQueryWrapper<ThemeEntity>()
                .eq(ThemeEntity::getTopicId, topidId);
        queryWrapper.select(ThemeEntity::getThemeId);
        return themeMapper.selectList(queryWrapper).stream().map(ThemeEntity::getThemeId).collect(Collectors.toList());
    }

刘基明's avatar
刘基明 committed
175
    /**
刘基明's avatar
刘基明 committed
176
     * 根据作者查询主题分页列表
刘基明's avatar
刘基明 committed
177
     * @param userIds
刘基明's avatar
刘基明 committed
178
     * @param pageStart
刘基明's avatar
刘基明 committed
179 180 181
     * @param pageSize
     * @return
     */
张辰's avatar
张辰 committed
182
    public List<ThemeEntity> queryByUserIdsCreateDesc(List<String> userIds, Integer pageStart, Integer pageSize) {
刘基明's avatar
刘基明 committed
183 184 185
        if (CollectionUtils.isEmpty(userIds)){
            return Collections.emptyList();
        }
刘基明's avatar
刘基明 committed
186
        LambdaQueryWrapper<ThemeEntity> queryWrapper = new LambdaQueryWrapper<ThemeEntity>()
刘基明's avatar
刘基明 committed
187 188 189 190
                .in(ThemeEntity::getAuthorId, userIds)
                .last("limit " + pageStart + ", " + pageSize)
                .orderByDesc(ThemeEntity::getCreateTime)
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED.getCode());
刘基明's avatar
刘基明 committed
191
        return themeMapper.selectList(queryWrapper);
刘基明's avatar
刘基明 committed
192 193 194

    }

刘基明's avatar
刘基明 committed
195 196
    public Integer getForwardCountById(String themeId) {
        return themeMapper.selectCount(new LambdaQueryWrapper<ThemeEntity>()
刘基明's avatar
刘基明 committed
197
                .eq(ThemeEntity::getFormerThemeId, themeId)
刘基明's avatar
刘基明 committed
198 199
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED));
    }
刘基明's avatar
刘基明 committed
200

刘基明's avatar
刘基明 committed
201
    public boolean judgeForwardByUser(String themeId, String userId) {
刘基明's avatar
刘基明 committed
202 203 204
        return themeMapper.selectCount(new LambdaQueryWrapper<ThemeEntity>()
                .eq(ThemeEntity::getFormerThemeId, themeId)
                .eq(ThemeEntity::getAuthorId, userId)
刘基明's avatar
刘基明 committed
205 206 207 208
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED))>0;
    }

    public Set<String> getForwardUsers(List<String> themeIds) {
刘基明's avatar
刘基明 committed
209 210 211
        if (CollectionUtils.isEmpty(themeIds)){
            return new HashSet<>();
        }
刘基明's avatar
刘基明 committed
212 213 214 215
        return themeMapper.selectList(new LambdaQueryWrapper<ThemeEntity>()
                .in(ThemeEntity::getFormerThemeId, themeIds)
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED))
                .stream().map(ThemeEntity::getAuthorId).collect(Collectors.toSet());
刘基明's avatar
刘基明 committed
216
    }
刘基明's avatar
刘基明 committed
217

刘基明's avatar
刘基明 committed
218 219


刘基明's avatar
刘基明 committed
220
    @Transactional
刘基明's avatar
刘基明 committed
221
    public void deleteById(String themeId,String userId) {
刘基明's avatar
刘基明 committed
222 223
        ThemeEntity themeEntity = themeMapper.selectOne(new LambdaQueryWrapper<ThemeEntity>()
                .eq(ThemeEntity::getThemeId, themeId));
刘基明's avatar
刘基明 committed
224 225
        if (themeEntity == null || !themeEntity.getAuthorId().equals(userId)) {
            throw new BizException("主题与用户不匹配,id:" + themeId+",userId"+userId);
刘基明's avatar
刘基明 committed
226 227 228 229
        }
        themeEntity.setDeleteTag(DeleteTagEnum.DELETED.getCode());
        themeMapper.updateById(themeEntity);
    }
刘基明's avatar
刘基明 committed
230

刘基明's avatar
刘基明 committed
231 232
    /**
     * 查询更新节点后的用户新建主题数
233 234
     *
     * @param userIds      用户ids
刘基明's avatar
刘基明 committed
235
     * @param lastId 更新时间节点
刘基明's avatar
刘基明 committed
236 237
     * @return
     */
张辰's avatar
张辰 committed
238
    public Integer queryCountFromLastId(List<String> userIds, Long lastId) {
刘基明's avatar
刘基明 committed
239 240 241 242 243
        if (CollectionUtils.isEmpty(userIds)) {
            return 0;
        }
        LambdaQueryWrapper<ThemeEntity> queryWrapper = new LambdaQueryWrapper<ThemeEntity>()
                .in(ThemeEntity::getAuthorId, userIds)
张辰's avatar
张辰 committed
244
                .gt(ThemeEntity::getId, lastId)
刘基明's avatar
刘基明 committed
245 246 247
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED.getCode());
        return themeMapper.selectCount(queryWrapper);
    }
刘基明's avatar
刘基明 committed
248 249


250 251 252 253 254 255 256 257
    public void updateReportStatus(String themeId) {
        ThemeEntity themeEntity = queryByThemeId(themeId);
        if (themeEntity == null) {
            throw new BizException("主题未找到,id:"+themeId);
        }
        themeEntity.setReportStatus(ReportStatusEnum.REPORTED.getCode());
        themeMapper.updateById(themeEntity);
    }
刘基明's avatar
刘基明 committed
258 259 260

    //统计主题集合的浏览量
    public Map<String, Integer> getForwardCountMap(List<String> themeIds) {
刘基明's avatar
刘基明 committed
261 262 263
        if (CollectionUtils.isEmpty(themeIds)){
            return new HashMap<String, Integer>();
        }
刘基明's avatar
刘基明 committed
264 265 266 267 268 269 270 271
        LambdaQueryWrapper<ThemeEntity> wrapper = new LambdaQueryWrapper<ThemeEntity>()
                .eq(ThemeEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED)
                .in(ThemeEntity::getFormerThemeId,themeIds)
                .groupBy(ThemeEntity::getFormerThemeId);
        return themeMapper.selectCountByThemeIds(wrapper).stream()
                .collect(Collectors.toMap(TimesCountEntity::getId, TimesCountEntity::getTimes));
    }

刘基明's avatar
刘基明 committed
272 273 274 275 276 277
    public List<ThemeEntity> queryAllForward() {
        return themeMapper.selectList(new LambdaQueryWrapper<ThemeEntity>()
                .eq(ThemeEntity::getThemeType, ThemeTypeEnum.FORWARD.getCode())
                .eq(ThemeEntity::getDeleteTag,DeleteTagEnum.NOT_DELETED.getCode())
                .orderByAsc(ThemeEntity::getCreateTime));
    }
刘基明's avatar
刘基明 committed
278
}