parent
aea4918a18
commit
0dd1dfb6f8
@ -0,0 +1,80 @@
|
||||
package com.luoo.music.listener;
|
||||
|
||||
import constants.Constants;
|
||||
import net.oschina.j2cache.CacheChannel;
|
||||
import org.springframework.amqp.rabbit.annotation.RabbitHandler;
|
||||
import org.springframework.amqp.rabbit.annotation.RabbitListener;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
import com.luoo.music.dao.JournalDao;
|
||||
import com.luoo.music.dto.request.JournalQueryReq;
|
||||
import com.luoo.music.pojo.Journal;
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
import java.util.Optional;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
@Component
|
||||
@RabbitListener(queues = Constants.RABBIT_MESSAGE_USER_COLLECT_JOURNAL)
|
||||
public class UserCollectJournalListener {
|
||||
private static final int DEFAULT_PAGE_SIZE = 10;
|
||||
@Autowired
|
||||
private CacheChannel cacheChannel;
|
||||
|
||||
@Autowired
|
||||
private JournalDao journalDao;
|
||||
|
||||
@RabbitHandler
|
||||
public void updateUserCollectCount(String journalId) {
|
||||
boolean isReduceCount = journalId.startsWith("-");
|
||||
if (isReduceCount) {
|
||||
journalId = journalId.replaceFirst("-", "");
|
||||
}
|
||||
Optional<Journal> optional = journalDao.findById(journalId);
|
||||
if (!optional.isPresent()) {
|
||||
return;
|
||||
}
|
||||
Journal journal = optional.get();
|
||||
int userCollectCount = journal.getUserCollectCount();
|
||||
journal.setUserCollectCount(isReduceCount ? (userCollectCount - 1) : (userCollectCount + 1));
|
||||
journalDao.save(journal);
|
||||
excuteClearCache(journal);
|
||||
}
|
||||
|
||||
private void excuteClearCache(Journal journal) {
|
||||
String journalQueryPageKey = getJournalQueryPageKey(journal);
|
||||
cacheChannel.evict(Constants.J2CACHE_REGION_JOURNAL_QUERY_PAGE, journalQueryPageKey);
|
||||
cacheChannel.evict(Constants.J2CACHE_REGION_JOURNAL_ID, journal.getId());
|
||||
cacheChannel.evict(constants.Constants.J2CACHE_REGION_JOURNAL_SONG_LIST, journal.getId());
|
||||
cacheChannel.evict(Constants.J2CACHE_REGION_JOURNAL_NO, journal.getJournalNo());
|
||||
}
|
||||
|
||||
private String getJournalQueryPageKey(Journal journal) {
|
||||
List<Integer> journalNos = journalDao.findValidJournals().stream().map(j -> Integer.valueOf(j.getJournalNo()))
|
||||
.sorted().collect(Collectors.toList());
|
||||
Collections.reverse(journalNos);
|
||||
JournalQueryReq journalQueryReq = new JournalQueryReq();
|
||||
journalQueryReq.setPageNum(getPageNum(Integer.valueOf(journal.getJournalNo()), journalNos));
|
||||
journalQueryReq.setPageSize(DEFAULT_PAGE_SIZE);
|
||||
return journalQueryReq.toString();
|
||||
}
|
||||
|
||||
private int getPageNum(int value, List<Integer> list) {
|
||||
if (value > list.get(0)) {
|
||||
return 0;
|
||||
}
|
||||
int pageSize = DEFAULT_PAGE_SIZE;
|
||||
for (int pageNum = 1; (pageNum - 1) * pageSize < list.size(); pageNum++) {
|
||||
int startIndex = (pageNum - 1) * pageSize;
|
||||
int endIndex = pageNum * pageSize - 1;
|
||||
if (endIndex > list.size()) {
|
||||
return pageNum;
|
||||
}
|
||||
if (list.get(startIndex) >= value && list.get(endIndex) <= value) {
|
||||
return pageNum;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
}
|
Loading…
Reference in new issue