TaskService.java 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366
  1. package cn.cslg.pas.service;
  2. import cn.cslg.pas.common.core.base.Constants;
  3. import cn.cslg.pas.common.model.dto.ClientDTO;
  4. import cn.cslg.pas.common.model.dto.QrtzTaskAddNewDTO;
  5. import cn.cslg.pas.common.model.vo.ProductVO;
  6. import cn.cslg.pas.common.model.vo.ProjectImportPatentVO;
  7. import cn.cslg.pas.common.model.vo.ProjectVO;
  8. import cn.cslg.pas.common.utils.*;
  9. import cn.cslg.pas.common.utils.SecurityUtils.LoginUtils;
  10. import cn.cslg.pas.domain.Project;
  11. import cn.cslg.pas.domain.SystemDict;
  12. import cn.cslg.pas.domain.Task;
  13. import cn.cslg.pas.common.model.vo.TaskVO;
  14. import cn.cslg.pas.domain.asso.AssoOsTaskQrtzTask;
  15. import cn.cslg.pas.mapper.TaskMapper;
  16. import cn.cslg.pas.common.model.dto.UploadFileDTO;
  17. import cn.dev33.satoken.stp.StpUtil;
  18. import cn.hutool.core.io.FileUtil;
  19. import com.alibaba.fastjson.JSON;
  20. import com.alibaba.fastjson.JSONArray;
  21. import com.alibaba.fastjson.JSONObject;
  22. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  23. import com.baomidou.mybatisplus.core.metadata.IPage;
  24. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  25. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  26. import lombok.RequiredArgsConstructor;
  27. import lombok.extern.slf4j.Slf4j;
  28. import org.springframework.context.annotation.Lazy;
  29. import org.springframework.stereotype.Service;
  30. import org.springframework.web.multipart.MultipartFile;
  31. import java.io.IOException;
  32. import java.util.ArrayList;
  33. import java.util.Arrays;
  34. import java.util.Collections;
  35. import java.util.List;
  36. import java.util.stream.Collectors;
  37. /**
  38. * <p>
  39. * 任务表 服务类
  40. * </p>
  41. *
  42. * @author 王岩
  43. * @since 2022-02-27
  44. */
  45. @Slf4j
  46. @Service
  47. @RequiredArgsConstructor(onConstructor_ = {@Lazy})
  48. public class TaskService extends ServiceImpl<TaskMapper, Task> implements ITaskService {
  49. private final FileUtils fileUtils;
  50. private final LoginUtils loginUtils;
  51. private final RequestService requestService;
  52. private final OutInterfaceService outInterfaceService;
  53. public String getFileUrl(Integer id) {
  54. Task task = this.getById(id);
  55. return fileUtils.getSystemPath() + task.getUrl();
  56. }
  57. public Integer add(UploadFileDTO fileDTO, Integer projectId, Integer productId, Integer total, Integer type, Integer fieldNum, String oldName) {
  58. //创建任务表实体类,准备装载数据 ↓
  59. Task task = new Task();
  60. //任务开始时间
  61. task.setStartTime(DateUtils.getDateTime());
  62. //任务状态(0.队列中 1.进行中 2.成功 3.失败)
  63. task.setStatus(0);
  64. if (projectId != null) {
  65. //专题库id
  66. task.setProjectId(projectId);
  67. }
  68. if (productId != null) {
  69. //产品id
  70. task.setProductId(productId);
  71. }
  72. //文件名称
  73. task.setFileName(fileDTO.getFileName());
  74. //文件路径
  75. task.setUrl(fileDTO.getPath());
  76. //文件的专利总数量
  77. task.setTotal(total);
  78. //文件大小
  79. task.setFileSize(fileDTO.getFileSize());
  80. //任务类型 (1.上传 2导出)
  81. task.setType(type);
  82. //导入导出字段数量
  83. task.setFieldNum(fieldNum);
  84. //创建人id
  85. task.setCreateBy(loginUtils.getId());
  86. //文件原始名称
  87. task.setOldName(oldName);
  88. //数据入任务表
  89. task.insert();
  90. return task.getId();
  91. }
  92. /**
  93. * 新增导入专利任务
  94. *
  95. * @param fileDTO Excel文件
  96. * @param json 前台参数
  97. * @return 返回任务id
  98. */
  99. public Integer addTask2(UploadFileDTO fileDTO, Integer total, String json) {
  100. //将前台参数json格式转换为实体类(从中取出专题库id存入任务表)
  101. ProjectImportPatentVO projectImportPatentVO = JsonUtils.jsonToPojo(json, ProjectImportPatentVO.class);
  102. //创建任务表实体类,准备装载数据 ↓
  103. Task task = new Task();
  104. //任务开始时间
  105. //task.setStartTime(DateUtils.getDateTime());
  106. //任务状态(0.队列中 1.进行中 2.成功 3.失败)
  107. task.setStatus(0);
  108. if (projectImportPatentVO.getProjectId() != null) {
  109. //专题库id
  110. task.setProjectId(projectImportPatentVO.getProjectId());
  111. }
  112. //文件名称
  113. task.setFileName(fileDTO.getFileName());
  114. //文件路径
  115. task.setUrl(fileDTO.getPath());
  116. //文件的专利总数量
  117. task.setTotal(total);
  118. //文件大小
  119. task.setFileSize(fileDTO.getFileSize());
  120. //任务类型 (1.上传 2导出)
  121. task.setType(1);
  122. //导入导出字段数量
  123. task.setFieldNum(0);
  124. //创建人id
  125. task.setCreateBy(loginUtils.getId());
  126. //文件原始名称
  127. task.setOldName(fileDTO.getName());
  128. //成功条数
  129. task.setSuccessNum(0);
  130. //失败条数
  131. task.setDefaultNum(0);
  132. //前台参数json格式
  133. task.setPramJson(json);
  134. //数据入任务表
  135. task.insert();
  136. return task.getId();
  137. }
  138. /**
  139. * 新增网站导入专利任务
  140. *
  141. * @param qrtzTaskAddNewDTO 前台参数
  142. * @return 返回任务id
  143. */
  144. public Integer addTask3(QrtzTaskAddNewDTO qrtzTaskAddNewDTO, Integer total, AssoOsTaskQrtzTask assoOsTaskQrtzTask) {
  145. //创建任务表实体类,准备装载数据 ↓
  146. Task task = new Task();
  147. //任务开始时间
  148. //task.setStartTime(DateUtils.getDateTime());
  149. //任务状态(0.队列中 1.进行中 2.成功 3.失败)
  150. task.setStatus(0);
  151. //专题库id
  152. task.setProjectId(qrtzTaskAddNewDTO.getProjectId());
  153. //专利总数量
  154. task.setTotal(total);
  155. //任务类型 (1上传 2导出 3网站导入)
  156. task.setType(3);
  157. //导入导出字段数量
  158. task.setFieldNum(0);
  159. //创建人id
  160. task.setCreateBy(loginUtils.getId());
  161. //成功条数
  162. task.setSuccessNum(0);
  163. //失败条数
  164. task.setDefaultNum(0);
  165. //所属任务条件id
  166. task.setQrtzTaskId(assoOsTaskQrtzTask.getId());
  167. //数据入任务表
  168. task.insert();
  169. return task.getId();
  170. }
  171. public Task edit(Integer id, Integer status) {
  172. Task task = this.getById(id);
  173. task.setStatus(status);
  174. task.setEndTime(DateUtils.getDateTime());
  175. task.updateById();
  176. return task;
  177. }
  178. public String delete(Integer id) {
  179. Task temp = this.getById(id);
  180. this.removeById(id);
  181. if (StringUtils.isNotEmpty(temp.getUrl())) {
  182. FileUtil.del(fileUtils.getSystemPath(temp.getUrl()));
  183. }
  184. return Response.success(true);
  185. }
  186. public IPage<Task> getPageList(TaskVO params) throws IOException {
  187. String createName = params.getCreateName();
  188. //如果此次查询是要根据创建人名称查询则👇
  189. if (createName != null && !createName.equals("")) {
  190. //远程调用权限系统的根据创建人名称模糊查询创建人ids的接口
  191. String res = outInterfaceService.getPersonIdByNamePCS(createName);
  192. List<Integer> createPersonIds = JSONArray.parseArray(res, Integer.class);
  193. //当未查询到时给创建人ids集合赋值唯一元素id=-1,即查空页返回
  194. if (createPersonIds == null || createPersonIds.size() == 0) {
  195. createPersonIds = new ArrayList<>(Collections.singletonList(-1));
  196. }
  197. params.setCreatePersonIds(createPersonIds);
  198. }
  199. IPage<Task> pageList = baseMapper.getPageList(new Page<>(params.getCurrent(), params.getSize()), params);
  200. this.setDataList(pageList.getRecords());
  201. return pageList;
  202. }
  203. public List<Task> getQueueList(Integer type, Integer projectId, Integer productId) {
  204. LambdaQueryWrapper<Task> queryWrapper = new LambdaQueryWrapper<>();
  205. queryWrapper.eq(Task::getCreateBy, loginUtils.getId());
  206. queryWrapper.eq(Task::getType, type);
  207. queryWrapper.in(Task::getStatus, new ArrayList<Integer>() {{
  208. add(0);
  209. add(1);
  210. }});
  211. if (projectId != null) {
  212. queryWrapper.eq(Task::getProjectId, projectId);
  213. }
  214. if (productId != null) {
  215. queryWrapper.eq(Task::getProductId, productId);
  216. }
  217. queryWrapper.orderByAsc(Task::getStartTime);
  218. return this.list(queryWrapper);
  219. }
  220. public Integer add2(Integer projectId, Long fieldNum, Integer total) {
  221. Task task = new Task();
  222. task.setStatus(0);
  223. task.setProjectId(projectId);
  224. task.setType(2);
  225. task.setTotal(total);
  226. task.setFieldNum(fieldNum.intValue());
  227. task.setCreateBy(loginUtils.getId());
  228. task.setStartTime(DateUtils.getDateTime());
  229. task.insert();
  230. return task.getId();
  231. }
  232. public void updateStatus(Integer id, Integer status, Integer endTime) {
  233. Task task = this.getById(id);
  234. task.setStatus(status);
  235. if (endTime != null) {
  236. task.setEndTime(endTime);
  237. }
  238. task.updateById();
  239. }
  240. public void updateTime(Integer id, Integer status, Integer endTime, String url, String fileName) {
  241. Task task = this.getById(id);
  242. task.setStatus(status);
  243. task.setEndTime(endTime);
  244. task.setFileName(fileName);
  245. task.setUrl(url);
  246. task.updateById();
  247. }
  248. private void setDataList(List<Task> taskList) throws IOException {
  249. //获得创建人的id集合
  250. List<Integer> createIds = taskList.stream().map(Task::getCreateBy).collect(Collectors.toList());
  251. //获取专题库负责人对应信息
  252. String jsonObject1 = requestService.getPersonnelFromPCS(createIds);
  253. JSONArray jsonArray = JSON.parseArray(jsonObject1);
  254. List<ProjectVO.Personnel> personnelList = jsonArray.toJavaList(ProjectVO.Personnel.class);
  255. for (Task task : taskList) {
  256. for (ProjectVO.Personnel personnel : personnelList) {
  257. //装载创建人名
  258. if (task.getCreateBy() != null) {
  259. if (task.getCreateBy().equals(personnel.getId())) {
  260. task.setCreateName(personnel.getPersonnelName());
  261. }
  262. }
  263. }
  264. }
  265. }
  266. /**
  267. * 暂停任务
  268. *
  269. * @param taskId 任务id
  270. */
  271. @Override
  272. public void pauseTask(Integer taskId) {
  273. log.info("开始处理【暂停任务】的业务,参数为:taskId={}", taskId);
  274. //1.检查尝试暂停的任务是否存在,若不存在则暂停失败,提示用户 "暂停失败,当前任务已不存在,请尝试刷新页面"
  275. log.info("检查尝试暂停的任务是否存在");
  276. Task task = this.getById(taskId);
  277. if (task == null) {
  278. ThrowException.throwXiaoShiException("暂停失败,当前任务已不存在,请尝试刷新页面");
  279. return;
  280. }
  281. //2.检查尝试暂停的任务是否已处于暂停状态,若是则暂停失败,提示用户 "暂停失败,当前任务已处于暂停状态,请尝试刷新页面"
  282. if (task.getStatus().equals(4)) {
  283. ThrowException.throwXiaoShiException("暂停失败,当前任务已处于暂停状态,请尝试刷新页面");
  284. }
  285. //3.检查尝试暂停的任务是否处于进行中状态,若不是则暂停失败,提示用户 "暂停失败,当前任务已结束或未开始,请尝试刷新页面"
  286. if (!task.getStatus().equals(1)) {
  287. ThrowException.throwXiaoShiException("暂停失败,当前任务已结束或未开始,请尝试刷新页面");
  288. }
  289. //4.暂停任务
  290. Task updateTask = new Task();
  291. updateTask.setId(taskId);
  292. updateTask.setStatus(4);
  293. log.info("任务表修改数据,暂停任务,任务id={}", taskId);
  294. boolean updateResult = this.updateById(updateTask);
  295. if (!updateResult) {
  296. ThrowException.throwXiaoShiException("暂停失败,服务器忙请稍后再试");
  297. }
  298. log.info("暂停任务成功");
  299. }
  300. /**
  301. * 继续任务
  302. *
  303. * @param taskId 任务id
  304. */
  305. @Override
  306. public void continueTask(Integer taskId) {
  307. log.info("开始处理【继续任务】的业务,参数为:taskId={}", taskId);
  308. //1.检查尝试继续的任务是否存在,若不存在则继续失败,提示用户 "继续失败,当前任务已不存在,请尝试刷新页面"
  309. log.info("检查尝试继续的任务是否存在");
  310. Task task = this.getById(taskId);
  311. if (task == null) {
  312. ThrowException.throwXiaoShiException("继续失败,当前任务已不存在,请尝试刷新页面");
  313. return;
  314. }
  315. //2.检查尝试继续的任务是否处于暂停状态,若不是则继续失败,提示用户 "继续失败,当前任务未暂停,请尝试刷新页面"
  316. if (!task.getStatus().equals(4)) {
  317. ThrowException.throwXiaoShiException("继续失败,当前任务未暂停,请尝试刷新页面");
  318. }
  319. //3.继续任务(将任务状态改为0即等待中)
  320. Task updateTask = new Task();
  321. updateTask.setId(taskId);
  322. updateTask.setStatus(0);
  323. log.info("任务表修改数据,继续任务,任务id={}", taskId);
  324. boolean updateResult = this.updateById(updateTask);
  325. if (!updateResult) {
  326. ThrowException.throwXiaoShiException("继续失败,服务器忙请稍后再试");
  327. }
  328. log.info("继续任务成功");
  329. }
  330. }