|
@@ -3,6 +3,7 @@ package com.qmth.themis.backend.api;
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
|
+import com.qmth.themis.backend.config.DictionaryConfig;
|
|
import com.qmth.themis.backend.util.ServletUtil;
|
|
import com.qmth.themis.backend.util.ServletUtil;
|
|
import com.qmth.themis.business.annotation.ApiJsonObject;
|
|
import com.qmth.themis.business.annotation.ApiJsonObject;
|
|
import com.qmth.themis.business.annotation.ApiJsonProperty;
|
|
import com.qmth.themis.business.annotation.ApiJsonProperty;
|
|
@@ -11,7 +12,9 @@ import com.qmth.themis.business.entity.TBOrg;
|
|
import com.qmth.themis.business.entity.TBUser;
|
|
import com.qmth.themis.business.entity.TBUser;
|
|
import com.qmth.themis.business.entity.TEExam;
|
|
import com.qmth.themis.business.entity.TEExam;
|
|
import com.qmth.themis.business.entity.TEExamActivity;
|
|
import com.qmth.themis.business.entity.TEExamActivity;
|
|
|
|
+import com.qmth.themis.business.enums.ExamModeEnum;
|
|
import com.qmth.themis.business.enums.FieldUniqueEnum;
|
|
import com.qmth.themis.business.enums.FieldUniqueEnum;
|
|
|
|
+import com.qmth.themis.business.enums.MqEnum;
|
|
import com.qmth.themis.business.service.TEExamActivityService;
|
|
import com.qmth.themis.business.service.TEExamActivityService;
|
|
import com.qmth.themis.business.service.TEExamService;
|
|
import com.qmth.themis.business.service.TEExamService;
|
|
import com.qmth.themis.business.util.JacksonUtil;
|
|
import com.qmth.themis.business.util.JacksonUtil;
|
|
@@ -20,16 +23,16 @@ import com.qmth.themis.common.enums.ExceptionResultEnum;
|
|
import com.qmth.themis.common.exception.BusinessException;
|
|
import com.qmth.themis.common.exception.BusinessException;
|
|
import com.qmth.themis.common.util.Result;
|
|
import com.qmth.themis.common.util.Result;
|
|
import com.qmth.themis.common.util.ResultUtil;
|
|
import com.qmth.themis.common.util.ResultUtil;
|
|
|
|
+import com.qmth.themis.mq.dto.MqDto;
|
|
|
|
+import com.qmth.themis.mq.service.MqDtoService;
|
|
import io.swagger.annotations.*;
|
|
import io.swagger.annotations.*;
|
|
|
|
+import org.springframework.beans.BeanUtils;
|
|
import org.springframework.dao.DuplicateKeyException;
|
|
import org.springframework.dao.DuplicateKeyException;
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
import org.springframework.web.bind.annotation.*;
|
|
import org.springframework.web.bind.annotation.*;
|
|
|
|
|
|
import javax.annotation.Resource;
|
|
import javax.annotation.Resource;
|
|
-import java.util.HashMap;
|
|
|
|
-import java.util.List;
|
|
|
|
-import java.util.Map;
|
|
|
|
-import java.util.Objects;
|
|
|
|
|
|
+import java.util.*;
|
|
|
|
|
|
/**
|
|
/**
|
|
* @Description: 考试批次 前端控制器
|
|
* @Description: 考试批次 前端控制器
|
|
@@ -49,6 +52,12 @@ public class TEExamController {
|
|
@Resource
|
|
@Resource
|
|
TEExamActivityService teExamActivityService;
|
|
TEExamActivityService teExamActivityService;
|
|
|
|
|
|
|
|
+ @Resource
|
|
|
|
+ MqDtoService mqDtoService;
|
|
|
|
+
|
|
|
|
+ @Resource
|
|
|
|
+ DictionaryConfig dictionaryConfig;
|
|
|
|
+
|
|
@ApiOperation(value = "考试批次修改/新增接口")
|
|
@ApiOperation(value = "考试批次修改/新增接口")
|
|
@RequestMapping(value = "/save", method = RequestMethod.POST)
|
|
@RequestMapping(value = "/save", method = RequestMethod.POST)
|
|
@Transactional
|
|
@Transactional
|
|
@@ -66,13 +75,65 @@ public class TEExamController {
|
|
}
|
|
}
|
|
teExam.setOrgId(tbOrg.getId());
|
|
teExam.setOrgId(tbOrg.getId());
|
|
}
|
|
}
|
|
- if (Objects.nonNull(teExam.getId())) {
|
|
|
|
|
|
+ Long oldId = teExam.getId();
|
|
|
|
+ TEExam oldTeExam = null;
|
|
|
|
+ if (Objects.nonNull(oldId)) {
|
|
teExam.setUpdateId(tbUser.getId());
|
|
teExam.setUpdateId(tbUser.getId());
|
|
|
|
+ oldTeExam = teExamService.getById(oldId);
|
|
} else {
|
|
} else {
|
|
teExam.setId(Constants.idGen.next());
|
|
teExam.setId(Constants.idGen.next());
|
|
teExam.setCreateId(tbUser.getId());
|
|
teExam.setCreateId(tbUser.getId());
|
|
}
|
|
}
|
|
teExamService.saveOrUpdate(teExam);
|
|
teExamService.saveOrUpdate(teExam);
|
|
|
|
+ if (Objects.nonNull(oldTeExam) && oldTeExam.getMode().intValue() != teExam.getMode().intValue()) {//如果模式改变,则删除之前模式的全部quartz
|
|
|
|
+ QueryWrapper<TEExamActivity> teExamActivityQueryWrapper = new QueryWrapper<>();
|
|
|
|
+ teExamActivityQueryWrapper.lambda().eq(TEExamActivity::getExamId, oldId);
|
|
|
|
+ List<TEExamActivity> teExamActivityList = teExamActivityService.list(teExamActivityQueryWrapper);
|
|
|
|
+ //删除quartz任务,发送mq消息start
|
|
|
|
+ Map<String, Object> prop = new HashMap<>();
|
|
|
|
+ prop.put("oper", "delete");
|
|
|
|
+ MqDto mqDto = new MqDto(dictionaryConfig.mqConfigDomain().getQuartzTopic(), dictionaryConfig.mqConfigDomain().getQuartzTopicExamActivityTag(), JacksonUtil.parseJson(teExamActivityList), MqEnum.QUARTZ_LOG, String.valueOf(teExam.getId()), prop, tbUser.getName());
|
|
|
|
+ mqDtoService.assembleSendOneWayMsg(mqDto);
|
|
|
|
+ //删除quartz任务,发送mq消息end
|
|
|
|
+
|
|
|
|
+ //删除数据
|
|
|
|
+ teExamActivityService.remove(teExamActivityQueryWrapper);
|
|
|
|
+ }
|
|
|
|
+ //如果是随到随考,则默认插入一条场次信息
|
|
|
|
+ if (teExam.getMode().intValue() == ExamModeEnum.anytime.ordinal()) {//随到随考模式
|
|
|
|
+ if (Objects.isNull(oldId)) {//如果是新增
|
|
|
|
+ if (teExam.getMode().intValue() == ExamModeEnum.anytime.ordinal()) {
|
|
|
|
+ TEExamActivity teExamActivity = new TEExamActivity(teExam.getId(), teExam.getPrepareSeconds(), teExam.getMaxDurationSeconds(), teExam.getOpeningSeconds(), teExam.getStartTime(), teExam.getEndTime(), tbUser.getId());
|
|
|
|
+ teExamActivityService.saveOrUpdate(teExamActivity);
|
|
|
|
+
|
|
|
|
+ //新增quartz任务,发送mq消息start
|
|
|
|
+ Map<String, Object> prop = new HashMap<>();
|
|
|
|
+ prop.put("oper", "insert");
|
|
|
|
+ prop.put("exam", teExam);
|
|
|
|
+ MqDto mqDto = new MqDto(dictionaryConfig.mqConfigDomain().getQuartzTopic(), dictionaryConfig.mqConfigDomain().getQuartzTopicExamActivityTag(), JacksonUtil.parseJson(Arrays.asList(teExamActivity)), MqEnum.QUARTZ_LOG, String.valueOf(teExam.getId()), prop, tbUser.getName());
|
|
|
|
+ mqDtoService.assembleSendOneWayMsg(mqDto);
|
|
|
|
+ //新增quartz任务,发送mq消息end
|
|
|
|
+ }
|
|
|
|
+ } else {//修改需删除之前生成的全部quartz任务
|
|
|
|
+ QueryWrapper<TEExamActivity> teExamActivityQueryWrapper = new QueryWrapper<>();
|
|
|
|
+ teExamActivityQueryWrapper.lambda().eq(TEExamActivity::getExamId, oldId);
|
|
|
|
+ List<TEExamActivity> teExamActivityList = teExamActivityService.list(teExamActivityQueryWrapper);
|
|
|
|
+ //修改数据
|
|
|
|
+ teExamActivityList.forEach(s -> {
|
|
|
|
+ s.setStartTime(teExam.getStartTime());
|
|
|
|
+ s.setFinishTime(teExam.getEndTime());
|
|
|
|
+ s.setUpdateId(tbUser.getId());
|
|
|
|
+ });
|
|
|
|
+ teExamActivityService.saveOrUpdateBatch(teExamActivityList);
|
|
|
|
+ //新增quartz任务,发送mq消息start
|
|
|
|
+ Map<String, Object> prop = new HashMap<>();
|
|
|
|
+ prop.put("oper", "insert");
|
|
|
|
+ prop.put("exam", teExam);
|
|
|
|
+ MqDto mqDto = new MqDto(dictionaryConfig.mqConfigDomain().getQuartzTopic(), dictionaryConfig.mqConfigDomain().getQuartzTopicExamActivityTag(), JacksonUtil.parseJson(teExamActivityList), MqEnum.QUARTZ_LOG, String.valueOf(teExam.getId()), prop, tbUser.getName());
|
|
|
|
+ mqDtoService.assembleSendOneWayMsg(mqDto);
|
|
|
|
+ //新增quartz任务,发送mq消息end
|
|
|
|
+ }
|
|
|
|
+ }
|
|
} catch (Exception e) {
|
|
} catch (Exception e) {
|
|
e.printStackTrace();
|
|
e.printStackTrace();
|
|
if (e instanceof DuplicateKeyException) {
|
|
if (e instanceof DuplicateKeyException) {
|