ImportTaskService.java 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581
  1. package cn.cslg.pas.service.business;
  2. import cn.cslg.pas.common.dto.ExportTaskDTO;
  3. import cn.cslg.pas.common.dto.ImportTaskDTO;
  4. import cn.cslg.pas.common.dto.PatentStarListDTO;
  5. import cn.cslg.pas.common.importTask.QuartzConditionDTO;
  6. import cn.cslg.pas.common.model.cronModel.Personnel;
  7. import cn.cslg.pas.common.model.cronModel.PersonnelVO;
  8. import cn.cslg.pas.common.model.cronModel.Records;
  9. import cn.cslg.pas.common.model.cronModel.SystemFile;
  10. import cn.cslg.pas.common.model.importPDF.AddImportPDFTaskDTO;
  11. import cn.cslg.pas.common.model.request.GroupRequest;
  12. import cn.cslg.pas.common.model.request.QueryRequest;
  13. import cn.cslg.pas.common.utils.*;
  14. import cn.cslg.pas.common.vo.ImportTaskAMVO;
  15. import cn.cslg.pas.common.vo.StarPatentVO;
  16. import cn.cslg.pas.common.vo.business.ImportTaskVO;
  17. import cn.cslg.pas.domain.business.*;
  18. import cn.cslg.pas.exception.UnLoginException;
  19. import cn.cslg.pas.exception.XiaoShiException;
  20. import cn.cslg.pas.factorys.businessFactory.Business;
  21. import cn.cslg.pas.mapper.ImportTaskMapper;
  22. import cn.cslg.pas.service.common.FileManagerService;
  23. import cn.cslg.pas.service.common.PatentStarApiService;
  24. import cn.cslg.pas.service.importPatent.SchedulingTaskService;
  25. import cn.cslg.pas.service.permissions.PermissionService;
  26. import cn.cslg.pas.service.query.FormatQueryService;
  27. import com.alibaba.fastjson.JSONArray;
  28. import com.alibaba.fastjson.JSONObject;
  29. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  30. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  31. import lombok.RequiredArgsConstructor;
  32. import org.apache.commons.compress.utils.IOUtils;
  33. import org.apache.poi.ss.usermodel.Sheet;
  34. import org.joda.time.DateTime;
  35. import org.springframework.beans.BeanUtils;
  36. import org.springframework.beans.factory.annotation.Autowired;
  37. import org.springframework.context.annotation.Lazy;
  38. import org.springframework.stereotype.Service;
  39. import org.springframework.transaction.annotation.Transactional;
  40. import org.springframework.web.multipart.MultipartFile;
  41. import java.io.*;
  42. import java.util.*;
  43. /**
  44. * 导入任务表业务层
  45. *
  46. * @author chenyu
  47. * @date 2023/10/20
  48. */
  49. @Service
  50. @RequiredArgsConstructor
  51. public class ImportTaskService extends ServiceImpl<ImportTaskMapper, ImportTask> implements Business {
  52. @Autowired
  53. private FormatQueryService formatQueryService;
  54. @Autowired
  55. private ImportTaskMapper importTaskMapper;
  56. @Autowired
  57. private FileManagerService fileManagerService;
  58. @Autowired
  59. private PatentStarApiService patentStarApiService;
  60. @Autowired
  61. private PermissionService permissionService;
  62. @Autowired
  63. @Lazy
  64. private SchedulingTaskService schedulingTaskService;
  65. @Autowired
  66. private CacheUtils cacheUtils;
  67. @Autowired
  68. private LoginUtils loginUtils;
  69. @Autowired
  70. private SystemDictService systemDictService;
  71. @Autowired
  72. private ProductService productService;
  73. @Autowired
  74. private ProjectService projectService;
  75. @Autowired
  76. private ImportTaskConditionService importTaskConditionService;
  77. @Override
  78. public Object queryMessage(QueryRequest queryRequest) throws Exception {
  79. List<String> sqls = formatQueryService.reSqls(queryRequest, "importTask");
  80. this.loadSearchSql(sqls, queryRequest.getProjectId());
  81. //根据sql查询事件信息
  82. List<ImportTaskVO> importTaskVOS = importTaskMapper.getImportTask(sqls.get(0), sqls.get(1), sqls.get(2));
  83. //查询总数
  84. Long total = importTaskMapper.getImportTaskCount(sqls.get(0));
  85. //装载事件信息
  86. this.loadImportTask(importTaskVOS);
  87. Records records = new Records();
  88. records.setCurrent(queryRequest.getCurrent());
  89. records.setSize(queryRequest.getSize());
  90. records.setData(importTaskVOS);
  91. records.setTotal(total);
  92. return records;
  93. }
  94. @Override
  95. public Object addMessage(Object object, List<MultipartFile> files) {
  96. return null;
  97. }
  98. @Override
  99. public Object deleteMessage(List<Integer> ids) throws IOException {
  100. return null;
  101. }
  102. @Override
  103. public Object updateMessage(Object object, List<MultipartFile> files) {
  104. return null;
  105. }
  106. @Override
  107. public Object getGroup(GroupRequest groupRequest, String tableName) throws Exception {
  108. return null;
  109. }
  110. @Override
  111. @Transactional(rollbackFor = Exception.class)
  112. public Object addMessage(Object object) {
  113. if (object == null) {
  114. throw new XiaoShiException("参数不能为空");
  115. }
  116. //TODO 校验参数
  117. ImportTaskDTO importTaskDTO = (ImportTaskDTO) object;
  118. Boolean ifUpdate = importTaskDTO.getIfUpdate();
  119. PersonnelVO personnelVO = new PersonnelVO();
  120. personnelVO = cacheUtils.getLoginUser(loginUtils.getId());
  121. if (importTaskDTO.getType() == null) {
  122. importTaskDTO.setType(4);
  123. }
  124. List<String> addPatentNos = importTaskDTO.getPatentNos();
  125. if (!importTaskDTO.getType().equals(1)) {
  126. importTaskDTO.setImportContent(MathUtils.BinaryToDecimal(importTaskDTO.getImportContent()));
  127. }
  128. ImportTaskCondition importTaskCondition = null;
  129. if (ifUpdate != null && ifUpdate) {
  130. QuartzConditionDTO quartzConditionDTO = new QuartzConditionDTO();
  131. BeanUtils.copyProperties(importTaskDTO, quartzConditionDTO);
  132. importTaskCondition = importTaskConditionService.addQuartzCondition(quartzConditionDTO);
  133. } else {
  134. importTaskCondition = importTaskConditionService.addQuartzCondition(importTaskDTO);
  135. }
  136. if (importTaskDTO.getImportToId() != null) {
  137. if (importTaskDTO.getImportToType().equals(0)) {
  138. importTaskCondition.setProjectType(0);
  139. importTaskCondition.setProjectId(importTaskDTO.getImportToId());
  140. } else if (importTaskDTO.getImportToType().equals(1)) {
  141. importTaskCondition.setProjectType(1);
  142. importTaskCondition.setProjectId(importTaskDTO.getImportToId());
  143. } else if (importTaskDTO.getImportToType().equals(2)) {
  144. importTaskCondition.setProductId(importTaskDTO.getImportToId());
  145. }
  146. }
  147. //装载任务
  148. ImportTask importTask = new ImportTask();
  149. importTask.setImportTaskConditionId(importTaskCondition.getId());
  150. importTask.setType(importTaskDTO.getType());
  151. importTask.setSearchCondition(importTaskDTO.getSearchCondition());
  152. importTask.setCreateId(personnelVO.getId());
  153. if (importTaskCondition.getType().equals(1)) {
  154. try {
  155. String res = fileManagerService.getSystemFileFromFMS(Arrays.asList(importTaskCondition.getFileGuid()));
  156. List<SystemFile> systemFiles = JSONArray.parseArray(res, SystemFile.class);
  157. SystemFile systemFile = systemFiles.get(0);
  158. String suffix = systemFile.getFileName().substring(systemFile.getFileName().lastIndexOf("."));
  159. //调用文件系统取出文件接口,获得文件流
  160. byte[] bytes = fileManagerService.downloadSystemFileFromFMS(importTaskCondition.getFileGuid());
  161. //创建临时文件tempFile,并将文件读取到tempFile
  162. File tempFile = File.createTempFile(systemFile.getFileName() + "temp", suffix);
  163. try (
  164. InputStream inputStream = new ByteArrayInputStream(bytes);
  165. FileOutputStream outputStream = new FileOutputStream(tempFile);
  166. ) {
  167. IOUtils.copy(inputStream, outputStream); // 将输入流复制到临时文件
  168. }
  169. Integer totalNum = ReadExcelUtils.textExcel(tempFile, importTaskCondition.getSourceId().toString());
  170. importTask.setAllNum(totalNum);
  171. //删除临时文件tempFile
  172. new File(tempFile.getPath()).delete();
  173. } catch (Exception e) {
  174. e.printStackTrace();
  175. throw new XiaoShiException(e.getMessage());
  176. }
  177. } else if (importTaskCondition.getType().equals(4)) {
  178. try {
  179. if (addPatentNos == null || addPatentNos.size() == 0) {
  180. PatentStarListDTO patentStarListDto = new PatentStarListDTO()
  181. .setCurrentQuery(importTaskCondition.getSearchCondition())
  182. .setOrderBy(importTaskCondition.getOrderBy())
  183. .setOrderByType(importTaskCondition.getOrderByType())
  184. .setPageNum(1)
  185. .setRowCount(50)
  186. .setDBType(importTaskCondition.getDbType());
  187. //调用一般接口返回一批专利著录相关数据
  188. Map<String, Object> resultMap = patentStarApiService.patentStarSearchApi(patentStarListDto);
  189. if (resultMap == null || (Integer) resultMap.get("total") == 0) {
  190. ThrowException.throwXiaoShiException("未检索到相关专利");
  191. } else {
  192. List<StarPatentVO> starPatentVOS =(List<StarPatentVO>)resultMap.get("records");
  193. StarPatentVO starPatentVO =starPatentVOS.get(0);
  194. String pDStr = starPatentVO.getPD();
  195. Date publicDate = DateUtils2.formStrToDate(pDStr);
  196. importTask.setUpdateToDate(publicDate);
  197. importTask.setAllNum((Integer) resultMap.get("total"));
  198. }
  199. } else {
  200. importTask.setAllNum(addPatentNos.size());
  201. }
  202. } catch (Exception e) {
  203. throw new XiaoShiException("文件错误");
  204. }
  205. } else if (importTaskCondition.getType().equals(2) || importTaskCondition.getType().equals(3)) {
  206. List<String> patentNos = new ArrayList<>();
  207. if (importTaskCondition.getType().equals(2)) {
  208. patentNos = Arrays.asList(importTaskCondition.getSearchCondition().split("[,|,]"));
  209. } else if (importTaskCondition.getType().equals(3)) {
  210. try {
  211. String res = fileManagerService.getSystemFileFromFMS(Arrays.asList(importTaskCondition.getFileGuid()));
  212. List<SystemFile> systemFiles = JSONArray.parseArray(res, SystemFile.class);
  213. SystemFile systemFile = systemFiles.get(0);
  214. String suffix = systemFile.getFileName().substring(systemFile.getFileName().lastIndexOf("."));
  215. //调用文件系统取出文件接口,获得文件流
  216. byte[] bytes = fileManagerService.downloadSystemFileFromFMS(importTaskCondition.getFileGuid());
  217. //创建临时文件tempFile,并将文件读取到tempFile
  218. File tempFile = File.createTempFile(systemFile.getFileName() + "temp", suffix);
  219. try (
  220. InputStream inputStream = new ByteArrayInputStream(bytes);
  221. FileOutputStream outputStream = new FileOutputStream(tempFile)
  222. ) {
  223. IOUtils.copy(inputStream, outputStream); // 将输入流复制到临时文件
  224. }
  225. Sheet sheet = ReadExcelUtils.readExcel(tempFile);
  226. patentNos = ReadExcelUtils.getPatentNoFromExcel(sheet);
  227. } catch (Exception e) {
  228. }
  229. }
  230. importTask.setAllNum(patentNos.size());
  231. }
  232. importTask.setProgress(0.0);
  233. String taskName = this.setImportTaskName(importTaskCondition, personnelVO.getName());
  234. importTask.setName(taskName);
  235. importTask.insert();
  236. schedulingTaskService.startTask();
  237. return importTask.getId();
  238. }
  239. @Override
  240. public Object updateMessage(Object object) {
  241. return null;
  242. }
  243. private void loadImportTask(List<ImportTaskVO> importTaskVOS) throws IOException {
  244. List<ImportTaskAMVO> importTaskAMVOS = schedulingTaskService.getImportTaskAMVOs();
  245. if (importTaskAMVOS == null) {
  246. importTaskAMVOS = new ArrayList<>();
  247. }
  248. List<String> createIds = new ArrayList<>();
  249. List<Integer> projectIds = new ArrayList<>();
  250. List<Integer> productIds = new ArrayList<>();
  251. importTaskVOS.forEach(item -> {
  252. if (item.getCreateId() != null) {
  253. createIds.add(item.getCreateId());
  254. }
  255. if (item.getProductId() != null) {
  256. productIds.add(item.getProductId());
  257. }
  258. if (item.getProjectId() != null) {
  259. projectIds.add(item.getProjectId());
  260. }
  261. });
  262. List<Personnel> personnels = new ArrayList<>();
  263. List<Product> products = new ArrayList<>();
  264. List<Project> projects = new ArrayList<>();
  265. //查询创建人名称
  266. if (createIds.size() != 0) {
  267. String res = permissionService.getPersonnelByIdsFromPCS(createIds);
  268. JSONObject jsonObject = JSONObject.parseObject(res);
  269. personnels = JSONObject.parseArray(jsonObject.getString("data"), Personnel.class);
  270. }
  271. //查询项目名称
  272. if (projectIds.size() != 0) {
  273. LambdaQueryWrapper<Project> queryWrapper = new LambdaQueryWrapper<>();
  274. queryWrapper.in(Project::getId, projectIds);
  275. projects = projectService.list(queryWrapper);
  276. }
  277. //查询产品名称
  278. if (productIds.size() != 0) {
  279. LambdaQueryWrapper<Product> queryWrapper = new LambdaQueryWrapper<>();
  280. queryWrapper.in(Product::getId, productIds);
  281. products = productService.list(queryWrapper);
  282. }
  283. LambdaQueryWrapper<SystemDict> lambdaQueryWrapper = new LambdaQueryWrapper<>();
  284. lambdaQueryWrapper.eq(SystemDict::getGroupType, "IMPORT_TASK");
  285. List<SystemDict> systemDictList = systemDictService.list(lambdaQueryWrapper);
  286. for (ImportTaskVO importTaskVO : importTaskVOS) {
  287. //装载创建人
  288. Personnel personnel = personnels.stream().filter(item -> item.getId().equals(importTaskVO.getCreateId())).findFirst().orElse(null);
  289. if (personnel != null) {
  290. importTaskVO.setCreateName(personnel.getPersonnelName());
  291. }
  292. //装载状态
  293. SystemDict systemDict1 = systemDictList.stream()
  294. .filter(item -> item.getType().equals("IMPORT_TASK_TYPE") && item.getType()
  295. .equals(importTaskVO.getType().toString())).findFirst().orElse(null);
  296. SystemDict systemDict2 = systemDictList.stream()
  297. .filter(item -> item.getType().equals("IMPORT_TASk_STATE") && item.getType()
  298. .equals(importTaskVO.getState().toString())).findFirst().orElse(null);
  299. if (systemDict1 != null) {
  300. importTaskVO.setTypeStr(systemDict1.getLabel());
  301. }
  302. if (systemDict2 != null) {
  303. importTaskVO.setStateStr(systemDict2.getLabel());
  304. }
  305. //装载正在进行中任务的完成条数
  306. ImportTaskAMVO importTaskAMVO = importTaskAMVOS.stream().filter(item -> item.getId().equals(importTaskVO.getId())).findFirst().orElse(null);
  307. if (importTaskAMVO != null) {
  308. importTaskVO.setDoneNum(importTaskAMVO.getDoneNum());
  309. importTaskAMVO.setAllNum(importTaskAMVO.getAllNum());
  310. }
  311. long percentage = (long) Math.floor((importTaskVO.getDoneNum() + 0D) / importTaskVO.getAllNum() * 100D);
  312. importTaskVO.setPercentage(percentage);
  313. //装载目标名称
  314. if (projects.size() > 0 && importTaskVO.getProjectId() != null) {
  315. Project project = projects.stream().filter(item -> item.getId().equals(importTaskVO.getProjectId())).findFirst().orElse(null);
  316. if (project != null) {
  317. importTaskVO.setImportToId(project.getId());
  318. importTaskVO.setImportToType(project.getType() - 1);
  319. importTaskVO.setImportToName(project.getName());
  320. }
  321. } else if (products.size() > 0 && importTaskVO.getProductId() != null) {
  322. Product product = products.stream().filter(item -> item.getId().equals(importTaskVO.getProductId())).findFirst().orElse(null);
  323. if (product != null) {
  324. importTaskVO.setImportToId(product.getId());
  325. importTaskVO.setImportToType(2);
  326. importTaskVO.setImportToName(product.getName());
  327. }
  328. }
  329. }
  330. }
  331. private String setImportTaskName(ImportTaskCondition importTaskCondition, String name) {
  332. //装载名称
  333. String type = "";
  334. String toName = "";
  335. String to = "";
  336. String taskName = "";
  337. if (importTaskCondition.getType().equals(2)) {
  338. type = "【专利号】";
  339. } else if (importTaskCondition.getType().equals(3) || importTaskCondition.getType().equals(4)) {
  340. type = "【检索式】";
  341. } else if (importTaskCondition.getType().equals(1)) {
  342. type = "【Excel】";
  343. }
  344. if (importTaskCondition.getProjectId() != null && importTaskCondition.getProjectType().equals(0)) {
  345. to = "专题库";
  346. LambdaQueryWrapper<Project> queryWrapper = new LambdaQueryWrapper<>();
  347. queryWrapper.in(Project::getId, importTaskCondition.getProjectId());
  348. List<Project> projects = projectService.list(queryWrapper);
  349. if (projects.size() != 0) {
  350. toName = projects.get(0).getName();
  351. }
  352. } else if (importTaskCondition.getProjectId() != null && importTaskCondition.getProjectType().equals(1)) {
  353. to = "报告";
  354. LambdaQueryWrapper<Project> queryWrapper = new LambdaQueryWrapper<>();
  355. queryWrapper.in(Project::getId, importTaskCondition.getProjectId());
  356. List<Project> projects = projectService.list(queryWrapper);
  357. if (projects.size() != 0) {
  358. toName = projects.get(0).getName();
  359. }
  360. } else if (importTaskCondition.getProductId() != null) {
  361. to = "产品";
  362. LambdaQueryWrapper<Product> queryWrapper = new LambdaQueryWrapper<>();
  363. queryWrapper.in(Product::getId, importTaskCondition.getProductId());
  364. List<Product> products = productService.list(queryWrapper);
  365. if (products.size() != 0) {
  366. toName = products.get(0).getName();
  367. }
  368. }
  369. //导入任务
  370. taskName = type + "导入到" + to + "【" + toName + "】 - " + name;
  371. return taskName;
  372. }
  373. public void updateImportTaskState(Integer taskId, Integer state) {
  374. ImportTask importTask = this.getById(taskId);
  375. importTask.setState(state);
  376. importTask.updateById();
  377. if (state.equals(4) || state.equals(5)) {
  378. schedulingTaskService.pauseTask(taskId, state);
  379. }
  380. if (state.equals(0)) {
  381. schedulingTaskService.startTask();
  382. }
  383. }
  384. public Integer addExportTask(ExportTaskDTO exportTaskDTO) {
  385. if (exportTaskDTO == null) {
  386. throw new XiaoShiException("入参不能为空");
  387. }
  388. ImportTaskCondition importTaskCondition = new ImportTaskCondition();
  389. if (exportTaskDTO.getProjectId() != null) {
  390. importTaskCondition.setProjectId(exportTaskDTO.getProjectId());
  391. }
  392. importTaskCondition.setIfUpdate(false);
  393. importTaskCondition.setType(exportTaskDTO.getType());
  394. importTaskCondition.setCreateId(exportTaskDTO.getCreateId());
  395. importTaskCondition.insert();
  396. Integer importTaskConditionId = importTaskCondition.getId();
  397. if (importTaskConditionId != null) {
  398. ImportTask importTask = new ImportTask();
  399. importTask.setImportTaskConditionId(importTaskConditionId);
  400. //设置任务的类型 6导出excel 7导出pdf首页
  401. importTask.setType(exportTaskDTO.getType());
  402. importTask.setAllNum(exportTaskDTO.getAllNum());
  403. importTask.setFinishTime(exportTaskDTO.getFinishTime());
  404. importTask.setState(0);
  405. importTask.setCreateId(exportTaskDTO.getCreateId());
  406. String name = "";
  407. if (exportTaskDTO.getType().equals(6)) {
  408. name = "【专利】";
  409. } else if (exportTaskDTO.getType().equals(7)) {
  410. name = "【PDF首页】";
  411. }
  412. String importTaskName = "导出" + name + "-" + exportTaskDTO.getCreateName();
  413. importTask.setName(importTaskName);
  414. importTask.insert();
  415. return importTask.getId();
  416. } else {
  417. throw new XiaoShiException("导出任务记录失败");
  418. }
  419. }
  420. public Integer updateExportTask(ExportTaskDTO exportTaskDTO) {
  421. if (exportTaskDTO == null) {
  422. throw new XiaoShiException("入参不能为空");
  423. }
  424. ImportTask importTask = this.getById(exportTaskDTO.getTaskId());
  425. if (importTask != null) {
  426. Integer importTaskConditionId = importTask.getImportTaskConditionId();
  427. ImportTaskCondition importTaskCondition = importTaskConditionService.getById(importTaskConditionId);
  428. importTaskCondition.setFileGuid(exportTaskDTO.getFileGuid());
  429. importTaskCondition.updateById();
  430. importTask.setState(exportTaskDTO.getState());
  431. importTask.setAllNum(exportTaskDTO.getAllNum());
  432. importTask.setDoneNum(exportTaskDTO.getDoneNum());
  433. importTask.setDefaultNum(exportTaskDTO.getDefaultNum());
  434. importTask.setFinishTime(exportTaskDTO.getFinishTime());
  435. importTask.updateById();
  436. }
  437. return importTask.getId();
  438. }
  439. //装载查询语句
  440. private List<String> loadSearchSql(List<String> sqls, Integer projectId) {
  441. PersonnelVO personnelVO = cacheUtils.getLoginUser(loginUtils.getId());
  442. String id = personnelVO.getId();
  443. String rootSql = "";
  444. if (sqls.get(0) == null || projectId == null) {
  445. rootSql = "it.create_id=" + id;
  446. } else {
  447. Project project = projectService.getById(projectId);
  448. if (project == null) {
  449. throw new XiaoShiException("未查询到专题库");
  450. }
  451. String createId = project.getCreateId();
  452. String headId = project.getHeadId();
  453. if (createId != id && headId != id) {
  454. rootSql = "it.create_id=" + id;
  455. }
  456. }
  457. if (sqls.get(0) != null && !sqls.get(0).equals("") && !rootSql.equals("")) {
  458. sqls.set(0, rootSql + " and " + "(" + sqls.get(0) + ")");
  459. } else if ((sqls.get(0) == null || sqls.get(0).equals("")) && !rootSql.equals("")) {
  460. sqls.set(0, rootSql);
  461. }
  462. return sqls;
  463. }
  464. public Integer addPdfTask(AddImportPDFTaskDTO addImportPDFTaskDTO) {
  465. String fileGuid = addImportPDFTaskDTO.getFileGuid();
  466. Integer pdfType = addImportPDFTaskDTO.getPdfType();
  467. String remark = addImportPDFTaskDTO.getRemark();
  468. ImportTaskCondition importTaskCondition = new ImportTaskCondition();
  469. importTaskCondition.setFileGuid(fileGuid);
  470. importTaskCondition.setType(5);
  471. importTaskCondition.setPdfType(pdfType);
  472. importTaskCondition.setCreateId("1");
  473. importTaskCondition.insert();
  474. ImportTask importTask = new ImportTask();
  475. importTask.setImportTaskConditionId(importTaskCondition.getId());
  476. importTask.setRemark(remark);
  477. importTask.setCreateId("1");
  478. importTask.setType(5);
  479. importTask.insert();
  480. schedulingTaskService.startTask();
  481. return importTask.getId();
  482. }
  483. public void addImportTaskByCondition(ImportTaskCondition importTaskCondition){
  484. //根据id查询最近更新的任务
  485. LambdaQueryWrapper<ImportTask> queryWrapper =new LambdaQueryWrapper<>();
  486. queryWrapper.eq(ImportTask::getImportTaskConditionId,importTaskCondition.getId())
  487. .orderByDesc(ImportTask::getUpdateToDate);
  488. ImportTask lastImportTask =this.getOne(queryWrapper);
  489. String condition =importTaskCondition.getSearchCondition();
  490. if(lastImportTask !=null&&lastImportTask.getUpdateToDate()!=null)
  491. {
  492. String dateStr= DateUtils2.dateTimeToPatentStr(lastImportTask.getUpdateToDate());
  493. condition =condition+"and PD="+dateStr;
  494. }
  495. PatentStarListDTO patentStarListDto = new PatentStarListDTO()
  496. .setCurrentQuery(condition )
  497. .setPageNum(1)
  498. .setRowCount(10)
  499. .setDBType(importTaskCondition.getDbType());
  500. //调用一般接口返回一批专利著录相关数据
  501. ImportTask importTask = new ImportTask();
  502. try {
  503. Map<String, Object> resultMap = patentStarApiService.patentStarSearchApi(patentStarListDto);
  504. if (resultMap == null || (Integer) resultMap.get("total") == 0) {
  505. return;
  506. }
  507. else {
  508. List<StarPatentVO> starPatentVOS =(List<StarPatentVO>)resultMap.get("records");
  509. StarPatentVO starPatentVO =starPatentVOS.get(0);
  510. String pDStr = starPatentVO.getPD();
  511. Date publicDate = DateUtils2.formStrToDate(pDStr);
  512. importTask.setUpdateToDate(publicDate);
  513. importTask.setAllNum((Integer) resultMap.get("total"));
  514. }
  515. }
  516. catch (Exception e){
  517. e.printStackTrace();
  518. }
  519. importTask.setImportTaskConditionId(importTaskCondition.getId());
  520. importTask.setType(importTaskCondition.getType());
  521. importTask.setSearchCondition(condition);
  522. importTask.setCreateId(importTaskCondition.getCreateId());
  523. importTask.insert();
  524. }
  525. }