ImportTaskService.java 24 KB

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