fix(项目管理): 修复消息中心全部已读的bug以及通知人是创建人但是收不到的问题
--bug=1039160 --user=郭雨琦 https://www.tapd.cn/55049933/bugtrace/bugs/view/1155049933001039160
This commit is contained in:
parent
d407f9d352
commit
ecaed710c6
|
@ -41,8 +41,8 @@ public class NotificationController {
|
||||||
|
|
||||||
@GetMapping(value = "/read/all")
|
@GetMapping(value = "/read/all")
|
||||||
@Operation(summary = "消息中心-将消息中心所有信息设置为已读消息")
|
@Operation(summary = "消息中心-将消息中心所有信息设置为已读消息")
|
||||||
public Integer readAll() {
|
public Integer readAll(@RequestParam(value = "resourceType", required = false) String resourceType) {
|
||||||
return notificationService.readAll(SessionUtils.getUserId());
|
return notificationService.readAll(resourceType, SessionUtils.getUserId());
|
||||||
}
|
}
|
||||||
|
|
||||||
@PostMapping(value = "/count")
|
@PostMapping(value = "/count")
|
||||||
|
|
|
@ -1,27 +1,31 @@
|
||||||
package io.metersphere.system.notice.sender;
|
package io.metersphere.system.notice.sender;
|
||||||
|
|
||||||
|
|
||||||
import io.metersphere.api.domain.ApiDefinitionFollower;
|
import io.metersphere.api.domain.*;
|
||||||
import io.metersphere.api.domain.ApiDefinitionFollowerExample;
|
|
||||||
import io.metersphere.api.domain.ApiScenarioFollower;
|
|
||||||
import io.metersphere.api.domain.ApiScenarioFollowerExample;
|
|
||||||
import io.metersphere.api.mapper.ApiDefinitionFollowerMapper;
|
import io.metersphere.api.mapper.ApiDefinitionFollowerMapper;
|
||||||
|
import io.metersphere.api.mapper.ApiDefinitionMapper;
|
||||||
import io.metersphere.api.mapper.ApiScenarioFollowerMapper;
|
import io.metersphere.api.mapper.ApiScenarioFollowerMapper;
|
||||||
|
import io.metersphere.api.mapper.ApiScenarioMapper;
|
||||||
|
import io.metersphere.bug.domain.Bug;
|
||||||
import io.metersphere.bug.domain.BugFollower;
|
import io.metersphere.bug.domain.BugFollower;
|
||||||
import io.metersphere.bug.domain.BugFollowerExample;
|
import io.metersphere.bug.domain.BugFollowerExample;
|
||||||
import io.metersphere.bug.mapper.BugFollowerMapper;
|
import io.metersphere.bug.mapper.BugFollowerMapper;
|
||||||
import io.metersphere.functional.domain.CaseReviewFollower;
|
import io.metersphere.bug.mapper.BugMapper;
|
||||||
import io.metersphere.functional.domain.CaseReviewFollowerExample;
|
import io.metersphere.functional.domain.*;
|
||||||
import io.metersphere.functional.domain.FunctionalCaseFollower;
|
|
||||||
import io.metersphere.functional.domain.FunctionalCaseFollowerExample;
|
|
||||||
import io.metersphere.functional.mapper.CaseReviewFollowerMapper;
|
import io.metersphere.functional.mapper.CaseReviewFollowerMapper;
|
||||||
|
import io.metersphere.functional.mapper.CaseReviewMapper;
|
||||||
import io.metersphere.functional.mapper.FunctionalCaseFollowerMapper;
|
import io.metersphere.functional.mapper.FunctionalCaseFollowerMapper;
|
||||||
|
import io.metersphere.functional.mapper.FunctionalCaseMapper;
|
||||||
|
import io.metersphere.load.domain.LoadTest;
|
||||||
import io.metersphere.load.domain.LoadTestFollower;
|
import io.metersphere.load.domain.LoadTestFollower;
|
||||||
import io.metersphere.load.domain.LoadTestFollowerExample;
|
import io.metersphere.load.domain.LoadTestFollowerExample;
|
||||||
import io.metersphere.load.mapper.LoadTestFollowerMapper;
|
import io.metersphere.load.mapper.LoadTestFollowerMapper;
|
||||||
|
import io.metersphere.load.mapper.LoadTestMapper;
|
||||||
|
import io.metersphere.plan.domain.TestPlan;
|
||||||
import io.metersphere.plan.domain.TestPlanFollower;
|
import io.metersphere.plan.domain.TestPlanFollower;
|
||||||
import io.metersphere.plan.domain.TestPlanFollowerExample;
|
import io.metersphere.plan.domain.TestPlanFollowerExample;
|
||||||
import io.metersphere.plan.mapper.TestPlanFollowerMapper;
|
import io.metersphere.plan.mapper.TestPlanFollowerMapper;
|
||||||
|
import io.metersphere.plan.mapper.TestPlanMapper;
|
||||||
import io.metersphere.sdk.util.JSON;
|
import io.metersphere.sdk.util.JSON;
|
||||||
import io.metersphere.sdk.util.LogUtils;
|
import io.metersphere.sdk.util.LogUtils;
|
||||||
import io.metersphere.system.domain.User;
|
import io.metersphere.system.domain.User;
|
||||||
|
@ -39,6 +43,7 @@ import org.apache.commons.lang3.StringUtils;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
public abstract class AbstractNoticeSender implements NoticeSender {
|
public abstract class AbstractNoticeSender implements NoticeSender {
|
||||||
|
@ -46,18 +51,32 @@ public abstract class AbstractNoticeSender implements NoticeSender {
|
||||||
@Resource
|
@Resource
|
||||||
private BugFollowerMapper bugFollowerMapper;
|
private BugFollowerMapper bugFollowerMapper;
|
||||||
@Resource
|
@Resource
|
||||||
|
private BugMapper bugMapper;
|
||||||
|
@Resource
|
||||||
private TestPlanFollowerMapper testPlanFollowerMapper;
|
private TestPlanFollowerMapper testPlanFollowerMapper;
|
||||||
@Resource
|
@Resource
|
||||||
|
private TestPlanMapper testPlanMapper;
|
||||||
|
@Resource
|
||||||
private FunctionalCaseFollowerMapper functionalCaseFollowerMapper;
|
private FunctionalCaseFollowerMapper functionalCaseFollowerMapper;
|
||||||
@Resource
|
@Resource
|
||||||
|
private FunctionalCaseMapper functionalCaseMapper;
|
||||||
|
@Resource
|
||||||
private ApiScenarioFollowerMapper apiScenarioFollowerMapper;
|
private ApiScenarioFollowerMapper apiScenarioFollowerMapper;
|
||||||
@Resource
|
@Resource
|
||||||
|
private ApiScenarioMapper apiScenarioMapper;
|
||||||
|
@Resource
|
||||||
private ApiDefinitionFollowerMapper apiDefinitionFollowerMapper;
|
private ApiDefinitionFollowerMapper apiDefinitionFollowerMapper;
|
||||||
@Resource
|
@Resource
|
||||||
|
private ApiDefinitionMapper apiDefinitionMapper;
|
||||||
|
@Resource
|
||||||
private LoadTestFollowerMapper loadTestFollowerMapper;
|
private LoadTestFollowerMapper loadTestFollowerMapper;
|
||||||
@Resource
|
@Resource
|
||||||
|
private LoadTestMapper loadTestMapper;
|
||||||
|
@Resource
|
||||||
private CaseReviewFollowerMapper caseReviewFollowerMapper;
|
private CaseReviewFollowerMapper caseReviewFollowerMapper;
|
||||||
@Resource
|
@Resource
|
||||||
|
private CaseReviewMapper caseReviewMapper;
|
||||||
|
@Resource
|
||||||
private ExtSystemProjectMapper extSystemProjectMapper;
|
private ExtSystemProjectMapper extSystemProjectMapper;
|
||||||
|
|
||||||
|
|
||||||
|
@ -116,7 +135,8 @@ public abstract class AbstractNoticeSender implements NoticeSender {
|
||||||
if (StringUtils.isNotBlank(createUser)) {
|
if (StringUtils.isNotBlank(createUser)) {
|
||||||
toUsers.add(new Receiver(createUser, NotificationConstants.Type.SYSTEM_NOTICE.name()));
|
toUsers.add(new Receiver(createUser, NotificationConstants.Type.SYSTEM_NOTICE.name()));
|
||||||
} else {
|
} else {
|
||||||
toUsers.add(new Receiver((String) paramMap.get(NoticeConstants.RelatedUser.OPERATOR), NotificationConstants.Type.SYSTEM_NOTICE.name()));
|
Receiver receiver = handleCreateUser(messageDetail, noticeModel);
|
||||||
|
toUsers.add(Objects.requireNonNullElseGet(receiver, () -> new Receiver((String) paramMap.get(NoticeConstants.RelatedUser.OPERATOR), NotificationConstants.Type.SYSTEM_NOTICE.name())));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
case NoticeConstants.RelatedUser.OPERATOR -> {
|
case NoticeConstants.RelatedUser.OPERATOR -> {
|
||||||
|
@ -152,7 +172,64 @@ public abstract class AbstractNoticeSender implements NoticeSender {
|
||||||
LogUtils.info("userIds: ", JSON.toJSONString(userIds));
|
LogUtils.info("userIds: ", JSON.toJSONString(userIds));
|
||||||
List<User> users = getUsers(userIds, messageDetail.getProjectId());
|
List<User> users = getUsers(userIds, messageDetail.getProjectId());
|
||||||
List<String> realUserIds = users.stream().map(User::getId).toList();
|
List<String> realUserIds = users.stream().map(User::getId).toList();
|
||||||
return toUsers;
|
return toUsers.stream().filter(t -> realUserIds.contains(t.getUserId())).toList();
|
||||||
|
}
|
||||||
|
|
||||||
|
private Receiver handleCreateUser(MessageDetail messageDetail, NoticeModel noticeModel) {
|
||||||
|
String id = (String) noticeModel.getParamMap().get("id");
|
||||||
|
if (StringUtils.isBlank(id)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
String taskType = messageDetail.getTaskType();
|
||||||
|
|
||||||
|
Receiver receiver = null;
|
||||||
|
switch (taskType) {
|
||||||
|
case NoticeConstants.TaskType.TEST_PLAN_TASK -> {
|
||||||
|
TestPlan testPlan = testPlanMapper.selectByPrimaryKey(id);
|
||||||
|
if (testPlan != null) {
|
||||||
|
receiver = new Receiver(testPlan.getCreateUser(), NotificationConstants.Type.SYSTEM_NOTICE.name());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case NoticeConstants.TaskType.CASE_REVIEW_TASK -> {
|
||||||
|
CaseReview caseReview = caseReviewMapper.selectByPrimaryKey(id);
|
||||||
|
if (caseReview != null) {
|
||||||
|
receiver = new Receiver(caseReview.getCreateUser(), NotificationConstants.Type.SYSTEM_NOTICE.name());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case NoticeConstants.TaskType.API_SCENARIO_TASK -> {
|
||||||
|
ApiScenario apiScenario = apiScenarioMapper.selectByPrimaryKey(id);
|
||||||
|
if (apiScenario != null) {
|
||||||
|
receiver = new Receiver(apiScenario.getCreateUser(), NotificationConstants.Type.SYSTEM_NOTICE.name());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case NoticeConstants.TaskType.API_DEFINITION_TASK -> {
|
||||||
|
ApiDefinition apiDefinition = apiDefinitionMapper.selectByPrimaryKey(id);
|
||||||
|
if (apiDefinition != null) {
|
||||||
|
receiver = new Receiver(apiDefinition.getCreateUser(), NotificationConstants.Type.SYSTEM_NOTICE.name());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case NoticeConstants.TaskType.LOAD_TEST_TASK -> {
|
||||||
|
LoadTest loadTest = loadTestMapper.selectByPrimaryKey(id);
|
||||||
|
if (loadTest != null) {
|
||||||
|
receiver = new Receiver(loadTest.getCreateUser(), NotificationConstants.Type.SYSTEM_NOTICE.name());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case NoticeConstants.TaskType.FUNCTIONAL_CASE_TASK -> {
|
||||||
|
FunctionalCase functionalCase = functionalCaseMapper.selectByPrimaryKey(id);
|
||||||
|
if (functionalCase != null) {
|
||||||
|
receiver = new Receiver(functionalCase.getCreateUser(), NotificationConstants.Type.SYSTEM_NOTICE.name());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case NoticeConstants.TaskType.BUG_TASK -> {
|
||||||
|
Bug bug = bugMapper.selectByPrimaryKey(id);
|
||||||
|
if (bug != null) {
|
||||||
|
receiver = new Receiver(bug.getCreateUser(), NotificationConstants.Type.SYSTEM_NOTICE.name());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
default -> {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return receiver;
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<Receiver> handleFollows(MessageDetail messageDetail, NoticeModel noticeModel) {
|
private List<Receiver> handleFollows(MessageDetail messageDetail, NoticeModel noticeModel) {
|
||||||
|
|
|
@ -42,10 +42,13 @@ public class NotificationService {
|
||||||
return notificationMapper.updateByExampleSelective(record, example);
|
return notificationMapper.updateByExampleSelective(record, example);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int readAll(String userId) {
|
public int readAll(String resourceType, String userId) {
|
||||||
Notification record = new Notification();
|
Notification record = new Notification();
|
||||||
record.setStatus(NotificationConstants.Status.READ.name());
|
record.setStatus(NotificationConstants.Status.READ.name());
|
||||||
NotificationExample example = new NotificationExample();
|
NotificationExample example = new NotificationExample();
|
||||||
|
if (StringUtils.isNotBlank(resourceType)) {
|
||||||
|
example.createCriteria().andResourceTypeEqualTo(resourceType);
|
||||||
|
}
|
||||||
example.createCriteria().andReceiverEqualTo(userId);
|
example.createCriteria().andReceiverEqualTo(userId);
|
||||||
return notificationMapper.updateByExampleSelective(record, example);
|
return notificationMapper.updateByExampleSelective(record, example);
|
||||||
}
|
}
|
||||||
|
|
|
@ -85,6 +85,6 @@ export function queryMessageHistoryCount(data: historyQueryParams) {
|
||||||
return MSR.post<OptionItem[]>({ url: '/notification/count', data });
|
return MSR.post<OptionItem[]>({ url: '/notification/count', data });
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getMessageReadAll() {
|
export function getMessageReadAll(resourceType?: string) {
|
||||||
return MSR.get<number>({ url: '/notification/read/all' });
|
return MSR.get<number>({ url: '/notification/read/all', params: { resourceType } });
|
||||||
}
|
}
|
||||||
|
|
|
@ -318,7 +318,7 @@
|
||||||
|
|
||||||
// 全部标记为已读
|
// 全部标记为已读
|
||||||
async function prepositionEdit() {
|
async function prepositionEdit() {
|
||||||
await getMessageReadAll();
|
await getMessageReadAll(currentResourceType.value);
|
||||||
messageHistoryList.value = [];
|
messageHistoryList.value = [];
|
||||||
pageNation.value.current = 1;
|
pageNation.value.current = 1;
|
||||||
// 左侧消息总数
|
// 左侧消息总数
|
||||||
|
|
Loading…
Reference in New Issue