-
Notifications
You must be signed in to change notification settings - Fork 8
Expand file tree
/
Copy pathAdminUserBanService.java
More file actions
113 lines (95 loc) · 4.63 KB
/
AdminUserBanService.java
File metadata and controls
113 lines (95 loc) · 4.63 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
package com.example.solidconnection.admin.service;
import static java.time.ZoneOffset.UTC;
import com.example.solidconnection.admin.dto.UserBanRequest;
import com.example.solidconnection.chat.repository.ChatMessageRepository;
import com.example.solidconnection.common.exception.CustomException;
import com.example.solidconnection.common.exception.ErrorCode;
import com.example.solidconnection.community.post.repository.PostRepository;
import com.example.solidconnection.report.repository.ReportRepository;
import com.example.solidconnection.siteuser.domain.SiteUser;
import com.example.solidconnection.siteuser.domain.UserBan;
import com.example.solidconnection.siteuser.domain.UserStatus;
import com.example.solidconnection.siteuser.repository.SiteUserRepository;
import com.example.solidconnection.siteuser.repository.UserBanRepository;
import java.time.ZonedDateTime;
import java.util.List;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@Slf4j
@RequiredArgsConstructor
@Service
public class AdminUserBanService {
private final UserBanRepository userBanRepository;
private final ReportRepository reportRepository;
private final SiteUserRepository siteUserRepository;
private final PostRepository postRepository;
private final ChatMessageRepository chatMessageRepository;
@Transactional
public void banUser(long userId, long adminId, UserBanRequest request) {
SiteUser user = siteUserRepository.findById(userId)
.orElseThrow(() -> new CustomException(ErrorCode.USER_NOT_FOUND));
validateNotAlreadyBanned(userId);
validateReportExists(userId);
user.updateUserStatus(UserStatus.BANNED);
updateReportedContentIsDeleted(userId, true);
createUserBan(userId, adminId, request);
}
private void validateNotAlreadyBanned(long userId) {
if (userBanRepository.existsByBannedUserIdAndIsExpiredFalseAndExpiredAtAfter(userId, ZonedDateTime.now(UTC))) {
throw new CustomException(ErrorCode.ALREADY_BANNED_USER);
}
}
private void validateReportExists(long userId) {
if (!reportRepository.existsByReportedId(userId)) {
throw new CustomException(ErrorCode.REPORT_NOT_FOUND);
}
}
private void updateReportedContentIsDeleted(long userId, boolean isDeleted) {
postRepository.updateReportedPostsIsDeleted(userId, isDeleted);
chatMessageRepository.updateReportedChatMessagesIsDeleted(userId, isDeleted);
}
private void createUserBan(long userId, long adminId, UserBanRequest request) {
ZonedDateTime now = ZonedDateTime.now(UTC);
ZonedDateTime expiredAt = now.plusDays(request.duration().getDays());
UserBan userBan = new UserBan(userId, adminId, request.duration(), expiredAt);
userBanRepository.save(userBan);
}
@Transactional
public void unbanUser(long userId, long adminId) {
SiteUser user = siteUserRepository.findById(userId)
.orElseThrow(() -> new CustomException(ErrorCode.USER_NOT_FOUND));
UserBan userBan = findActiveBan(userId);
userBan.manuallyUnban(adminId);
user.updateUserStatus(UserStatus.REPORTED);
updateReportedContentIsDeleted(userId, false);
}
private UserBan findActiveBan(long userId) {
return userBanRepository
.findByBannedUserIdAndIsExpiredFalseAndExpiredAtAfter(userId, ZonedDateTime.now(UTC))
.orElseThrow(() -> new CustomException(ErrorCode.NOT_BANNED_USER));
}
@Transactional
@Scheduled(cron = "0 0 0 * * *")
public void expireUserBans() {
try {
ZonedDateTime now = ZonedDateTime.now(UTC);
List<Long> expiredUserIds = userBanRepository.findExpiredBannedUserIds(now);
if (expiredUserIds.isEmpty()) {
return;
}
userBanRepository.bulkExpireUserBans(now);
siteUserRepository.bulkUpdateUserStatus(expiredUserIds, UserStatus.REPORTED);
bulkUpdateReportedContentIsDeleted(expiredUserIds);
log.info("Finished processing expired blocks:: userIds={}", expiredUserIds);
} catch (Exception e) {
log.error("Failed to process expired blocks", e);
}
}
private void bulkUpdateReportedContentIsDeleted(List<Long> expiredUserIds) {
postRepository.bulkUpdateReportedPostsIsDeleted(expiredUserIds, false);
chatMessageRepository.bulkUpdateReportedChatMessagesIsDeleted(expiredUserIds, false);
}
}