Merge branch 'master' of https://github.com/metersphere/metersphere
This commit is contained in:
commit
ade3fe2043
backend/src/main/java/io/metersphere
api
base
domain
mapper
commons
config
notice
performance
track/service
frontend/src/business/components
settings/organization/components
DefectTaskNotification.vueJenkinsNotification.vueTestPlanTaskNotification.vueTestReviewNotification.vue
xpack
|
@ -9,12 +9,9 @@ import io.metersphere.commons.constants.TestPlanTestCaseStatus;
|
||||||
import io.metersphere.commons.utils.CommonBeanFactory;
|
import io.metersphere.commons.utils.CommonBeanFactory;
|
||||||
import io.metersphere.commons.utils.LogUtil;
|
import io.metersphere.commons.utils.LogUtil;
|
||||||
import io.metersphere.dto.BaseSystemConfigDTO;
|
import io.metersphere.dto.BaseSystemConfigDTO;
|
||||||
import io.metersphere.notice.domain.MessageDetail;
|
import io.metersphere.i18n.Translator;
|
||||||
import io.metersphere.notice.domain.MessageSettingDetail;
|
import io.metersphere.notice.sender.NoticeModel;
|
||||||
import io.metersphere.notice.service.DingTaskService;
|
import io.metersphere.notice.service.NoticeSendService;
|
||||||
import io.metersphere.notice.service.MailService;
|
|
||||||
import io.metersphere.notice.service.NoticeService;
|
|
||||||
import io.metersphere.notice.service.WxChatTaskService;
|
|
||||||
import io.metersphere.service.SystemParameterService;
|
import io.metersphere.service.SystemParameterService;
|
||||||
import io.metersphere.track.service.TestPlanTestCaseService;
|
import io.metersphere.track.service.TestPlanTestCaseService;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
@ -47,12 +44,6 @@ public class APIBackendListenerClient extends AbstractBackendListenerClient impl
|
||||||
|
|
||||||
private APIReportService apiReportService;
|
private APIReportService apiReportService;
|
||||||
|
|
||||||
private TestPlanTestCaseService testPlanTestCaseService;
|
|
||||||
|
|
||||||
private NoticeService noticeService;
|
|
||||||
|
|
||||||
private MailService mailService;
|
|
||||||
|
|
||||||
private ApiDefinitionService apiDefinitionService;
|
private ApiDefinitionService apiDefinitionService;
|
||||||
|
|
||||||
private ApiDefinitionExecResultService apiDefinitionExecResultService;
|
private ApiDefinitionExecResultService apiDefinitionExecResultService;
|
||||||
|
@ -92,18 +83,6 @@ public class APIBackendListenerClient extends AbstractBackendListenerClient impl
|
||||||
if (apiReportService == null) {
|
if (apiReportService == null) {
|
||||||
LogUtil.error("apiReportService is required");
|
LogUtil.error("apiReportService is required");
|
||||||
}
|
}
|
||||||
testPlanTestCaseService = CommonBeanFactory.getBean(TestPlanTestCaseService.class);
|
|
||||||
if (testPlanTestCaseService == null) {
|
|
||||||
LogUtil.error("testPlanTestCaseService is required");
|
|
||||||
}
|
|
||||||
noticeService = CommonBeanFactory.getBean(NoticeService.class);
|
|
||||||
if (noticeService == null) {
|
|
||||||
LogUtil.error("noticeService is required");
|
|
||||||
}
|
|
||||||
mailService = CommonBeanFactory.getBean(MailService.class);
|
|
||||||
if (mailService == null) {
|
|
||||||
LogUtil.error("mailService is required");
|
|
||||||
}
|
|
||||||
apiDefinitionService = CommonBeanFactory.getBean(ApiDefinitionService.class);
|
apiDefinitionService = CommonBeanFactory.getBean(ApiDefinitionService.class);
|
||||||
if (apiDefinitionService == null) {
|
if (apiDefinitionService == null) {
|
||||||
LogUtil.error("apiDefinitionService is required");
|
LogUtil.error("apiDefinitionService is required");
|
||||||
|
@ -226,61 +205,38 @@ public class APIBackendListenerClient extends AbstractBackendListenerClient impl
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void sendTask(ApiTestReport report, TestResult testResult) {
|
private static void sendTask(ApiTestReport report, TestResult testResult) {
|
||||||
NoticeService noticeService = CommonBeanFactory.getBean(NoticeService.class);
|
|
||||||
MailService mailService = CommonBeanFactory.getBean(MailService.class);
|
|
||||||
DingTaskService dingTaskService = CommonBeanFactory.getBean(DingTaskService.class);
|
|
||||||
WxChatTaskService wxChatTaskService = CommonBeanFactory.getBean(WxChatTaskService.class);
|
|
||||||
SystemParameterService systemParameterService = CommonBeanFactory.getBean(SystemParameterService.class);
|
SystemParameterService systemParameterService = CommonBeanFactory.getBean(SystemParameterService.class);
|
||||||
if (StringUtils.equals(NoticeConstants.API, report.getTriggerMode()) || StringUtils.equals(NoticeConstants.SCHEDULE, report.getTriggerMode())) {
|
NoticeSendService noticeSendService = CommonBeanFactory.getBean(NoticeSendService.class);
|
||||||
List<String> userIds = new ArrayList<>();
|
assert systemParameterService != null;
|
||||||
List<MessageDetail> taskList = new ArrayList<>();
|
assert noticeSendService != null;
|
||||||
String successContext = "";
|
|
||||||
String failedContext = "";
|
|
||||||
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
||||||
String url = baseSystemConfigDTO.getUrl() + "/#/api/report/view/" + report.getId();
|
String url = baseSystemConfigDTO.getUrl() + "/#/api/report/view/" + report.getId();
|
||||||
if (StringUtils.equals(NoticeConstants.API, report.getTriggerMode())) {
|
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
String successContext = "";
|
||||||
taskList = messageSettingDetail.getJenkinsTask();
|
String failedContext = "";
|
||||||
successContext = "ApiJenkins任务通知:'" + report.getName() + "'执行成功" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
String subject = "";
|
||||||
failedContext = "ApiJenkins任务通知:'" + report.getName() + "'执行失败" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
if (StringUtils.equals(NoticeConstants.Mode.API, report.getTriggerMode())) {
|
||||||
|
successContext = "接口测试 API任务通知:'" + report.getName() + "'执行成功" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
||||||
|
failedContext = "接口测试 API任务通知:'" + report.getName() + "'执行失败" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
||||||
|
subject = Translator.get("task_notification_jenkins");
|
||||||
}
|
}
|
||||||
if (StringUtils.equals(NoticeConstants.SCHEDULE, report.getTriggerMode())) {
|
if (StringUtils.equals(NoticeConstants.Mode.SCHEDULE, report.getTriggerMode())) {
|
||||||
taskList = noticeService.searchMessageSchedule(testResult.getTestId());
|
successContext = "接口测试定时任务通知:'" + report.getName() + "'执行成功" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
||||||
successContext = "Api定时任务通知:'" + report.getName() + "'执行成功" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
failedContext = "接口测试定时任务通知:'" + report.getName() + "'执行失败" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
||||||
failedContext = "Api定时任务通知:'" + report.getName() + "'执行失败" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
subject = Translator.get("task_notification");
|
||||||
}
|
|
||||||
String finalSuccessContext = successContext;
|
|
||||||
String finalFailedContext = failedContext;
|
|
||||||
taskList.forEach(r -> {
|
|
||||||
switch (r.getType()) {
|
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
|
||||||
if (StringUtils.equals(NoticeConstants.EXECUTE_SUCCESSFUL, r.getEvent()) && StringUtils.equals(report.getStatus(), "Success")) {
|
|
||||||
dingTaskService.sendNailRobot(r, userIds, finalSuccessContext, NoticeConstants.EXECUTE_SUCCESSFUL);
|
|
||||||
}
|
|
||||||
if (StringUtils.equals(NoticeConstants.EXECUTE_FAILED, r.getEvent()) && StringUtils.equals(report.getStatus(), "Error")) {
|
|
||||||
dingTaskService.sendNailRobot(r, userIds, finalFailedContext, NoticeConstants.EXECUTE_FAILED);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
|
||||||
if (StringUtils.equals(NoticeConstants.EXECUTE_SUCCESSFUL, r.getEvent()) && StringUtils.equals(report.getStatus(), "Success")) {
|
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, finalSuccessContext, NoticeConstants.EXECUTE_SUCCESSFUL);
|
|
||||||
}
|
|
||||||
if (StringUtils.equals(NoticeConstants.EXECUTE_FAILED, r.getEvent()) && StringUtils.equals(report.getStatus(), "Error")) {
|
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, finalFailedContext, NoticeConstants.EXECUTE_FAILED);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case NoticeConstants.EMAIL:
|
|
||||||
if (StringUtils.equals(NoticeConstants.EXECUTE_SUCCESSFUL, r.getEvent()) && StringUtils.equals(report.getStatus(), "Success")) {
|
|
||||||
mailService.sendApiNotification(r, report, NoticeConstants.EXECUTE_SUCCESSFUL);
|
|
||||||
}
|
|
||||||
if (StringUtils.equals(NoticeConstants.EXECUTE_FAILED, r.getEvent()) && StringUtils.equals(report.getStatus(), "Error")) {
|
|
||||||
mailService.sendApiNotification(r, report, NoticeConstants.EXECUTE_FAILED);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
NoticeModel noticeModel = NoticeModel.builder()
|
||||||
}
|
.successContext(successContext)
|
||||||
|
.successMailTemplate("ApiSuccessfulNotification")
|
||||||
|
.failedContext(failedContext)
|
||||||
|
.failedMailTemplate("ApiFailedNotification")
|
||||||
|
.testId(testResult.getTestId())
|
||||||
|
.status(report.getStatus())
|
||||||
|
.subject(subject)
|
||||||
|
.build();
|
||||||
|
noticeSendService.send(report.getTriggerMode(), noticeModel);
|
||||||
}
|
}
|
||||||
|
|
||||||
private RequestResult getRequestResult(SampleResult result) {
|
private RequestResult getRequestResult(SampleResult result) {
|
||||||
|
|
|
@ -23,8 +23,6 @@ import io.metersphere.controller.request.QueryScheduleRequest;
|
||||||
import io.metersphere.dto.ScheduleDao;
|
import io.metersphere.dto.ScheduleDao;
|
||||||
import io.metersphere.i18n.Translator;
|
import io.metersphere.i18n.Translator;
|
||||||
import io.metersphere.job.sechedule.ApiTestJob;
|
import io.metersphere.job.sechedule.ApiTestJob;
|
||||||
import io.metersphere.notice.service.MailService;
|
|
||||||
import io.metersphere.notice.service.NoticeService;
|
|
||||||
import io.metersphere.service.FileService;
|
import io.metersphere.service.FileService;
|
||||||
import io.metersphere.service.QuotaService;
|
import io.metersphere.service.QuotaService;
|
||||||
import io.metersphere.service.ScheduleService;
|
import io.metersphere.service.ScheduleService;
|
||||||
|
@ -64,11 +62,6 @@ public class APITestService {
|
||||||
private ScheduleService scheduleService;
|
private ScheduleService scheduleService;
|
||||||
@Resource
|
@Resource
|
||||||
private TestCaseService testCaseService;
|
private TestCaseService testCaseService;
|
||||||
@Resource
|
|
||||||
private MailService mailService;
|
|
||||||
@Resource
|
|
||||||
private NoticeService noticeService;
|
|
||||||
|
|
||||||
|
|
||||||
private static final String BODY_FILE_DIR = "/opt/metersphere/data/body";
|
private static final String BODY_FILE_DIR = "/opt/metersphere/data/body";
|
||||||
|
|
||||||
|
@ -91,6 +84,7 @@ public class APITestService {
|
||||||
ApiTest test = createTest(request, file);
|
ApiTest test = createTest(request, file);
|
||||||
createBodyFiles(test, bodyUploadIds, bodyFiles);
|
createBodyFiles(test, bodyUploadIds, bodyFiles);
|
||||||
}
|
}
|
||||||
|
|
||||||
private ApiTest createTest(SaveAPITestRequest request, MultipartFile file) {
|
private ApiTest createTest(SaveAPITestRequest request, MultipartFile file) {
|
||||||
if (file == null) {
|
if (file == null) {
|
||||||
throw new IllegalArgumentException(Translator.get("file_cannot_be_null"));
|
throw new IllegalArgumentException(Translator.get("file_cannot_be_null"));
|
||||||
|
|
|
@ -1,21 +0,0 @@
|
||||||
package io.metersphere.base.domain;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import lombok.Data;
|
|
||||||
|
|
||||||
@Data
|
|
||||||
public class Notice implements Serializable {
|
|
||||||
private String id;
|
|
||||||
|
|
||||||
private String event;
|
|
||||||
|
|
||||||
private String testId;
|
|
||||||
|
|
||||||
private String enable;
|
|
||||||
|
|
||||||
private String type;
|
|
||||||
|
|
||||||
private String userId;
|
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
|
||||||
}
|
|
|
@ -1,620 +0,0 @@
|
||||||
package io.metersphere.base.domain;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
public class NoticeExample {
|
|
||||||
protected String orderByClause;
|
|
||||||
|
|
||||||
protected boolean distinct;
|
|
||||||
|
|
||||||
protected List<Criteria> oredCriteria;
|
|
||||||
|
|
||||||
public NoticeExample() {
|
|
||||||
oredCriteria = new ArrayList<Criteria>();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setOrderByClause(String orderByClause) {
|
|
||||||
this.orderByClause = orderByClause;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getOrderByClause() {
|
|
||||||
return orderByClause;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setDistinct(boolean distinct) {
|
|
||||||
this.distinct = distinct;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isDistinct() {
|
|
||||||
return distinct;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<Criteria> getOredCriteria() {
|
|
||||||
return oredCriteria;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void or(Criteria criteria) {
|
|
||||||
oredCriteria.add(criteria);
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria or() {
|
|
||||||
Criteria criteria = createCriteriaInternal();
|
|
||||||
oredCriteria.add(criteria);
|
|
||||||
return criteria;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria createCriteria() {
|
|
||||||
Criteria criteria = createCriteriaInternal();
|
|
||||||
if (oredCriteria.size() == 0) {
|
|
||||||
oredCriteria.add(criteria);
|
|
||||||
}
|
|
||||||
return criteria;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected Criteria createCriteriaInternal() {
|
|
||||||
Criteria criteria = new Criteria();
|
|
||||||
return criteria;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void clear() {
|
|
||||||
oredCriteria.clear();
|
|
||||||
orderByClause = null;
|
|
||||||
distinct = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected abstract static class GeneratedCriteria {
|
|
||||||
protected List<Criterion> criteria;
|
|
||||||
|
|
||||||
protected GeneratedCriteria() {
|
|
||||||
super();
|
|
||||||
criteria = new ArrayList<Criterion>();
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isValid() {
|
|
||||||
return criteria.size() > 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<Criterion> getAllCriteria() {
|
|
||||||
return criteria;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<Criterion> getCriteria() {
|
|
||||||
return criteria;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void addCriterion(String condition) {
|
|
||||||
if (condition == null) {
|
|
||||||
throw new RuntimeException("Value for condition cannot be null");
|
|
||||||
}
|
|
||||||
criteria.add(new Criterion(condition));
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void addCriterion(String condition, Object value, String property) {
|
|
||||||
if (value == null) {
|
|
||||||
throw new RuntimeException("Value for " + property + " cannot be null");
|
|
||||||
}
|
|
||||||
criteria.add(new Criterion(condition, value));
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void addCriterion(String condition, Object value1, Object value2, String property) {
|
|
||||||
if (value1 == null || value2 == null) {
|
|
||||||
throw new RuntimeException("Between values for " + property + " cannot be null");
|
|
||||||
}
|
|
||||||
criteria.add(new Criterion(condition, value1, value2));
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdIsNull() {
|
|
||||||
addCriterion("id is null");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdIsNotNull() {
|
|
||||||
addCriterion("id is not null");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdEqualTo(String value) {
|
|
||||||
addCriterion("id =", value, "id");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdNotEqualTo(String value) {
|
|
||||||
addCriterion("id <>", value, "id");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdGreaterThan(String value) {
|
|
||||||
addCriterion("id >", value, "id");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdGreaterThanOrEqualTo(String value) {
|
|
||||||
addCriterion("id >=", value, "id");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdLessThan(String value) {
|
|
||||||
addCriterion("id <", value, "id");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdLessThanOrEqualTo(String value) {
|
|
||||||
addCriterion("id <=", value, "id");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdLike(String value) {
|
|
||||||
addCriterion("id like", value, "id");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdNotLike(String value) {
|
|
||||||
addCriterion("id not like", value, "id");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdIn(List<String> values) {
|
|
||||||
addCriterion("id in", values, "id");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdNotIn(List<String> values) {
|
|
||||||
addCriterion("id not in", values, "id");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdBetween(String value1, String value2) {
|
|
||||||
addCriterion("id between", value1, value2, "id");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andIdNotBetween(String value1, String value2) {
|
|
||||||
addCriterion("id not between", value1, value2, "id");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventIsNull() {
|
|
||||||
addCriterion("EVENT is null");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventIsNotNull() {
|
|
||||||
addCriterion("EVENT is not null");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventEqualTo(String value) {
|
|
||||||
addCriterion("EVENT =", value, "event");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventNotEqualTo(String value) {
|
|
||||||
addCriterion("EVENT <>", value, "event");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventGreaterThan(String value) {
|
|
||||||
addCriterion("EVENT >", value, "event");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventGreaterThanOrEqualTo(String value) {
|
|
||||||
addCriterion("EVENT >=", value, "event");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventLessThan(String value) {
|
|
||||||
addCriterion("EVENT <", value, "event");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventLessThanOrEqualTo(String value) {
|
|
||||||
addCriterion("EVENT <=", value, "event");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventLike(String value) {
|
|
||||||
addCriterion("EVENT like", value, "event");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventNotLike(String value) {
|
|
||||||
addCriterion("EVENT not like", value, "event");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventIn(List<String> values) {
|
|
||||||
addCriterion("EVENT in", values, "event");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventNotIn(List<String> values) {
|
|
||||||
addCriterion("EVENT not in", values, "event");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventBetween(String value1, String value2) {
|
|
||||||
addCriterion("EVENT between", value1, value2, "event");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEventNotBetween(String value1, String value2) {
|
|
||||||
addCriterion("EVENT not between", value1, value2, "event");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdIsNull() {
|
|
||||||
addCriterion("TEST_ID is null");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdIsNotNull() {
|
|
||||||
addCriterion("TEST_ID is not null");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdEqualTo(String value) {
|
|
||||||
addCriterion("TEST_ID =", value, "testId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdNotEqualTo(String value) {
|
|
||||||
addCriterion("TEST_ID <>", value, "testId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdGreaterThan(String value) {
|
|
||||||
addCriterion("TEST_ID >", value, "testId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdGreaterThanOrEqualTo(String value) {
|
|
||||||
addCriterion("TEST_ID >=", value, "testId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdLessThan(String value) {
|
|
||||||
addCriterion("TEST_ID <", value, "testId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdLessThanOrEqualTo(String value) {
|
|
||||||
addCriterion("TEST_ID <=", value, "testId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdLike(String value) {
|
|
||||||
addCriterion("TEST_ID like", value, "testId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdNotLike(String value) {
|
|
||||||
addCriterion("TEST_ID not like", value, "testId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdIn(List<String> values) {
|
|
||||||
addCriterion("TEST_ID in", values, "testId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdNotIn(List<String> values) {
|
|
||||||
addCriterion("TEST_ID not in", values, "testId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdBetween(String value1, String value2) {
|
|
||||||
addCriterion("TEST_ID between", value1, value2, "testId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTestIdNotBetween(String value1, String value2) {
|
|
||||||
addCriterion("TEST_ID not between", value1, value2, "testId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableIsNull() {
|
|
||||||
addCriterion("`ENABLE` is null");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableIsNotNull() {
|
|
||||||
addCriterion("`ENABLE` is not null");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableEqualTo(String value) {
|
|
||||||
addCriterion("`ENABLE` =", value, "enable");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableNotEqualTo(String value) {
|
|
||||||
addCriterion("`ENABLE` <>", value, "enable");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableGreaterThan(String value) {
|
|
||||||
addCriterion("`ENABLE` >", value, "enable");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableGreaterThanOrEqualTo(String value) {
|
|
||||||
addCriterion("`ENABLE` >=", value, "enable");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableLessThan(String value) {
|
|
||||||
addCriterion("`ENABLE` <", value, "enable");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableLessThanOrEqualTo(String value) {
|
|
||||||
addCriterion("`ENABLE` <=", value, "enable");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableLike(String value) {
|
|
||||||
addCriterion("`ENABLE` like", value, "enable");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableNotLike(String value) {
|
|
||||||
addCriterion("`ENABLE` not like", value, "enable");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableIn(List<String> values) {
|
|
||||||
addCriterion("`ENABLE` in", values, "enable");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableNotIn(List<String> values) {
|
|
||||||
addCriterion("`ENABLE` not in", values, "enable");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableBetween(String value1, String value2) {
|
|
||||||
addCriterion("`ENABLE` between", value1, value2, "enable");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andEnableNotBetween(String value1, String value2) {
|
|
||||||
addCriterion("`ENABLE` not between", value1, value2, "enable");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeIsNull() {
|
|
||||||
addCriterion("`type` is null");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeIsNotNull() {
|
|
||||||
addCriterion("`type` is not null");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeEqualTo(String value) {
|
|
||||||
addCriterion("`type` =", value, "type");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeNotEqualTo(String value) {
|
|
||||||
addCriterion("`type` <>", value, "type");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeGreaterThan(String value) {
|
|
||||||
addCriterion("`type` >", value, "type");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeGreaterThanOrEqualTo(String value) {
|
|
||||||
addCriterion("`type` >=", value, "type");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeLessThan(String value) {
|
|
||||||
addCriterion("`type` <", value, "type");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeLessThanOrEqualTo(String value) {
|
|
||||||
addCriterion("`type` <=", value, "type");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeLike(String value) {
|
|
||||||
addCriterion("`type` like", value, "type");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeNotLike(String value) {
|
|
||||||
addCriterion("`type` not like", value, "type");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeIn(List<String> values) {
|
|
||||||
addCriterion("`type` in", values, "type");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeNotIn(List<String> values) {
|
|
||||||
addCriterion("`type` not in", values, "type");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeBetween(String value1, String value2) {
|
|
||||||
addCriterion("`type` between", value1, value2, "type");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andTypeNotBetween(String value1, String value2) {
|
|
||||||
addCriterion("`type` not between", value1, value2, "type");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdIsNull() {
|
|
||||||
addCriterion("user_id is null");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdIsNotNull() {
|
|
||||||
addCriterion("user_id is not null");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdEqualTo(String value) {
|
|
||||||
addCriterion("user_id =", value, "userId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdNotEqualTo(String value) {
|
|
||||||
addCriterion("user_id <>", value, "userId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdGreaterThan(String value) {
|
|
||||||
addCriterion("user_id >", value, "userId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdGreaterThanOrEqualTo(String value) {
|
|
||||||
addCriterion("user_id >=", value, "userId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdLessThan(String value) {
|
|
||||||
addCriterion("user_id <", value, "userId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdLessThanOrEqualTo(String value) {
|
|
||||||
addCriterion("user_id <=", value, "userId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdLike(String value) {
|
|
||||||
addCriterion("user_id like", value, "userId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdNotLike(String value) {
|
|
||||||
addCriterion("user_id not like", value, "userId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdIn(List<String> values) {
|
|
||||||
addCriterion("user_id in", values, "userId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdNotIn(List<String> values) {
|
|
||||||
addCriterion("user_id not in", values, "userId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdBetween(String value1, String value2) {
|
|
||||||
addCriterion("user_id between", value1, value2, "userId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Criteria andUserIdNotBetween(String value1, String value2) {
|
|
||||||
addCriterion("user_id not between", value1, value2, "userId");
|
|
||||||
return (Criteria) this;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class Criteria extends GeneratedCriteria {
|
|
||||||
|
|
||||||
protected Criteria() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class Criterion {
|
|
||||||
private String condition;
|
|
||||||
|
|
||||||
private Object value;
|
|
||||||
|
|
||||||
private Object secondValue;
|
|
||||||
|
|
||||||
private boolean noValue;
|
|
||||||
|
|
||||||
private boolean singleValue;
|
|
||||||
|
|
||||||
private boolean betweenValue;
|
|
||||||
|
|
||||||
private boolean listValue;
|
|
||||||
|
|
||||||
private String typeHandler;
|
|
||||||
|
|
||||||
public String getCondition() {
|
|
||||||
return condition;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Object getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Object getSecondValue() {
|
|
||||||
return secondValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isNoValue() {
|
|
||||||
return noValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isSingleValue() {
|
|
||||||
return singleValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isBetweenValue() {
|
|
||||||
return betweenValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isListValue() {
|
|
||||||
return listValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getTypeHandler() {
|
|
||||||
return typeHandler;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected Criterion(String condition) {
|
|
||||||
super();
|
|
||||||
this.condition = condition;
|
|
||||||
this.typeHandler = null;
|
|
||||||
this.noValue = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected Criterion(String condition, Object value, String typeHandler) {
|
|
||||||
super();
|
|
||||||
this.condition = condition;
|
|
||||||
this.value = value;
|
|
||||||
this.typeHandler = typeHandler;
|
|
||||||
if (value instanceof List<?>) {
|
|
||||||
this.listValue = true;
|
|
||||||
} else {
|
|
||||||
this.singleValue = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected Criterion(String condition, Object value) {
|
|
||||||
this(condition, value, null);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
|
|
||||||
super();
|
|
||||||
this.condition = condition;
|
|
||||||
this.value = value;
|
|
||||||
this.secondValue = secondValue;
|
|
||||||
this.typeHandler = typeHandler;
|
|
||||||
this.betweenValue = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected Criterion(String condition, Object value, Object secondValue) {
|
|
||||||
this(condition, value, secondValue, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,30 +0,0 @@
|
||||||
package io.metersphere.base.mapper;
|
|
||||||
|
|
||||||
import io.metersphere.base.domain.Notice;
|
|
||||||
import io.metersphere.base.domain.NoticeExample;
|
|
||||||
import java.util.List;
|
|
||||||
import org.apache.ibatis.annotations.Param;
|
|
||||||
|
|
||||||
public interface NoticeMapper {
|
|
||||||
long countByExample(NoticeExample example);
|
|
||||||
|
|
||||||
int deleteByExample(NoticeExample example);
|
|
||||||
|
|
||||||
int deleteByPrimaryKey(String id);
|
|
||||||
|
|
||||||
int insert(Notice record);
|
|
||||||
|
|
||||||
int insertSelective(Notice record);
|
|
||||||
|
|
||||||
List<Notice> selectByExample(NoticeExample example);
|
|
||||||
|
|
||||||
Notice selectByPrimaryKey(String id);
|
|
||||||
|
|
||||||
int updateByExampleSelective(@Param("record") Notice record, @Param("example") NoticeExample example);
|
|
||||||
|
|
||||||
int updateByExample(@Param("record") Notice record, @Param("example") NoticeExample example);
|
|
||||||
|
|
||||||
int updateByPrimaryKeySelective(Notice record);
|
|
||||||
|
|
||||||
int updateByPrimaryKey(Notice record);
|
|
||||||
}
|
|
|
@ -1,228 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
|
||||||
<mapper namespace="io.metersphere.base.mapper.NoticeMapper">
|
|
||||||
<resultMap id="BaseResultMap" type="io.metersphere.base.domain.Notice">
|
|
||||||
<id column="id" jdbcType="VARCHAR" property="id" />
|
|
||||||
<result column="EVENT" jdbcType="VARCHAR" property="event" />
|
|
||||||
<result column="TEST_ID" jdbcType="VARCHAR" property="testId" />
|
|
||||||
<result column="ENABLE" jdbcType="VARCHAR" property="enable" />
|
|
||||||
<result column="type" jdbcType="VARCHAR" property="type" />
|
|
||||||
<result column="user_id" jdbcType="VARCHAR" property="userId" />
|
|
||||||
</resultMap>
|
|
||||||
<sql id="Example_Where_Clause">
|
|
||||||
<where>
|
|
||||||
<foreach collection="oredCriteria" item="criteria" separator="or">
|
|
||||||
<if test="criteria.valid">
|
|
||||||
<trim prefix="(" prefixOverrides="and" suffix=")">
|
|
||||||
<foreach collection="criteria.criteria" item="criterion">
|
|
||||||
<choose>
|
|
||||||
<when test="criterion.noValue">
|
|
||||||
and ${criterion.condition}
|
|
||||||
</when>
|
|
||||||
<when test="criterion.singleValue">
|
|
||||||
and ${criterion.condition} #{criterion.value}
|
|
||||||
</when>
|
|
||||||
<when test="criterion.betweenValue">
|
|
||||||
and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
|
|
||||||
</when>
|
|
||||||
<when test="criterion.listValue">
|
|
||||||
and ${criterion.condition}
|
|
||||||
<foreach close=")" collection="criterion.value" item="listItem" open="(" separator=",">
|
|
||||||
#{listItem}
|
|
||||||
</foreach>
|
|
||||||
</when>
|
|
||||||
</choose>
|
|
||||||
</foreach>
|
|
||||||
</trim>
|
|
||||||
</if>
|
|
||||||
</foreach>
|
|
||||||
</where>
|
|
||||||
</sql>
|
|
||||||
<sql id="Update_By_Example_Where_Clause">
|
|
||||||
<where>
|
|
||||||
<foreach collection="example.oredCriteria" item="criteria" separator="or">
|
|
||||||
<if test="criteria.valid">
|
|
||||||
<trim prefix="(" prefixOverrides="and" suffix=")">
|
|
||||||
<foreach collection="criteria.criteria" item="criterion">
|
|
||||||
<choose>
|
|
||||||
<when test="criterion.noValue">
|
|
||||||
and ${criterion.condition}
|
|
||||||
</when>
|
|
||||||
<when test="criterion.singleValue">
|
|
||||||
and ${criterion.condition} #{criterion.value}
|
|
||||||
</when>
|
|
||||||
<when test="criterion.betweenValue">
|
|
||||||
and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
|
|
||||||
</when>
|
|
||||||
<when test="criterion.listValue">
|
|
||||||
and ${criterion.condition}
|
|
||||||
<foreach close=")" collection="criterion.value" item="listItem" open="(" separator=",">
|
|
||||||
#{listItem}
|
|
||||||
</foreach>
|
|
||||||
</when>
|
|
||||||
</choose>
|
|
||||||
</foreach>
|
|
||||||
</trim>
|
|
||||||
</if>
|
|
||||||
</foreach>
|
|
||||||
</where>
|
|
||||||
</sql>
|
|
||||||
<sql id="Base_Column_List">
|
|
||||||
id, EVENT, TEST_ID, `ENABLE`, `type`, user_id
|
|
||||||
</sql>
|
|
||||||
<select id="selectByExample" parameterType="io.metersphere.base.domain.NoticeExample" resultMap="BaseResultMap">
|
|
||||||
select
|
|
||||||
<if test="distinct">
|
|
||||||
distinct
|
|
||||||
</if>
|
|
||||||
<include refid="Base_Column_List" />
|
|
||||||
from notice
|
|
||||||
<if test="_parameter != null">
|
|
||||||
<include refid="Example_Where_Clause" />
|
|
||||||
</if>
|
|
||||||
<if test="orderByClause != null">
|
|
||||||
order by ${orderByClause}
|
|
||||||
</if>
|
|
||||||
</select>
|
|
||||||
<select id="selectByPrimaryKey" parameterType="java.lang.String" resultMap="BaseResultMap">
|
|
||||||
select
|
|
||||||
<include refid="Base_Column_List" />
|
|
||||||
from notice
|
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
|
||||||
</select>
|
|
||||||
<delete id="deleteByPrimaryKey" parameterType="java.lang.String">
|
|
||||||
delete from notice
|
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
|
||||||
</delete>
|
|
||||||
<delete id="deleteByExample" parameterType="io.metersphere.base.domain.NoticeExample">
|
|
||||||
delete from notice
|
|
||||||
<if test="_parameter != null">
|
|
||||||
<include refid="Example_Where_Clause" />
|
|
||||||
</if>
|
|
||||||
</delete>
|
|
||||||
<insert id="insert" parameterType="io.metersphere.base.domain.Notice">
|
|
||||||
insert into notice (id, EVENT, TEST_ID,
|
|
||||||
`ENABLE`, `type`, user_id
|
|
||||||
)
|
|
||||||
values (#{id,jdbcType=VARCHAR}, #{event,jdbcType=VARCHAR}, #{testId,jdbcType=VARCHAR},
|
|
||||||
#{enable,jdbcType=VARCHAR}, #{type,jdbcType=VARCHAR}, #{userId,jdbcType=VARCHAR}
|
|
||||||
)
|
|
||||||
</insert>
|
|
||||||
<insert id="insertSelective" parameterType="io.metersphere.base.domain.Notice">
|
|
||||||
insert into notice
|
|
||||||
<trim prefix="(" suffix=")" suffixOverrides=",">
|
|
||||||
<if test="id != null">
|
|
||||||
id,
|
|
||||||
</if>
|
|
||||||
<if test="event != null">
|
|
||||||
EVENT,
|
|
||||||
</if>
|
|
||||||
<if test="testId != null">
|
|
||||||
TEST_ID,
|
|
||||||
</if>
|
|
||||||
<if test="enable != null">
|
|
||||||
`ENABLE`,
|
|
||||||
</if>
|
|
||||||
<if test="type != null">
|
|
||||||
`type`,
|
|
||||||
</if>
|
|
||||||
<if test="userId != null">
|
|
||||||
user_id,
|
|
||||||
</if>
|
|
||||||
</trim>
|
|
||||||
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
|
||||||
<if test="id != null">
|
|
||||||
#{id,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="event != null">
|
|
||||||
#{event,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="testId != null">
|
|
||||||
#{testId,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="enable != null">
|
|
||||||
#{enable,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="type != null">
|
|
||||||
#{type,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="userId != null">
|
|
||||||
#{userId,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
</trim>
|
|
||||||
</insert>
|
|
||||||
<select id="countByExample" parameterType="io.metersphere.base.domain.NoticeExample" resultType="java.lang.Long">
|
|
||||||
select count(*) from notice
|
|
||||||
<if test="_parameter != null">
|
|
||||||
<include refid="Example_Where_Clause" />
|
|
||||||
</if>
|
|
||||||
</select>
|
|
||||||
<update id="updateByExampleSelective" parameterType="map">
|
|
||||||
update notice
|
|
||||||
<set>
|
|
||||||
<if test="record.id != null">
|
|
||||||
id = #{record.id,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="record.event != null">
|
|
||||||
EVENT = #{record.event,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="record.testId != null">
|
|
||||||
TEST_ID = #{record.testId,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="record.enable != null">
|
|
||||||
`ENABLE` = #{record.enable,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="record.type != null">
|
|
||||||
`type` = #{record.type,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="record.userId != null">
|
|
||||||
user_id = #{record.userId,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
</set>
|
|
||||||
<if test="_parameter != null">
|
|
||||||
<include refid="Update_By_Example_Where_Clause" />
|
|
||||||
</if>
|
|
||||||
</update>
|
|
||||||
<update id="updateByExample" parameterType="map">
|
|
||||||
update notice
|
|
||||||
set id = #{record.id,jdbcType=VARCHAR},
|
|
||||||
EVENT = #{record.event,jdbcType=VARCHAR},
|
|
||||||
TEST_ID = #{record.testId,jdbcType=VARCHAR},
|
|
||||||
`ENABLE` = #{record.enable,jdbcType=VARCHAR},
|
|
||||||
`type` = #{record.type,jdbcType=VARCHAR},
|
|
||||||
user_id = #{record.userId,jdbcType=VARCHAR}
|
|
||||||
<if test="_parameter != null">
|
|
||||||
<include refid="Update_By_Example_Where_Clause" />
|
|
||||||
</if>
|
|
||||||
</update>
|
|
||||||
<update id="updateByPrimaryKeySelective" parameterType="io.metersphere.base.domain.Notice">
|
|
||||||
update notice
|
|
||||||
<set>
|
|
||||||
<if test="event != null">
|
|
||||||
EVENT = #{event,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="testId != null">
|
|
||||||
TEST_ID = #{testId,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="enable != null">
|
|
||||||
`ENABLE` = #{enable,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="type != null">
|
|
||||||
`type` = #{type,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
<if test="userId != null">
|
|
||||||
user_id = #{userId,jdbcType=VARCHAR},
|
|
||||||
</if>
|
|
||||||
</set>
|
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
|
||||||
</update>
|
|
||||||
<update id="updateByPrimaryKey" parameterType="io.metersphere.base.domain.Notice">
|
|
||||||
update notice
|
|
||||||
set EVENT = #{event,jdbcType=VARCHAR},
|
|
||||||
TEST_ID = #{testId,jdbcType=VARCHAR},
|
|
||||||
`ENABLE` = #{enable,jdbcType=VARCHAR},
|
|
||||||
`type` = #{type,jdbcType=VARCHAR},
|
|
||||||
user_id = #{userId,jdbcType=VARCHAR}
|
|
||||||
where id = #{id,jdbcType=VARCHAR}
|
|
||||||
</update>
|
|
||||||
</mapper>
|
|
|
@ -1,12 +0,0 @@
|
||||||
package io.metersphere.base.mapper.ext;
|
|
||||||
|
|
||||||
import io.metersphere.base.domain.MessageTask;
|
|
||||||
import org.apache.ibatis.annotations.Param;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
public interface ExtMessageMapper {
|
|
||||||
List<MessageTask> searchMessageByTestId(@Param("testId") String testId);
|
|
||||||
|
|
||||||
List<MessageTask> searchMessageByOrganizationId(@Param("organizationId") String organizationId);
|
|
||||||
}
|
|
|
@ -1,23 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
|
||||||
<mapper namespace="io.metersphere.base.mapper.ext.ExtMessageMapper">
|
|
||||||
<select id="searchMessageByTestId" resultType="io.metersphere.base.domain.MessageTask">
|
|
||||||
select m.* from message_task m
|
|
||||||
<where>
|
|
||||||
<if test="testId!=null">
|
|
||||||
and m.test_id=#{testId}
|
|
||||||
</if>
|
|
||||||
</where>
|
|
||||||
order by m.create_time DESC
|
|
||||||
</select>
|
|
||||||
<select id="searchMessageByOrganizationId" resultType="io.metersphere.base.domain.MessageTask">
|
|
||||||
select m.* from message_task m
|
|
||||||
<where>
|
|
||||||
<if test="organizationId!=null">
|
|
||||||
and m.organization_id=#{organizationId}
|
|
||||||
</if>
|
|
||||||
</where>
|
|
||||||
order by m.create_time DESC
|
|
||||||
</select>
|
|
||||||
|
|
||||||
</mapper>
|
|
|
@ -1,24 +1,37 @@
|
||||||
package io.metersphere.commons.constants;
|
package io.metersphere.commons.constants;
|
||||||
|
|
||||||
public interface NoticeConstants {
|
public interface NoticeConstants {
|
||||||
String EXECUTE_SUCCESSFUL = "EXECUTE_SUCCESSFUL";
|
|
||||||
String EXECUTE_FAILED = "EXECUTE_FAILED";
|
interface TaskType {
|
||||||
String EMAIL = "EMAIL";
|
|
||||||
String NAIL_ROBOT = "NAIL_ROBOT";
|
|
||||||
String WECHAT_ROBOT = "WECHAT_ROBOT";
|
|
||||||
String CREATE = "CREATE";
|
|
||||||
String UPDATE = "UPDATE";
|
|
||||||
String DELETE = "DELETE";
|
|
||||||
String COMMENT = "COMMENT";
|
|
||||||
String JENKINS_TASK = "JENKINS_TASK";
|
String JENKINS_TASK = "JENKINS_TASK";
|
||||||
String TEST_PLAN_TASK = "TEST_PLAN_TASK";
|
String TEST_PLAN_TASK = "TEST_PLAN_TASK";
|
||||||
String REVIEW_TASK = "REVIEW_TASK";
|
String REVIEW_TASK = "REVIEW_TASK";
|
||||||
String DEFECT_TASK = "DEFECT_TASK";
|
String DEFECT_TASK = "DEFECT_TASK";
|
||||||
|
}
|
||||||
|
|
||||||
|
interface Mode {
|
||||||
|
String API = "API";
|
||||||
|
String SCHEDULE = "SCHEDULE";
|
||||||
|
}
|
||||||
|
|
||||||
|
interface Type {
|
||||||
|
String EMAIL = "EMAIL";
|
||||||
|
String NAIL_ROBOT = "NAIL_ROBOT";
|
||||||
|
String WECHAT_ROBOT = "WECHAT_ROBOT";
|
||||||
|
}
|
||||||
|
|
||||||
|
interface Event {
|
||||||
|
String EXECUTE_SUCCESSFUL = "EXECUTE_SUCCESSFUL";
|
||||||
|
String EXECUTE_FAILED = "EXECUTE_FAILED";
|
||||||
|
String CREATE = "CREATE";
|
||||||
|
String UPDATE = "UPDATE";
|
||||||
|
String DELETE = "DELETE";
|
||||||
|
String COMMENT = "COMMENT";
|
||||||
|
}
|
||||||
|
|
||||||
|
interface RelatedUser {
|
||||||
String FOUNDER = "FOUNDER";//创建人
|
String FOUNDER = "FOUNDER";//创建人
|
||||||
String EXECUTOR = "EXECUTOR";//负责人(评审人)
|
String EXECUTOR = "EXECUTOR";//负责人(评审人)
|
||||||
String MAINTAINER = "MAINTAINER";//维护人
|
String MAINTAINER = "MAINTAINER";//维护人
|
||||||
String API = "API";
|
}
|
||||||
String SCHEDULE = "SCHEDULE";
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,7 +24,9 @@ public class SessionUtils {
|
||||||
try {
|
try {
|
||||||
Subject subject = SecurityUtils.getSubject();
|
Subject subject = SecurityUtils.getSubject();
|
||||||
Session session = subject.getSession();
|
Session session = subject.getSession();
|
||||||
return (SessionUser) session.getAttribute(ATTR_USER);
|
SessionUser user = (SessionUser) session.getAttribute(ATTR_USER);
|
||||||
|
assert user != null;
|
||||||
|
return user;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,21 @@
|
||||||
|
package io.metersphere.config;
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.core.task.AsyncTaskExecutor;
|
||||||
|
import org.springframework.scheduling.annotation.EnableAsync;
|
||||||
|
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
|
||||||
|
|
||||||
|
@EnableAsync
|
||||||
|
@Configuration
|
||||||
|
public class AsyncConfig {
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public AsyncTaskExecutor taskExecutor() {
|
||||||
|
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
|
||||||
|
executor.setThreadNamePrefix("Async-Executor");
|
||||||
|
executor.setCorePoolSize(5);
|
||||||
|
executor.setMaxPoolSize(10);
|
||||||
|
return executor;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,8 +1,6 @@
|
||||||
package io.metersphere.notice.controller;
|
package io.metersphere.notice.controller;
|
||||||
|
|
||||||
import io.metersphere.notice.controller.request.MessageRequest;
|
|
||||||
import io.metersphere.notice.domain.MessageDetail;
|
import io.metersphere.notice.domain.MessageDetail;
|
||||||
import io.metersphere.notice.domain.MessageSettingDetail;
|
|
||||||
import io.metersphere.notice.service.NoticeService;
|
import io.metersphere.notice.service.NoticeService;
|
||||||
import org.springframework.web.bind.annotation.*;
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
@ -16,18 +14,18 @@ public class NoticeController {
|
||||||
private NoticeService noticeService;
|
private NoticeService noticeService;
|
||||||
|
|
||||||
@PostMapping("save/message/task")
|
@PostMapping("save/message/task")
|
||||||
public void saveMessage(@RequestBody MessageRequest messageRequest) {
|
public void saveMessage(@RequestBody MessageDetail messageDetail) {
|
||||||
noticeService.saveMessageTask(messageRequest);
|
noticeService.saveMessageTask(messageDetail);
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/search/message")
|
@GetMapping("/search/message/type/{type}")
|
||||||
public MessageSettingDetail searchMessage() {
|
public List<MessageDetail> searchMessage(@PathVariable String type) {
|
||||||
return noticeService.searchMessage();
|
return noticeService.searchMessageByType(type);
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/search/message/{testId}")
|
@GetMapping("/search/message/{testId}")
|
||||||
public List<MessageDetail> searchMessageSchedule(@PathVariable String testId) {
|
public List<MessageDetail> searchMessageSchedule(@PathVariable String testId) {
|
||||||
return noticeService.searchMessageSchedule(testId);
|
return noticeService.searchMessageByTestId(testId);
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/delete/message/{identification}")
|
@GetMapping("/delete/message/{identification}")
|
||||||
|
|
|
@ -1,12 +0,0 @@
|
||||||
package io.metersphere.notice.controller.request;
|
|
||||||
|
|
||||||
import io.metersphere.notice.domain.NoticeDetail;
|
|
||||||
import lombok.Data;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
@Data
|
|
||||||
public class NoticeRequest {
|
|
||||||
private String testId;
|
|
||||||
private List<NoticeDetail> notices;
|
|
||||||
}
|
|
|
@ -1,12 +0,0 @@
|
||||||
package io.metersphere.notice.domain;
|
|
||||||
|
|
||||||
import io.metersphere.base.domain.Notice;
|
|
||||||
import lombok.Data;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
@Data
|
|
||||||
public class NoticeDetail extends Notice {
|
|
||||||
private List<String> userIds = new ArrayList<>();
|
|
||||||
}
|
|
|
@ -0,0 +1,127 @@
|
||||||
|
package io.metersphere.notice.sender;
|
||||||
|
|
||||||
|
import io.metersphere.commons.constants.NoticeConstants;
|
||||||
|
import io.metersphere.commons.utils.LogUtil;
|
||||||
|
import io.metersphere.notice.domain.MessageDetail;
|
||||||
|
import io.metersphere.notice.domain.UserDetail;
|
||||||
|
import io.metersphere.service.UserService;
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
public abstract class AbstractNoticeSender implements NoticeSender {
|
||||||
|
@Resource
|
||||||
|
private UserService userService;
|
||||||
|
|
||||||
|
protected String getContext(MessageDetail messageDetail, NoticeModel noticeModel) {
|
||||||
|
// 处理 userIds 中包含的特殊值
|
||||||
|
List<String> realUserIds = getRealUserIds(messageDetail.getUserIds(), noticeModel.getRelatedUsers(), messageDetail.getEvent());
|
||||||
|
messageDetail.setUserIds(realUserIds);
|
||||||
|
|
||||||
|
// 处理 WeCom Ding context
|
||||||
|
String context = "";
|
||||||
|
String status = noticeModel.getStatus();
|
||||||
|
switch (messageDetail.getEvent()) {
|
||||||
|
case NoticeConstants.Event.CREATE:
|
||||||
|
case NoticeConstants.Event.UPDATE:
|
||||||
|
case NoticeConstants.Event.DELETE:
|
||||||
|
case NoticeConstants.Event.COMMENT:
|
||||||
|
context = noticeModel.getContext();
|
||||||
|
break;
|
||||||
|
case NoticeConstants.Event.EXECUTE_FAILED:
|
||||||
|
context = noticeModel.getFailedContext();
|
||||||
|
break;
|
||||||
|
case NoticeConstants.Event.EXECUTE_SUCCESSFUL:
|
||||||
|
context = noticeModel.getSuccessContext();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return context;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected String getHtmlContext(MessageDetail messageDetail, NoticeModel noticeModel) {
|
||||||
|
// 处理 userIds 中包含的特殊值
|
||||||
|
List<String> realUserIds = getRealUserIds(messageDetail.getUserIds(), noticeModel.getRelatedUsers(), messageDetail.getEvent());
|
||||||
|
messageDetail.setUserIds(realUserIds);
|
||||||
|
|
||||||
|
// 处理 mail context
|
||||||
|
String context = "";
|
||||||
|
try {
|
||||||
|
switch (messageDetail.getEvent()) {
|
||||||
|
case NoticeConstants.Event.CREATE:
|
||||||
|
case NoticeConstants.Event.UPDATE:
|
||||||
|
case NoticeConstants.Event.DELETE:
|
||||||
|
case NoticeConstants.Event.COMMENT:
|
||||||
|
URL resource = this.getClass().getResource("/mail/" + noticeModel.getMailTemplate() + ".html");
|
||||||
|
context = IOUtils.toString(resource, StandardCharsets.UTF_8);
|
||||||
|
break;
|
||||||
|
case NoticeConstants.Event.EXECUTE_FAILED:
|
||||||
|
URL resource1 = this.getClass().getResource("/mail/" + noticeModel.getFailedMailTemplate() + ".html");
|
||||||
|
context = IOUtils.toString(resource1, StandardCharsets.UTF_8);
|
||||||
|
break;
|
||||||
|
case NoticeConstants.Event.EXECUTE_SUCCESSFUL:
|
||||||
|
URL resource2 = this.getClass().getResource("/mail/" + noticeModel.getSuccessMailTemplate() + ".html");
|
||||||
|
context = IOUtils.toString(resource2, StandardCharsets.UTF_8);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
LogUtil.error(e);
|
||||||
|
}
|
||||||
|
return context;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected List<String> getUserPhones(List<String> userIds) {
|
||||||
|
List<UserDetail> list = userService.queryTypeByIds(userIds);
|
||||||
|
List<String> phoneList = new ArrayList<>();
|
||||||
|
list.forEach(u -> phoneList.add(u.getPhone()));
|
||||||
|
LogUtil.info("收件人地址: " + phoneList);
|
||||||
|
return phoneList.stream().distinct().collect(Collectors.toList());
|
||||||
|
}
|
||||||
|
|
||||||
|
protected List<String> getUserEmails(List<String> userIds) {
|
||||||
|
List<UserDetail> list = userService.queryTypeByIds(userIds);
|
||||||
|
List<String> phoneList = new ArrayList<>();
|
||||||
|
list.forEach(u -> phoneList.add(u.getEmail()));
|
||||||
|
LogUtil.info("收件人地址: " + phoneList);
|
||||||
|
return phoneList.stream().distinct().collect(Collectors.toList());
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<String> getRealUserIds(List<String> userIds, List<String> relatedUsers, String event) {
|
||||||
|
List<String> toUserIds = new ArrayList<>();
|
||||||
|
for (String userId : userIds) {
|
||||||
|
switch (userId) {
|
||||||
|
case NoticeConstants.RelatedUser.EXECUTOR:
|
||||||
|
if (StringUtils.equals(NoticeConstants.Event.CREATE, event)) {
|
||||||
|
toUserIds.addAll(relatedUsers);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case NoticeConstants.RelatedUser.FOUNDER:
|
||||||
|
if (StringUtils.equals(NoticeConstants.Event.UPDATE, event)
|
||||||
|
|| StringUtils.equals(NoticeConstants.Event.DELETE, event)) {
|
||||||
|
toUserIds.addAll(relatedUsers);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case NoticeConstants.RelatedUser.MAINTAINER:
|
||||||
|
if (StringUtils.equals(NoticeConstants.Event.COMMENT, event)) {
|
||||||
|
toUserIds.addAll(relatedUsers);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
toUserIds.add(userId);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return toUserIds;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,47 @@
|
||||||
|
package io.metersphere.notice.sender;
|
||||||
|
|
||||||
|
import lombok.Builder;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@Builder
|
||||||
|
public class NoticeModel {
|
||||||
|
/**
|
||||||
|
* 保存 测试id
|
||||||
|
*/
|
||||||
|
private String testId;
|
||||||
|
/**
|
||||||
|
* 保存状态
|
||||||
|
*/
|
||||||
|
private String status;
|
||||||
|
/**
|
||||||
|
* 消息主题
|
||||||
|
*/
|
||||||
|
private String subject;
|
||||||
|
/**
|
||||||
|
* 消息内容
|
||||||
|
*/
|
||||||
|
private String context;
|
||||||
|
private String successContext;
|
||||||
|
private String failedContext;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* html 消息模版
|
||||||
|
*/
|
||||||
|
private String mailTemplate;
|
||||||
|
private String failedMailTemplate;
|
||||||
|
private String successMailTemplate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 保存特殊的用户
|
||||||
|
*/
|
||||||
|
private List<String> relatedUsers;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 模版里的参数信息
|
||||||
|
*/
|
||||||
|
private Map<String, Object> paramMap;
|
||||||
|
}
|
|
@ -0,0 +1,9 @@
|
||||||
|
package io.metersphere.notice.sender;
|
||||||
|
|
||||||
|
import io.metersphere.notice.domain.MessageDetail;
|
||||||
|
import org.springframework.scheduling.annotation.Async;
|
||||||
|
|
||||||
|
public interface NoticeSender {
|
||||||
|
@Async
|
||||||
|
void send(MessageDetail messageDetail, NoticeModel noticeModel);
|
||||||
|
}
|
|
@ -0,0 +1,47 @@
|
||||||
|
package io.metersphere.notice.sender.impl;
|
||||||
|
|
||||||
|
import com.dingtalk.api.DefaultDingTalkClient;
|
||||||
|
import com.dingtalk.api.DingTalkClient;
|
||||||
|
import com.dingtalk.api.request.OapiRobotSendRequest;
|
||||||
|
import com.taobao.api.ApiException;
|
||||||
|
import io.metersphere.commons.utils.LogUtil;
|
||||||
|
import io.metersphere.notice.domain.MessageDetail;
|
||||||
|
import io.metersphere.notice.sender.AbstractNoticeSender;
|
||||||
|
import io.metersphere.notice.sender.NoticeModel;
|
||||||
|
import org.apache.commons.collections4.CollectionUtils;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class DingNoticeSender extends AbstractNoticeSender {
|
||||||
|
|
||||||
|
public void sendNailRobot(MessageDetail messageDetail, String context) {
|
||||||
|
List<String> userIds = messageDetail.getUserIds();
|
||||||
|
if (CollectionUtils.isEmpty(userIds)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
DingTalkClient client = new DefaultDingTalkClient(messageDetail.getWebhook());
|
||||||
|
OapiRobotSendRequest request = new OapiRobotSendRequest();
|
||||||
|
request.setMsgtype("text");
|
||||||
|
OapiRobotSendRequest.Text text = new OapiRobotSendRequest.Text();
|
||||||
|
text.setContent(context);
|
||||||
|
request.setText(text);
|
||||||
|
OapiRobotSendRequest.At at = new OapiRobotSendRequest.At();
|
||||||
|
List<String> phoneList = super.getUserPhones(userIds);
|
||||||
|
LogUtil.info("收件人地址: " + phoneList);
|
||||||
|
at.setAtMobiles(phoneList);
|
||||||
|
request.setAt(at);
|
||||||
|
try {
|
||||||
|
client.execute(request);
|
||||||
|
} catch (ApiException e) {
|
||||||
|
LogUtil.error(e.getMessage(), e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void send(MessageDetail messageDetail, NoticeModel noticeModel) {
|
||||||
|
String context = super.getContext(messageDetail, noticeModel);
|
||||||
|
sendNailRobot(messageDetail, context);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,62 @@
|
||||||
|
package io.metersphere.notice.sender.impl;
|
||||||
|
|
||||||
|
import io.metersphere.commons.utils.LogUtil;
|
||||||
|
import io.metersphere.notice.domain.MessageDetail;
|
||||||
|
import io.metersphere.notice.sender.AbstractNoticeSender;
|
||||||
|
import io.metersphere.notice.sender.NoticeModel;
|
||||||
|
import io.metersphere.notice.service.MailService;
|
||||||
|
import org.apache.commons.collections4.MapUtils;
|
||||||
|
import org.apache.commons.lang3.RegExUtils;
|
||||||
|
import org.springframework.mail.javamail.JavaMailSenderImpl;
|
||||||
|
import org.springframework.mail.javamail.MimeMessageHelper;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
import javax.mail.MessagingException;
|
||||||
|
import javax.mail.internet.MimeMessage;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class MailNoticeSender extends AbstractNoticeSender {
|
||||||
|
@Resource
|
||||||
|
private MailService mailService;
|
||||||
|
|
||||||
|
private void sendMail(MessageDetail messageDetail, String template, NoticeModel noticeModel) throws MessagingException {
|
||||||
|
JavaMailSenderImpl javaMailSender = mailService.getMailSender();
|
||||||
|
MimeMessage mimeMessage = javaMailSender.createMimeMessage();
|
||||||
|
MimeMessageHelper helper = new MimeMessageHelper(mimeMessage, true);
|
||||||
|
helper.setFrom(javaMailSender.getUsername());
|
||||||
|
helper.setSubject("MeterSphere " + noticeModel.getSubject());
|
||||||
|
List<String> emails = super.getUserEmails(messageDetail.getUserIds());
|
||||||
|
String[] users = emails.toArray(new String[0]);
|
||||||
|
LogUtil.info("收件人地址: " + emails);
|
||||||
|
helper.setText(this.getContent(template, noticeModel.getParamMap()), true);
|
||||||
|
helper.setTo(users);
|
||||||
|
javaMailSender.send(mimeMessage);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public String getContent(String template, Map<String, Object> context) {
|
||||||
|
if (MapUtils.isNotEmpty(context)) {
|
||||||
|
for (String k : context.keySet()) {
|
||||||
|
if (context.get(k) != null) {
|
||||||
|
template = RegExUtils.replaceAll(template, "\\$\\{" + k + "}", context.get(k).toString());
|
||||||
|
} else {
|
||||||
|
template = RegExUtils.replaceAll(template, "\\$\\{" + k + "}", "未设置");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return template;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void send(MessageDetail messageDetail, NoticeModel noticeModel) {
|
||||||
|
String context = super.getHtmlContext(messageDetail, noticeModel);
|
||||||
|
try {
|
||||||
|
sendMail(messageDetail, context, noticeModel);
|
||||||
|
} catch (Exception e) {
|
||||||
|
LogUtil.error(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,39 @@
|
||||||
|
package io.metersphere.notice.sender.impl;
|
||||||
|
|
||||||
|
import io.metersphere.commons.utils.LogUtil;
|
||||||
|
import io.metersphere.notice.domain.MessageDetail;
|
||||||
|
import io.metersphere.notice.message.TextMessage;
|
||||||
|
import io.metersphere.notice.sender.AbstractNoticeSender;
|
||||||
|
import io.metersphere.notice.sender.NoticeModel;
|
||||||
|
import io.metersphere.notice.util.WxChatbotClient;
|
||||||
|
import org.apache.commons.collections4.CollectionUtils;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class WeComNoticeSender extends AbstractNoticeSender {
|
||||||
|
|
||||||
|
|
||||||
|
public void sendWechatRobot(MessageDetail messageDetail, String context) {
|
||||||
|
List<String> userIds = messageDetail.getUserIds();
|
||||||
|
if (CollectionUtils.isEmpty(userIds)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
TextMessage message = new TextMessage(context);
|
||||||
|
List<String> phoneLists = super.getUserPhones(userIds);
|
||||||
|
message.setMentionedMobileList(phoneLists);
|
||||||
|
try {
|
||||||
|
WxChatbotClient.send(messageDetail.getWebhook(), message);
|
||||||
|
} catch (IOException e) {
|
||||||
|
LogUtil.error(e.getMessage(), e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void send(MessageDetail messageDetail, NoticeModel noticeModel) {
|
||||||
|
String context = super.getContext(messageDetail, noticeModel);
|
||||||
|
sendWechatRobot(messageDetail, context);
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,74 +0,0 @@
|
||||||
package io.metersphere.notice.service;
|
|
||||||
|
|
||||||
import com.dingtalk.api.DefaultDingTalkClient;
|
|
||||||
import com.dingtalk.api.DingTalkClient;
|
|
||||||
import com.dingtalk.api.request.OapiRobotSendRequest;
|
|
||||||
import com.dingtalk.api.response.OapiRobotSendResponse;
|
|
||||||
import com.taobao.api.ApiException;
|
|
||||||
import io.metersphere.commons.constants.NoticeConstants;
|
|
||||||
import io.metersphere.commons.utils.LogUtil;
|
|
||||||
import io.metersphere.notice.domain.MessageDetail;
|
|
||||||
import io.metersphere.notice.domain.UserDetail;
|
|
||||||
import io.metersphere.service.UserService;
|
|
||||||
import org.apache.commons.collections4.CollectionUtils;
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
import org.springframework.transaction.annotation.Propagation;
|
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
@Service
|
|
||||||
@Transactional(propagation = Propagation.NOT_SUPPORTED)
|
|
||||||
public class DingTaskService {
|
|
||||||
@Resource
|
|
||||||
private UserService userService;
|
|
||||||
|
|
||||||
public void sendNailRobot(MessageDetail messageDetail, List<String> userIds, String context, String eventType) {
|
|
||||||
List<String> addresseeIdList = new ArrayList<>();
|
|
||||||
if (StringUtils.equals(eventType, messageDetail.getEvent())) {
|
|
||||||
messageDetail.getUserIds().forEach(u -> {
|
|
||||||
if (!StringUtils.equals(NoticeConstants.EXECUTOR, u) && !StringUtils.equals(NoticeConstants.FOUNDER, u) && !StringUtils.equals(NoticeConstants.MAINTAINER, u)) {
|
|
||||||
addresseeIdList.add(u);
|
|
||||||
}else{
|
|
||||||
addresseeIdList.addAll(userIds);
|
|
||||||
}
|
|
||||||
|
|
||||||
});
|
|
||||||
sendDingTask(context, addresseeIdList, messageDetail.getWebhook());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void sendDingTask(String context, List<String> userIds, String Webhook) {
|
|
||||||
if (CollectionUtils.isEmpty(userIds)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
DingTalkClient client = new DefaultDingTalkClient(Webhook);
|
|
||||||
OapiRobotSendRequest request = new OapiRobotSendRequest();
|
|
||||||
request.setMsgtype("text");
|
|
||||||
OapiRobotSendRequest.Text text = new OapiRobotSendRequest.Text();
|
|
||||||
text.setContent(context);
|
|
||||||
request.setText(text);
|
|
||||||
OapiRobotSendRequest.At at = new OapiRobotSendRequest.At();
|
|
||||||
List<UserDetail> list = userService.queryTypeByIds(userIds);
|
|
||||||
List<String> phoneList = new ArrayList<>();
|
|
||||||
list.forEach(u -> {
|
|
||||||
phoneList.add(u.getPhone());
|
|
||||||
});
|
|
||||||
LogUtil.info("收件人地址" + phoneList);
|
|
||||||
List<String> phoneLists = phoneList.stream().distinct().collect(Collectors.toList());
|
|
||||||
at.setAtMobiles(phoneLists);
|
|
||||||
request.setAt(at);
|
|
||||||
OapiRobotSendResponse response = null;
|
|
||||||
try {
|
|
||||||
response = client.execute(request);
|
|
||||||
} catch (ApiException e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
System.out.println(response.getErrcode());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,375 +1,26 @@
|
||||||
package io.metersphere.notice.service;
|
package io.metersphere.notice.service;
|
||||||
|
|
||||||
import io.metersphere.base.domain.*;
|
import io.metersphere.base.domain.SystemParameter;
|
||||||
import io.metersphere.base.mapper.UserMapper;
|
import io.metersphere.commons.constants.ParamConstants;
|
||||||
import io.metersphere.commons.constants.*;
|
|
||||||
import io.metersphere.commons.user.SessionUser;
|
|
||||||
import io.metersphere.commons.utils.EncryptUtils;
|
import io.metersphere.commons.utils.EncryptUtils;
|
||||||
import io.metersphere.commons.utils.LogUtil;
|
|
||||||
import io.metersphere.dto.BaseSystemConfigDTO;
|
|
||||||
import io.metersphere.i18n.Translator;
|
|
||||||
import io.metersphere.notice.domain.MessageDetail;
|
|
||||||
import io.metersphere.notice.domain.UserDetail;
|
|
||||||
import io.metersphere.service.SystemParameterService;
|
import io.metersphere.service.SystemParameterService;
|
||||||
import io.metersphere.service.UserService;
|
|
||||||
import io.metersphere.track.request.testcase.IssuesRequest;
|
|
||||||
import io.metersphere.track.request.testplan.AddTestPlanRequest;
|
|
||||||
import io.metersphere.track.request.testreview.SaveCommentRequest;
|
|
||||||
import io.metersphere.track.request.testreview.SaveTestCaseReviewRequest;
|
|
||||||
import org.apache.commons.collections4.CollectionUtils;
|
|
||||||
import org.apache.commons.collections4.MapUtils;
|
|
||||||
import org.apache.commons.io.IOUtils;
|
|
||||||
import org.apache.commons.lang3.BooleanUtils;
|
import org.apache.commons.lang3.BooleanUtils;
|
||||||
import org.apache.commons.lang3.RegExUtils;
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
|
||||||
import org.springframework.mail.MailException;
|
|
||||||
import org.springframework.mail.javamail.JavaMailSenderImpl;
|
import org.springframework.mail.javamail.JavaMailSenderImpl;
|
||||||
import org.springframework.mail.javamail.MimeMessageHelper;
|
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Propagation;
|
import org.springframework.transaction.annotation.Propagation;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import javax.mail.MessagingException;
|
import java.util.List;
|
||||||
import javax.mail.internet.MimeMessage;
|
import java.util.Properties;
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
import java.text.SimpleDateFormat;
|
|
||||||
import java.util.*;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
@Transactional(propagation = Propagation.NOT_SUPPORTED)
|
@Transactional(propagation = Propagation.NOT_SUPPORTED)
|
||||||
public class MailService {
|
public class MailService {
|
||||||
@Resource
|
|
||||||
private UserService userService;
|
|
||||||
@Resource
|
@Resource
|
||||||
private SystemParameterService systemParameterService;
|
private SystemParameterService systemParameterService;
|
||||||
@Resource
|
|
||||||
private UserMapper userMapper;
|
|
||||||
|
|
||||||
//接口和性能测试
|
public JavaMailSenderImpl getMailSender() {
|
||||||
public void sendLoadNotification(MessageDetail messageDetail, LoadTestReportWithBLOBs loadTestReport, String eventType) {
|
|
||||||
List<String> userIds = new ArrayList<>();
|
|
||||||
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
|
||||||
Map<String, String> context = new HashMap<>();
|
|
||||||
context.put("testName", loadTestReport.getName());
|
|
||||||
context.put("id", loadTestReport.getId());
|
|
||||||
context.put("type", "performance");
|
|
||||||
context.put("url", baseSystemConfigDTO.getUrl());
|
|
||||||
String performanceTemplate = "";
|
|
||||||
try {
|
|
||||||
if (StringUtils.equals(loadTestReport.getStatus(), PerformanceTestStatus.Completed.name())) {
|
|
||||||
performanceTemplate = IOUtils.toString(this.getClass().getResource("/mail/PerformanceApiSuccessNotification.html"), StandardCharsets.UTF_8);
|
|
||||||
} else if (StringUtils.equals(loadTestReport.getStatus(), PerformanceTestStatus.Error.name())) {
|
|
||||||
performanceTemplate = IOUtils.toString(this.getClass().getResource("/mail/PerformanceFailedNotification.html"), StandardCharsets.UTF_8);
|
|
||||||
}
|
|
||||||
sendApiOrLoadNotification(addresseeIdList(messageDetail, userIds, eventType), context, performanceTemplate, loadTestReport.getTriggerMode());
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void sendApiNotification(MessageDetail messageDetail, ApiTestReport apiTestReport, String eventType) {
|
|
||||||
List<String> userIds = new ArrayList<>();
|
|
||||||
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
|
||||||
Map<String, String> context = new HashMap<>();
|
|
||||||
context.put("testName", apiTestReport.getName());
|
|
||||||
context.put("type", "api");
|
|
||||||
context.put("url", baseSystemConfigDTO.getUrl());
|
|
||||||
context.put("id", apiTestReport.getId());
|
|
||||||
String apiTemplate = "";
|
|
||||||
try {
|
|
||||||
if (StringUtils.equals(APITestStatus.Success.name(), apiTestReport.getStatus())) {
|
|
||||||
apiTemplate = IOUtils.toString(this.getClass().getResource("/mail/ApiSuccessfulNotification.html"), StandardCharsets.UTF_8);
|
|
||||||
} else if (StringUtils.equals(APITestStatus.Error.name(), apiTestReport.getStatus())) {
|
|
||||||
apiTemplate = IOUtils.toString(this.getClass().getResource("/mail/ApiFailedNotification.html"), StandardCharsets.UTF_8);
|
|
||||||
}
|
|
||||||
sendApiOrLoadNotification(addresseeIdList(messageDetail, userIds, eventType), context, apiTemplate, apiTestReport.getTriggerMode());
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void sendApiOrLoadNotification(List<String> userIds, Map<String, String> context, String Template, String type) throws MessagingException {
|
|
||||||
if (CollectionUtils.isEmpty(userIds)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
JavaMailSenderImpl javaMailSender = getMailSender();
|
|
||||||
MimeMessage mimeMessage = javaMailSender.createMimeMessage();
|
|
||||||
MimeMessageHelper helper = new MimeMessageHelper(mimeMessage, true);
|
|
||||||
helper.setFrom(javaMailSender.getUsername());
|
|
||||||
if (StringUtils.equals(type, NoticeConstants.API)) {
|
|
||||||
helper.setSubject("MeterSphere平台" + Translator.get("task_notification_jenkins"));
|
|
||||||
}
|
|
||||||
if (StringUtils.equals(type, NoticeConstants.SCHEDULE)) {
|
|
||||||
helper.setSubject("MeterSphere平台" + Translator.get("task_notification"));
|
|
||||||
}
|
|
||||||
String[] users;
|
|
||||||
List<String> emails = new ArrayList<>();
|
|
||||||
List<UserDetail> list = userService.queryTypeByIds(userIds);
|
|
||||||
list.forEach(u -> {
|
|
||||||
emails.add(u.getEmail());
|
|
||||||
});
|
|
||||||
List<String> email = emails.stream().distinct().collect(Collectors.toList());
|
|
||||||
users = email.toArray(new String[0]);
|
|
||||||
LogUtil.info("收件人地址" + users);
|
|
||||||
helper.setText(getContent(Template, context), true);
|
|
||||||
helper.setTo(users);
|
|
||||||
try {
|
|
||||||
javaMailSender.send(mimeMessage);
|
|
||||||
} catch (MailException e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//测试评审
|
|
||||||
|
|
||||||
public void sendEndNotice(MessageDetail messageDetail, List<String> userIds, SaveTestCaseReviewRequest reviewRequest, String eventType) {
|
|
||||||
Map<String, String> context = getReviewContext(reviewRequest);
|
|
||||||
try {
|
|
||||||
String endTemplate = IOUtils.toString(this.getClass().getResource("/mail/ReviewEnd.html"), StandardCharsets.UTF_8);
|
|
||||||
sendReviewNotice(addresseeIdList(messageDetail, userIds, eventType), context, endTemplate);
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void sendDeleteNotice(MessageDetail messageDetail, List<String> userIds, SaveTestCaseReviewRequest reviewRequest, String eventType) {
|
|
||||||
Map<String, String> context = getReviewContext(reviewRequest);
|
|
||||||
try {
|
|
||||||
String endTemplate = IOUtils.toString(this.getClass().getResource("/mail/ReviewDelete.html"), StandardCharsets.UTF_8);
|
|
||||||
sendReviewNotice(addresseeIdList(messageDetail, userIds, eventType), context, endTemplate);
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void sendCommentNotice(MessageDetail messageDetail, List<String> userIds, SaveCommentRequest request, TestCaseWithBLOBs testCaseWithBLOBs, String eventType) {
|
|
||||||
User user = userMapper.selectByPrimaryKey(testCaseWithBLOBs.getMaintainer());
|
|
||||||
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
|
||||||
Map<String, String> context = new HashMap<>();
|
|
||||||
context.put("maintainer", user.getName());
|
|
||||||
context.put("testCaseName", testCaseWithBLOBs.getName());
|
|
||||||
context.put("description", request.getDescription());
|
|
||||||
context.put("url", baseSystemConfigDTO.getUrl());
|
|
||||||
context.put("id", request.getReviewId());
|
|
||||||
try {
|
|
||||||
String commentTemplate = IOUtils.toString(this.getClass().getResource("/mail/ReviewComments.html"), StandardCharsets.UTF_8);
|
|
||||||
sendReviewNotice(addresseeIdList(messageDetail, userIds, eventType), context, commentTemplate);
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void sendReviewerNotice(MessageDetail messageDetail, List<String> userIds, SaveTestCaseReviewRequest reviewRequest, String eventType) {
|
|
||||||
Map<String, String> context = getReviewContext(reviewRequest);
|
|
||||||
try {
|
|
||||||
String reviewerTemplate = IOUtils.toString(this.getClass().getResource("/mail/ReviewInitiate.html"), StandardCharsets.UTF_8);
|
|
||||||
sendReviewNotice(addresseeIdList(messageDetail, userIds, eventType), context, reviewerTemplate);
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void sendReviewNotice(List<String> userIds, Map<String, String> context, String Template) throws MessagingException {
|
|
||||||
if (CollectionUtils.isEmpty(userIds)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
JavaMailSenderImpl javaMailSender = getMailSender();
|
|
||||||
MimeMessage mimeMessage = javaMailSender.createMimeMessage();
|
|
||||||
MimeMessageHelper helper = new MimeMessageHelper(mimeMessage, true);
|
|
||||||
helper.setFrom(javaMailSender.getUsername());
|
|
||||||
helper.setSubject("MeterSphere平台" + Translator.get("test_review_task_notice"));
|
|
||||||
String[] users;
|
|
||||||
List<String> emails = new ArrayList<>();
|
|
||||||
List<UserDetail> list = userService.queryTypeByIds(userIds);
|
|
||||||
list.forEach(u -> {
|
|
||||||
emails.add(u.getEmail());
|
|
||||||
});
|
|
||||||
List<String> email = emails.stream().distinct().collect(Collectors.toList());
|
|
||||||
users = email.toArray(new String[0]);
|
|
||||||
LogUtil.info("收件人地址" + users);
|
|
||||||
helper.setText(getContent(Template, context), true);
|
|
||||||
helper.setTo(users);
|
|
||||||
if (users.length > 0) {
|
|
||||||
javaMailSender.send(mimeMessage);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//测试计划
|
|
||||||
|
|
||||||
public void sendTestPlanStartNotice(MessageDetail messageDetail, List<String> userIds, AddTestPlanRequest testPlan, String eventType) {
|
|
||||||
Map<String, String> context = getTestPlanContext(testPlan);
|
|
||||||
User user = userMapper.selectByPrimaryKey(testPlan.getCreator());
|
|
||||||
context.put("creator", user.getName());
|
|
||||||
try {
|
|
||||||
String endTemplate = IOUtils.toString(this.getClass().getResource("/mail/TestPlanStart.html"), StandardCharsets.UTF_8);
|
|
||||||
sendTestPlanNotice(addresseeIdList(messageDetail, userIds, eventType), context, endTemplate);
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void sendTestPlanEndNotice(MessageDetail messageDetail, List<String> userIds, AddTestPlanRequest testPlan, String eventType) {
|
|
||||||
User user = userMapper.selectByPrimaryKey(testPlan.getCreator());
|
|
||||||
Map<String, String> context = getTestPlanContext(testPlan);
|
|
||||||
context.put("creator", user.getName());
|
|
||||||
try {
|
|
||||||
String endTemplate = IOUtils.toString(this.getClass().getResource("/mail/TestPlanEnd.html"), StandardCharsets.UTF_8);
|
|
||||||
sendTestPlanNotice(addresseeIdList(messageDetail, userIds, eventType), context, endTemplate);
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void sendTestPlanDeleteNotice(MessageDetail messageDetail, List<String> userIds, AddTestPlanRequest testPlan, String eventType) {
|
|
||||||
User user = userMapper.selectByPrimaryKey(testPlan.getCreator());
|
|
||||||
Map<String, String> context = getTestPlanContext(testPlan);
|
|
||||||
context.put("creator", user.getName());
|
|
||||||
try {
|
|
||||||
String endTemplate = IOUtils.toString(this.getClass().getResource("/mail/TestPlanDelete.html"), StandardCharsets.UTF_8);
|
|
||||||
sendTestPlanNotice(addresseeIdList(messageDetail, userIds, eventType), context, endTemplate);
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void sendTestPlanNotice(List<String> userIds, Map<String, String> context, String Template) throws MessagingException {
|
|
||||||
if (CollectionUtils.isEmpty(userIds)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
JavaMailSenderImpl javaMailSender = getMailSender();
|
|
||||||
MimeMessage mimeMessage = javaMailSender.createMimeMessage();
|
|
||||||
MimeMessageHelper helper = new MimeMessageHelper(mimeMessage, true);
|
|
||||||
helper.setFrom(javaMailSender.getUsername());
|
|
||||||
helper.setSubject("MeterSphere平台" + Translator.get("test_plan_notification"));
|
|
||||||
String[] users;
|
|
||||||
List<String> emails = new ArrayList<>();
|
|
||||||
List<UserDetail> list = userService.queryTypeByIds(userIds);
|
|
||||||
list.forEach(u -> {
|
|
||||||
emails.add(u.getEmail());
|
|
||||||
});
|
|
||||||
List<String> email = emails.stream().distinct().collect(Collectors.toList());
|
|
||||||
users = email.toArray(new String[0]);
|
|
||||||
LogUtil.info("收件人地址" + users);
|
|
||||||
helper.setText(getContent(Template, context), true);
|
|
||||||
helper.setTo(users);
|
|
||||||
javaMailSender.send(mimeMessage);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
//缺陷任务
|
|
||||||
public void sendIssuesNotice(MessageDetail messageDetail, List<String> userIds, IssuesRequest issuesRequest, String eventType, SessionUser user) {
|
|
||||||
Map<String, String> context = new HashMap<>();
|
|
||||||
context.put("issuesName", issuesRequest.getTitle());
|
|
||||||
context.put("creator", user.getName());
|
|
||||||
try {
|
|
||||||
String endTemplate = IOUtils.toString(this.getClass().getResource("/mail/IssuesCreate.html"), StandardCharsets.UTF_8);
|
|
||||||
sendIssuesNotice(addresseeIdList(messageDetail, userIds, eventType), context, endTemplate);
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void sendIssuesNotice(List<String> userIds, Map<String, String> context, String Template) throws MessagingException {
|
|
||||||
if (CollectionUtils.isEmpty(userIds)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
JavaMailSenderImpl javaMailSender = getMailSender();
|
|
||||||
MimeMessage mimeMessage = javaMailSender.createMimeMessage();
|
|
||||||
MimeMessageHelper helper = new MimeMessageHelper(mimeMessage, true);
|
|
||||||
helper.setFrom(javaMailSender.getUsername());
|
|
||||||
helper.setSubject("MeterSphere平台" + Translator.get("task_defect_notification"));
|
|
||||||
String[] users;
|
|
||||||
List<String> emails = new ArrayList<>();
|
|
||||||
List<UserDetail> list = userService.queryTypeByIds(userIds);
|
|
||||||
list.forEach(u -> {
|
|
||||||
emails.add(u.getEmail());
|
|
||||||
});
|
|
||||||
List<String> email = emails.stream().distinct().collect(Collectors.toList());
|
|
||||||
users = email.toArray(new String[0]);
|
|
||||||
LogUtil.info("收件人地址" + users);
|
|
||||||
helper.setText(getContent(Template, context), true);
|
|
||||||
helper.setTo(users);
|
|
||||||
javaMailSender.send(mimeMessage);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
//评审内容
|
|
||||||
private Map<String, String> getReviewContext(SaveTestCaseReviewRequest reviewRequest) {
|
|
||||||
Long startTime = reviewRequest.getCreateTime();
|
|
||||||
Long endTime = reviewRequest.getEndTime();
|
|
||||||
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
|
|
||||||
String start = null;
|
|
||||||
String sTime = String.valueOf(startTime);
|
|
||||||
String eTime = String.valueOf(endTime);
|
|
||||||
if (!sTime.equals("null")) {
|
|
||||||
start = sdf.format(new Date(Long.parseLong(sTime)));
|
|
||||||
}
|
|
||||||
String end = null;
|
|
||||||
if (!eTime.equals("null")) {
|
|
||||||
end = sdf.format(new Date(Long.parseLong(eTime)));
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, String> context = new HashMap<>();
|
|
||||||
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
|
||||||
context.put("url", baseSystemConfigDTO.getUrl());
|
|
||||||
User user = userMapper.selectByPrimaryKey(reviewRequest.getCreator());
|
|
||||||
context.put("creator", user.getName());
|
|
||||||
context.put("reviewName", reviewRequest.getName());
|
|
||||||
context.put("start", start);
|
|
||||||
context.put("end", end);
|
|
||||||
context.put("id", reviewRequest.getId());
|
|
||||||
String status = "";
|
|
||||||
if (StringUtils.equals(TestPlanStatus.Underway.name(), reviewRequest.getStatus())) {
|
|
||||||
status = "进行中";
|
|
||||||
} else if (StringUtils.equals(TestPlanStatus.Prepare.name(), reviewRequest.getStatus())) {
|
|
||||||
status = "未开始";
|
|
||||||
} else if (StringUtils.equals(TestPlanStatus.Completed.name(), reviewRequest.getStatus())) {
|
|
||||||
status = "已完成";
|
|
||||||
}
|
|
||||||
context.put("status", status);
|
|
||||||
return context;
|
|
||||||
}
|
|
||||||
|
|
||||||
//计划内容
|
|
||||||
private Map<String, String> getTestPlanContext(AddTestPlanRequest testPlan) {
|
|
||||||
Long startTime = testPlan.getPlannedStartTime();
|
|
||||||
Long endTime = testPlan.getPlannedEndTime();
|
|
||||||
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
|
|
||||||
String start = null;
|
|
||||||
String sTime = String.valueOf(startTime);
|
|
||||||
String eTime = String.valueOf(endTime);
|
|
||||||
if (!sTime.equals("null")) {
|
|
||||||
start = sdf.format(new Date(Long.parseLong(sTime)));
|
|
||||||
}
|
|
||||||
String end = null;
|
|
||||||
if (!eTime.equals("null")) {
|
|
||||||
end = sdf.format(new Date(Long.parseLong(eTime)));
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, String> context = new HashMap<>();
|
|
||||||
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
|
||||||
context.put("url", baseSystemConfigDTO.getUrl());
|
|
||||||
context.put("testPlanName", testPlan.getName());
|
|
||||||
context.put("start", start);
|
|
||||||
context.put("end", end);
|
|
||||||
context.put("id", testPlan.getId());
|
|
||||||
String status = "";
|
|
||||||
if (StringUtils.equals(TestPlanStatus.Underway.name(), testPlan.getStatus())) {
|
|
||||||
status = "进行中";
|
|
||||||
} else if (StringUtils.equals(TestPlanStatus.Prepare.name(), testPlan.getStatus())) {
|
|
||||||
status = "未开始";
|
|
||||||
} else if (StringUtils.equals(TestPlanStatus.Completed.name(), testPlan.getStatus())) {
|
|
||||||
status = "已完成";
|
|
||||||
}
|
|
||||||
context.put("status", status);
|
|
||||||
User user = userMapper.selectByPrimaryKey(testPlan.getCreator());
|
|
||||||
context.put("creator", user.getName());
|
|
||||||
return context;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private JavaMailSenderImpl getMailSender() {
|
|
||||||
Properties props = new Properties();
|
Properties props = new Properties();
|
||||||
JavaMailSenderImpl javaMailSender = new JavaMailSenderImpl();
|
JavaMailSenderImpl javaMailSender = new JavaMailSenderImpl();
|
||||||
List<SystemParameter> paramList = systemParameterService.getParamList(ParamConstants.Classify.MAIL.getValue());
|
List<SystemParameter> paramList = systemParameterService.getParamList(ParamConstants.Classify.MAIL.getValue());
|
||||||
|
@ -420,47 +71,6 @@ public class MailService {
|
||||||
javaMailSender.setJavaMailProperties(props);
|
javaMailSender.setJavaMailProperties(props);
|
||||||
return javaMailSender;
|
return javaMailSender;
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getContent(String template, Map<String, String> context) {
|
|
||||||
if (MapUtils.isNotEmpty(context)) {
|
|
||||||
for (String k : context.keySet()) {
|
|
||||||
if (StringUtils.isNotBlank(context.get(k))) {
|
|
||||||
template = RegExUtils.replaceAll(template, "\\$\\{" + k + "}", context.get(k));
|
|
||||||
} else {
|
|
||||||
template = RegExUtils.replaceAll(template, "\\$\\{" + k + "}", "未设置");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return template;
|
|
||||||
}
|
|
||||||
|
|
||||||
private List<String> addresseeIdList(MessageDetail messageDetail, List<String> userIds, String eventType) {
|
|
||||||
List<String> addresseeIdList = new ArrayList<>();
|
|
||||||
if (StringUtils.equals(eventType, messageDetail.getEvent())) {
|
|
||||||
messageDetail.getUserIds().forEach(u -> {
|
|
||||||
if (!StringUtils.equals(NoticeConstants.EXECUTOR, u) && !StringUtils.equals(NoticeConstants.FOUNDER, u) && !StringUtils.equals(NoticeConstants.MAINTAINER, u)) {
|
|
||||||
addresseeIdList.add(u);
|
|
||||||
}
|
|
||||||
if (StringUtils.equals(NoticeConstants.CREATE, eventType) && StringUtils.equals(NoticeConstants.EXECUTOR, u)) {
|
|
||||||
addresseeIdList.addAll(userIds);
|
|
||||||
}
|
|
||||||
if (StringUtils.equals(NoticeConstants.UPDATE, eventType) && StringUtils.equals(NoticeConstants.FOUNDER, u)) {
|
|
||||||
addresseeIdList.addAll(userIds);
|
|
||||||
}
|
|
||||||
if (StringUtils.equals(NoticeConstants.DELETE, eventType) && StringUtils.equals(NoticeConstants.FOUNDER, u)) {
|
|
||||||
addresseeIdList.addAll(userIds);
|
|
||||||
}
|
|
||||||
if (StringUtils.equals(NoticeConstants.COMMENT, eventType) && StringUtils.equals(NoticeConstants.MAINTAINER, u)) {
|
|
||||||
addresseeIdList.addAll(userIds);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return addresseeIdList;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,63 @@
|
||||||
|
package io.metersphere.notice.service;
|
||||||
|
|
||||||
|
import io.metersphere.commons.constants.NoticeConstants;
|
||||||
|
import io.metersphere.commons.utils.CommonBeanFactory;
|
||||||
|
import io.metersphere.notice.domain.MessageDetail;
|
||||||
|
import io.metersphere.notice.sender.NoticeModel;
|
||||||
|
import io.metersphere.notice.sender.NoticeSender;
|
||||||
|
import io.metersphere.notice.sender.impl.DingNoticeSender;
|
||||||
|
import io.metersphere.notice.sender.impl.MailNoticeSender;
|
||||||
|
import io.metersphere.notice.sender.impl.WeComNoticeSender;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class NoticeSendService {
|
||||||
|
@Resource
|
||||||
|
private MailNoticeSender mailNoticeSender;
|
||||||
|
@Resource
|
||||||
|
private WeComNoticeSender weComNoticeSender;
|
||||||
|
@Resource
|
||||||
|
private DingNoticeSender dingNoticeSender;
|
||||||
|
|
||||||
|
private NoticeSender getNoticeSender(MessageDetail messageDetail) {
|
||||||
|
NoticeSender noticeSender = null;
|
||||||
|
switch (messageDetail.getType()) {
|
||||||
|
case NoticeConstants.Type.EMAIL:
|
||||||
|
noticeSender = mailNoticeSender;
|
||||||
|
break;
|
||||||
|
case NoticeConstants.Type.WECHAT_ROBOT:
|
||||||
|
noticeSender = weComNoticeSender;
|
||||||
|
break;
|
||||||
|
case NoticeConstants.Type.NAIL_ROBOT:
|
||||||
|
noticeSender = dingNoticeSender;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return noticeSender;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void send(String taskType, NoticeModel noticeModel) {
|
||||||
|
NoticeService noticeService = CommonBeanFactory.getBean(NoticeService.class);
|
||||||
|
assert noticeService != null;
|
||||||
|
List<MessageDetail> messageDetails;
|
||||||
|
switch (taskType) {
|
||||||
|
case NoticeConstants.Mode.API:
|
||||||
|
messageDetails = noticeService.searchMessageByType(NoticeConstants.TaskType.JENKINS_TASK);
|
||||||
|
break;
|
||||||
|
case NoticeConstants.Mode.SCHEDULE:
|
||||||
|
messageDetails = noticeService.searchMessageByTestId(noticeModel.getTestId());
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
messageDetails = noticeService.searchMessageByType(taskType);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
messageDetails.forEach(messageDetail ->
|
||||||
|
this.getNoticeSender(messageDetail).send(messageDetail, noticeModel)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
|
@ -3,15 +3,11 @@ package io.metersphere.notice.service;
|
||||||
import io.metersphere.base.domain.MessageTask;
|
import io.metersphere.base.domain.MessageTask;
|
||||||
import io.metersphere.base.domain.MessageTaskExample;
|
import io.metersphere.base.domain.MessageTaskExample;
|
||||||
import io.metersphere.base.mapper.MessageTaskMapper;
|
import io.metersphere.base.mapper.MessageTaskMapper;
|
||||||
import io.metersphere.base.mapper.ext.ExtMessageMapper;
|
|
||||||
import io.metersphere.commons.constants.NoticeConstants;
|
|
||||||
import io.metersphere.commons.exception.MSException;
|
import io.metersphere.commons.exception.MSException;
|
||||||
import io.metersphere.commons.user.SessionUser;
|
import io.metersphere.commons.user.SessionUser;
|
||||||
import io.metersphere.commons.utils.SessionUtils;
|
import io.metersphere.commons.utils.SessionUtils;
|
||||||
import io.metersphere.i18n.Translator;
|
import io.metersphere.i18n.Translator;
|
||||||
import io.metersphere.notice.controller.request.MessageRequest;
|
|
||||||
import io.metersphere.notice.domain.MessageDetail;
|
import io.metersphere.notice.domain.MessageDetail;
|
||||||
import io.metersphere.notice.domain.MessageSettingDetail;
|
|
||||||
import org.apache.commons.collections.CollectionUtils;
|
import org.apache.commons.collections.CollectionUtils;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
@ -26,69 +22,106 @@ import java.util.stream.Collectors;
|
||||||
public class NoticeService {
|
public class NoticeService {
|
||||||
@Resource
|
@Resource
|
||||||
private MessageTaskMapper messageTaskMapper;
|
private MessageTaskMapper messageTaskMapper;
|
||||||
@Resource
|
|
||||||
private ExtMessageMapper extMessageMapper;
|
|
||||||
|
|
||||||
|
public void saveMessageTask(MessageDetail messageDetail) {
|
||||||
public void saveMessageTask(MessageRequest messageRequest) {
|
|
||||||
messageRequest.getMessageDetail().forEach(list -> {
|
|
||||||
MessageTaskExample example = new MessageTaskExample();
|
MessageTaskExample example = new MessageTaskExample();
|
||||||
example.createCriteria().andIdentificationEqualTo(list.getIdentification());
|
example.createCriteria().andIdentificationEqualTo(messageDetail.getIdentification());
|
||||||
List<MessageTask> messageTaskLists = messageTaskMapper.selectByExample(example);
|
List<MessageTask> messageTaskLists = messageTaskMapper.selectByExample(example);
|
||||||
if (messageTaskLists.size() > 0) {
|
if (messageTaskLists.size() > 0) {
|
||||||
delMessage(list.getIdentification());
|
delMessage(messageDetail.getIdentification());
|
||||||
getSaveMessageTask(list);
|
|
||||||
}
|
}
|
||||||
if (messageTaskLists.size() <= 0) {
|
|
||||||
getSaveMessageTask(list);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public void getSaveMessageTask(MessageDetail list) {
|
|
||||||
SessionUser user = SessionUtils.getUser();
|
SessionUser user = SessionUtils.getUser();
|
||||||
assert user != null;
|
|
||||||
String orgId = user.getLastOrganizationId();
|
String orgId = user.getLastOrganizationId();
|
||||||
long time = System.currentTimeMillis();
|
long time = System.currentTimeMillis();
|
||||||
String identification = UUID.randomUUID().toString();
|
String identification = UUID.randomUUID().toString();
|
||||||
list.getUserIds().forEach(m -> {
|
messageDetail.getUserIds().forEach(m -> {
|
||||||
checkUserIdExist(m, list,orgId);
|
checkUserIdExist(m, messageDetail, orgId);
|
||||||
MessageTask message = new MessageTask();
|
MessageTask messageTask = new MessageTask();
|
||||||
message.setId(UUID.randomUUID().toString());
|
messageTask.setId(UUID.randomUUID().toString());
|
||||||
message.setEvent(list.getEvent());
|
messageTask.setEvent(messageDetail.getEvent());
|
||||||
message.setTaskType(list.getTaskType());
|
messageTask.setTaskType(messageDetail.getTaskType());
|
||||||
message.setUserId(m);
|
messageTask.setUserId(m);
|
||||||
message.setType(list.getType());
|
messageTask.setType(messageDetail.getType());
|
||||||
message.setWebhook(list.getWebhook());
|
messageTask.setWebhook(messageDetail.getWebhook());
|
||||||
message.setIdentification(identification);
|
messageTask.setIdentification(identification);
|
||||||
message.setIsSet(false);
|
messageTask.setIsSet(false);
|
||||||
message.setOrganizationId(orgId);
|
messageTask.setOrganizationId(orgId);
|
||||||
message.setTestId(list.getTestId());
|
messageTask.setTestId(messageDetail.getTestId());
|
||||||
message.setCreateTime(time);
|
messageTask.setCreateTime(time);
|
||||||
messageTaskMapper.insert(message);
|
messageTaskMapper.insert(messageTask);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkUserIdExist(String userId, MessageDetail list, String orgId) {
|
private void checkUserIdExist(String userId, MessageDetail list, String orgId) {
|
||||||
MessageTaskExample example = new MessageTaskExample();
|
MessageTaskExample example = new MessageTaskExample();
|
||||||
if (StringUtils.isBlank(list.getTestId())) {
|
if (StringUtils.isBlank(list.getTestId())) {
|
||||||
example.createCriteria().andUserIdEqualTo(userId).andEventEqualTo(list.getEvent()).andTypeEqualTo(list.getType()).andTaskTypeEqualTo(list.getTaskType()).andWebhookEqualTo(list.getWebhook()).andOrganizationIdEqualTo(orgId);
|
example.createCriteria()
|
||||||
|
.andUserIdEqualTo(userId)
|
||||||
|
.andEventEqualTo(list.getEvent())
|
||||||
|
.andTypeEqualTo(list.getType())
|
||||||
|
.andTaskTypeEqualTo(list.getTaskType())
|
||||||
|
.andWebhookEqualTo(list.getWebhook())
|
||||||
|
.andOrganizationIdEqualTo(orgId);
|
||||||
} else {
|
} else {
|
||||||
example.createCriteria().andUserIdEqualTo(userId).andEventEqualTo(list.getEvent()).andTypeEqualTo(list.getType()).andTaskTypeEqualTo(list.getTaskType()).andWebhookEqualTo(list.getWebhook()).andTestIdEqualTo(list.getTestId()).andOrganizationIdEqualTo(orgId);
|
example.createCriteria()
|
||||||
|
.andUserIdEqualTo(userId)
|
||||||
|
.andEventEqualTo(list.getEvent())
|
||||||
|
.andTypeEqualTo(list.getType())
|
||||||
|
.andTaskTypeEqualTo(list.getTaskType())
|
||||||
|
.andWebhookEqualTo(list.getWebhook())
|
||||||
|
.andTestIdEqualTo(list.getTestId())
|
||||||
|
.andOrganizationIdEqualTo(orgId);
|
||||||
}
|
}
|
||||||
if (messageTaskMapper.countByExample(example) > 0) {
|
if (messageTaskMapper.countByExample(example) > 0) {
|
||||||
MSException.throwException(Translator.get("message_task_already_exists"));
|
MSException.throwException(Translator.get("message_task_already_exists"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<MessageDetail> searchMessageSchedule(String testId) {
|
public List<MessageDetail> searchMessageByTestId(String testId) {
|
||||||
List<MessageTask> messageTaskLists = extMessageMapper.searchMessageByTestId(testId);
|
MessageTaskExample example = new MessageTaskExample();
|
||||||
|
example.createCriteria().andTestIdEqualTo(testId);
|
||||||
|
List<MessageTask> messageTaskLists = messageTaskMapper.selectByExample(example);
|
||||||
List<MessageDetail> scheduleMessageTask = new ArrayList<>();
|
List<MessageDetail> scheduleMessageTask = new ArrayList<>();
|
||||||
Map<String, List<MessageTask>> MessageTaskMap = messageTaskLists.stream().collect(Collectors.groupingBy(MessageTask::getIdentification));
|
Map<String, List<MessageTask>> MessageTaskMap = messageTaskLists.stream().collect(Collectors.groupingBy(MessageTask::getIdentification));
|
||||||
MessageTaskMap.forEach((k, v) -> {
|
MessageTaskMap.forEach((k, v) -> {
|
||||||
|
MessageDetail messageDetail = getMessageDetail(v);
|
||||||
|
scheduleMessageTask.add(messageDetail);
|
||||||
|
});
|
||||||
|
scheduleMessageTask.sort(Comparator.comparing(MessageDetail::getCreateTime, Comparator.nullsLast(Long::compareTo)).reversed());
|
||||||
|
return scheduleMessageTask;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<MessageDetail> searchMessageByType(String type) {
|
||||||
|
SessionUser user = SessionUtils.getUser();
|
||||||
|
String orgId = user.getLastOrganizationId();
|
||||||
|
List<MessageDetail> messageDetails = new ArrayList<>();
|
||||||
|
|
||||||
|
MessageTaskExample example = new MessageTaskExample();
|
||||||
|
example.createCriteria()
|
||||||
|
.andTaskTypeEqualTo(type)
|
||||||
|
.andOrganizationIdEqualTo(orgId);
|
||||||
|
List<MessageTask> messageTaskLists = messageTaskMapper.selectByExample(example);
|
||||||
|
|
||||||
|
Map<String, List<MessageTask>> messageTaskMap = messageTaskLists.stream()
|
||||||
|
.collect(Collectors.groupingBy(NoticeService::fetchGroupKey));
|
||||||
|
messageTaskMap.forEach((k, v) -> {
|
||||||
|
MessageDetail messageDetail = getMessageDetail(v);
|
||||||
|
messageDetails.add(messageDetail);
|
||||||
|
});
|
||||||
|
|
||||||
|
return messageDetails.stream()
|
||||||
|
.sorted(Comparator.comparing(MessageDetail::getCreateTime, Comparator.nullsLast(Long::compareTo)).reversed())
|
||||||
|
.collect(Collectors.toList())
|
||||||
|
.stream()
|
||||||
|
.distinct()
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
}
|
||||||
|
|
||||||
|
private MessageDetail getMessageDetail(List<MessageTask> messageTasks) {
|
||||||
Set<String> userIds = new HashSet<>();
|
Set<String> userIds = new HashSet<>();
|
||||||
|
|
||||||
MessageDetail messageDetail = new MessageDetail();
|
MessageDetail messageDetail = new MessageDetail();
|
||||||
for (MessageTask m : v) {
|
for (MessageTask m : messageTasks) {
|
||||||
userIds.add(m.getUserId());
|
userIds.add(m.getUserId());
|
||||||
messageDetail.setEvent(m.getEvent());
|
messageDetail.setEvent(m.getEvent());
|
||||||
messageDetail.setTaskType(m.getTaskType());
|
messageDetail.setTaskType(m.getTaskType());
|
||||||
|
@ -101,54 +134,11 @@ public class NoticeService {
|
||||||
if (CollectionUtils.isNotEmpty(userIds)) {
|
if (CollectionUtils.isNotEmpty(userIds)) {
|
||||||
messageDetail.setUserIds(new ArrayList<>(userIds));
|
messageDetail.setUserIds(new ArrayList<>(userIds));
|
||||||
}
|
}
|
||||||
scheduleMessageTask.add(messageDetail);
|
return messageDetail;
|
||||||
});
|
|
||||||
scheduleMessageTask.sort(Comparator.comparing(MessageDetail::getCreateTime, Comparator.nullsLast(Long::compareTo)).reversed());
|
|
||||||
return scheduleMessageTask;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public MessageSettingDetail searchMessage() {
|
private static String fetchGroupKey(MessageTask messageTask) {
|
||||||
SessionUser user = SessionUtils.getUser();
|
return messageTask.getTaskType() + "#" + messageTask.getIdentification();
|
||||||
assert user != null;
|
|
||||||
String orgId = user.getLastOrganizationId();
|
|
||||||
List<MessageTask> messageTaskLists;
|
|
||||||
MessageSettingDetail messageSettingDetail = new MessageSettingDetail();
|
|
||||||
List<MessageDetail> MessageDetailList = new ArrayList<>();
|
|
||||||
messageTaskLists = extMessageMapper.searchMessageByOrganizationId(orgId);
|
|
||||||
Map<String, List<MessageTask>> MessageTaskMap = messageTaskLists.stream().collect(Collectors.groupingBy(NoticeService::fetchGroupKey));
|
|
||||||
MessageTaskMap.forEach((k, v) -> {
|
|
||||||
Set<String> userIds = new HashSet<>();
|
|
||||||
MessageDetail messageDetail = new MessageDetail();
|
|
||||||
for (MessageTask m : v) {
|
|
||||||
userIds.add(m.getUserId());
|
|
||||||
messageDetail.setEvent(m.getEvent());
|
|
||||||
messageDetail.setTaskType(m.getTaskType());
|
|
||||||
messageDetail.setWebhook(m.getWebhook());
|
|
||||||
messageDetail.setIdentification(m.getIdentification());
|
|
||||||
messageDetail.setType(m.getType());
|
|
||||||
messageDetail.setIsSet(m.getIsSet());
|
|
||||||
messageDetail.setCreateTime(m.getCreateTime());
|
|
||||||
}
|
|
||||||
messageDetail.setUserIds(new ArrayList<String>(userIds));
|
|
||||||
MessageDetailList.add(messageDetail);
|
|
||||||
});
|
|
||||||
List<MessageDetail> jenkinsTask = (MessageDetailList.stream().filter(a -> a.getTaskType().equals(NoticeConstants.JENKINS_TASK)).sorted(Comparator.comparing(
|
|
||||||
MessageDetail::getCreateTime, Comparator.nullsLast(Long::compareTo)).reversed()).collect(Collectors.toList())).stream().distinct().collect(Collectors.toList());
|
|
||||||
List<MessageDetail> testCasePlanTask = (MessageDetailList.stream().filter(a -> a.getTaskType().equals(NoticeConstants.TEST_PLAN_TASK)).sorted(Comparator.comparing(
|
|
||||||
MessageDetail::getCreateTime, Comparator.nullsLast(Long::compareTo)).reversed()).collect(Collectors.toList())).stream().distinct().collect(Collectors.toList());
|
|
||||||
List<MessageDetail> reviewTask = (MessageDetailList.stream().filter(a -> a.getTaskType().equals(NoticeConstants.REVIEW_TASK)).sorted(Comparator.comparing(
|
|
||||||
MessageDetail::getCreateTime, Comparator.nullsLast(Long::compareTo)).reversed()).collect(Collectors.toList())).stream().distinct().collect(Collectors.toList());
|
|
||||||
List<MessageDetail> defectTask = (MessageDetailList.stream().filter(a -> a.getTaskType().equals(NoticeConstants.DEFECT_TASK)).sorted(Comparator.comparing(
|
|
||||||
MessageDetail::getCreateTime, Comparator.nullsLast(Long::compareTo)).reversed()).collect(Collectors.toList())).stream().distinct().collect(Collectors.toList());
|
|
||||||
messageSettingDetail.setJenkinsTask(jenkinsTask);
|
|
||||||
messageSettingDetail.setTestCasePlanTask(testCasePlanTask);
|
|
||||||
messageSettingDetail.setReviewTask(reviewTask);
|
|
||||||
messageSettingDetail.setDefectTask(defectTask);
|
|
||||||
return messageSettingDetail;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static String fetchGroupKey(MessageTask user) {
|
|
||||||
return user.getTaskType() + "#" + user.getIdentification();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public int delMessage(String identification) {
|
public int delMessage(String identification) {
|
||||||
|
|
|
@ -1,66 +0,0 @@
|
||||||
package io.metersphere.notice.service;
|
|
||||||
|
|
||||||
import io.metersphere.commons.constants.NoticeConstants;
|
|
||||||
import io.metersphere.commons.utils.LogUtil;
|
|
||||||
import io.metersphere.notice.domain.MessageDetail;
|
|
||||||
import io.metersphere.notice.domain.UserDetail;
|
|
||||||
import io.metersphere.notice.message.TextMessage;
|
|
||||||
import io.metersphere.notice.util.SendResult;
|
|
||||||
import io.metersphere.notice.util.WxChatbotClient;
|
|
||||||
import io.metersphere.service.UserService;
|
|
||||||
import org.apache.commons.collections4.CollectionUtils;
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
import org.springframework.transaction.annotation.Propagation;
|
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
@Service
|
|
||||||
@Transactional(propagation = Propagation.NOT_SUPPORTED)
|
|
||||||
public class WxChatTaskService {
|
|
||||||
@Resource
|
|
||||||
private UserService userService;
|
|
||||||
|
|
||||||
public void sendWechatRobot(MessageDetail messageDetail, List<String> userIds, String context, String eventType) {
|
|
||||||
List<String> addresseeIdList = new ArrayList<>();
|
|
||||||
if (StringUtils.equals(eventType, messageDetail.getEvent())) {
|
|
||||||
messageDetail.getUserIds().forEach(u -> {
|
|
||||||
if (!StringUtils.equals(NoticeConstants.EXECUTOR, u) && !StringUtils.equals(NoticeConstants.FOUNDER, u) && !StringUtils.equals(NoticeConstants.MAINTAINER, u)) {
|
|
||||||
addresseeIdList.add(u);
|
|
||||||
}else{
|
|
||||||
addresseeIdList.addAll(userIds);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
enterpriseWechatTask(context, addresseeIdList, messageDetail.getWebhook());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void enterpriseWechatTask(String context, List<String> userIds, String Webhook) {
|
|
||||||
if (CollectionUtils.isEmpty(userIds)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
TextMessage message = new TextMessage(context);
|
|
||||||
List<String> mentionedMobileList = new ArrayList<>();
|
|
||||||
List<UserDetail> list = userService.queryTypeByIds(userIds);
|
|
||||||
List<String> phoneList = new ArrayList<>();
|
|
||||||
list.forEach(u -> {
|
|
||||||
phoneList.add(u.getPhone());
|
|
||||||
});
|
|
||||||
LogUtil.info("收件人地址" + phoneList);
|
|
||||||
List<String> phoneLists = phoneList.stream().distinct().collect(Collectors.toList());
|
|
||||||
mentionedMobileList.addAll(phoneLists);
|
|
||||||
message.setMentionedMobileList(mentionedMobileList);
|
|
||||||
try {
|
|
||||||
SendResult result = WxChatbotClient.send(Webhook, message);
|
|
||||||
System.out.println(result);
|
|
||||||
} catch (IOException e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -6,46 +6,35 @@ import io.metersphere.commons.constants.NoticeConstants;
|
||||||
import io.metersphere.commons.constants.PerformanceTestStatus;
|
import io.metersphere.commons.constants.PerformanceTestStatus;
|
||||||
import io.metersphere.commons.utils.LogUtil;
|
import io.metersphere.commons.utils.LogUtil;
|
||||||
import io.metersphere.dto.BaseSystemConfigDTO;
|
import io.metersphere.dto.BaseSystemConfigDTO;
|
||||||
import io.metersphere.notice.domain.MessageDetail;
|
import io.metersphere.i18n.Translator;
|
||||||
import io.metersphere.notice.domain.MessageSettingDetail;
|
import io.metersphere.notice.sender.NoticeModel;
|
||||||
import io.metersphere.notice.service.DingTaskService;
|
import io.metersphere.notice.service.NoticeSendService;
|
||||||
import io.metersphere.notice.service.MailService;
|
|
||||||
import io.metersphere.notice.service.NoticeService;
|
|
||||||
import io.metersphere.notice.service.WxChatTaskService;
|
|
||||||
import io.metersphere.service.SystemParameterService;
|
import io.metersphere.service.SystemParameterService;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
import javax.annotation.PreDestroy;
|
import javax.annotation.PreDestroy;
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.concurrent.ExecutorService;
|
import java.util.concurrent.ExecutorService;
|
||||||
import java.util.concurrent.Executors;
|
import java.util.concurrent.Executors;
|
||||||
|
|
||||||
@Component
|
@Component
|
||||||
public class PerformanceNoticeTask {
|
public class PerformanceNoticeTask {
|
||||||
@Resource
|
|
||||||
private NoticeService noticeService;
|
|
||||||
@Resource
|
|
||||||
private DingTaskService dingTaskService;
|
|
||||||
@Resource
|
|
||||||
private WxChatTaskService wxChatTaskService;
|
|
||||||
@Resource
|
|
||||||
private MailService mailService;
|
|
||||||
@Resource
|
@Resource
|
||||||
private SystemParameterService systemParameterService;
|
private SystemParameterService systemParameterService;
|
||||||
@Resource
|
@Resource
|
||||||
private LoadTestReportMapper loadTestReportMapper;
|
private LoadTestReportMapper loadTestReportMapper;
|
||||||
|
@Resource
|
||||||
|
private NoticeSendService noticeSendService;
|
||||||
|
|
||||||
private final ExecutorService executorService = Executors.newFixedThreadPool(20);
|
private final ExecutorService executorService = Executors.newFixedThreadPool(20);
|
||||||
|
|
||||||
private boolean isRunning = false;
|
private boolean isRunning = false;
|
||||||
|
|
||||||
/*@PreDestroy
|
@PreDestroy
|
||||||
public void preDestroy() {
|
public void preDestroy() {
|
||||||
isRunning = false;
|
isRunning = false;
|
||||||
}*/
|
}
|
||||||
|
|
||||||
public void registerNoticeTask(LoadTestReportWithBLOBs loadTestReport) {
|
public void registerNoticeTask(LoadTestReportWithBLOBs loadTestReport) {
|
||||||
isRunning = true;
|
isRunning = true;
|
||||||
|
@ -53,12 +42,9 @@ public class PerformanceNoticeTask {
|
||||||
LogUtil.info("性能测试定时任务");
|
LogUtil.info("性能测试定时任务");
|
||||||
while (isRunning) {
|
while (isRunning) {
|
||||||
LoadTestReportWithBLOBs loadTestReportFromDatabase = loadTestReportMapper.selectByPrimaryKey(loadTestReport.getId());
|
LoadTestReportWithBLOBs loadTestReportFromDatabase = loadTestReportMapper.selectByPrimaryKey(loadTestReport.getId());
|
||||||
if (StringUtils.equals(loadTestReportFromDatabase.getStatus(), PerformanceTestStatus.Completed.name())) {
|
if (StringUtils.equalsAny(loadTestReportFromDatabase.getStatus(),
|
||||||
sendSuccessNotice(loadTestReportFromDatabase);
|
PerformanceTestStatus.Completed.name(), PerformanceTestStatus.Error.name())) {
|
||||||
isRunning=false;
|
sendNotice(loadTestReportFromDatabase);
|
||||||
}
|
|
||||||
if (StringUtils.equals(loadTestReportFromDatabase.getStatus(), PerformanceTestStatus.Error.name())) {
|
|
||||||
sendFailNotice(loadTestReportFromDatabase);
|
|
||||||
isRunning = false;
|
isRunning = false;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
|
@ -71,81 +57,32 @@ public class PerformanceNoticeTask {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public void sendSuccessNotice(LoadTestReportWithBLOBs loadTestReport) {
|
public void sendNotice(LoadTestReportWithBLOBs loadTestReport) {
|
||||||
List<String> userIds = new ArrayList<>();
|
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
||||||
List<MessageDetail> taskList = new ArrayList<>();
|
String url = baseSystemConfigDTO.getUrl() + "/#/performance/report/view/" + loadTestReport.getId();
|
||||||
String successContext = "";
|
String successContext = "";
|
||||||
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
|
||||||
String url = baseSystemConfigDTO.getUrl() + "/#/performance/report/view/" + loadTestReport.getId();
|
|
||||||
if (StringUtils.equals(NoticeConstants.API, loadTestReport.getTriggerMode())) {
|
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
|
||||||
taskList = messageSettingDetail.getJenkinsTask();
|
|
||||||
successContext = "LoadJenkins任务通知:" + loadTestReport.getName() + "执行成功" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
|
||||||
}
|
|
||||||
if (StringUtils.equals(NoticeConstants.SCHEDULE, loadTestReport.getTriggerMode())) {
|
|
||||||
taskList = noticeService.searchMessageSchedule(loadTestReport.getTestId());
|
|
||||||
successContext = "Load定时任务通知:" + loadTestReport.getName() + "执行成功" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
|
||||||
}
|
|
||||||
String finalSuccessContext = successContext;
|
|
||||||
taskList.forEach(r -> {
|
|
||||||
switch (r.getType()) {
|
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
|
||||||
if (StringUtils.equals(NoticeConstants.EXECUTE_SUCCESSFUL, r.getEvent()) && StringUtils.equals(loadTestReport.getStatus(), PerformanceTestStatus.Completed.name())) {
|
|
||||||
dingTaskService.sendNailRobot(r, userIds, finalSuccessContext, NoticeConstants.EXECUTE_SUCCESSFUL);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
|
||||||
if (StringUtils.equals(NoticeConstants.EXECUTE_SUCCESSFUL, r.getEvent()) && StringUtils.equals(loadTestReport.getStatus(), PerformanceTestStatus.Completed.name())) {
|
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, finalSuccessContext, NoticeConstants.EXECUTE_SUCCESSFUL);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case NoticeConstants.EMAIL:
|
|
||||||
if (StringUtils.equals(NoticeConstants.EXECUTE_SUCCESSFUL, r.getEvent()) && StringUtils.equals(loadTestReport.getStatus(), PerformanceTestStatus.Completed.name())) {
|
|
||||||
mailService.sendLoadNotification(r, loadTestReport, NoticeConstants.EXECUTE_SUCCESSFUL);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public void sendFailNotice(LoadTestReportWithBLOBs loadTestReport) {
|
|
||||||
List<String> userIds = new ArrayList<>();
|
|
||||||
List<MessageDetail> taskList = new ArrayList<>();
|
|
||||||
String failedContext = "";
|
String failedContext = "";
|
||||||
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
String subject = "";
|
||||||
String url = baseSystemConfigDTO.getUrl() + "/#/performance/report/view/" + loadTestReport.getId();
|
if (StringUtils.equals(NoticeConstants.Mode.API, loadTestReport.getTriggerMode())) {
|
||||||
if (StringUtils.equals(NoticeConstants.API, loadTestReport.getTriggerMode())) {
|
successContext = "性能测试 API任务通知:" + loadTestReport.getName() + "执行成功" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
failedContext = "性能测试 API任务通知:" + loadTestReport.getName() + "执行失败" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
||||||
taskList = messageSettingDetail.getJenkinsTask();
|
subject = Translator.get("task_notification_jenkins");
|
||||||
failedContext = "LoadJenkins任务通知:" + loadTestReport.getName() + "执行失败" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
|
||||||
}
|
}
|
||||||
if (StringUtils.equals(NoticeConstants.SCHEDULE, loadTestReport.getTriggerMode())) {
|
if (StringUtils.equals(NoticeConstants.Mode.SCHEDULE, loadTestReport.getTriggerMode())) {
|
||||||
taskList = noticeService.searchMessageSchedule(loadTestReport.getTestId());
|
successContext = "性能测试定时任务通知:" + loadTestReport.getName() + "执行成功" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
||||||
failedContext = "Load定时任务通知:" + loadTestReport.getName() + "执行失败" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
failedContext = "性能测试定时任务通知:" + loadTestReport.getName() + "执行失败" + "\n" + "请点击下面链接进入测试报告页面" + "\n" + url;
|
||||||
}
|
subject = Translator.get("task_notification");
|
||||||
String finalFailedContext = failedContext;
|
|
||||||
taskList.forEach(r -> {
|
|
||||||
switch (r.getType()) {
|
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
|
||||||
if (StringUtils.equals(NoticeConstants.EXECUTE_FAILED, r.getEvent()) && StringUtils.equals(loadTestReport.getStatus(), PerformanceTestStatus.Error.name())) {
|
|
||||||
dingTaskService.sendNailRobot(r, userIds, finalFailedContext, NoticeConstants.EXECUTE_FAILED);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
|
||||||
if (StringUtils.equals(NoticeConstants.EXECUTE_FAILED, r.getEvent()) && StringUtils.equals(loadTestReport.getStatus(), PerformanceTestStatus.Error.name())) {
|
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, finalFailedContext, NoticeConstants.EXECUTE_FAILED);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case NoticeConstants.EMAIL:
|
|
||||||
if (StringUtils.equals(NoticeConstants.EXECUTE_FAILED, r.getEvent()) && StringUtils.equals(loadTestReport.getStatus(), PerformanceTestStatus.Error.name())) {
|
|
||||||
mailService.sendLoadNotification(r, loadTestReport, NoticeConstants.EXECUTE_FAILED);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
NoticeModel noticeModel = NoticeModel.builder()
|
||||||
|
.successContext(successContext)
|
||||||
|
.successMailTemplate("PerformanceApiSuccessNotification")
|
||||||
|
.failedContext(failedContext)
|
||||||
|
.failedMailTemplate("PerformanceFailedNotification")
|
||||||
|
.testId(loadTestReport.getTestId())
|
||||||
|
.status(loadTestReport.getStatus())
|
||||||
|
.subject(subject)
|
||||||
|
.build();
|
||||||
|
noticeSendService.send(loadTestReport.getTriggerMode(), noticeModel);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -232,7 +232,7 @@ public class PerformanceTestService {
|
||||||
startEngine(loadTest, engine, request.getTriggerMode());
|
startEngine(loadTest, engine, request.getTriggerMode());
|
||||||
|
|
||||||
LoadTestReportWithBLOBs loadTestReport = loadTestReportMapper.selectByPrimaryKey(engine.getReportId());
|
LoadTestReportWithBLOBs loadTestReport = loadTestReportMapper.selectByPrimaryKey(engine.getReportId());
|
||||||
if (StringUtils.equals(NoticeConstants.API, loadTestReport.getTriggerMode()) || StringUtils.equals(NoticeConstants.SCHEDULE, loadTestReport.getTriggerMode())) {
|
if (StringUtils.equals(NoticeConstants.Mode.API, loadTestReport.getTriggerMode()) || StringUtils.equals(NoticeConstants.Mode.SCHEDULE, loadTestReport.getTriggerMode())) {
|
||||||
performanceNoticeTask.registerNoticeTask(loadTestReport);
|
performanceNoticeTask.registerNoticeTask(loadTestReport);
|
||||||
}
|
}
|
||||||
return engine.getReportId();
|
return engine.getReportId();
|
||||||
|
|
|
@ -8,15 +8,11 @@ import io.metersphere.base.mapper.IssuesMapper;
|
||||||
import io.metersphere.commons.constants.IssuesManagePlatform;
|
import io.metersphere.commons.constants.IssuesManagePlatform;
|
||||||
import io.metersphere.commons.constants.NoticeConstants;
|
import io.metersphere.commons.constants.NoticeConstants;
|
||||||
import io.metersphere.commons.user.SessionUser;
|
import io.metersphere.commons.user.SessionUser;
|
||||||
import io.metersphere.commons.utils.LogUtil;
|
|
||||||
import io.metersphere.commons.utils.SessionUtils;
|
import io.metersphere.commons.utils.SessionUtils;
|
||||||
import io.metersphere.controller.request.IntegrationRequest;
|
import io.metersphere.controller.request.IntegrationRequest;
|
||||||
import io.metersphere.notice.domain.MessageDetail;
|
import io.metersphere.i18n.Translator;
|
||||||
import io.metersphere.notice.domain.MessageSettingDetail;
|
import io.metersphere.notice.sender.NoticeModel;
|
||||||
import io.metersphere.notice.service.DingTaskService;
|
import io.metersphere.notice.service.NoticeSendService;
|
||||||
import io.metersphere.notice.service.MailService;
|
|
||||||
import io.metersphere.notice.service.NoticeService;
|
|
||||||
import io.metersphere.notice.service.WxChatTaskService;
|
|
||||||
import io.metersphere.service.IntegrationService;
|
import io.metersphere.service.IntegrationService;
|
||||||
import io.metersphere.service.ProjectService;
|
import io.metersphere.service.ProjectService;
|
||||||
import io.metersphere.track.issue.*;
|
import io.metersphere.track.issue.*;
|
||||||
|
@ -27,7 +23,9 @@ import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
@Transactional(rollbackFor = Exception.class)
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
@ -42,13 +40,7 @@ public class IssuesService {
|
||||||
@Resource
|
@Resource
|
||||||
private IssuesMapper issuesMapper;
|
private IssuesMapper issuesMapper;
|
||||||
@Resource
|
@Resource
|
||||||
MailService mailService;
|
private NoticeSendService noticeSendService;
|
||||||
@Resource
|
|
||||||
DingTaskService dingTaskService;
|
|
||||||
@Resource
|
|
||||||
WxChatTaskService wxChatTaskService;
|
|
||||||
@Resource
|
|
||||||
NoticeService noticeService;
|
|
||||||
|
|
||||||
public void testAuth(String platform) {
|
public void testAuth(String platform) {
|
||||||
AbstractIssuePlatform abstractPlatform = IssueFactory.createPlatform(platform, new IssuesRequest());
|
AbstractIssuePlatform abstractPlatform = IssueFactory.createPlatform(platform, new IssuesRequest());
|
||||||
|
@ -98,27 +90,18 @@ public class IssuesService {
|
||||||
});
|
});
|
||||||
List<String> userIds = new ArrayList<>();
|
List<String> userIds = new ArrayList<>();
|
||||||
userIds.add(orgId);
|
userIds.add(orgId);
|
||||||
try {
|
String context = getIssuesContext(user, issuesRequest, NoticeConstants.Event.CREATE);
|
||||||
String context = getIssuesContext(user, issuesRequest, NoticeConstants.CREATE);
|
Map<String, Object> paramMap = new HashMap<>();
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
paramMap.put("issuesName", issuesRequest.getTitle());
|
||||||
List<MessageDetail> taskList = messageSettingDetail.getDefectTask();
|
paramMap.put("creator", user.getName());
|
||||||
taskList.forEach(r -> {
|
NoticeModel noticeModel = NoticeModel.builder()
|
||||||
switch (r.getType()) {
|
.context(context)
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
.relatedUsers(userIds)
|
||||||
dingTaskService.sendNailRobot(r, userIds, context, NoticeConstants.CREATE);
|
.subject(Translator.get("task_defect_notification"))
|
||||||
break;
|
.mailTemplate("IssuesCreate")
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
.paramMap(paramMap)
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, context, NoticeConstants.CREATE);
|
.build();
|
||||||
break;
|
noticeSendService.send(NoticeConstants.TaskType.DEFECT_TASK, noticeModel);
|
||||||
case NoticeConstants.EMAIL:
|
|
||||||
mailService.sendIssuesNotice(r, userIds, issuesRequest, NoticeConstants.CREATE, user);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<Issues> getIssues(String caseId) {
|
public List<Issues> getIssues(String caseId) {
|
||||||
|
@ -222,7 +205,7 @@ public class IssuesService {
|
||||||
|
|
||||||
private static String getIssuesContext(SessionUser user, IssuesRequest issuesRequest, String type) {
|
private static String getIssuesContext(SessionUser user, IssuesRequest issuesRequest, String type) {
|
||||||
String context = "";
|
String context = "";
|
||||||
if (StringUtils.equals(NoticeConstants.CREATE, type)) {
|
if (StringUtils.equals(NoticeConstants.Event.CREATE, type)) {
|
||||||
context = "缺陷任务通知:" + user.getName() + "发起了一个缺陷" + "'" + issuesRequest.getTitle() + "'" + "请跟进";
|
context = "缺陷任务通知:" + user.getName() + "发起了一个缺陷" + "'" + issuesRequest.getTitle() + "'" + "请跟进";
|
||||||
}
|
}
|
||||||
return context;
|
return context;
|
||||||
|
|
|
@ -10,15 +10,12 @@ import io.metersphere.base.mapper.UserMapper;
|
||||||
import io.metersphere.base.mapper.ext.ExtTestCaseCommentMapper;
|
import io.metersphere.base.mapper.ext.ExtTestCaseCommentMapper;
|
||||||
import io.metersphere.commons.constants.NoticeConstants;
|
import io.metersphere.commons.constants.NoticeConstants;
|
||||||
import io.metersphere.commons.exception.MSException;
|
import io.metersphere.commons.exception.MSException;
|
||||||
import io.metersphere.commons.utils.LogUtil;
|
|
||||||
import io.metersphere.commons.utils.SessionUtils;
|
import io.metersphere.commons.utils.SessionUtils;
|
||||||
|
import io.metersphere.dto.BaseSystemConfigDTO;
|
||||||
import io.metersphere.i18n.Translator;
|
import io.metersphere.i18n.Translator;
|
||||||
import io.metersphere.notice.domain.MessageDetail;
|
import io.metersphere.notice.sender.NoticeModel;
|
||||||
import io.metersphere.notice.domain.MessageSettingDetail;
|
import io.metersphere.notice.service.NoticeSendService;
|
||||||
import io.metersphere.notice.service.DingTaskService;
|
import io.metersphere.service.SystemParameterService;
|
||||||
import io.metersphere.notice.service.MailService;
|
|
||||||
import io.metersphere.notice.service.NoticeService;
|
|
||||||
import io.metersphere.notice.service.WxChatTaskService;
|
|
||||||
import io.metersphere.track.dto.TestCaseCommentDTO;
|
import io.metersphere.track.dto.TestCaseCommentDTO;
|
||||||
import io.metersphere.track.request.testreview.SaveCommentRequest;
|
import io.metersphere.track.request.testreview.SaveCommentRequest;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
@ -27,10 +24,7 @@ import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.ArrayList;
|
import java.util.*;
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
@Transactional(rollbackFor = Exception.class)
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
@ -39,19 +33,15 @@ public class TestCaseCommentService {
|
||||||
@Resource
|
@Resource
|
||||||
private TestCaseCommentMapper testCaseCommentMapper;
|
private TestCaseCommentMapper testCaseCommentMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private MailService mailService;
|
|
||||||
@Resource
|
|
||||||
private TestCaseMapper testCaseMapper;
|
private TestCaseMapper testCaseMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private DingTaskService dingTaskService;
|
|
||||||
@Resource
|
|
||||||
private WxChatTaskService wxChatTaskService;
|
|
||||||
@Resource
|
|
||||||
private NoticeService noticeService;
|
|
||||||
@Resource
|
|
||||||
private ExtTestCaseCommentMapper extTestCaseCommentMapper;
|
private ExtTestCaseCommentMapper extTestCaseCommentMapper;
|
||||||
@Resource
|
@Resource
|
||||||
private UserMapper userMapper;
|
private UserMapper userMapper;
|
||||||
|
@Resource
|
||||||
|
private NoticeSendService noticeSendService;
|
||||||
|
@Resource
|
||||||
|
private SystemParameterService systemParameterService;
|
||||||
|
|
||||||
public void saveComment(SaveCommentRequest request) {
|
public void saveComment(SaveCommentRequest request) {
|
||||||
TestCaseComment testCaseComment = new TestCaseComment();
|
TestCaseComment testCaseComment = new TestCaseComment();
|
||||||
|
@ -64,29 +54,27 @@ public class TestCaseCommentService {
|
||||||
testCaseCommentMapper.insert(testCaseComment);
|
testCaseCommentMapper.insert(testCaseComment);
|
||||||
TestCaseWithBLOBs testCaseWithBLOBs;
|
TestCaseWithBLOBs testCaseWithBLOBs;
|
||||||
testCaseWithBLOBs = testCaseMapper.selectByPrimaryKey(request.getCaseId());
|
testCaseWithBLOBs = testCaseMapper.selectByPrimaryKey(request.getCaseId());
|
||||||
|
|
||||||
|
// 发送通知
|
||||||
|
User user = userMapper.selectByPrimaryKey(testCaseWithBLOBs.getMaintainer());
|
||||||
|
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
||||||
List<String> userIds = new ArrayList<>();
|
List<String> userIds = new ArrayList<>();
|
||||||
userIds.add(testCaseWithBLOBs.getMaintainer());//用例维护人
|
userIds.add(testCaseWithBLOBs.getMaintainer());//用例维护人
|
||||||
try {
|
|
||||||
String context = getReviewContext(testCaseComment, testCaseWithBLOBs);
|
String context = getReviewContext(testCaseComment, testCaseWithBLOBs);
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
Map<String, Object> paramMap = new HashMap<>();
|
||||||
List<MessageDetail> taskList = messageSettingDetail.getReviewTask();
|
paramMap.put("maintainer", user.getName());
|
||||||
taskList.forEach(r -> {
|
paramMap.put("testCaseName", testCaseWithBLOBs.getName());
|
||||||
switch (r.getType()) {
|
paramMap.put("description", request.getDescription());
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
paramMap.put("url", baseSystemConfigDTO.getUrl());
|
||||||
dingTaskService.sendNailRobot(r, userIds, context, NoticeConstants.COMMENT);
|
paramMap.put("id", request.getReviewId());
|
||||||
break;
|
NoticeModel noticeModel = NoticeModel.builder()
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
.context(context)
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, context, NoticeConstants.COMMENT);
|
.relatedUsers(userIds)
|
||||||
break;
|
.subject(Translator.get("test_review_task_notice"))
|
||||||
case NoticeConstants.EMAIL:
|
.mailTemplate("ReviewComments")
|
||||||
mailService.sendCommentNotice(r, userIds, request, testCaseWithBLOBs, NoticeConstants.COMMENT);
|
.paramMap(paramMap)
|
||||||
break;
|
.build();
|
||||||
}
|
noticeSendService.send(NoticeConstants.TaskType.REVIEW_TASK, noticeModel);
|
||||||
});
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<TestCaseCommentDTO> getCaseComments(String caseId) {
|
public List<TestCaseCommentDTO> getCaseComments(String caseId) {
|
||||||
|
|
|
@ -16,12 +16,11 @@ import io.metersphere.commons.utils.LogUtil;
|
||||||
import io.metersphere.commons.utils.ServiceUtils;
|
import io.metersphere.commons.utils.ServiceUtils;
|
||||||
import io.metersphere.commons.utils.SessionUtils;
|
import io.metersphere.commons.utils.SessionUtils;
|
||||||
import io.metersphere.controller.request.member.QueryMemberRequest;
|
import io.metersphere.controller.request.member.QueryMemberRequest;
|
||||||
import io.metersphere.notice.domain.MessageDetail;
|
import io.metersphere.dto.BaseSystemConfigDTO;
|
||||||
import io.metersphere.notice.domain.MessageSettingDetail;
|
import io.metersphere.i18n.Translator;
|
||||||
import io.metersphere.notice.service.DingTaskService;
|
import io.metersphere.notice.sender.NoticeModel;
|
||||||
import io.metersphere.notice.service.MailService;
|
import io.metersphere.notice.service.NoticeSendService;
|
||||||
import io.metersphere.notice.service.NoticeService;
|
import io.metersphere.service.SystemParameterService;
|
||||||
import io.metersphere.notice.service.WxChatTaskService;
|
|
||||||
import io.metersphere.service.UserService;
|
import io.metersphere.service.UserService;
|
||||||
import io.metersphere.track.dto.TestCaseReviewDTO;
|
import io.metersphere.track.dto.TestCaseReviewDTO;
|
||||||
import io.metersphere.track.dto.TestReviewCaseDTO;
|
import io.metersphere.track.dto.TestReviewCaseDTO;
|
||||||
|
@ -75,14 +74,9 @@ public class TestCaseReviewService {
|
||||||
@Resource
|
@Resource
|
||||||
ExtTestCaseMapper extTestCaseMapper;
|
ExtTestCaseMapper extTestCaseMapper;
|
||||||
@Resource
|
@Resource
|
||||||
NoticeService noticeService;
|
private NoticeSendService noticeSendService;
|
||||||
@Resource
|
@Resource
|
||||||
MailService mailService;
|
private SystemParameterService systemParameterService;
|
||||||
@Resource
|
|
||||||
DingTaskService dingTaskService;
|
|
||||||
@Resource
|
|
||||||
WxChatTaskService wxChatTaskService;
|
|
||||||
|
|
||||||
|
|
||||||
public void saveTestCaseReview(SaveTestCaseReviewRequest reviewRequest) {
|
public void saveTestCaseReview(SaveTestCaseReviewRequest reviewRequest) {
|
||||||
checkCaseReviewExist(reviewRequest);
|
checkCaseReviewExist(reviewRequest);
|
||||||
|
@ -109,27 +103,54 @@ public class TestCaseReviewService {
|
||||||
reviewRequest.setCreator(SessionUtils.getUser().getId());//创建人
|
reviewRequest.setCreator(SessionUtils.getUser().getId());//创建人
|
||||||
reviewRequest.setStatus(TestCaseReviewStatus.Prepare.name());
|
reviewRequest.setStatus(TestCaseReviewStatus.Prepare.name());
|
||||||
testCaseReviewMapper.insert(reviewRequest);
|
testCaseReviewMapper.insert(reviewRequest);
|
||||||
try {
|
// 发送通知
|
||||||
String context = getReviewContext(reviewRequest, NoticeConstants.CREATE);
|
String context = getReviewContext(reviewRequest, NoticeConstants.Event.CREATE);
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
Map<String, Object> paramMap = new HashMap<>(getReviewParamMap(reviewRequest));
|
||||||
List<MessageDetail> taskList = messageSettingDetail.getReviewTask();
|
NoticeModel noticeModel = NoticeModel.builder()
|
||||||
taskList.forEach(r -> {
|
.context(context)
|
||||||
switch (r.getType()) {
|
.relatedUsers(userIds)
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
.subject(Translator.get("test_review_task_notice"))
|
||||||
dingTaskService.sendNailRobot(r, userIds, context, NoticeConstants.CREATE);
|
.mailTemplate("ReviewInitiate")
|
||||||
break;
|
.paramMap(paramMap)
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
.build();
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, context, NoticeConstants.CREATE);
|
noticeSendService.send(NoticeConstants.TaskType.REVIEW_TASK, noticeModel);
|
||||||
break;
|
|
||||||
case NoticeConstants.EMAIL:
|
|
||||||
mailService.sendReviewerNotice(r, userIds, reviewRequest, NoticeConstants.CREATE);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//评审内容
|
||||||
|
private Map<String, String> getReviewParamMap(SaveTestCaseReviewRequest reviewRequest) {
|
||||||
|
Long startTime = reviewRequest.getCreateTime();
|
||||||
|
Long endTime = reviewRequest.getEndTime();
|
||||||
|
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
|
||||||
|
String start = null;
|
||||||
|
String sTime = String.valueOf(startTime);
|
||||||
|
String eTime = String.valueOf(endTime);
|
||||||
|
if (!sTime.equals("null")) {
|
||||||
|
start = sdf.format(new Date(Long.parseLong(sTime)));
|
||||||
|
}
|
||||||
|
String end = null;
|
||||||
|
if (!eTime.equals("null")) {
|
||||||
|
end = sdf.format(new Date(Long.parseLong(eTime)));
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, String> paramMap = new HashMap<>();
|
||||||
|
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
||||||
|
paramMap.put("url", baseSystemConfigDTO.getUrl());
|
||||||
|
User user = userMapper.selectByPrimaryKey(reviewRequest.getCreator());
|
||||||
|
paramMap.put("creator", user.getName());
|
||||||
|
paramMap.put("reviewName", reviewRequest.getName());
|
||||||
|
paramMap.put("start", start);
|
||||||
|
paramMap.put("end", end);
|
||||||
|
paramMap.put("id", reviewRequest.getId());
|
||||||
|
String status = "";
|
||||||
|
if (StringUtils.equals(TestPlanStatus.Underway.name(), reviewRequest.getStatus())) {
|
||||||
|
status = "进行中";
|
||||||
|
} else if (StringUtils.equals(TestPlanStatus.Prepare.name(), reviewRequest.getStatus())) {
|
||||||
|
status = "未开始";
|
||||||
|
} else if (StringUtils.equals(TestPlanStatus.Completed.name(), reviewRequest.getStatus())) {
|
||||||
|
status = "已完成";
|
||||||
|
}
|
||||||
|
paramMap.put("status", status);
|
||||||
|
return paramMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<TestCaseReviewDTO> listCaseReview(QueryCaseReviewRequest request) {
|
public List<TestCaseReviewDTO> listCaseReview(QueryCaseReviewRequest request) {
|
||||||
|
@ -185,29 +206,18 @@ public class TestCaseReviewService {
|
||||||
testCaseReview.setUpdateTime(System.currentTimeMillis());
|
testCaseReview.setUpdateTime(System.currentTimeMillis());
|
||||||
checkCaseReviewExist(testCaseReview);
|
checkCaseReviewExist(testCaseReview);
|
||||||
testCaseReviewMapper.updateByPrimaryKeySelective(testCaseReview);
|
testCaseReviewMapper.updateByPrimaryKeySelective(testCaseReview);
|
||||||
List<String> userIds = new ArrayList<>();
|
// 发送通知
|
||||||
userIds.addAll(testCaseReview.getUserIds());
|
List<String> userIds = new ArrayList<>(testCaseReview.getUserIds());
|
||||||
try {
|
String context = getReviewContext(testCaseReview, NoticeConstants.Event.UPDATE);
|
||||||
String context = getReviewContext(testCaseReview, NoticeConstants.UPDATE);
|
Map<String, Object> paramMap = new HashMap<>(getReviewParamMap(testCaseReview));
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
NoticeModel noticeModel = NoticeModel.builder()
|
||||||
List<MessageDetail> taskList = messageSettingDetail.getReviewTask();
|
.context(context)
|
||||||
taskList.forEach(r -> {
|
.relatedUsers(userIds)
|
||||||
switch (r.getType()) {
|
.subject(Translator.get("test_review_task_notice"))
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
.mailTemplate("ReviewEnd")
|
||||||
dingTaskService.sendNailRobot(r, userIds, context, NoticeConstants.UPDATE);
|
.paramMap(paramMap)
|
||||||
break;
|
.build();
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
noticeSendService.send(NoticeConstants.TaskType.REVIEW_TASK, noticeModel);
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, context, NoticeConstants.UPDATE);
|
|
||||||
break;
|
|
||||||
case NoticeConstants.EMAIL:
|
|
||||||
mailService.sendEndNotice(r, userIds, testCaseReview, NoticeConstants.UPDATE);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void editCaseReviewer(SaveTestCaseReviewRequest testCaseReview) {
|
private void editCaseReviewer(SaveTestCaseReviewRequest testCaseReview) {
|
||||||
|
@ -294,31 +304,25 @@ public class TestCaseReviewService {
|
||||||
deleteCaseReviewUsers(reviewId);
|
deleteCaseReviewUsers(reviewId);
|
||||||
deleteCaseReviewTestCase(reviewId);
|
deleteCaseReviewTestCase(reviewId);
|
||||||
testCaseReviewMapper.deleteByPrimaryKey(reviewId);
|
testCaseReviewMapper.deleteByPrimaryKey(reviewId);
|
||||||
|
// 发送通知
|
||||||
|
try {
|
||||||
List<String> userIds = new ArrayList<>();
|
List<String> userIds = new ArrayList<>();
|
||||||
userIds.add(SessionUtils.getUser().getId());
|
userIds.add(SessionUtils.getUser().getId());
|
||||||
SaveTestCaseReviewRequest testCaseReviewRequest = new SaveTestCaseReviewRequest();
|
SaveTestCaseReviewRequest testCaseReviewRequest = new SaveTestCaseReviewRequest();
|
||||||
try {
|
|
||||||
BeanUtils.copyProperties(testCaseReviewRequest, testCaseReview);
|
BeanUtils.copyProperties(testCaseReviewRequest, testCaseReview);
|
||||||
String context = getReviewContext(testCaseReviewRequest, NoticeConstants.DELETE);
|
String context = getReviewContext(testCaseReviewRequest, NoticeConstants.Event.DELETE);
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
Map<String, Object> paramMap = new HashMap<>(getReviewParamMap(testCaseReviewRequest));
|
||||||
List<MessageDetail> taskList = messageSettingDetail.getReviewTask();
|
NoticeModel noticeModel = NoticeModel.builder()
|
||||||
taskList.forEach(r -> {
|
.context(context)
|
||||||
switch (r.getType()) {
|
.relatedUsers(userIds)
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
.subject(Translator.get("test_review_task_notice"))
|
||||||
dingTaskService.sendNailRobot(r, userIds, context, NoticeConstants.DELETE);
|
.mailTemplate("ReviewDelete")
|
||||||
break;
|
.paramMap(paramMap)
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
.build();
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, context, NoticeConstants.DELETE);
|
noticeSendService.send(NoticeConstants.TaskType.REVIEW_TASK, noticeModel);
|
||||||
break;
|
|
||||||
case NoticeConstants.EMAIL:
|
|
||||||
mailService.sendDeleteNotice(r, userIds, testCaseReviewRequest, NoticeConstants.DELETE);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LogUtil.error(e.getMessage(), e);
|
LogUtil.error(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void deleteCaseReviewProject(String reviewId) {
|
private void deleteCaseReviewProject(String reviewId) {
|
||||||
|
@ -446,25 +450,18 @@ public class TestCaseReviewService {
|
||||||
List<String> userIds = new ArrayList<>();
|
List<String> userIds = new ArrayList<>();
|
||||||
userIds.add(_testCaseReview.getCreator());
|
userIds.add(_testCaseReview.getCreator());
|
||||||
if (StringUtils.equals(TestCaseReviewStatus.Completed.name(), _testCaseReview.getStatus())) {
|
if (StringUtils.equals(TestCaseReviewStatus.Completed.name(), _testCaseReview.getStatus())) {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
BeanUtils.copyProperties(testCaseReviewRequest, _testCaseReview);
|
BeanUtils.copyProperties(testCaseReviewRequest, _testCaseReview);
|
||||||
String context = getReviewContext(testCaseReviewRequest, NoticeConstants.UPDATE);
|
String context = getReviewContext(testCaseReviewRequest, NoticeConstants.Event.UPDATE);
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
Map<String, Object> paramMap = new HashMap<>(getReviewParamMap(testCaseReviewRequest));
|
||||||
List<MessageDetail> taskList = messageSettingDetail.getReviewTask();
|
NoticeModel noticeModel = NoticeModel.builder()
|
||||||
taskList.forEach(r -> {
|
.context(context)
|
||||||
switch (r.getType()) {
|
.relatedUsers(userIds)
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
.subject(Translator.get("test_review_task_notice"))
|
||||||
dingTaskService.sendNailRobot(r, userIds, context, NoticeConstants.UPDATE);
|
.mailTemplate("ReviewEnd")
|
||||||
break;
|
.paramMap(paramMap)
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
.build();
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, context, NoticeConstants.UPDATE);
|
noticeSendService.send(NoticeConstants.TaskType.REVIEW_TASK, noticeModel);
|
||||||
break;
|
|
||||||
case NoticeConstants.EMAIL:
|
|
||||||
mailService.sendEndNotice(r, userIds, testCaseReviewRequest, NoticeConstants.UPDATE);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LogUtil.error(e.getMessage(), e);
|
LogUtil.error(e.getMessage(), e);
|
||||||
}
|
}
|
||||||
|
@ -580,9 +577,9 @@ public class TestCaseReviewService {
|
||||||
start = "未设置";
|
start = "未设置";
|
||||||
}
|
}
|
||||||
String context = "";
|
String context = "";
|
||||||
if (StringUtils.equals(NoticeConstants.CREATE, type)) {
|
if (StringUtils.equals(NoticeConstants.Event.CREATE, type)) {
|
||||||
context = "测试评审任务通知:" + user.getName() + "发起的" + "'" + reviewRequest.getName() + "'" + "待开始,计划开始时间是" + start + "计划结束时间为" + end + "请跟进";
|
context = "测试评审任务通知:" + user.getName() + "发起的" + "'" + reviewRequest.getName() + "'" + "待开始,计划开始时间是" + start + "计划结束时间为" + end + "请跟进";
|
||||||
} else if (StringUtils.equals(NoticeConstants.UPDATE, type)) {
|
} else if (StringUtils.equals(NoticeConstants.Event.UPDATE, type)) {
|
||||||
String status = "";
|
String status = "";
|
||||||
if (StringUtils.equals(TestPlanStatus.Underway.name(), reviewRequest.getStatus())) {
|
if (StringUtils.equals(TestPlanStatus.Underway.name(), reviewRequest.getStatus())) {
|
||||||
status = "进行中";
|
status = "进行中";
|
||||||
|
@ -592,7 +589,7 @@ public class TestCaseReviewService {
|
||||||
status = "已完成";
|
status = "已完成";
|
||||||
}
|
}
|
||||||
context = "测试评审任务通知:" + user.getName() + "发起的" + "'" + reviewRequest.getName() + "'" + "计划开始时间是" + start + "计划结束时间为" + end + status;
|
context = "测试评审任务通知:" + user.getName() + "发起的" + "'" + reviewRequest.getName() + "'" + "计划开始时间是" + start + "计划结束时间为" + end + status;
|
||||||
} else if (StringUtils.equals(NoticeConstants.DELETE, type)) {
|
} else if (StringUtils.equals(NoticeConstants.Event.DELETE, type)) {
|
||||||
context = "测试评审任务通知:" + user.getName() + "发起的" + "'" + reviewRequest.getName() + "'" + "计划开始时间是" + start + "计划结束时间为" + end + "已删除";
|
context = "测试评审任务通知:" + user.getName() + "发起的" + "'" + reviewRequest.getName() + "'" + "计划开始时间是" + start + "计划结束时间为" + end + "已删除";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -15,13 +15,11 @@ import io.metersphere.commons.constants.TestPlanTestCaseStatus;
|
||||||
import io.metersphere.commons.exception.MSException;
|
import io.metersphere.commons.exception.MSException;
|
||||||
import io.metersphere.commons.user.SessionUser;
|
import io.metersphere.commons.user.SessionUser;
|
||||||
import io.metersphere.commons.utils.*;
|
import io.metersphere.commons.utils.*;
|
||||||
|
import io.metersphere.dto.BaseSystemConfigDTO;
|
||||||
import io.metersphere.i18n.Translator;
|
import io.metersphere.i18n.Translator;
|
||||||
import io.metersphere.notice.domain.MessageDetail;
|
import io.metersphere.notice.sender.NoticeModel;
|
||||||
import io.metersphere.notice.domain.MessageSettingDetail;
|
import io.metersphere.notice.service.NoticeSendService;
|
||||||
import io.metersphere.notice.service.DingTaskService;
|
import io.metersphere.service.SystemParameterService;
|
||||||
import io.metersphere.notice.service.MailService;
|
|
||||||
import io.metersphere.notice.service.NoticeService;
|
|
||||||
import io.metersphere.notice.service.WxChatTaskService;
|
|
||||||
import io.metersphere.track.Factory.ReportComponentFactory;
|
import io.metersphere.track.Factory.ReportComponentFactory;
|
||||||
import io.metersphere.track.domain.ReportComponent;
|
import io.metersphere.track.domain.ReportComponent;
|
||||||
import io.metersphere.track.dto.TestCaseReportMetricDTO;
|
import io.metersphere.track.dto.TestCaseReportMetricDTO;
|
||||||
|
@ -51,32 +49,23 @@ import java.util.stream.Collectors;
|
||||||
public class TestPlanService {
|
public class TestPlanService {
|
||||||
@Resource
|
@Resource
|
||||||
TestPlanMapper testPlanMapper;
|
TestPlanMapper testPlanMapper;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
ExtTestPlanMapper extTestPlanMapper;
|
ExtTestPlanMapper extTestPlanMapper;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
ExtTestPlanTestCaseMapper extTestPlanTestCaseMapper;
|
ExtTestPlanTestCaseMapper extTestPlanTestCaseMapper;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
TestCaseMapper testCaseMapper;
|
TestCaseMapper testCaseMapper;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
TestPlanTestCaseMapper testPlanTestCaseMapper;
|
TestPlanTestCaseMapper testPlanTestCaseMapper;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
SqlSessionFactory sqlSessionFactory;
|
SqlSessionFactory sqlSessionFactory;
|
||||||
|
|
||||||
@Lazy
|
@Lazy
|
||||||
@Resource
|
@Resource
|
||||||
TestPlanTestCaseService testPlanTestCaseService;
|
TestPlanTestCaseService testPlanTestCaseService;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
ExtProjectMapper extProjectMapper;
|
ExtProjectMapper extProjectMapper;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
TestCaseReportMapper testCaseReportMapper;
|
TestCaseReportMapper testCaseReportMapper;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
TestPlanProjectMapper testPlanProjectMapper;
|
TestPlanProjectMapper testPlanProjectMapper;
|
||||||
@Resource
|
@Resource
|
||||||
|
@ -86,15 +75,11 @@ public class TestPlanService {
|
||||||
@Resource
|
@Resource
|
||||||
ExtTestCaseMapper extTestCaseMapper;
|
ExtTestCaseMapper extTestCaseMapper;
|
||||||
@Resource
|
@Resource
|
||||||
NoticeService noticeService;
|
|
||||||
@Resource
|
|
||||||
MailService mailService;
|
|
||||||
@Resource
|
|
||||||
DingTaskService dingTaskService;
|
|
||||||
@Resource
|
|
||||||
WxChatTaskService wxChatTaskService;
|
|
||||||
@Resource
|
|
||||||
UserMapper userMapper;
|
UserMapper userMapper;
|
||||||
|
@Resource
|
||||||
|
private NoticeSendService noticeSendService;
|
||||||
|
@Resource
|
||||||
|
private SystemParameterService systemParameterService;
|
||||||
|
|
||||||
public synchronized void addTestPlan(AddTestPlanRequest testPlan) {
|
public synchronized void addTestPlan(AddTestPlanRequest testPlan) {
|
||||||
if (getTestPlanByName(testPlan.getName()).size() > 0) {
|
if (getTestPlanByName(testPlan.getName()).size() > 0) {
|
||||||
|
@ -117,28 +102,21 @@ public class TestPlanService {
|
||||||
testPlan.setUpdateTime(System.currentTimeMillis());
|
testPlan.setUpdateTime(System.currentTimeMillis());
|
||||||
testPlan.setCreator(SessionUtils.getUser().getId());
|
testPlan.setCreator(SessionUtils.getUser().getId());
|
||||||
testPlanMapper.insert(testPlan);
|
testPlanMapper.insert(testPlan);
|
||||||
|
|
||||||
List<String> userIds = new ArrayList<>();
|
List<String> userIds = new ArrayList<>();
|
||||||
userIds.add(testPlan.getPrincipal());
|
userIds.add(testPlan.getPrincipal());
|
||||||
try {
|
String context = getTestPlanContext(testPlan, NoticeConstants.Event.CREATE);
|
||||||
String context = getTestPlanContext(testPlan, NoticeConstants.CREATE);
|
User user = userMapper.selectByPrimaryKey(testPlan.getCreator());
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
Map<String, Object> paramMap = getTestPlanParamMap(testPlan);
|
||||||
List<MessageDetail> taskList = messageSettingDetail.getTestCasePlanTask();
|
paramMap.put("creator", user.getName());
|
||||||
taskList.forEach(r -> {
|
NoticeModel noticeModel = NoticeModel.builder()
|
||||||
switch (r.getType()) {
|
.context(context)
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
.relatedUsers(userIds)
|
||||||
dingTaskService.sendNailRobot(r, userIds, context, NoticeConstants.CREATE);
|
.subject(Translator.get("test_plan_notification"))
|
||||||
break;
|
.mailTemplate("TestPlanStart")
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
.paramMap(paramMap)
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, context, NoticeConstants.CREATE);
|
.build();
|
||||||
break;
|
noticeSendService.send(NoticeConstants.TaskType.TEST_PLAN_TASK, noticeModel);
|
||||||
case NoticeConstants.EMAIL:
|
|
||||||
mailService.sendTestPlanStartNotice(r, userIds, testPlan, NoticeConstants.CREATE);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<TestPlan> getTestPlanByName(String name) {
|
public List<TestPlan> getTestPlanByName(String name) {
|
||||||
|
@ -169,27 +147,19 @@ public class TestPlanService {
|
||||||
AddTestPlanRequest testPlans = new AddTestPlanRequest();
|
AddTestPlanRequest testPlans = new AddTestPlanRequest();
|
||||||
int i = testPlanMapper.updateByPrimaryKeySelective(testPlan);
|
int i = testPlanMapper.updateByPrimaryKeySelective(testPlan);
|
||||||
if (!StringUtils.isBlank(testPlan.getStatus())) {
|
if (!StringUtils.isBlank(testPlan.getStatus())) {
|
||||||
try {
|
|
||||||
BeanUtils.copyBean(testPlans, getTestPlan(testPlan.getId()));
|
BeanUtils.copyBean(testPlans, getTestPlan(testPlan.getId()));
|
||||||
String context = getTestPlanContext(testPlans, NoticeConstants.UPDATE);
|
String context = getTestPlanContext(testPlans, NoticeConstants.Event.UPDATE);
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
User user = userMapper.selectByPrimaryKey(testPlan.getCreator());
|
||||||
List<MessageDetail> taskList = messageSettingDetail.getTestCasePlanTask();
|
Map<String, Object> paramMap = getTestPlanParamMap(testPlan);
|
||||||
taskList.forEach(r -> {
|
paramMap.put("creator", user.getName());
|
||||||
switch (r.getType()) {
|
NoticeModel noticeModel = NoticeModel.builder()
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
.context(context)
|
||||||
dingTaskService.sendNailRobot(r, userIds, context, NoticeConstants.UPDATE);
|
.relatedUsers(userIds)
|
||||||
break;
|
.subject(Translator.get("test_plan_notification"))
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
.mailTemplate("TestPlanEnd")
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, context, NoticeConstants.UPDATE);
|
.paramMap(paramMap)
|
||||||
break;
|
.build();
|
||||||
case NoticeConstants.EMAIL:
|
noticeSendService.send(NoticeConstants.TaskType.TEST_PLAN_TASK, noticeModel);
|
||||||
mailService.sendTestPlanEndNotice(r, userIds, testPlans, NoticeConstants.UPDATE);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} catch (Exception e) {
|
|
||||||
LogUtil.error(e.getMessage(), e);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
@ -232,6 +202,44 @@ public class TestPlanService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//计划内容
|
||||||
|
private Map<String, Object> getTestPlanParamMap(TestPlan testPlan) {
|
||||||
|
Long startTime = testPlan.getPlannedStartTime();
|
||||||
|
Long endTime = testPlan.getPlannedEndTime();
|
||||||
|
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
|
||||||
|
String start = null;
|
||||||
|
String sTime = String.valueOf(startTime);
|
||||||
|
String eTime = String.valueOf(endTime);
|
||||||
|
if (!sTime.equals("null")) {
|
||||||
|
start = sdf.format(new Date(Long.parseLong(sTime)));
|
||||||
|
}
|
||||||
|
String end = null;
|
||||||
|
if (!eTime.equals("null")) {
|
||||||
|
end = sdf.format(new Date(Long.parseLong(eTime)));
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, Object> context = new HashMap<>();
|
||||||
|
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
|
||||||
|
context.put("url", baseSystemConfigDTO.getUrl());
|
||||||
|
context.put("testPlanName", testPlan.getName());
|
||||||
|
context.put("start", start);
|
||||||
|
context.put("end", end);
|
||||||
|
context.put("id", testPlan.getId());
|
||||||
|
String status = "";
|
||||||
|
if (StringUtils.equals(TestPlanStatus.Underway.name(), testPlan.getStatus())) {
|
||||||
|
status = "进行中";
|
||||||
|
} else if (StringUtils.equals(TestPlanStatus.Prepare.name(), testPlan.getStatus())) {
|
||||||
|
status = "未开始";
|
||||||
|
} else if (StringUtils.equals(TestPlanStatus.Completed.name(), testPlan.getStatus())) {
|
||||||
|
status = "已完成";
|
||||||
|
}
|
||||||
|
context.put("status", status);
|
||||||
|
User user = userMapper.selectByPrimaryKey(testPlan.getCreator());
|
||||||
|
context.put("creator", user.getName());
|
||||||
|
return context;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
private void checkTestPlanExist(TestPlan testPlan) {
|
private void checkTestPlanExist(TestPlan testPlan) {
|
||||||
if (testPlan.getName() != null) {
|
if (testPlan.getName() != null) {
|
||||||
TestPlanExample example = new TestPlanExample();
|
TestPlanExample example = new TestPlanExample();
|
||||||
|
@ -255,22 +263,18 @@ public class TestPlanService {
|
||||||
userIds.add(testPlan.getCreator());
|
userIds.add(testPlan.getCreator());
|
||||||
try {
|
try {
|
||||||
BeanUtils.copyBean(testPlans, testPlan);
|
BeanUtils.copyBean(testPlans, testPlan);
|
||||||
String context = getTestPlanContext(testPlans, NoticeConstants.DELETE);
|
String context = getTestPlanContext(testPlans, NoticeConstants.Event.DELETE);
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
User user = userMapper.selectByPrimaryKey(testPlan.getCreator());
|
||||||
List<MessageDetail> taskList = messageSettingDetail.getTestCasePlanTask();
|
Map<String, Object> paramMap = getTestPlanParamMap(testPlan);
|
||||||
taskList.forEach(r -> {
|
paramMap.put("creator", user.getName());
|
||||||
switch (r.getType()) {
|
NoticeModel noticeModel = NoticeModel.builder()
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
.context(context)
|
||||||
dingTaskService.sendNailRobot(r, userIds, context, NoticeConstants.DELETE);
|
.relatedUsers(userIds)
|
||||||
break;
|
.subject(Translator.get("test_plan_notification"))
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
.mailTemplate("TestPlanDelete")
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, context, NoticeConstants.DELETE);
|
.paramMap(paramMap)
|
||||||
break;
|
.build();
|
||||||
case NoticeConstants.EMAIL:
|
noticeSendService.send(NoticeConstants.TaskType.TEST_PLAN_TASK, noticeModel);
|
||||||
mailService.sendTestPlanDeleteNotice(r, userIds, testPlans, NoticeConstants.DELETE);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LogUtil.error(e.getMessage(), e);
|
LogUtil.error(e.getMessage(), e);
|
||||||
}
|
}
|
||||||
|
@ -496,22 +500,18 @@ public class TestPlanService {
|
||||||
if (StringUtils.equals(TestPlanStatus.Completed.name(), testPlans.getStatus())) {
|
if (StringUtils.equals(TestPlanStatus.Completed.name(), testPlans.getStatus())) {
|
||||||
try {
|
try {
|
||||||
BeanUtils.copyBean(_testPlans, testPlans);
|
BeanUtils.copyBean(_testPlans, testPlans);
|
||||||
String context = getTestPlanContext(_testPlans, NoticeConstants.UPDATE);
|
String context = getTestPlanContext(_testPlans, NoticeConstants.Event.UPDATE);
|
||||||
MessageSettingDetail messageSettingDetail = noticeService.searchMessage();
|
User user = userMapper.selectByPrimaryKey(testPlan.getCreator());
|
||||||
List<MessageDetail> taskList = messageSettingDetail.getTestCasePlanTask();
|
Map<String, Object> paramMap = getTestPlanParamMap(testPlan);
|
||||||
taskList.forEach(r -> {
|
paramMap.put("creator", user.getName());
|
||||||
switch (r.getType()) {
|
NoticeModel noticeModel = NoticeModel.builder()
|
||||||
case NoticeConstants.NAIL_ROBOT:
|
.context(context)
|
||||||
dingTaskService.sendNailRobot(r, userIds, context, NoticeConstants.UPDATE);
|
.relatedUsers(userIds)
|
||||||
break;
|
.subject(Translator.get("test_plan_notification"))
|
||||||
case NoticeConstants.WECHAT_ROBOT:
|
.mailTemplate("TestPlanEnd")
|
||||||
wxChatTaskService.sendWechatRobot(r, userIds, context, NoticeConstants.UPDATE);
|
.paramMap(paramMap)
|
||||||
break;
|
.build();
|
||||||
case NoticeConstants.EMAIL:
|
noticeSendService.send(NoticeConstants.TaskType.TEST_PLAN_TASK, noticeModel);
|
||||||
mailService.sendTestPlanEndNotice(r, userIds, _testPlans, NoticeConstants.UPDATE);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LogUtil.error(e.getMessage(), e);
|
LogUtil.error(e.getMessage(), e);
|
||||||
}
|
}
|
||||||
|
@ -558,9 +558,9 @@ public class TestPlanService {
|
||||||
end = "未设置";
|
end = "未设置";
|
||||||
}
|
}
|
||||||
String context = "";
|
String context = "";
|
||||||
if (StringUtils.equals(NoticeConstants.CREATE, type)) {
|
if (StringUtils.equals(NoticeConstants.Event.CREATE, type)) {
|
||||||
context = "测试计划任务通知:" + user.getName() + "创建的" + "'" + testPlan.getName() + "'" + "待开始,计划开始时间是:" + "'" + start + "'" + ";" + "计划结束时间是:" + "'" + end + "'" + " " + "请跟进";
|
context = "测试计划任务通知:" + user.getName() + "创建的" + "'" + testPlan.getName() + "'" + "待开始,计划开始时间是:" + "'" + start + "'" + ";" + "计划结束时间是:" + "'" + end + "'" + " " + "请跟进";
|
||||||
} else if (StringUtils.equals(NoticeConstants.UPDATE, type)) {
|
} else if (StringUtils.equals(NoticeConstants.Event.UPDATE, type)) {
|
||||||
String status = "";
|
String status = "";
|
||||||
if (StringUtils.equals(TestPlanStatus.Underway.name(), testPlan.getStatus())) {
|
if (StringUtils.equals(TestPlanStatus.Underway.name(), testPlan.getStatus())) {
|
||||||
status = "进行中";
|
status = "进行中";
|
||||||
|
@ -570,7 +570,7 @@ public class TestPlanService {
|
||||||
status = "已完成";
|
status = "已完成";
|
||||||
}
|
}
|
||||||
context = "测试计划任务通知:" + user.getName() + "创建的" + "'" + testPlan.getName() + "'" + "计划开始时间是:" + "'" + start + "'" + ";" + "计划结束时间是:" + "'" + end + "'" + " " + status;
|
context = "测试计划任务通知:" + user.getName() + "创建的" + "'" + testPlan.getName() + "'" + "计划开始时间是:" + "'" + start + "'" + ";" + "计划结束时间是:" + "'" + end + "'" + " " + status;
|
||||||
} else if (StringUtils.equals(NoticeConstants.DELETE, type)) {
|
} else if (StringUtils.equals(NoticeConstants.Event.DELETE, type)) {
|
||||||
context = "测试计划任务通知:" + user.getName() + "创建的" + "'" + testPlan.getName() + "'" + "计划开始时间是:" + "'" + start + "'" + ";" + "计划结束时间是:" + "'" + end + "'" + " " + "已删除";
|
context = "测试计划任务通知:" + user.getName() + "创建的" + "'" + testPlan.getName() + "'" + "计划开始时间是:" + "'" + start + "'" + ";" + "计划结束时间是:" + "'" + end + "'" + " " + "已删除";
|
||||||
}
|
}
|
||||||
return context;
|
return context;
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="10">
|
<el-col :span="10">
|
||||||
<h3>{{ $t('organization.message.defect_task_notification') }}</h3>
|
<h3>{{ $t('organization.message.defect_task_notification') }}</h3>
|
||||||
<el-button icon="el-icon-circle-plus-outline" plain size="mini" @click="handleAddTaskModel('defectTask')">
|
<el-button icon="el-icon-circle-plus-outline" plain size="mini" @click="handleAddTaskModel">
|
||||||
{{ $t('organization.message.create_new_notification') }}
|
{{ $t('organization.message.create_new_notification') }}
|
||||||
</el-button>
|
</el-button>
|
||||||
</el-col>
|
</el-col>
|
||||||
|
@ -14,13 +14,12 @@
|
||||||
:data="form.defectTask"
|
:data="form.defectTask"
|
||||||
class="tb-edit"
|
class="tb-edit"
|
||||||
border
|
border
|
||||||
size="mini"
|
|
||||||
:cell-style="rowClass"
|
:cell-style="rowClass"
|
||||||
:header-cell-style="headClass"
|
:header-cell-style="headClass"
|
||||||
>
|
>
|
||||||
<el-table-column :label="$t('schedule.event')" min-width="20%" prop="events">
|
<el-table-column :label="$t('schedule.event')" min-width="20%" prop="events">
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<el-select v-model="scope.row.event" :placeholder="$t('organization.message.select_events')"
|
<el-select v-model="scope.row.event" :placeholder="$t('organization.message.select_events')" size="mini"
|
||||||
prop="event" :disabled="!scope.row.isSet">
|
prop="event" :disabled="!scope.row.isSet">
|
||||||
<el-option
|
<el-option
|
||||||
v-for="item in defectEventOptions"
|
v-for="item in defectEventOptions"
|
||||||
|
@ -33,7 +32,7 @@
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column :label="$t('schedule.receiver')" prop="receiver" min-width="20%">
|
<el-table-column :label="$t('schedule.receiver')" prop="receiver" min-width="20%">
|
||||||
<template v-slot:default="{row}">
|
<template v-slot:default="{row}">
|
||||||
<el-select v-model="row.userIds" filterable multiple
|
<el-select v-model="row.userIds" filterable multiple size="mini"
|
||||||
:placeholder="$t('commons.please_select')"
|
:placeholder="$t('commons.please_select')"
|
||||||
style="width: 100%;" :disabled="!row.isSet">
|
style="width: 100%;" :disabled="!row.isSet">
|
||||||
<el-option
|
<el-option
|
||||||
|
@ -48,6 +47,7 @@
|
||||||
<el-table-column :label="$t('schedule.receiving_mode')" min-width="20%" prop="type">
|
<el-table-column :label="$t('schedule.receiving_mode')" min-width="20%" prop="type">
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<el-select v-model="scope.row.type" :placeholder="$t('organization.message.select_receiving_method')"
|
<el-select v-model="scope.row.type" :placeholder="$t('organization.message.select_receiving_method')"
|
||||||
|
size="mini"
|
||||||
:disabled="!scope.row.isSet" @change="handleEdit(scope.$index, scope.row)">
|
:disabled="!scope.row.isSet" @change="handleEdit(scope.$index, scope.row)">
|
||||||
<el-option
|
<el-option
|
||||||
v-for="item in receiveTypeOptions"
|
v-for="item in receiveTypeOptions"
|
||||||
|
@ -60,7 +60,7 @@
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="webhook" min-width="20%" prop="webhook">
|
<el-table-column label="webhook" min-width="20%" prop="webhook">
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
<el-input v-model="scope.row.webhook" placeholder="webhook地址"
|
<el-input v-model="scope.row.webhook" placeholder="webhook地址" size="mini"
|
||||||
:disabled="!scope.row.isSet||!scope.row.isReadOnly"></el-input>
|
:disabled="!scope.row.isSet||!scope.row.isReadOnly"></el-input>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
|
@ -84,7 +84,8 @@
|
||||||
size="mini"
|
size="mini"
|
||||||
v-show="!scope.row.isSet"
|
v-show="!scope.row.isSet"
|
||||||
@click="handleEditTask(scope.$index,scope.row)"
|
@click="handleEditTask(scope.$index,scope.row)"
|
||||||
>{{ $t('commons.edit') }}</el-button>
|
>{{ $t('commons.edit') }}
|
||||||
|
</el-button>
|
||||||
<el-button
|
<el-button
|
||||||
type="danger"
|
type="danger"
|
||||||
icon="el-icon-delete"
|
icon="el-icon-delete"
|
||||||
|
@ -101,6 +102,8 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
const TASK_TYPE = 'DEFECT_TASK';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "DefectTaskNotification",
|
name: "DefectTaskNotification",
|
||||||
props: {
|
props: {
|
||||||
|
@ -137,8 +140,8 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
initForm() {
|
initForm() {
|
||||||
this.result = this.$get('/notice/search/message', response => {
|
this.result = this.$get('/notice/search/message/type/' + TASK_TYPE, response => {
|
||||||
this.form.defectTask = response.data.defectTask;
|
this.form.defectTask = response.data;
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
handleEdit(index, data) {
|
handleEdit(index, data) {
|
||||||
|
@ -157,7 +160,7 @@ export default {
|
||||||
data.isReadOnly = true;
|
data.isReadOnly = true;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
handleAddTaskModel(type) {
|
handleAddTaskModel() {
|
||||||
let Task = {};
|
let Task = {};
|
||||||
Task.event = [];
|
Task.event = [];
|
||||||
Task.userIds = [];
|
Task.userIds = [];
|
||||||
|
@ -165,22 +168,8 @@ export default {
|
||||||
Task.webhook = '';
|
Task.webhook = '';
|
||||||
Task.isSet = true;
|
Task.isSet = true;
|
||||||
Task.identification = '';
|
Task.identification = '';
|
||||||
if (type === 'jenkinsTask') {
|
Task.taskType = TASK_TYPE
|
||||||
Task.taskType = 'JENKINS_TASK'
|
|
||||||
this.form.jenkinsTask.push(Task)
|
|
||||||
}
|
|
||||||
if (type === 'testPlanTask') {
|
|
||||||
Task.taskType = 'TEST_PLAN_TASK'
|
|
||||||
this.form.testCasePlanTask.push(Task)
|
|
||||||
}
|
|
||||||
if (type === 'reviewTask') {
|
|
||||||
Task.taskType = 'REVIEW_TASK'
|
|
||||||
this.form.reviewTask.push(Task)
|
|
||||||
}
|
|
||||||
if (type === 'defectTask') {
|
|
||||||
Task.taskType = 'DEFECT_TASK'
|
|
||||||
this.form.defectTask.push(Task)
|
this.form.defectTask.push(Task)
|
||||||
}
|
|
||||||
},
|
},
|
||||||
handleAddTask(index, data) {
|
handleAddTask(index, data) {
|
||||||
|
|
||||||
|
@ -200,12 +189,8 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
addTask(data) {
|
addTask(data) {
|
||||||
let list = []
|
|
||||||
data.isSet = false
|
data.isSet = false
|
||||||
list.push(data)
|
this.result = this.$post("/notice/save/message/task", data, () => {
|
||||||
let param = {};
|
|
||||||
param.messageDetail = list
|
|
||||||
this.result = this.$post("/notice/save/message/task", param, () => {
|
|
||||||
this.initForm()
|
this.initForm()
|
||||||
this.$success(this.$t('commons.save_success'));
|
this.$success(this.$t('commons.save_success'));
|
||||||
})
|
})
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="10">
|
<el-col :span="10">
|
||||||
<h3>{{ $t('organization.message.jenkins_task_notification') }}</h3>
|
<h3>{{ $t('organization.message.jenkins_task_notification') }}</h3>
|
||||||
<el-button icon="el-icon-circle-plus-outline" plain size="mini" @click="handleAddTaskModel('jenkinsTask')">
|
<el-button icon="el-icon-circle-plus-outline" plain size="mini" @click="handleAddTaskModel">
|
||||||
{{ $t('organization.message.create_new_notification') }}
|
{{ $t('organization.message.create_new_notification') }}
|
||||||
</el-button>
|
</el-button>
|
||||||
</el-col>
|
</el-col>
|
||||||
|
@ -14,13 +14,13 @@
|
||||||
:data="form.jenkinsTask"
|
:data="form.jenkinsTask"
|
||||||
class="tb-edit"
|
class="tb-edit"
|
||||||
border
|
border
|
||||||
size="mini"
|
|
||||||
:cell-style="rowClass"
|
:cell-style="rowClass"
|
||||||
:header-cell-style="headClass">
|
:header-cell-style="headClass">
|
||||||
<el-table-column :label="$t('schedule.event')" min-width="20%" prop="events">
|
<el-table-column :label="$t('schedule.event')" min-width="20%" prop="events">
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<el-select v-model="scope.row.event"
|
<el-select v-model="scope.row.event"
|
||||||
:placeholder="$t('organization.message.select_events')"
|
:placeholder="$t('organization.message.select_events')"
|
||||||
|
size="mini"
|
||||||
prop="events" :disabled="!scope.row.isSet">
|
prop="events" :disabled="!scope.row.isSet">
|
||||||
<el-option
|
<el-option
|
||||||
v-for="item in jenkinsEventOptions"
|
v-for="item in jenkinsEventOptions"
|
||||||
|
@ -33,7 +33,7 @@
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column :label="$t('schedule.receiver')" prop="userIds" min-width="20%">
|
<el-table-column :label="$t('schedule.receiver')" prop="userIds" min-width="20%">
|
||||||
<template v-slot:default="{row}">
|
<template v-slot:default="{row}">
|
||||||
<el-select v-model="row.userIds" filterable multiple
|
<el-select v-model="row.userIds" filterable multiple size="mini"
|
||||||
:placeholder="$t('commons.please_select')" style="width: 100%;" :disabled="!row.isSet">
|
:placeholder="$t('commons.please_select')" style="width: 100%;" :disabled="!row.isSet">
|
||||||
<el-option
|
<el-option
|
||||||
v-for="item in jenkinsReceiverOptions"
|
v-for="item in jenkinsReceiverOptions"
|
||||||
|
@ -47,6 +47,7 @@
|
||||||
<el-table-column :label="$t('schedule.receiving_mode')" min-width="20%" prop="type">
|
<el-table-column :label="$t('schedule.receiving_mode')" min-width="20%" prop="type">
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<el-select v-model="scope.row.type" :placeholder="$t('organization.message.select_receiving_method')"
|
<el-select v-model="scope.row.type" :placeholder="$t('organization.message.select_receiving_method')"
|
||||||
|
size="mini"
|
||||||
:disabled="!scope.row.isSet" @change="handleEdit(scope.$index, scope.row)"
|
:disabled="!scope.row.isSet" @change="handleEdit(scope.$index, scope.row)"
|
||||||
>
|
>
|
||||||
<el-option
|
<el-option
|
||||||
|
@ -61,6 +62,7 @@
|
||||||
<el-table-column label="webhook" min-width="20%" prop="webhook">
|
<el-table-column label="webhook" min-width="20%" prop="webhook">
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
<el-input v-model="scope.row.webhook" placeholder="webhook地址"
|
<el-input v-model="scope.row.webhook" placeholder="webhook地址"
|
||||||
|
size="mini"
|
||||||
:disabled="!scope.row.isSet||!scope.row.isReadOnly"></el-input>
|
:disabled="!scope.row.isSet||!scope.row.isReadOnly"></el-input>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
|
@ -102,6 +104,8 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
const TASK_TYPE = 'JENKINS_TASK';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "JenkinsNotification",
|
name: "JenkinsNotification",
|
||||||
props: {
|
props: {
|
||||||
|
@ -139,8 +143,8 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
initForm() {
|
initForm() {
|
||||||
this.result = this.$get('/notice/search/message', response => {
|
this.result = this.$get('/notice/search/message/type/' + TASK_TYPE, response => {
|
||||||
this.form.jenkinsTask = response.data.jenkinsTask;
|
this.form.jenkinsTask = response.data;
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
handleEdit(index, data) {
|
handleEdit(index, data) {
|
||||||
|
@ -150,7 +154,7 @@ export default {
|
||||||
data.webhook = '';
|
data.webhook = '';
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
handleAddTaskModel(type) {
|
handleAddTaskModel() {
|
||||||
let Task = {};
|
let Task = {};
|
||||||
Task.event = [];
|
Task.event = [];
|
||||||
Task.userIds = [];
|
Task.userIds = [];
|
||||||
|
@ -158,22 +162,8 @@ export default {
|
||||||
Task.webhook = '';
|
Task.webhook = '';
|
||||||
Task.isSet = true;
|
Task.isSet = true;
|
||||||
Task.identification = '';
|
Task.identification = '';
|
||||||
if (type === 'jenkinsTask') {
|
Task.taskType = TASK_TYPE
|
||||||
Task.taskType = 'JENKINS_TASK'
|
|
||||||
this.form.jenkinsTask.push(Task)
|
this.form.jenkinsTask.push(Task)
|
||||||
}
|
|
||||||
if (type === 'testPlanTask') {
|
|
||||||
Task.taskType = 'TEST_PLAN_TASK'
|
|
||||||
this.form.testCasePlanTask.push(Task)
|
|
||||||
}
|
|
||||||
if (type === 'reviewTask') {
|
|
||||||
Task.taskType = 'REVIEW_TASK'
|
|
||||||
this.form.reviewTask.push(Task)
|
|
||||||
}
|
|
||||||
if (type === 'defectTask') {
|
|
||||||
Task.taskType = 'DEFECT_TASK'
|
|
||||||
this.form.defectTask.push(Task)
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
handleAddTask(index, data) {
|
handleAddTask(index, data) {
|
||||||
if (data.event && data.userIds.length > 0 && data.type) {
|
if (data.event && data.userIds.length > 0 && data.type) {
|
||||||
|
@ -202,11 +192,7 @@ export default {
|
||||||
|
|
||||||
},
|
},
|
||||||
addTask(data) {
|
addTask(data) {
|
||||||
let list = [];
|
this.result = this.$post("/notice/save/message/task", data, () => {
|
||||||
list.push(data);
|
|
||||||
let param = {};
|
|
||||||
param.messageDetail = list;
|
|
||||||
this.result = this.$post("/notice/save/message/task", param, () => {
|
|
||||||
this.initForm();
|
this.initForm();
|
||||||
this.$success(this.$t('commons.save_success'));
|
this.$success(this.$t('commons.save_success'));
|
||||||
})
|
})
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="10">
|
<el-col :span="10">
|
||||||
<h3>{{ $t('organization.message.test_plan_task_notification') }}</h3>
|
<h3>{{ $t('organization.message.test_plan_task_notification') }}</h3>
|
||||||
<el-button icon="el-icon-circle-plus-outline" plain size="mini" @click="handleAddTaskModel('testPlanTask')">
|
<el-button icon="el-icon-circle-plus-outline" plain size="mini" @click="handleAddTaskModel">
|
||||||
{{ $t('organization.message.create_new_notification') }}
|
{{ $t('organization.message.create_new_notification') }}
|
||||||
</el-button>
|
</el-button>
|
||||||
</el-col>
|
</el-col>
|
||||||
|
@ -14,14 +14,13 @@
|
||||||
:data="form.testCasePlanTask"
|
:data="form.testCasePlanTask"
|
||||||
class="tb-edit"
|
class="tb-edit"
|
||||||
border
|
border
|
||||||
size="mini"
|
|
||||||
:cell-style="rowClass"
|
:cell-style="rowClass"
|
||||||
:header-cell-style="headClass"
|
:header-cell-style="headClass"
|
||||||
>
|
>
|
||||||
<el-table-column :label="$t('schedule.event')" min-width="20%" prop="events">
|
<el-table-column :label="$t('schedule.event')" min-width="20%" prop="events">
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<el-select v-model="scope.row.event" :placeholder="$t('organization.message.select_events')"
|
<el-select v-model="scope.row.event" :placeholder="$t('organization.message.select_events')"
|
||||||
@change="handleTestPlanReceivers(scope.row)"
|
@change="handleTestPlanReceivers(scope.row)" size="mini"
|
||||||
prop="events" :disabled="!scope.row.isSet">
|
prop="events" :disabled="!scope.row.isSet">
|
||||||
<el-option
|
<el-option
|
||||||
v-for="item in otherEventOptions"
|
v-for="item in otherEventOptions"
|
||||||
|
@ -34,7 +33,7 @@
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column :label="$t('schedule.receiver')" prop="userIds" min-width="20%">
|
<el-table-column :label="$t('schedule.receiver')" prop="userIds" min-width="20%">
|
||||||
<template v-slot:default="{row}">
|
<template v-slot:default="{row}">
|
||||||
<el-select v-model="row.userIds" filterable multiple
|
<el-select v-model="row.userIds" filterable multiple size="mini"
|
||||||
:placeholder="$t('commons.please_select')" style="width: 100%;" :disabled="!row.isSet">
|
:placeholder="$t('commons.please_select')" style="width: 100%;" :disabled="!row.isSet">
|
||||||
<el-option
|
<el-option
|
||||||
v-for="item in row.testPlanReceiverOptions"
|
v-for="item in row.testPlanReceiverOptions"
|
||||||
|
@ -48,6 +47,7 @@
|
||||||
<el-table-column :label="$t('schedule.receiving_mode')" min-width="20%" prop="type">
|
<el-table-column :label="$t('schedule.receiving_mode')" min-width="20%" prop="type">
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<el-select v-model="scope.row.type" :placeholder="$t('organization.message.select_receiving_method')"
|
<el-select v-model="scope.row.type" :placeholder="$t('organization.message.select_receiving_method')"
|
||||||
|
size="mini"
|
||||||
:disabled="!scope.row.isSet" @change="handleEdit(scope.$index, scope.row)">
|
:disabled="!scope.row.isSet" @change="handleEdit(scope.$index, scope.row)">
|
||||||
<el-option
|
<el-option
|
||||||
v-for="item in receiveTypeOptions"
|
v-for="item in receiveTypeOptions"
|
||||||
|
@ -60,7 +60,7 @@
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="webhook" min-width="20%" prop="webhook">
|
<el-table-column label="webhook" min-width="20%" prop="webhook">
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
<el-input v-model="scope.row.webhook" placeholder="webhook地址"
|
<el-input v-model="scope.row.webhook" placeholder="webhook地址" size="mini"
|
||||||
:disabled="!scope.row.isSet||!scope.row.isReadOnly"></el-input>
|
:disabled="!scope.row.isSet||!scope.row.isReadOnly"></el-input>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
|
@ -84,7 +84,8 @@
|
||||||
size="mini"
|
size="mini"
|
||||||
v-show="!scope.row.isSet"
|
v-show="!scope.row.isSet"
|
||||||
@click="handleEditTask(scope.$index,scope.row)"
|
@click="handleEditTask(scope.$index,scope.row)"
|
||||||
>{{ $t('commons.edit') }}</el-button>
|
>{{ $t('commons.edit') }}
|
||||||
|
</el-button>
|
||||||
<el-button
|
<el-button
|
||||||
type="danger"
|
type="danger"
|
||||||
icon="el-icon-delete"
|
icon="el-icon-delete"
|
||||||
|
@ -102,6 +103,8 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
const TASK_TYPE = 'TEST_PLAN_TASK';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "TestPlanTaskNotification",
|
name: "TestPlanTaskNotification",
|
||||||
props: {
|
props: {
|
||||||
|
@ -140,8 +143,8 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
initForm() {
|
initForm() {
|
||||||
this.result = this.$get('/notice/search/message', response => {
|
this.result = this.$get('/notice/search/message/type/' + TASK_TYPE, response => {
|
||||||
this.form.testCasePlanTask = response.data.testCasePlanTask;
|
this.form.testCasePlanTask = response.data;
|
||||||
this.form.testCasePlanTask.forEach(planTask => {
|
this.form.testCasePlanTask.forEach(planTask => {
|
||||||
this.handleTestPlanReceivers(planTask);
|
this.handleTestPlanReceivers(planTask);
|
||||||
});
|
});
|
||||||
|
@ -163,7 +166,7 @@ export default {
|
||||||
data.isReadOnly = true;
|
data.isReadOnly = true;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
handleAddTaskModel(type) {
|
handleAddTaskModel() {
|
||||||
let Task = {};
|
let Task = {};
|
||||||
Task.event = [];
|
Task.event = [];
|
||||||
Task.userIds = [];
|
Task.userIds = [];
|
||||||
|
@ -171,22 +174,8 @@ export default {
|
||||||
Task.webhook = '';
|
Task.webhook = '';
|
||||||
Task.isSet = true;
|
Task.isSet = true;
|
||||||
Task.identification = '';
|
Task.identification = '';
|
||||||
if (type === 'jenkinsTask') {
|
Task.taskType = TASK_TYPE
|
||||||
Task.taskType = 'JENKINS_TASK'
|
|
||||||
this.form.jenkinsTask.push(Task)
|
|
||||||
}
|
|
||||||
if (type === 'testPlanTask') {
|
|
||||||
Task.taskType = 'TEST_PLAN_TASK'
|
|
||||||
this.form.testCasePlanTask.push(Task)
|
this.form.testCasePlanTask.push(Task)
|
||||||
}
|
|
||||||
if (type === 'reviewTask') {
|
|
||||||
Task.taskType = 'REVIEW_TASK'
|
|
||||||
this.form.reviewTask.push(Task)
|
|
||||||
}
|
|
||||||
if (type === 'defectTask') {
|
|
||||||
Task.taskType = 'DEFECT_TASK'
|
|
||||||
this.form.defectTask.push(Task)
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
handleAddTask(index, data) {
|
handleAddTask(index, data) {
|
||||||
|
|
||||||
|
@ -206,12 +195,8 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
addTask(data) {
|
addTask(data) {
|
||||||
let list = []
|
|
||||||
data.isSet = false
|
data.isSet = false
|
||||||
list.push(data)
|
this.result = this.$post("/notice/save/message/task", data, () => {
|
||||||
let param = {};
|
|
||||||
param.messageDetail = list
|
|
||||||
this.result = this.$post("/notice/save/message/task", param, () => {
|
|
||||||
this.initForm()
|
this.initForm()
|
||||||
this.$success(this.$t('commons.save_success'));
|
this.$success(this.$t('commons.save_success'));
|
||||||
})
|
})
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="10">
|
<el-col :span="10">
|
||||||
<h3>{{ $t('organization.message.test_review_task_notice') }}</h3>
|
<h3>{{ $t('organization.message.test_review_task_notice') }}</h3>
|
||||||
<el-button icon="el-icon-circle-plus-outline" plain size="mini" @click="handleAddTaskModel('reviewTask')">
|
<el-button icon="el-icon-circle-plus-outline" plain size="mini" @click="handleAddTaskModel">
|
||||||
{{ $t('organization.message.create_new_notification') }}
|
{{ $t('organization.message.create_new_notification') }}
|
||||||
</el-button>
|
</el-button>
|
||||||
</el-col>
|
</el-col>
|
||||||
|
@ -14,13 +14,12 @@
|
||||||
:data="form.reviewTask"
|
:data="form.reviewTask"
|
||||||
class="tb-edit"
|
class="tb-edit"
|
||||||
border
|
border
|
||||||
size="mini"
|
|
||||||
:cell-style="rowClass"
|
:cell-style="rowClass"
|
||||||
:header-cell-style="headClass"
|
:header-cell-style="headClass"
|
||||||
>
|
>
|
||||||
<el-table-column :label="$t('schedule.event')" min-width="20%" prop="events">
|
<el-table-column :label="$t('schedule.event')" min-width="20%" prop="events">
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<el-select v-model="scope.row.event" :placeholder="$t('organization.message.select_events')"
|
<el-select v-model="scope.row.event" :placeholder="$t('organization.message.select_events')" size="mini"
|
||||||
@change="handleReviewReceivers(scope.row)"
|
@change="handleReviewReceivers(scope.row)"
|
||||||
prop="event" :disabled="!scope.row.isSet">
|
prop="event" :disabled="!scope.row.isSet">
|
||||||
<el-option
|
<el-option
|
||||||
|
@ -34,7 +33,7 @@
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column :label="$t('schedule.receiver')" prop="receiver" min-width="20%">
|
<el-table-column :label="$t('schedule.receiver')" prop="receiver" min-width="20%">
|
||||||
<template v-slot:default="{row}">
|
<template v-slot:default="{row}">
|
||||||
<el-select v-model="row.userIds" filterable multiple
|
<el-select v-model="row.userIds" filterable multiple size="mini"
|
||||||
:placeholder="$t('commons.please_select')"
|
:placeholder="$t('commons.please_select')"
|
||||||
style="width: 100%;" :disabled="!row.isSet">
|
style="width: 100%;" :disabled="!row.isSet">
|
||||||
<el-option
|
<el-option
|
||||||
|
@ -49,6 +48,7 @@
|
||||||
<el-table-column :label="$t('schedule.receiving_mode')" min-width="20%" prop="type">
|
<el-table-column :label="$t('schedule.receiving_mode')" min-width="20%" prop="type">
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<el-select v-model="scope.row.type" :placeholder="$t('organization.message.select_receiving_method')"
|
<el-select v-model="scope.row.type" :placeholder="$t('organization.message.select_receiving_method')"
|
||||||
|
size="mini"
|
||||||
:disabled="!scope.row.isSet" @change="handleEdit(scope.$index, scope.row)">
|
:disabled="!scope.row.isSet" @change="handleEdit(scope.$index, scope.row)">
|
||||||
<el-option
|
<el-option
|
||||||
v-for="item in receiveTypeOptions"
|
v-for="item in receiveTypeOptions"
|
||||||
|
@ -61,7 +61,7 @@
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="webhook" min-width="20%" prop="webhook">
|
<el-table-column label="webhook" min-width="20%" prop="webhook">
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
<el-input v-model="scope.row.webhook" placeholder="webhook地址"
|
<el-input v-model="scope.row.webhook" placeholder="webhook地址" size="mini"
|
||||||
:disabled="!scope.row.isSet||!scope.row.isReadOnly"></el-input>
|
:disabled="!scope.row.isSet||!scope.row.isReadOnly"></el-input>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
|
@ -85,7 +85,8 @@
|
||||||
size="mini"
|
size="mini"
|
||||||
v-show="!scope.row.isSet"
|
v-show="!scope.row.isSet"
|
||||||
@click="handleEditTask(scope.$index,scope.row)"
|
@click="handleEditTask(scope.$index,scope.row)"
|
||||||
>{{ $t('commons.edit') }}</el-button>
|
>{{ $t('commons.edit') }}
|
||||||
|
</el-button>
|
||||||
<el-button
|
<el-button
|
||||||
type="danger"
|
type="danger"
|
||||||
icon="el-icon-delete"
|
icon="el-icon-delete"
|
||||||
|
@ -102,6 +103,8 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
const TASK_TYPE = 'REVIEW_TASK';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "TestReviewNotification",
|
name: "TestReviewNotification",
|
||||||
props: {
|
props: {
|
||||||
|
@ -141,8 +144,8 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
initForm() {
|
initForm() {
|
||||||
this.result = this.$get('/notice/search/message', response => {
|
this.result = this.$get('/notice/search/message/type/' + TASK_TYPE, response => {
|
||||||
this.form.reviewTask = response.data.reviewTask;
|
this.form.reviewTask = response.data;
|
||||||
this.form.reviewTask.forEach(planTask => {
|
this.form.reviewTask.forEach(planTask => {
|
||||||
this.handleReviewReceivers(planTask);
|
this.handleReviewReceivers(planTask);
|
||||||
});
|
});
|
||||||
|
@ -164,7 +167,7 @@ export default {
|
||||||
data.isReadOnly = true;
|
data.isReadOnly = true;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
handleAddTaskModel(type) {
|
handleAddTaskModel() {
|
||||||
let Task = {};
|
let Task = {};
|
||||||
Task.event = [];
|
Task.event = [];
|
||||||
Task.userIds = [];
|
Task.userIds = [];
|
||||||
|
@ -172,22 +175,8 @@ export default {
|
||||||
Task.webhook = '';
|
Task.webhook = '';
|
||||||
Task.isSet = true;
|
Task.isSet = true;
|
||||||
Task.identification = '';
|
Task.identification = '';
|
||||||
if (type === 'jenkinsTask') {
|
Task.taskType = TASK_TYPE
|
||||||
Task.taskType = 'JENKINS_TASK'
|
|
||||||
this.form.jenkinsTask.push(Task)
|
|
||||||
}
|
|
||||||
if (type === 'testPlanTask') {
|
|
||||||
Task.taskType = 'TEST_PLAN_TASK'
|
|
||||||
this.form.testCasePlanTask.push(Task)
|
|
||||||
}
|
|
||||||
if (type === 'reviewTask') {
|
|
||||||
Task.taskType = 'REVIEW_TASK'
|
|
||||||
this.form.reviewTask.push(Task)
|
this.form.reviewTask.push(Task)
|
||||||
}
|
|
||||||
if (type === 'defectTask') {
|
|
||||||
Task.taskType = 'DEFECT_TASK'
|
|
||||||
this.form.defectTask.push(Task)
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
handleAddTask(index, data) {
|
handleAddTask(index, data) {
|
||||||
|
|
||||||
|
@ -207,12 +196,8 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
addTask(data) {
|
addTask(data) {
|
||||||
let list = [];
|
|
||||||
data.isSet = false;
|
data.isSet = false;
|
||||||
list.push(data);
|
this.result = this.$post("/notice/save/message/task", data, () => {
|
||||||
let param = {};
|
|
||||||
param.messageDetail = list;
|
|
||||||
this.result = this.$post("/notice/save/message/task", param, () => {
|
|
||||||
this.initForm();
|
this.initForm();
|
||||||
this.$success(this.$t('commons.save_success'));
|
this.$success(this.$t('commons.save_success'));
|
||||||
})
|
})
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 8a972a198775b3783ed6e4cef27197e53d1ebdc8
|
Subproject commit a22a3005d9bd254793fcf634d72539cbdf31be3a
|
Loading…
Reference in New Issue