VisitLogService.java 5.91 KB
Newer Older
张辰's avatar
张辰 committed
1 2 3
package com.tanpu.community.service;

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
张辰's avatar
张辰 committed
4
import com.tanpu.biz.common.enums.clue.PageEnum;
刘基明's avatar
刘基明 committed
5
import com.tanpu.community.api.enums.DeleteTagEnum;
刘基明's avatar
刘基明 committed
6
import com.tanpu.community.cache.RedisCache;
刘基明's avatar
刘基明 committed
7
import com.tanpu.community.dao.entity.community.TimesCountEntity;
刘基明's avatar
刘基明 committed
8 9
import com.tanpu.community.dao.entity.community.VisitLogEntity;
import com.tanpu.community.dao.mapper.community.VisitLogMapper;
张辰's avatar
张辰 committed
10
import lombok.extern.slf4j.Slf4j;
刘基明's avatar
刘基明 committed
11
import org.apache.commons.collections4.CollectionUtils;
张辰's avatar
张辰 committed
12
import org.apache.commons.collections4.ListUtils;
刘基明's avatar
刘基明 committed
13
import org.apache.commons.lang3.StringUtils;
张辰's avatar
张辰 committed
14
import org.apache.commons.lang3.time.DateUtils;
张辰's avatar
张辰 committed
15
import org.springframework.stereotype.Service;
刘基明's avatar
刘基明 committed
16
import org.springframework.transaction.annotation.Transactional;
张辰's avatar
张辰 committed
17 18

import javax.annotation.Resource;
张辰's avatar
张辰 committed
19
import java.util.Date;
刘基明's avatar
刘基明 committed
20
import java.util.HashMap;
刘基明's avatar
刘基明 committed
21
import java.util.List;
刘基明's avatar
刘基明 committed
22
import java.util.Map;
张辰's avatar
张辰 committed
23
import java.util.stream.Collectors;
张辰's avatar
张辰 committed
24

25 26
import static com.tanpu.biz.common.enums.clue.PageEnum.COMM_VISIT_TOPIC_DETAIL;

张辰's avatar
张辰 committed
27 28
@Slf4j
@Service
刘基明's avatar
刘基明 committed
29
public class VisitLogService {
张辰's avatar
张辰 committed
30 31

    @Resource
刘基明's avatar
刘基明 committed
32
    private VisitLogMapper visitLogMapper;
张辰's avatar
张辰 committed
33

刘基明's avatar
刘基明 committed
34 35 36
    @Resource
    private RedisCache redisCache;

张辰's avatar
张辰 committed
37 38 39 40
    // 获取用户7天内访问过的
    public List<String> queryUserRecentVisited(String userId) {
        Date endDate = new Date();
        Date startDate = DateUtils.addDays(endDate, -7);
张辰's avatar
张辰 committed
41
        List<String> visited = visitLogMapper.selectRefIdByVisitorIdAndCreateBetween(userId, startDate, endDate);
张辰's avatar
张辰 committed
42 43 44
        return visited;
    }

45
    // 从refIds中去掉用户已经访问过的
张辰's avatar
张辰 committed
46 47 48 49
    public List<String> filterUserNotVisited(String userId, List<String> refIds) {
        if (refIds.isEmpty()) {
            return refIds;
        }
刘基明's avatar
刘基明 committed
50 51 52 53
        List<String> visited = visitLogMapper.selectList(new LambdaQueryWrapper<VisitLogEntity>()
                .eq(VisitLogEntity::getVisitorId, userId)
                .in(VisitLogEntity::getRefId, refIds))
                .stream().map(VisitLogEntity::getRefId).distinct().collect(Collectors.toList());
张辰's avatar
张辰 committed
54 55
        return ListUtils.subtract(refIds, visited);
    }
刘基明's avatar
刘基明 committed
56

刘基明's avatar
刘基明 committed
57
    public List<String> queryUserVisited(String userId) {
刘基明's avatar
刘基明 committed
58 59 60
        List<String> visited = visitLogMapper.selectList(new LambdaQueryWrapper<VisitLogEntity>()
                .eq(VisitLogEntity::getVisitorId, userId))
                .stream().map(VisitLogEntity::getRefId).distinct().collect(Collectors.toList());
刘基明's avatar
刘基明 committed
61 62 63
        return visited;
    }

张辰's avatar
张辰 committed
64 65

    @Transactional
刘基明's avatar
刘基明 committed
66
    public void insertOrUpdateDur(VisitLogEntity vs) {
刘基明's avatar
刘基明 committed
67 68 69 70 71 72 73 74 75 76 77 78 79
        // 分布式锁
        for (;;) {
            String key = getVisitLogRedisKey(vs);
            if (redisCache.setIfAbsent(key, "1", 15)) {
                if (visitLogMapper.selectByIdentAndRefId(vs.getIdent(), vs.getRefId(), vs.getRefType()) == null) {
                    visitLogMapper.insert(vs);
                } else {
                    visitLogMapper.updateDurByIdent(vs.getDuration(), vs.getIdent());
                }
                // 如果执行超时,会删除别的实例的key
                redisCache.evict(key);
                return;
            }
张辰's avatar
张辰 committed
80 81 82
        }
    }

刘基明's avatar
刘基明 committed
83 84 85 86
    private String getVisitLogRedisKey(VisitLogEntity vs) {
        return StringUtils.join("insertOrUpdateDur:", vs.getIdent().substring(0, 4), vs.getRefId(), vs.getRefType());
    }

刘基明's avatar
刘基明 committed
87 88
    @Transactional
    //TODO 临时埋点,接入新埋点后删除
89
    public void addPageView(String userId, String targetId, PageEnum type) {
刘基明's avatar
刘基明 committed
90
        visitLogMapper.insert(VisitLogEntity.builder()
刘基明's avatar
刘基明 committed
91 92
                .visitorId(userId)
                .refId(targetId)
93
                .refType(type.getId())
刘基明's avatar
刘基明 committed
94 95 96 97
                .duration(0)
                .build());
    }

张辰's avatar
张辰 committed
98 99
    // 查询话题 详细页面 浏览量
    public Integer queryTopicDetailVisit(String topicId) {
刘基明's avatar
刘基明 committed
100 101
        return visitLogMapper.selectCount(new LambdaQueryWrapper<VisitLogEntity>()
                .eq(VisitLogEntity::getRefId, topicId)
102
                .eq(VisitLogEntity::getRefType, COMM_VISIT_TOPIC_DETAIL.getId()));
刘基明's avatar
刘基明 committed
103 104 105 106
    }

    // 查询主题 浏览量
    public Integer queryThemeVisit(String theme) {
刘基明's avatar
刘基明 committed
107 108
        return visitLogMapper.selectCount(new LambdaQueryWrapper<VisitLogEntity>()
                .eq(VisitLogEntity::getRefId, theme)
张辰's avatar
张辰 committed
109
                .eq(VisitLogEntity::getRefType, PageEnum.COMM_VISIT_THEME.getId()));
刘基明's avatar
刘基明 committed
110 111 112 113
    }

    // 查询主题 浏览量
    public Integer queryThemeVisit(List<String> themes) {
刘基明's avatar
刘基明 committed
114
        if (CollectionUtils.isEmpty(themes)) {
刘基明's avatar
刘基明 committed
115 116
            return 0;
        }
刘基明's avatar
刘基明 committed
117 118
        return visitLogMapper.selectCount(new LambdaQueryWrapper<VisitLogEntity>()
                .in(VisitLogEntity::getRefId, themes)
张辰's avatar
张辰 committed
119
                .eq(VisitLogEntity::getRefType, PageEnum.COMM_VISIT_THEME.getId()));
张辰's avatar
张辰 committed
120
    }
张辰's avatar
张辰 committed
121

张辰's avatar
张辰 committed
122 123 124 125 126 127 128 129 130 131 132
//    public LocalDateTime queryLatestViewFollow(String userId) {
//        List<VisitLogEntity> visitSummaryEntities = visitLogMapper.selectList(new LambdaQueryWrapper<VisitLogEntity>()
//                .eq(VisitLogEntity::getVisitorId, userId)
//                .eq(VisitLogEntity::getRefType, VisitTypeEnum.FOLLOW_THEME_VIEW.getCode())
//                .orderByDesc(VisitLogEntity::getCreateTime));
//        if (CollectionUtils.isEmpty(visitSummaryEntities)) {
//            return null;
//        } else {
//            return visitSummaryEntities.get(0).getCreateTime();
//        }
//    }
刘基明's avatar
刘基明 committed
133

刘基明's avatar
刘基明 committed
134
    //统计行为集合的浏览量
张辰's avatar
张辰 committed
135
    public Map<String, Integer> getCountMapByTargetIds(List<String> refIds, String refType) {
刘基明's avatar
刘基明 committed
136
        if (CollectionUtils.isEmpty(refIds)) {
刘基明's avatar
刘基明 committed
137 138
            return new HashMap<>();
        }
刘基明's avatar
刘基明 committed
139
        LambdaQueryWrapper<VisitLogEntity> wrapper = (new LambdaQueryWrapper<VisitLogEntity>()
刘基明's avatar
刘基明 committed
140
                .in(VisitLogEntity::getRefId, refIds))
刘基明's avatar
刘基明 committed
141
                .eq(VisitLogEntity::getDeleteTag, DeleteTagEnum.NOT_DELETED)
张辰's avatar
张辰 committed
142
                .eq(VisitLogEntity::getRefType, refType)
刘基明's avatar
刘基明 committed
143 144
                .groupBy(VisitLogEntity::getRefId);
        return visitLogMapper.selectCountByThemeIds(wrapper).stream()
刘基明's avatar
刘基明 committed
145 146
                .collect(Collectors.toMap(TimesCountEntity::getId, TimesCountEntity::getTimes));
    }
张辰's avatar
张辰 committed
147
}